This repository has been archived on 2026-02-15. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
breakpilot-pwa/website/components/wizard/WizardProvider.tsx
BreakPilot Dev 19855efacc
Some checks failed
Tests / Go Tests (push) Has been cancelled
Tests / Python Tests (push) Has been cancelled
Tests / Integration Tests (push) Has been cancelled
Tests / Go Lint (push) Has been cancelled
Tests / Python Lint (push) Has been cancelled
Tests / Security Scan (push) Has been cancelled
Tests / All Checks Passed (push) Has been cancelled
Security Scanning / Secret Scanning (push) Has been cancelled
Security Scanning / Dependency Vulnerability Scan (push) Has been cancelled
Security Scanning / Go Security Scan (push) Has been cancelled
Security Scanning / Python Security Scan (push) Has been cancelled
Security Scanning / Node.js Security Scan (push) Has been cancelled
Security Scanning / Docker Image Security (push) Has been cancelled
Security Scanning / Security Summary (push) Has been cancelled
CI/CD Pipeline / Go Tests (push) Has been cancelled
CI/CD Pipeline / Python Tests (push) Has been cancelled
CI/CD Pipeline / Website Tests (push) Has been cancelled
CI/CD Pipeline / Linting (push) Has been cancelled
CI/CD Pipeline / Security Scan (push) Has been cancelled
CI/CD Pipeline / Docker Build & Push (push) Has been cancelled
CI/CD Pipeline / Integration Tests (push) Has been cancelled
CI/CD Pipeline / Deploy to Staging (push) Has been cancelled
CI/CD Pipeline / Deploy to Production (push) Has been cancelled
CI/CD Pipeline / CI Summary (push) Has been cancelled
ci/woodpecker/manual/build-ci-image Pipeline was successful
ci/woodpecker/manual/main Pipeline failed
feat: BreakPilot PWA - Full codebase (clean push without large binaries)
All services: admin-v2, studio-v2, website, ai-compliance-sdk,
consent-service, klausur-service, voice-service, and infrastructure.
Large PDFs and compiled binaries excluded via .gitignore.
2026-02-11 13:25:58 +01:00

73 lines
1.9 KiB
TypeScript

'use client'
import { createContext, useContext, useState, ReactNode, useCallback } from 'react'
import type { WizardStep, WizardContextValue, TestCategoryResult, FullTestResults } from './types'
const WizardContext = createContext<WizardContextValue | null>(null)
export function useWizard(): WizardContextValue {
const context = useContext(WizardContext)
if (!context) {
throw new Error('useWizard must be used within a WizardProvider')
}
return context
}
interface WizardProviderProps {
children: ReactNode
initialSteps: WizardStep[]
module: string
}
export function WizardProvider({ children, initialSteps, module }: WizardProviderProps) {
const [currentStep, setCurrentStep] = useState(0)
const [steps, setSteps] = useState<WizardStep[]>(initialSteps)
const [categoryResults, setCategoryResults] = useState<Record<string, TestCategoryResult>>({})
const [fullResults, setFullResults] = useState<FullTestResults | null>(null)
const [isLoading, setIsLoading] = useState(false)
const [error, setError] = useState<string | null>(null)
const goToNext = useCallback(() => {
if (currentStep < steps.length - 1) {
setSteps((prev) =>
prev.map((step, idx) =>
idx === currentStep && step.status === 'pending'
? { ...step, status: 'completed' }
: step
)
)
setCurrentStep((prev) => prev + 1)
}
}, [currentStep, steps.length])
const goToPrev = useCallback(() => {
if (currentStep > 0) {
setCurrentStep((prev) => prev - 1)
}
}, [currentStep])
const value: WizardContextValue = {
currentStep,
steps,
setCurrentStep,
setSteps,
goToNext,
goToPrev,
module,
categoryResults,
setCategoryResults,
fullResults,
setFullResults,
isLoading,
setIsLoading,
error,
setError,
}
return (
<WizardContext.Provider value={value}>
{children}
</WizardContext.Provider>
)
}