import { useEffect, useMemo } from "react";
import { useNavigate } from "react-router-dom";
import {
Card,
CardDescription,
CardTitle,
} from "../../../components/ui/card";
import Button from "../../../components/ui/button/Button";
import PageMeta from "../../../components/common/PageMeta";
import SiteAndSectorSelector from "../../../components/common/SiteAndSectorSelector";
import Alert from "../../../components/ui/alert/Alert";
import {
Loader2,
PlayCircle,
RefreshCw,
Wand2,
} from "lucide-react";
import { useSiteStore } from "../../../store/siteStore";
import { useSectorStore } from "../../../store/sectorStore";
import { useBuilderStore } from "../../../store/builderStore";
import { BusinessDetailsStep } from "./steps/BusinessDetailsStep";
import { BriefStep } from "./steps/BriefStep";
import { ObjectivesStep } from "./steps/ObjectivesStep";
import { StyleStep } from "./steps/StyleStep";
export default function SiteBuilderWizard() {
const navigate = useNavigate();
const { activeSite } = useSiteStore();
const { activeSector } = useSectorStore();
const {
form,
currentStep,
setStep,
setField,
updateStyle,
addObjective,
removeObjective,
nextStep,
previousStep,
submitWizard,
isSubmitting,
error,
activeBlueprint,
refreshPages,
pages,
generationProgress,
isGenerating,
syncContextFromStores,
} = useBuilderStore();
useEffect(() => {
syncContextFromStores();
}, [activeSite?.id, activeSite?.name, activeSector?.id]);
const steps = useMemo(
() => [
{
title: "Business context",
component: (
Sites / Create Site
Create a new site using IGNY8’s AI-powered wizard. Align the estate, strategy, and tone before publishing.
Task IDs
{generationProgress.taskIds.join(", ")}
Celery task ID: {generationProgress.celeryTaskId}
)}