Se corrigen bugs sobre crear carreras, filtrado y que aparezcan las materias cuando se crean
This commit is contained in:
@@ -30,7 +30,7 @@ export function useDeleteCarreraDialog(carreraId: string, onDeleted?: () => void
|
||||
|
||||
const dialog = (
|
||||
<Dialog open={open} onOpenChange={setOpen}>
|
||||
<DialogContent>
|
||||
<DialogContent className="bg-white">
|
||||
<DialogHeader>
|
||||
<DialogTitle className="font-mono" >¿Eliminar carrera?</DialogTitle>
|
||||
<DialogDescription>
|
||||
|
||||
@@ -11,9 +11,11 @@ import { supabase, useSupabaseAuth } from "@/auth/supabase"
|
||||
import { Field } from "./Field"
|
||||
import { Tabs, TabsContent, TabsList, TabsTrigger } from "../ui/tabs"
|
||||
import { asignaturaKeys } from "./planQueries"
|
||||
import { useRouter } from "@tanstack/react-router"
|
||||
|
||||
export function AddAsignaturaButton({ planId, onAdded }: { planId: string; onAdded?: () => void }) {
|
||||
const qc = useQueryClient()
|
||||
const router = useRouter()
|
||||
const supabaseAuth = useSupabaseAuth()
|
||||
const [open, setOpen] = useState(false)
|
||||
const [saving, setSaving] = useState(false)
|
||||
@@ -45,7 +47,13 @@ export function AddAsignaturaButton({ planId, onAdded }: { planId: string; onAdd
|
||||
objetivos: toNull(f.objetivos),
|
||||
contenidos: [], bibliografia: [], criterios_evaluacion: null,
|
||||
}
|
||||
const { error } = await supabase.from("asignaturas").insert([payload])
|
||||
const { error,data } = await supabase.from("asignaturas").insert([payload]).select().single()
|
||||
console.log(data);
|
||||
router.invalidate()
|
||||
router.navigate({
|
||||
to: "/asignatura/$asignaturaId",
|
||||
params: { asignaturaId: data.id },
|
||||
})
|
||||
setSaving(false)
|
||||
if (error) { alert(error.message); return }
|
||||
setOpen(false)
|
||||
@@ -64,8 +72,17 @@ export function AddAsignaturaButton({ planId, onAdded }: { planId: string; onAdd
|
||||
body: JSON.stringify({ planEstudiosId: planId, prompt: iaPrompt, semestre: iaSemestre.trim() ? Number(iaSemestre) : undefined, insert: true, uuid: supabaseAuth.user?.id }),
|
||||
})
|
||||
if (!res.ok) throw new Error(await res.text())
|
||||
const data = await res.json()
|
||||
console.log("Asignatura generada:", data)
|
||||
const asignaturaId = data.asignaturaId || data.insertResult?.id
|
||||
if (!asignaturaId) throw new Error("No se recibió el ID de la asignatura generada")
|
||||
confetti({ particleCount: 120, spread: 80, origin: { y: 0.6 } })
|
||||
setOpen(false)
|
||||
router.invalidate()
|
||||
router.navigate({
|
||||
to: "/asignatura/$asignaturaId",
|
||||
params: { asignaturaId },
|
||||
})
|
||||
onAdded?.()
|
||||
// qc.invalidateQueries({ queryKey: asignaturaKeys.preview(planId) })
|
||||
// qc.invalidateQueries({ queryKey: asignaturaKeys.count(planId) })
|
||||
|
||||
Reference in New Issue
Block a user