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/admin-v2/components/wizard/WizardProvider.tsx
BreakPilot Dev 660295e218 fix(admin-v2): Restore complete admin-v2 application
The admin-v2 application was incomplete in the repository. This commit
restores all missing components:

- Admin pages (76 pages): dashboard, ai, compliance, dsgvo, education,
  infrastructure, communication, development, onboarding, rbac
- SDK pages (45 pages): tom, dsfa, vvt, loeschfristen, einwilligungen,
  vendor-compliance, tom-generator, dsr, and more
- Developer portal (25 pages): API docs, SDK guides, frameworks
- All components, lib files, hooks, and types
- Updated package.json with all dependencies

The issue was caused by incomplete initial repository state - the full
admin-v2 codebase existed in backend/admin-v2 and docs-src/admin-v2
but was never fully synced to the main admin-v2 directory.

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-08 23:40:15 -08: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>
)
}