refactor ai event creation into a promise toast
This commit is contained in:
130
src/app/page.tsx
130
src/app/page.tsx
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user