SDK modules added/enhanced: - compliance-hub, compliance-scope, consent-management, notfallplan - audit-report, workflow, source-policy, dsms - advisory-board documentation section - TOM dashboard components, TOM generator SDM mapping - DSFA: mitigation library, risk catalog, threshold analysis, source attribution - VVT: baseline catalog, profiling engine, types - Loeschfristen: baseline catalog, compliance engine, export, profiling, types - Compliance scope: engine, profiling, golden tests, types Existing SDK pages updated: - dsfa/[id], tom, vvt, loeschfristen, advisory-board — expanded functionality - SDKSidebar, StepHeader — new navigation items and layout - SDK layout, context, types — expanded type system Other admin-v2 changes: - AI agents page, RAG pipeline DSFA integration - GridOverlay component updates - Companion feature (development + education) - Compliance advisor SOUL definition Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
81 lines
2.0 KiB
TypeScript
81 lines
2.0 KiB
TypeScript
'use client'
|
|
|
|
import { LessonSession, LessonStatus } from '@/lib/companion/types'
|
|
import { LessonStartForm } from './LessonStartForm'
|
|
import { LessonActiveView } from './LessonActiveView'
|
|
import { LessonEndedView } from './LessonEndedView'
|
|
|
|
interface LessonContainerProps {
|
|
session: LessonSession | null
|
|
onStartLesson: (data: { classId: string; subject: string; topic?: string; templateId?: string }) => void
|
|
onEndLesson: () => void
|
|
onPauseToggle: () => void
|
|
onExtendTime: (minutes: number) => void
|
|
onSkipPhase: () => void
|
|
onSaveReflection: (rating: number, notes: string, nextSteps: string) => void
|
|
onAddHomework: (title: string, dueDate: string) => void
|
|
onRemoveHomework: (id: string) => void
|
|
loading?: boolean
|
|
}
|
|
|
|
export function LessonContainer({
|
|
session,
|
|
onStartLesson,
|
|
onEndLesson,
|
|
onPauseToggle,
|
|
onExtendTime,
|
|
onSkipPhase,
|
|
onSaveReflection,
|
|
onAddHomework,
|
|
onRemoveHomework,
|
|
loading,
|
|
}: LessonContainerProps) {
|
|
// Determine which view to show based on session state
|
|
const getView = (): 'start' | 'active' | 'ended' => {
|
|
if (!session) return 'start'
|
|
|
|
const status = session.status
|
|
if (status === 'completed') return 'ended'
|
|
if (status === 'not_started') return 'start'
|
|
|
|
return 'active'
|
|
}
|
|
|
|
const view = getView()
|
|
|
|
if (view === 'start') {
|
|
return (
|
|
<LessonStartForm
|
|
onStart={onStartLesson}
|
|
loading={loading}
|
|
/>
|
|
)
|
|
}
|
|
|
|
if (view === 'ended' && session) {
|
|
return (
|
|
<LessonEndedView
|
|
session={session}
|
|
onSaveReflection={onSaveReflection}
|
|
onAddHomework={onAddHomework}
|
|
onRemoveHomework={onRemoveHomework}
|
|
onStartNew={() => onEndLesson()} // This will clear the session and show start form
|
|
/>
|
|
)
|
|
}
|
|
|
|
if (session) {
|
|
return (
|
|
<LessonActiveView
|
|
session={session}
|
|
onPauseToggle={onPauseToggle}
|
|
onExtendTime={onExtendTime}
|
|
onSkipPhase={onSkipPhase}
|
|
onEndLesson={onEndLesson}
|
|
/>
|
|
)
|
|
}
|
|
|
|
return null
|
|
}
|