From 7a4236032f9992cbf28c18f4f7539f6bd95a8de4 Mon Sep 17 00:00:00 2001 From: Doug Date: Tue, 2 Nov 2021 18:46:36 +0000 Subject: [PATCH 1/3] Filter out cached room previews in the room lists. --- .../Data/RoomList/MXRoomListDataFilterOptions.swift | 9 +++++++-- changelog.d/5083.bugfix | 1 + 2 files changed, 8 insertions(+), 2 deletions(-) create mode 100644 changelog.d/5083.bugfix diff --git a/MatrixSDK/Data/RoomList/MXRoomListDataFilterOptions.swift b/MatrixSDK/Data/RoomList/MXRoomListDataFilterOptions.swift index 1970262fe8..8990d05d53 100644 --- a/MatrixSDK/Data/RoomList/MXRoomListDataFilterOptions.swift +++ b/MatrixSDK/Data/RoomList/MXRoomListDataFilterOptions.swift @@ -83,6 +83,11 @@ public struct MXRoomListDataFilterOptions: Equatable { } if !onlySuggested { + // Filter out any room previews by making sure the user has valid membership. + let memberPredicate = NSPredicate(format: "%K != %d", + #keyPath(MXRoomSummaryProtocol.membership), MXMembership.unknown.rawValue) + subpredicates.append(memberPredicate) + if !dataTypes.isEmpty { let subpredicate = NSPredicate(format: "(%K & %d) != 0", #keyPath(MXRoomSummaryProtocol.dataTypes), dataTypes.rawValue) @@ -119,9 +124,9 @@ public struct MXRoomListDataFilterOptions: Equatable { #keyPath(MXRoomSummaryProtocol.dataTypes), favoritedDataTypes.rawValue) let subpredicate4_1 = NSPredicate(format: "%K == NULL", - #keyPath(MXRoomSummaryProtocol.parentSpaceIds)) + #keyPath(MXRoomSummaryProtocol.parentSpaceIds)) let subpredicate4_2 = NSPredicate(format: "%K.@count == 0", - #keyPath(MXRoomSummaryProtocol.parentSpaceIds)) + #keyPath(MXRoomSummaryProtocol.parentSpaceIds)) let subpredicate4 = NSCompoundPredicate(type: .or, subpredicates: [subpredicate4_1, subpredicate4_2]) diff --git a/changelog.d/5083.bugfix b/changelog.d/5083.bugfix new file mode 100644 index 0000000000..3433752b1f --- /dev/null +++ b/changelog.d/5083.bugfix @@ -0,0 +1 @@ +MXRoomListDataFilterOptions: Filter out any cached room previews. \ No newline at end of file From 8e56f39d127fbf31aab0097e6d4b001ea913da8a Mon Sep 17 00:00:00 2001 From: Doug Date: Wed, 3 Nov 2021 10:21:04 +0000 Subject: [PATCH 2/3] Make MXSession's isJoinedOnRoom public. Use it in accountKnowingRoomWithRoomIdOrAlias. --- MatrixSDK/MXSession.h | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/MatrixSDK/MXSession.h b/MatrixSDK/MXSession.h index c973937e3f..b4b2d9142d 100644 --- a/MatrixSDK/MXSession.h +++ b/MatrixSDK/MXSession.h @@ -503,6 +503,16 @@ FOUNDATION_EXPORT NSString *const kMXSessionNoRoomTag; */ @property (nonatomic, readonly, getter=isPauseable) BOOL pauseable; +/** + Whether the user is part of a room with the membership state of `join` or + they are in the process of joining. + + @param roomIdOrAlias The ID or alias of the room to check. + + @return YES if they are. + */ +- (BOOL)isJoinedOnRoom:(NSString *)roomIdOrAlias; + #pragma mark - Class methods /** From 6e4509497219dcf5641de12dc37b96fd920c26e6 Mon Sep 17 00:00:00 2001 From: Doug Date: Wed, 3 Nov 2021 12:03:52 +0000 Subject: [PATCH 3/3] Add hideUnknownMembershipRooms property. --- .../RoomList/MXRoomListDataFilterOptions.swift | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/MatrixSDK/Data/RoomList/MXRoomListDataFilterOptions.swift b/MatrixSDK/Data/RoomList/MXRoomListDataFilterOptions.swift index 8990d05d53..56bd499e98 100644 --- a/MatrixSDK/Data/RoomList/MXRoomListDataFilterOptions.swift +++ b/MatrixSDK/Data/RoomList/MXRoomListDataFilterOptions.swift @@ -40,6 +40,10 @@ public struct MXRoomListDataFilterOptions: Equatable { /// Flag to filter only suggested rooms, if set to `true`, `dataTypes` and `notDataTypes` are not valid. public let onlySuggested: Bool + /// Flag to hide any rooms where the user's membership is unknown. This has no effect when `onlySuggested` is `true`. + /// When set to `false`, rooms that have been cached during peeking may be included in the filtered results. + public let hideUnknownMembershipRooms: Bool + /// Initializer /// - Parameters: /// - dataTypes: data types to fetch. Pass `MXRoomListDataFilterOptions.emptyDataTypes` not to specify any. @@ -50,13 +54,15 @@ public struct MXRoomListDataFilterOptions: Equatable { onlySuggested: Bool = false, query: String? = nil, space: MXSpace? = nil, - showAllRoomsInHomeSpace: Bool) { + showAllRoomsInHomeSpace: Bool, + hideUnknownMembershipRooms: Bool = true) { self.dataTypes = dataTypes self.notDataTypes = notDataTypes self.onlySuggested = onlySuggested self.query = query self.space = space self.showAllRoomsInHomeSpace = showAllRoomsInHomeSpace + self.hideUnknownMembershipRooms = hideUnknownMembershipRooms } /// Just to be used for in-memory data @@ -83,10 +89,11 @@ public struct MXRoomListDataFilterOptions: Equatable { } if !onlySuggested { - // Filter out any room previews by making sure the user has valid membership. - let memberPredicate = NSPredicate(format: "%K != %d", - #keyPath(MXRoomSummaryProtocol.membership), MXMembership.unknown.rawValue) - subpredicates.append(memberPredicate) + if hideUnknownMembershipRooms { + let memberPredicate = NSPredicate(format: "%K != %d", + #keyPath(MXRoomSummaryProtocol.membership), MXMembership.unknown.rawValue) + subpredicates.append(memberPredicate) + } if !dataTypes.isEmpty { let subpredicate = NSPredicate(format: "(%K & %d) != 0",