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.
143 lines
4.5 KiB
Objective-C
143 lines
4.5 KiB
Objective-C
//
|
|
// Copyright (c) 2019 Open Whisper Systems. All rights reserved.
|
|
//
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
@class ConversationStyle;
|
|
@class ConversationViewModel;
|
|
@class OWSQuotedReplyModel;
|
|
@class TSOutgoingMessage;
|
|
@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 -
|
|
|
|
@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 -
|
|
|
|
@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;
|
|
|
|
// Called after the view model recovers from a severe error
|
|
// to prod the view to reset its scroll state, etc.
|
|
- (void)conversationViewModelDidReset;
|
|
|
|
@end
|
|
|
|
#pragma mark -
|
|
|
|
// Always load up to n messages when user arrives.
|
|
//
|
|
// The smaller this number is, the faster the conversation can display.
|
|
// To test, shrink you accessibility font as much as possible, then count how many 1-line system info messages (our
|
|
// shortest cells) can fit on screen at a time on an iPhoneX
|
|
//
|
|
// PERF: we could do less messages on shorter (older, slower) devices
|
|
// PERF: we could cache the cell height, since some messages will be much taller.
|
|
static const int kYapDatabasePageSize = 250;
|
|
|
|
// Never show more than n messages in conversation view when user arrives.
|
|
static const int kConversationInitialMaxRangeSize = 250;
|
|
|
|
// Never show more than n messages in conversation view at a time.
|
|
static const int kYapDatabaseRangeMaxLength = 250000;
|
|
|
|
#pragma mark -
|
|
|
|
@interface ConversationViewModel : NSObject
|
|
|
|
@property (nonatomic, readonly) ConversationViewState *viewState;
|
|
@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;
|
|
|
|
- (void)ensureDynamicInteractionsAndUpdateIfNecessary;
|
|
|
|
- (void)loadAnotherPageOfMessages;
|
|
|
|
- (void)viewDidResetContentAndLayout;
|
|
|
|
- (void)viewDidLoad;
|
|
|
|
- (BOOL)canLoadMoreItems;
|
|
|
|
- (nullable NSIndexPath *)ensureLoadWindowContainsQuotedReply:(OWSQuotedReplyModel *)quotedReply;
|
|
- (nullable NSIndexPath *)ensureLoadWindowContainsInteractionId:(NSString *)interactionId;
|
|
|
|
- (void)appendUnsavedOutgoingTextMessage:(TSOutgoingMessage *)outgoingMessage;
|
|
|
|
- (BOOL)reloadViewItems;
|
|
|
|
@end
|
|
|
|
NS_ASSUME_NONNULL_END
|