fix: add error rollback and error state hygiene in digest store

This commit is contained in:
pyr0ball 2026-03-20 09:56:22 -07:00
parent 4c2a08057c
commit 9bf14fbc75

View file

@ -12,6 +12,7 @@ export interface DigestEntry {
body: string | null
}
/** Extracted link from a digest email body. Used by DigestView.vue. */
export interface DigestLink {
url: string
score: number // 2 = job-likely, 1 = other
@ -24,16 +25,25 @@ export const useDigestStore = defineStore('digest', () => {
const error = ref<string | null>(null)
async function fetchAll() {
error.value = null
loading.value = true
const { data, error: err } = await useApiFetch<DigestEntry[]>('/api/digest-queue')
loading.value = false
if (err) { error.value = 'Could not load digest queue'; return }
if (err) {
error.value = err.kind === 'network' ? 'Network error' : `Error ${err.status}`
return
}
entries.value = data ?? []
}
async function remove(id: number) {
const snapshot = entries.value.find(e => e.id === id)
entries.value = entries.value.filter(e => e.id !== id)
await useApiFetch(`/api/digest-queue/${id}`, { method: 'DELETE' })
const { error: err } = await useApiFetch(`/api/digest-queue/${id}`, { method: 'DELETE' })
if (err) {
if (snapshot) entries.value = [...entries.value, snapshot]
error.value = err.kind === 'network' ? 'Network error' : `Error ${err.status}`
}
}
return { entries, loading, error, fetchAll, remove }