forked from germc/Atlas-iOS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ATLParticipantTableViewController.h
129 lines (109 loc) · 5.23 KB
/
ATLParticipantTableViewController.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
//
// ATLUIParticipantListViewController.h
// Atlas
//
// Created by Kevin Coleman on 8/29/14.
// Copyright (c) 2014 Layer, Inc. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#import <UIKit/UIKit.h>
#import "ATLParticipantTableViewCell.h"
@class ATLParticipantTableViewController;
/**
@abstract The `ATLParticipantViewControllerDelegate` protocol provides a method for notifying the adopting delegate about information changes.
*/
NS_ASSUME_NONNULL_BEGIN
@protocol ATLParticipantTableViewControllerDelegate <NSObject>
/**
@abstract Informs the receiver that the user has selected a participant.
@param participantTableViewController The participant table view controller in which the selection was made.
@param participant The participant who was selected.
*/
- (void)participantTableViewController:(ATLParticipantTableViewController *)participantTableViewController didSelectParticipant:(id<ATLParticipant>)participant;
/**
@abstract Informs the delegate that a search has been made with the following search string.
@param participantTableViewController The participant table view controller in which the search was made.
@param searchText The search string that was just used for search.
@param completion The completion block that should be called when the results are fetched from the search.
*/
- (void)participantTableViewController:(ATLParticipantTableViewController *)participantTableViewController didSearchWithString:(NSString *)searchText completion:(void (^)(NSSet *filteredParticipants))completion;
@optional
/**
@abstract Informs the receiver that the user has deselected a participant.
@param participantTableViewController The participant table view controller in which the deselection was made.
@param participant The participant who was deselected.
*/
- (void)participantTableViewController:(ATLParticipantTableViewController *)participantTableViewController didDeselectParticipant:(id<ATLParticipant>)participant;
@end
/**
@abstract The `ATLParticipantTableViewController` sorts, groups, and displays a list of participants. It provides search capability.
*/
@interface ATLParticipantTableViewController : UITableViewController
/**
@abstract Creates and returns an `ATLParticipantTableViewController` initialized with the given set of participants and sort type.
@param participants The set of participants to be used for display in the table view.
@param sortType The sort order applied to the participants.
@return A new participant picker initialized with the given participant set and sort type.
*/
+ (instancetype)participantTableViewControllerWithParticipants:(NSSet <id<ATLParticipant>> *)participants sortType:(ATLParticipantPickerSortType)sortType;
/**
@abstract The participants to display.
@raises NSInternalInconsistencyException Raised if the value is mutated after the receiver has been presented.
*/
@property (nonatomic) NSSet <id<ATLParticipant>> *participants;
/**
@abstract An `NSSet` of identifiers representing blocked participants.
*/
@property (nonatomic) NSSet <NSString*> *blockedParticipantIdentifiers;
/**
@abstract Defines the sort ordering of the participant list.
@default `ATLParticipantPickerSortTypeFirstName`.
@raises NSInternalInconsistencyException Raised if the value is mutated after the receiver has been presented.
*/
@property (nonatomic, assign) ATLParticipantPickerSortType sortType;
/**
@abstract Defines whether the avatar item is shown in each cell.
@default `YES`.
*/
@property (nonatomic, assign) BOOL shouldShowAvatarItem;
/**
@abstract Defines whether presence status is enabled for each cell's avatar item.
@default `YES`.
*/
@property (nonatomic, assign) BOOL presenceStatusEnabled;
/**
@abstract The delegate for the participant table view controller.
*/
@property (nonatomic, weak) id<ATLParticipantTableViewControllerDelegate> delegate;
/**
@abstract The table view cell class for customizing the display of participants.
@default `[ATLParticipantTableViewCell class]`
@raises NSInternalInconsistencyException Raised if the value is mutated after the receiver has been presented.
*/
@property (nonatomic) Class<ATLParticipantPresenting> cellClass;
/**
@abstract Sets the height for cells within the receiver.
@default `48.0`
@raises NSInternalInconsistencyException Raised if the value is mutated after the receiver has been presented.
*/
@property (nonatomic, assign) CGFloat rowHeight;
/**
@abstract A boolean value that determines whether multiple participants can be selected at once.
@default YES
@discussion The default value of this property is `YES`.
@raises NSInternalInconsistencyException Raised if the value is mutated after the receiver has been presented.
*/
@property (nonatomic, assign) BOOL allowsMultipleSelection;
@end
NS_ASSUME_NONNULL_END