refactor ai event creation into a promise toast

This commit is contained in:
2025-08-20 13:14:29 -04:00
parent 275e83a6c0
commit 9a836fc866

View File

@@ -138,62 +138,88 @@ export default function HomePage() {
const handleAiCreate = async () => { const handleAiCreate = async () => {
if (!aiPrompt.trim()) return if (!aiPrompt.trim()) return
setAiLoading(true) setAiLoading(true)
try {
const res = await fetch('/api/ai-event', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ prompt: aiPrompt })
})
if (res.status === 401) { const promise = (): Promise<{ message: string }> => new Promise(async (resolve, reject) => {
toast.info('Please sign in to use AI features.') try {
setAiLoading(false) const res = await fetch('/api/ai-event', {
return method: 'POST',
} headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ prompt: aiPrompt })
})
const data = await res.json() if (res.status === 401) {
setAiLoading(false)
if (Array.isArray(data) && data.length > 0) { reject({
if (data.length === 1) { message: 'Please sign in to use AI features.'
// Prefill dialog directly (same as before) })
const ev = data[0] return
setTitle(ev.title || '')
setDescription(ev.description || '')
setLocation(ev.location || '')
setUrl(ev.url || '')
setStart(ev.start || '')
setEnd(ev.end || '')
setAllDay(ev.allDay || false)
setEditingId(null)
setAiPrompt("")
setDialogOpen(true)
setRecurrenceRule(ev.recurrenceRule || undefined)
} else {
// Save them all directly to DB
for (const ev of data) {
const newEvent = {
id: nanoid(),
...ev,
createdAt: new Date().toISOString(),
lastModified: new Date().toISOString(),
}
await addEvent(newEvent)
}
const stored = await getAllEvents()
setEvents(stored)
setAiPrompt("")
setSummary(`Added ${data.length} AI-generated events.`)
setSummaryUpdated(new Date().toLocaleString())
} }
} else {
toast.error('AI did not return event data.') const data = await res.json()
if (Array.isArray(data) && data.length > 0) {
if (data.length === 1) {
// Prefill dialog directly (same as before)
const ev = data[0]
setTitle(ev.title || '')
setDescription(ev.description || '')
setLocation(ev.location || '')
setUrl(ev.url || '')
setStart(ev.start || '')
setEnd(ev.end || '')
setAllDay(ev.allDay || false)
setEditingId(null)
setAiPrompt("")
setDialogOpen(true)
setRecurrenceRule(ev.recurrenceRule || undefined)
resolve({
message: 'Event has been created!'
})
} else {
// Save them all directly to DB
for (const ev of data) {
const newEvent = {
id: nanoid(),
...ev,
createdAt: new Date().toISOString(),
lastModified: new Date().toISOString(),
}
await addEvent(newEvent)
}
const stored = await getAllEvents()
setEvents(stored)
setAiPrompt("")
setSummary(`Added ${data.length} AI-generated events.`)
setSummaryUpdated(new Date().toLocaleString())
resolve({
message: 'Event has been created!'
})
}
} else {
reject({
message: 'AI did not return event data.'
})
}
} catch (err) {
console.error(err)
reject({
message: 'Error from AI service.'
})
} }
} catch (err) { })
console.error(err)
toast.error('Error from AI service.') toast.promise(promise, {
} finally { loading: "Generating event...",
setAiLoading(false) success: ({ message }) => {
} return message
},
error: ({ message }) => {
return message
}
})
setAiLoading(false)
} }
// AI Summarize Events // AI Summarize Events