90 lines
2.2 KiB
Objective-C
90 lines
2.2 KiB
Objective-C
/*
|
|
Copyright 2024 New Vector Ltd.
|
|
Copyright 2015 OpenMarket Ltd
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
Please see LICENSE in the repository root for full details.
|
|
*/
|
|
|
|
#import <UIKit/UIKit.h>
|
|
#import <MatrixSDK/MatrixSDK.h>
|
|
|
|
#import "MXKDataSource.h"
|
|
#import "MXKRoomMemberCellData.h"
|
|
|
|
#import "MXKAppSettings.h"
|
|
|
|
/**
|
|
Identifier to use for cells that display a room member.
|
|
*/
|
|
extern NSString *const kMXKRoomMemberCellIdentifier;
|
|
|
|
/**
|
|
The data source for `MXKRoomMemberListViewController`.
|
|
*/
|
|
@interface MXKRoomMemberListDataSource : MXKDataSource <UITableViewDataSource> {
|
|
|
|
@protected
|
|
|
|
/**
|
|
The data for the cells served by `MXKRoomMembersDataSource`.
|
|
*/
|
|
NSMutableArray *cellDataArray;
|
|
|
|
/**
|
|
The filtered members: sub-list of `cellDataArray` defined by `searchWithPatterns:`.
|
|
*/
|
|
NSMutableArray *filteredCellDataArray;
|
|
}
|
|
|
|
/**
|
|
The id of the room managed by the data source.
|
|
*/
|
|
@property (nonatomic, readonly) NSString *roomId;
|
|
|
|
/**
|
|
The settings used to sort/display room members.
|
|
|
|
By default the shared application settings are considered.
|
|
*/
|
|
@property (nonatomic) MXKAppSettings *settings;
|
|
|
|
|
|
#pragma mark - Life cycle
|
|
|
|
/**
|
|
Initialise the data source to serve members corresponding to the passed room.
|
|
|
|
@param roomId the id of the room to get members from.
|
|
@param mxSession the Matrix session to get data from.
|
|
@return the newly created instance.
|
|
*/
|
|
- (instancetype)initWithRoomId:(NSString*)roomId andMatrixSession:(MXSession*)mxSession;
|
|
|
|
/**
|
|
Filter the current members list according to the provided patterns.
|
|
When patterns are not empty, the search result is stored in `filteredCellDataArray`,
|
|
this array provides then data for the cells served by `MXKRoomMembersDataSource`.
|
|
|
|
@param patternsList the list of patterns (`NSString` instances) to match with. Set nil to cancel search.
|
|
*/
|
|
- (void)searchWithPatterns:(NSArray*)patternsList;
|
|
|
|
/**
|
|
Get the data for the cell at the given index.
|
|
|
|
@param index the index of the cell in the array
|
|
@return the cell data
|
|
*/
|
|
- (id<MXKRoomMemberCellDataStoring>)cellDataAtIndex:(NSInteger)index;
|
|
|
|
/**
|
|
Get height of the celle at the given index.
|
|
|
|
@param index the index of the cell in the array
|
|
@return the cell height
|
|
*/
|
|
- (CGFloat)cellHeightAtIndex:(NSInteger)index;
|
|
|
|
@end
|