Fix out of order undos for turbo zaps (#883)

Turbo zaps had different toast bodies so they weren't merged together. This gave stackers the option to undo these zaps out of order.

When zaps are undone out of order, the client cache can get in a bad state. Using the item id as a tag fixes that such that zaps for the same item will always get merged together.

This can be seen as a workaround for hacky zap undo code but I think it's also better UX so maybe we should do this anyway.
This commit is contained in:
ekzyis 2024-02-27 01:10:43 +01:00 committed by GitHub
parent bbdd969394
commit 89de8a9907
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 4 additions and 4 deletions

View File

@ -340,6 +340,7 @@ export function useZap () {
let undoUpdate let undoUpdate
return { return {
flowId, flowId,
tag: itemId,
type: 'zap', type: 'zap',
pendingMessage: `zapped ${amount} sats`, pendingMessage: `zapped ${amount} sats`,
onPending: () => onPending: () =>

View File

@ -127,13 +127,12 @@ export const ToastProvider = ({ children }) => {
// merge toasts with same tag // merge toasts with same tag
const prevToast = toasts[idx] const prevToast = toasts[idx]
let { rawBody, body, amount } = prevToast let { amount } = prevToast
rawBody ??= body
amount = amount ? amount + 1 : 2 amount = amount ? amount + 1 : 2
body = `(${amount}) ${rawBody}` const body = `(${amount}) ${toast.body}`
return [ return [
...toasts.slice(0, idx), ...toasts.slice(0, idx),
{ ...toast, rawBody, amount, body }, { ...toast, amount, body },
...toasts.slice(idx + 1) ...toasts.slice(idx + 1)
] ]
} }