'use client'
import type { TrainingModule, ModuleContent, TrainingMedia } from '@/lib/sdk/training/types'
import AudioPlayer from '@/components/training/AudioPlayer'
import VideoPlayer from '@/components/training/VideoPlayer'
import ScriptPreview from '@/components/training/ScriptPreview'
interface ContentTabProps {
modules: TrainingModule[]
selectedModuleId: string
onSelectModule: (id: string) => void
generatedContent: ModuleContent | null
generating: boolean
bulkGenerating: boolean
bulkResult: { generated: number; skipped: number; errors: string[] } | null
moduleMedia: TrainingMedia[]
onGenerateContent: () => void
onGenerateQuiz: () => void
onBulkContent: () => void
onBulkQuiz: () => void
onPublishContent: (contentId: string) => void
onReloadMedia: () => void
}
export function ContentTab({
modules,
selectedModuleId,
onSelectModule,
generatedContent,
generating,
bulkGenerating,
bulkResult,
moduleMedia,
onGenerateContent,
onGenerateQuiz,
onBulkContent,
onBulkQuiz,
onPublishContent,
onReloadMedia,
}: ContentTabProps) {
return (
{/* Bulk Generation */}
Bulk-Generierung
Generiere Inhalte und Quiz-Fragen fuer alle Module auf einmal
{bulkResult && (
Generiert: {bulkResult.generated}
Uebersprungen: {bulkResult.skipped}
{bulkResult.errors?.length > 0 && (
Fehler: {bulkResult.errors.length}
)}
{bulkResult.errors?.length > 0 && (
{bulkResult.errors.map((err, i) =>
{err}
)}
)}
)}
LLM-Content-Generator
Generiere Schulungsinhalte und Quiz-Fragen automatisch via KI
{generatedContent && (
Generierter Inhalt (v{generatedContent.version})
Generiert von: {generatedContent.generated_by} ({generatedContent.llm_model})
{!generatedContent.is_published ? (
) : (
Veroeffentlicht
)}
{generatedContent.content_body}
)}
{/* Audio Player */}
{selectedModuleId && generatedContent?.is_published && (
m.media_type === 'audio') || null}
onMediaUpdate={onReloadMedia}
/>
)}
{/* Video Player */}
{selectedModuleId && generatedContent?.is_published && (
m.media_type === 'video') || null}
onMediaUpdate={onReloadMedia}
/>
)}
{/* Script Preview */}
{selectedModuleId && generatedContent?.is_published && (
)}
)
}