refactor delete notification (#731)
Co-authored-by: ekzyis <ek@stacker.news>
This commit is contained in:
parent
8996fd085a
commit
31a40e15be
|
@ -81,7 +81,7 @@ export function BountyForm ({
|
||||||
const prefix = sub?.name ? `/~${sub.name}` : ''
|
const prefix = sub?.name ? `/~${sub.name}` : ''
|
||||||
await router.push(prefix + '/recent')
|
await router.push(prefix + '/recent')
|
||||||
}
|
}
|
||||||
toastDeleteScheduled(toaster, data, !!item, values.text)
|
toastDeleteScheduled(toaster, data, 'upsertBounty', !!item, values.text)
|
||||||
}, [upsertBounty, router]
|
}, [upsertBounty, router]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -43,7 +43,7 @@ export default function CommentEdit ({ comment, editThreshold, onSuccess, onCanc
|
||||||
if (error) {
|
if (error) {
|
||||||
throw new Error({ message: error.toString() })
|
throw new Error({ message: error.toString() })
|
||||||
}
|
}
|
||||||
toastDeleteScheduled(toaster, data, true, values.text)
|
toastDeleteScheduled(toaster, data, 'upsertComment', true, values.text)
|
||||||
if (onSuccess) {
|
if (onSuccess) {
|
||||||
onSuccess()
|
onSuccess()
|
||||||
}
|
}
|
||||||
|
|
|
@ -104,7 +104,7 @@ export function DiscussionForm ({
|
||||||
const prefix = sub?.name ? `/~${sub.name}` : ''
|
const prefix = sub?.name ? `/~${sub.name}` : ''
|
||||||
await router.push(prefix + '/recent')
|
await router.push(prefix + '/recent')
|
||||||
}
|
}
|
||||||
toastDeleteScheduled(toaster, data, !!item, values.text)
|
toastDeleteScheduled(toaster, data, 'upsertDiscussion', !!item, values.text)
|
||||||
}, [upsertDiscussion, router, item, sub, crossposter]
|
}, [upsertDiscussion, router, item, sub, crossposter]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -82,7 +82,7 @@ export default function JobForm ({ item, sub }) {
|
||||||
} else {
|
} else {
|
||||||
await router.push(`/~${sub.name}/recent`)
|
await router.push(`/~${sub.name}/recent`)
|
||||||
}
|
}
|
||||||
toastDeleteScheduled(toaster, data, !!item, values.text)
|
toastDeleteScheduled(toaster, data, 'upsertJob', !!item, values.text)
|
||||||
}, [upsertJob, router, logoId]
|
}, [upsertJob, router, logoId]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -98,7 +98,7 @@ export function LinkForm ({ item, sub, editThreshold, children }) {
|
||||||
const prefix = sub?.name ? `/~${sub.name}` : ''
|
const prefix = sub?.name ? `/~${sub.name}` : ''
|
||||||
await router.push(prefix + '/recent')
|
await router.push(prefix + '/recent')
|
||||||
}
|
}
|
||||||
toastDeleteScheduled(toaster, data, !!item, values.text)
|
toastDeleteScheduled(toaster, data, 'upsertLink', !!item, values.text)
|
||||||
}, [upsertLink, router]
|
}, [upsertLink, router]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ export function PollForm ({ item, sub, editThreshold, children }) {
|
||||||
const prefix = sub?.name ? `/~${sub.name}` : ''
|
const prefix = sub?.name ? `/~${sub.name}` : ''
|
||||||
await router.push(prefix + '/recent')
|
await router.push(prefix + '/recent')
|
||||||
}
|
}
|
||||||
toastDeleteScheduled(toaster, data, !!item, values.text)
|
toastDeleteScheduled(toaster, data, 'upsertPoll', !!item, values.text)
|
||||||
}, [upsertPoll, router]
|
}, [upsertPoll, router]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -99,7 +99,7 @@ export default forwardRef(function Reply ({ item, onSuccess, replyOpen, children
|
||||||
|
|
||||||
const onSubmit = useCallback(async ({ amount, hash, hmac, ...values }, { resetForm }) => {
|
const onSubmit = useCallback(async ({ amount, hash, hmac, ...values }, { resetForm }) => {
|
||||||
const { data } = await upsertComment({ variables: { parentId, hash, hmac, ...values } })
|
const { data } = await upsertComment({ variables: { parentId, hash, hmac, ...values } })
|
||||||
toastDeleteScheduled(toaster, data, false, values.text)
|
toastDeleteScheduled(toaster, data, 'upsertComment', false, values.text)
|
||||||
resetForm({ text: '' })
|
resetForm({ text: '' })
|
||||||
setReply(replyOpen || false)
|
setReply(replyOpen || false)
|
||||||
}, [upsertComment, setReply, parentId])
|
}, [upsertComment, setReply, parentId])
|
||||||
|
|
26
lib/form.js
26
lib/form.js
|
@ -13,11 +13,22 @@ export const normalizeForwards = (forward) => {
|
||||||
return forward.filter(fwd => fwd.nym || fwd.user?.name).map(fwd => ({ nym: fwd.nym ?? fwd.user?.name, pct: Number(fwd.pct) }))
|
return forward.filter(fwd => fwd.nym || fwd.user?.name).map(fwd => ({ nym: fwd.nym ?? fwd.user?.name, pct: Number(fwd.pct) }))
|
||||||
}
|
}
|
||||||
|
|
||||||
export const toastDeleteScheduled = (toaster, upsertResponseData, isEdit, itemText) => {
|
export const toastDeleteScheduled = (toaster, upsertResponseData, dataKey, isEdit, itemText) => {
|
||||||
const keys = Object.keys(upsertResponseData)
|
const data = upsertResponseData[dataKey]
|
||||||
const data = upsertResponseData[keys[0]]
|
|
||||||
if (!data) return
|
if (!data) return
|
||||||
const deleteScheduledAt = data.deleteScheduledAt ? new Date(data.deleteScheduledAt) : undefined
|
|
||||||
|
const deleteMentioned = hasDeleteMention(itemText)
|
||||||
|
const deletedScheduled = !!data.deleteScheduledAt
|
||||||
|
|
||||||
|
if (!deleteMentioned) return
|
||||||
|
if (deleteMentioned && !deletedScheduled) {
|
||||||
|
// There's a delete mention but the deletion wasn't scheduled
|
||||||
|
toaster.warning('it looks like you tried to use the delete bot but it didn\'t work. make sure you use the correct format: "@delete in n units" e.g. "@delete in 2 hours"', 10000)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// when we reached this code, we know that a delete was scheduled
|
||||||
|
const deleteScheduledAt = new Date(data.deleteScheduledAt)
|
||||||
if (deleteScheduledAt) {
|
if (deleteScheduledAt) {
|
||||||
const itemType = {
|
const itemType = {
|
||||||
upsertDiscussion: 'discussion post',
|
upsertDiscussion: 'discussion post',
|
||||||
|
@ -26,14 +37,9 @@ export const toastDeleteScheduled = (toaster, upsertResponseData, isEdit, itemTe
|
||||||
upsertBounty: 'bounty',
|
upsertBounty: 'bounty',
|
||||||
upsertJob: 'job',
|
upsertJob: 'job',
|
||||||
upsertComment: 'comment'
|
upsertComment: 'comment'
|
||||||
}[keys[0]] ?? 'item'
|
}[dataKey] ?? 'item'
|
||||||
|
|
||||||
const message = `${itemType === 'comment' ? 'your comment' : isEdit ? `this ${itemType}` : `your new ${itemType}`} will be deleted at ${deleteScheduledAt.toLocaleString()}`
|
const message = `${itemType === 'comment' ? 'your comment' : isEdit ? `this ${itemType}` : `your new ${itemType}`} will be deleted at ${deleteScheduledAt.toLocaleString()}`
|
||||||
toaster.success(message)
|
toaster.success(message)
|
||||||
return
|
|
||||||
}
|
|
||||||
if (hasDeleteMention(itemText)) {
|
|
||||||
// There's a delete mention but the deletion wasn't scheduled
|
|
||||||
toaster.warning('it looks like you tried to use the delete bot but it didn\'t work. make sure you use the correct format: "@delete in n units" e.g. "@delete in 2 hours"', 10000)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue