Fix delivery shown for undelieverd disappearing messages.

fixes  #1380

// FREEBIE
This commit is contained in:
Michael Kirk 2016-10-12 13:00:06 -04:00
parent ddc8db6ac3
commit 6a4fc3168d

View file

@ -93,7 +93,7 @@ typedef enum : NSUInteger {
} }
@property TSThread *thread; @property TSThread *thread;
@property TSMessage *lastDeliveredMessage; @property TSMessageAdapter *lastDeliveredMessage;
@property (nonatomic, strong) YapDatabaseConnection *editingDatabaseConnection; @property (nonatomic, strong) YapDatabaseConnection *editingDatabaseConnection;
@property (nonatomic, strong) YapDatabaseConnection *uiDatabaseConnection; @property (nonatomic, strong) YapDatabaseConnection *uiDatabaseConnection;
@property (nonatomic, strong) YapDatabaseViewMappings *messageMappings; @property (nonatomic, strong) YapDatabaseViewMappings *messageMappings;
@ -646,10 +646,7 @@ typedef enum : NSUInteger {
[[TSMessagesManager sharedManager] sendMessage:message [[TSMessagesManager sharedManager] sendMessage:message
inThread:self.thread inThread:self.thread
success:^{ success:^{
TSMessage *penultimateMessage = self.lastDeliveredMessage; DDLogInfo(@"%@ Successfully sent message.", self.tag);
self.lastDeliveredMessage = message;
// Touch the old one to remove "delivered" label
[penultimateMessage touch];
} }
failure:^{ failure:^{
DDLogWarn(@"%@ Failed to deliver message.", self.tag); DDLogWarn(@"%@ Failed to deliver message.", self.tag);
@ -954,28 +951,7 @@ typedef enum : NSUInteger {
return YES; return YES;
} }
// If message failed, say that message should be tapped to retry; return !![self collectionView:self.collectionView attributedTextForCellBottomLabelAtIndexPath:indexPath];
if (currentMessage.messageType == TSOutgoingMessageAdapter) {
TSOutgoingMessage *outgoingMessage = (TSOutgoingMessage *)currentMessage;
if(outgoingMessage.messageState == TSOutgoingMessageStateUnsent) {
return YES;
}
}
if ([self.thread isKindOfClass:[TSGroupThread class]]) {
return currentMessage.messageType == TSIncomingMessageAdapter;
} else {
if (indexPath.item == [self.collectionView numberOfItemsInSection:indexPath.section] - 1) {
return [self isMessageOutgoingAndDelivered:currentMessage];
}
if (![self isMessageOutgoingAndDelivered:currentMessage]) {
return NO;
}
TSMessageAdapter *nextMessage = [self nextOutgoingMessage:indexPath];
return ![self isMessageOutgoingAndDelivered:nextMessage];
}
} }
- (TSMessageAdapter *)nextOutgoingMessage:(NSIndexPath *)indexPath { - (TSMessageAdapter *)nextOutgoingMessage:(NSIndexPath *)indexPath {
@ -1008,10 +984,6 @@ typedef enum : NSUInteger {
- (NSAttributedString *)collectionView:(JSQMessagesCollectionView *)collectionView - (NSAttributedString *)collectionView:(JSQMessagesCollectionView *)collectionView
attributedTextForCellBottomLabelAtIndexPath:(NSIndexPath *)indexPath attributedTextForCellBottomLabelAtIndexPath:(NSIndexPath *)indexPath
{ {
if (![self shouldShowMessageStatusAtIndexPath:indexPath]) {
return nil;
}
id<OWSMessageData> messageData = [self messageAtIndexPath:indexPath]; id<OWSMessageData> messageData = [self messageAtIndexPath:indexPath];
if (![messageData isKindOfClass:[TSMessageAdapter class]]) { if (![messageData isKindOfClass:[TSMessageAdapter class]]) {
return nil; return nil;
@ -1025,12 +997,23 @@ typedef enum : NSUInteger {
[[NSAttributedString alloc] initWithString:NSLocalizedString(@"FAILED_SENDING_TEXT", nil)]; [[NSAttributedString alloc] initWithString:NSLocalizedString(@"FAILED_SENDING_TEXT", nil)];
return failedString; return failedString;
} else if ([outgoingMessage isEqual:self.lastDeliveredMessage]) { } else if ([self isMessageOutgoingAndDelivered:message]) {
NSAttributedString *deliveredString = NSAttributedString *deliveredString =
[[NSAttributedString alloc] initWithString:NSLocalizedString(@"DELIVERED_MESSAGE_TEXT", @"")]; [[NSAttributedString alloc] initWithString:NSLocalizedString(@"DELIVERED_MESSAGE_TEXT", @"")];
// Show when it's the last message in the thread
if (indexPath.item == [self.collectionView numberOfItemsInSection:indexPath.section] - 1) {
[self updateLastDeliveredMessage:message];
return deliveredString; return deliveredString;
} }
// Or when the next message is *not* an outgoing delivered message.
TSMessageAdapter *nextMessage = [self nextOutgoingMessage:indexPath];
if (![self isMessageOutgoingAndDelivered:nextMessage]) {
[self updateLastDeliveredMessage:message];
return deliveredString;
}
}
} else if (message.messageType == TSIncomingMessageAdapter && [self.thread isKindOfClass:[TSGroupThread class]]) { } else if (message.messageType == TSIncomingMessageAdapter && [self.thread isKindOfClass:[TSGroupThread class]]) {
TSIncomingMessage *incomingMessage = (TSIncomingMessage *)message.interaction; TSIncomingMessage *incomingMessage = (TSIncomingMessage *)message.interaction;
NSString *_Nonnull name = [self.contactsManager nameStringForPhoneIdentifier:incomingMessage.authorId]; NSString *_Nonnull name = [self.contactsManager nameStringForPhoneIdentifier:incomingMessage.authorId];
@ -1042,9 +1025,19 @@ typedef enum : NSUInteger {
return nil; return nil;
} }
- (void)updateLastDeliveredMessage:(TSMessageAdapter *)newLastDeliveredMessage
{
if (newLastDeliveredMessage.interaction.timestamp > self.lastDeliveredMessage.interaction.timestamp) {
TSMessageAdapter *penultimateDeliveredMessage = self.lastDeliveredMessage;
self.lastDeliveredMessage = newLastDeliveredMessage;
[penultimateDeliveredMessage.interaction touch];
}
}
- (CGFloat)collectionView:(JSQMessagesCollectionView *)collectionView - (CGFloat)collectionView:(JSQMessagesCollectionView *)collectionView
layout:(JSQMessagesCollectionViewFlowLayout *)collectionViewLayout layout:(JSQMessagesCollectionViewFlowLayout *)collectionViewLayout
heightForCellBottomLabelAtIndexPath:(NSIndexPath *)indexPath { heightForCellBottomLabelAtIndexPath:(NSIndexPath *)indexPath
{
if ([self shouldShowMessageStatusAtIndexPath:indexPath]) { if ([self shouldShowMessageStatusAtIndexPath:indexPath]) {
return 16.0f; return 16.0f;
} }