mirror of https://github.com/oxen-io/session-ios
				
				
				
			
			You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
	
	
		
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
		
		
			
		
	
	
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
| 
											7 years ago
										 | //
 | ||
| 
											7 years ago
										 | //  Copyright (c) 2019 Open Whisper Systems. All rights reserved.
 | ||
| 
											7 years ago
										 | //
 | ||
|  | 
 | ||
|  | NS_ASSUME_NONNULL_BEGIN | ||
|  | 
 | ||
|  | @class ConversationStyle; | ||
|  | @class ConversationViewModel; | ||
|  | @class OWSQuotedReplyModel; | ||
| 
											7 years ago
										 | @class TSOutgoingMessage; | ||
| 
											7 years ago
										 | @class TSThread; | ||
|  | @class ThreadDynamicInteractions; | ||
|  | 
 | ||
|  | @protocol ConversationViewItem; | ||
|  | 
 | ||
|  | typedef NS_ENUM(NSUInteger, ConversationUpdateType) { | ||
|  |     // No view items in the load window were effected.
 | ||
|  |     ConversationUpdateType_Minor, | ||
|  |     // A subset of view items in the load window were effected;
 | ||
|  |     // the view should be updated using the update items.
 | ||
|  |     ConversationUpdateType_Diff, | ||
|  |     // Complicated or unexpected changes occurred in the load window;
 | ||
|  |     // the view should be reloaded.
 | ||
|  |     ConversationUpdateType_Reload, | ||
|  | }; | ||
|  | 
 | ||
|  | #pragma mark -
 | ||
|  | 
 | ||
|  | typedef NS_ENUM(NSUInteger, ConversationUpdateItemType) { | ||
|  |     ConversationUpdateItemType_Insert, | ||
|  |     ConversationUpdateItemType_Delete, | ||
|  |     ConversationUpdateItemType_Update, | ||
|  | }; | ||
|  | 
 | ||
|  | #pragma mark -
 | ||
|  | 
 | ||
| 
											7 years ago
										 | @interface ConversationViewState : NSObject | ||
|  | 
 | ||
|  | @property (nonatomic, readonly) NSArray<id<ConversationViewItem>> *viewItems; | ||
|  | @property (nonatomic, readonly) NSDictionary<NSString *, NSNumber *> *interactionIndexMap; | ||
|  | // We have to track interactionIds separately.  We can't just use interactionIndexMap.allKeys,
 | ||
|  | // as that won't preserve ordering.
 | ||
|  | @property (nonatomic, readonly) NSArray<NSString *> *interactionIds; | ||
|  | @property (nonatomic, readonly, nullable) NSNumber *unreadIndicatorIndex; | ||
|  | 
 | ||
|  | @end | ||
|  | 
 | ||
|  | #pragma mark -
 | ||
|  | 
 | ||
| 
											7 years ago
										 | @interface ConversationUpdateItem : NSObject | ||
|  | 
 | ||
|  | @property (nonatomic, readonly) ConversationUpdateItemType updateItemType; | ||
|  | // Only applies in the "delete" and "update" cases.
 | ||
|  | @property (nonatomic, readonly) NSUInteger oldIndex; | ||
|  | // Only applies in the "insert" and "update" cases.
 | ||
|  | @property (nonatomic, readonly) NSUInteger newIndex; | ||
|  | // Only applies in the "insert" and "update" cases.
 | ||
|  | @property (nonatomic, readonly, nullable) id<ConversationViewItem> viewItem; | ||
|  | 
 | ||
|  | @end | ||
|  | 
 | ||
|  | #pragma mark -
 | ||
|  | 
 | ||
|  | @interface ConversationUpdate : NSObject | ||
|  | 
 | ||
|  | @property (nonatomic, readonly) ConversationUpdateType conversationUpdateType; | ||
|  | // Only applies in the "diff" case.
 | ||
|  | @property (nonatomic, readonly, nullable) NSArray<ConversationUpdateItem *> *updateItems; | ||
|  | //// Only applies in the "diff" case.
 | ||
|  | @property (nonatomic, readonly) BOOL shouldAnimateUpdates; | ||
|  | 
 | ||
|  | @end | ||
|  | 
 | ||
|  | #pragma mark -
 | ||
|  | 
 | ||
|  | @protocol ConversationViewModelDelegate <NSObject> | ||
|  | 
 | ||
|  | - (void)conversationViewModelWillUpdate; | ||
|  | - (void)conversationViewModelDidUpdate:(ConversationUpdate *)conversationUpdate; | ||
|  | 
 | ||
|  | - (void)conversationViewModelWillLoadMoreItems; | ||
|  | - (void)conversationViewModelDidLoadMoreItems; | ||
|  | - (void)conversationViewModelDidLoadPrevPage; | ||
|  | - (void)conversationViewModelRangeDidChange; | ||
|  | 
 | ||
| 
											7 years ago
										 | // Called after the view model recovers from a severe error
 | ||
|  | // to prod the view to reset its scroll state, etc.
 | ||
| 
											7 years ago
										 | - (void)conversationViewModelDidReset; | ||
|  | 
 | ||
| 
											7 years ago
										 | - (ConversationStyle *)conversationStyle; | ||
|  | 
 | ||
|  | @end | ||
|  | 
 | ||
|  | #pragma mark -
 | ||
|  | 
 | ||
|  | @interface ConversationViewModel : NSObject | ||
|  | 
 | ||
| 
											7 years ago
										 | @property (nonatomic, readonly) ConversationViewState *viewState; | ||
| 
											7 years ago
										 | @property (nonatomic, nullable) NSString *focusMessageIdOnOpen; | ||
|  | @property (nonatomic, readonly, nullable) ThreadDynamicInteractions *dynamicInteractions; | ||
|  | 
 | ||
|  | - (instancetype)init NS_UNAVAILABLE; | ||
|  | - (instancetype)initWithThread:(TSThread *)thread | ||
|  |           focusMessageIdOnOpen:(nullable NSString *)focusMessageIdOnOpen | ||
|  |                       delegate:(id<ConversationViewModelDelegate>)delegate NS_DESIGNATED_INITIALIZER; | ||
|  | 
 | ||
| 
											7 years ago
										 | - (void)ensureDynamicInteractionsAndUpdateIfNecessary:(BOOL)updateIfNecessary; | ||
| 
											7 years ago
										 | 
 | ||
|  | - (void)clearUnreadMessagesIndicator; | ||
|  | 
 | ||
|  | - (void)loadAnotherPageOfMessages; | ||
|  | 
 | ||
|  | - (void)viewDidResetContentAndLayout; | ||
|  | 
 | ||
|  | - (void)viewDidLoad; | ||
|  | 
 | ||
|  | - (BOOL)canLoadMoreItems; | ||
|  | 
 | ||
|  | - (nullable NSIndexPath *)ensureLoadWindowContainsQuotedReply:(OWSQuotedReplyModel *)quotedReply; | ||
| 
											7 years ago
										 | - (nullable NSIndexPath *)ensureLoadWindowContainsInteractionId:(NSString *)interactionId; | ||
| 
											7 years ago
										 | 
 | ||
| 
											7 years ago
										 | - (void)appendUnsavedOutgoingTextMessage:(TSOutgoingMessage *)outgoingMessage; | ||
| 
											7 years ago
										 | 
 | ||
| 
											6 years ago
										 | - (BOOL)reloadViewItems; | ||
|  | 
 | ||
| 
											7 years ago
										 | @end | ||
|  | 
 | ||
|  | NS_ASSUME_NONNULL_END |