"use client" import React, { useEffect, useRef, useState, useTransition } from 'react' import { Card, CardContent, CardHeader } from '@/components/ui/card' import { Button } from '@/components/ui/button' import { InputField } from '@/components/form/input-field' import { Toaster } from '@/components/ui/sonner' import { cn } from '@/lib/utils/cn' import { useStore } from './store' import { TextareaField } from '@/components/form/textarea-field' import { DeviceFrameset } from 'react-device-frameset' import 'react-device-frameset/styles/marvel-devices.min.css' import { generateClap } from './server/aitube/generateClap' export function Main() { const [_isPending, startTransition] = useTransition() const storyPromptDraft = useStore(s => s.storyPromptDraft) const storyPrompt = useStore(s => s.storyPrompt) const status = useStore(s => s.status) const storyGenerationStatus = useStore(s => s.storyGenerationStatus) const voiceGenerationStatus = useStore(s => s.voiceGenerationStatus) const imageGenerationStatus = useStore(s => s.imageGenerationStatus) const videoGenerationStatus = useStore(s => s.videoGenerationStatus) const setStoryPromptDraft = useStore(s => s.setStoryPromptDraft) const setStoryPrompt = useStore(s => s.setStoryPrompt) const setStatus = useStore(s => s.setStatus) const setStoryGenerationStatus = useStore(s => s.setStoryGenerationStatus) const setVoiceGenerationStatus = useStore(s => s.setVoiceGenerationStatus) const setImageGenerationStatus = useStore(s => s.setImageGenerationStatus) const setVideoGenerationStatus = useStore(s => s.setVideoGenerationStatus) const hasPendingTasks = storyGenerationStatus === "generating" && voiceGenerationStatus === "generating" && imageGenerationStatus === "generating" && videoGenerationStatus === "generating" const isBusy = status === "generating" || hasPendingTasks const handleSubmit = async () => { const prompt = storyPromptDraft setStatus("generating") setStoryPrompt(prompt) startTransition(async () => { console.log(`handleSubmit(): generating a clap using prompt = "${prompt}" `) try { const clap = await generateClap({ prompt }) console.log(`handleSubmit(): received a clap = `, clap) setStatus("finished") } catch (err) { setStatus("error") } }) } return (
AI
Stories Factory

Generate video stories with AI ✨

{ setStoryPromptDraft(e.target.value) }} placeholder="Yesterday I was at my favorite pizza place and.." inputClassName="h-80" disabled={isBusy} value={storyPromptDraft} />
{isBusy ? `Generation in progress (${status})` : "" }
Hello world
); }