[🐴] Better retry styling (#4032)

* Pass whole object to MessageItem for clarity

* Add retry to pending-message

* Style send failure, retry

* Group pending messages

* Remove todos

* Fix types with fake message
This commit is contained in:
Eric Bailey 2024-05-15 11:45:18 -05:00 committed by GitHub
parent ed8922281a
commit 04aea93192
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 121 additions and 87 deletions

View file

@ -735,6 +735,8 @@ export class Convo {
}
}
private pendingFailed = false
async sendMessage(message: ChatBskyConvoSendMessage.InputSchema['message']) {
// Ignore empty messages for now since they have no other purpose atm
if (!message.text.trim()) return
@ -747,11 +749,9 @@ export class Convo {
id: tempId,
message,
})
// remove on each send, it might go through now without user having to click
this.footerItems.delete(ConvoItemError.PendingFailed)
this.commit()
if (!this.isProcessingPendingMessages) {
if (!this.isProcessingPendingMessages && !this.pendingFailed) {
this.processPendingMessages()
}
}
@ -805,16 +805,7 @@ export class Convo {
this.commit()
} catch (e: any) {
logger.error(e, {context: `Convo: failed to send message`})
this.footerItems.set(ConvoItemError.PendingFailed, {
type: 'error-recoverable',
key: ConvoItemError.PendingFailed,
code: ConvoItemError.PendingFailed,
retry: () => {
this.footerItems.delete(ConvoItemError.PendingFailed)
this.commit()
this.batchRetryPendingMessages()
},
})
this.pendingFailed = true
this.commit()
} finally {
this.isProcessingPendingMessages = false
@ -868,16 +859,7 @@ export class Convo {
)
} catch (e: any) {
logger.error(e, {context: `Convo: failed to batch retry messages`})
this.footerItems.set(ConvoItemError.PendingFailed, {
type: 'error-recoverable',
key: ConvoItemError.PendingFailed,
code: ConvoItemError.PendingFailed,
retry: () => {
this.footerItems.delete(ConvoItemError.PendingFailed)
this.commit()
this.batchRetryPendingMessages()
},
})
this.pendingFailed = true
this.commit()
}
}
@ -958,6 +940,7 @@ export class Convo {
key: m.id,
message: {
...m.message,
$type: 'chat.bsky.convo.defs#messageView',
id: nanoid(),
rev: '__fake__',
sentAt: new Date().toISOString(),
@ -968,6 +951,13 @@ export class Convo {
sender: this.sender!,
},
nextMessage: null,
retry: this.pendingFailed
? () => {
this.pendingFailed = false
this.commit()
this.batchRetryPendingMessages()
}
: undefined,
})
})

View file

@ -35,10 +35,6 @@ export enum ConvoItemError {
* Error fetching past messages
*/
HistoryFailed = 'historyFailed',
/**
* Error sending new message
*/
PendingFailed = 'pendingFailed',
}
export enum ConvoErrorCode {
@ -83,7 +79,7 @@ export type ConvoDispatch =
export type ConvoItem =
| {
type: 'message' | 'pending-message'
type: 'message'
key: string
message: ChatBskyConvoDefs.MessageView
nextMessage:
@ -91,6 +87,19 @@ export type ConvoItem =
| ChatBskyConvoDefs.DeletedMessageView
| null
}
| {
type: 'pending-message'
key: string
message: ChatBskyConvoDefs.MessageView
nextMessage:
| ChatBskyConvoDefs.MessageView
| ChatBskyConvoDefs.DeletedMessageView
| null
/**
* Retry sending the message. If present, the message is in a failed state.
*/
retry?: () => void
}
| {
type: 'deleted-message'
key: string