@djangocfg/ui-tools 2.1.94 → 2.1.95

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/tools/Mermaid/index.tsx","../src/tools/LottiePlayer/index.tsx","../src/tools/JsonForm/templates/FieldTemplate.tsx","../src/tools/JsonForm/templates/ObjectFieldTemplate.tsx","../src/tools/JsonForm/templates/ArrayFieldTemplate.tsx","../src/tools/JsonForm/templates/ArrayFieldItemTemplate.tsx","../src/tools/JsonForm/templates/ErrorListTemplate.tsx","../src/tools/JsonForm/templates/BaseInputTemplate.tsx","../src/tools/JsonForm/utils.ts","../src/tools/JsonForm/widgets/TextWidget.tsx","../src/tools/JsonForm/widgets/NumberWidget.tsx","../src/tools/JsonForm/widgets/CheckboxWidget.tsx","../src/tools/JsonForm/widgets/SelectWidget.tsx","../src/tools/JsonForm/widgets/SwitchWidget.tsx","../src/tools/JsonForm/widgets/ColorWidget.tsx","../src/tools/JsonForm/widgets/SliderWidget.tsx","../src/tools/JsonForm/JsonSchemaForm.tsx","../src/tools/OpenapiViewer/index.tsx","../src/stores/mediaCache.ts","../src/tools/VideoPlayer/utils/debug.ts","../src/tools/VideoPlayer/providers/VidstackProvider.tsx","../src/tools/VideoPlayer/hooks/useVideoPlayerSettings.ts","../src/tools/VideoPlayer/providers/NativeProvider.tsx","../src/tools/VideoPlayer/providers/StreamProvider.tsx","../src/tools/VideoPlayer/context/VideoPlayerContext.tsx","../src/tools/VideoPlayer/utils/resolvers.ts","../src/tools/VideoPlayer/utils/fileSource.ts","../src/tools/VideoPlayer/components/VideoPlayer.tsx","../src/tools/VideoPlayer/components/VideoControls.tsx","../src/tools/VideoPlayer/components/VideoErrorFallback.tsx","../src/tools/AudioPlayer/hooks/useHybridAudio.ts","../src/tools/AudioPlayer/hooks/useHybridAudioAnalysis.ts","../src/tools/AudioPlayer/hooks/useVisualization.tsx","../src/tools/AudioPlayer/context/HybridAudioProvider.tsx","../src/tools/AudioPlayer/components/HybridWaveform.tsx","../src/tools/AudioPlayer/utils/formatTime.ts","../src/tools/AudioPlayer/utils/debug.ts","../src/tools/AudioPlayer/components/HybridAudioPlayer.tsx","../src/tools/AudioPlayer/effects/index.ts","../src/tools/AudioPlayer/components/ReactiveCover/effects/GlowEffect.tsx","../src/tools/AudioPlayer/components/ReactiveCover/effects/OrbsEffect.tsx","../src/tools/AudioPlayer/components/ReactiveCover/effects/SpotlightEffect.tsx","../src/tools/AudioPlayer/components/ReactiveCover/effects/MeshEffect.tsx","../src/tools/AudioPlayer/components/ReactiveCover/AudioReactiveCover.tsx","../src/tools/AudioPlayer/components/HybridSimplePlayer.tsx","../src/tools/ImageViewer/utils/constants.ts","../src/tools/ImageViewer/utils/lqip.ts","../src/tools/ImageViewer/utils/debug.ts","../src/tools/ImageViewer/components/ImageToolbar.tsx","../src/tools/ImageViewer/components/ImageInfo.tsx","../src/tools/ImageViewer/hooks/useImageTransform.ts","../src/tools/ImageViewer/hooks/useImageLoading.ts","../src/tools/ImageViewer/components/ImageViewer.tsx","../src/components/markdown/MarkdownMessage.tsx"],"names":["lazy","LoadingFallback","jsx","jsxs","Suspense","cn","useMemo","useCallback","Input","hexValue","consola","Alert","AlertCircle","AlertDescription","Button","useEffect","useRef","useState","useVideoPlayerSettings","forwardRef","useImperativeHandle","DefaultErrorFallback","AspectRatio","Fragment","Preloader","formatTime","createContext","useContext","HybridWaveform","createMediaLogger","memo","HybridAudioPlayer","Pause","Play","VolumeX","Volume2","Slider","COLOR_SCHEMES","DropdownMenu","DropdownMenuTrigger","DropdownMenuContent","DropdownMenuItem","contentKey","url","React","useResolvedTheme"],"mappings":"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","file":"index.mjs","sourcesContent":["/**\n * Mermaid Component - Dynamic Import Wrapper\n *\n * Lazy loads the heavy Mermaid library (~800KB) only when needed.\n * This significantly reduces the initial bundle size.\n */\n\n'use client';\n\nimport React, { lazy, Suspense } from 'react';\n\n// Lazy load the client component\nconst MermaidClient = lazy(() => import('./Mermaid.client'));\n\n// Loading fallback component\nconst LoadingFallback = () => (\n <div className=\"relative bg-card rounded-sm border border-border overflow-hidden\">\n <div className=\"p-4 border-b border-border bg-muted/50\">\n <h6 className=\"text-sm font-semibold text-foreground\">Diagram</h6>\n <p className=\"text-xs text-muted-foreground mt-1\">Loading...</p>\n </div>\n <div className=\"p-4\">\n <div className=\"flex justify-center items-center min-h-[200px]\">\n <div className=\"animate-spin rounded-full h-8 w-8 border-b-2 border-primary\"></div>\n </div>\n </div>\n </div>\n);\n\ninterface MermaidProps {\n chart: string;\n className?: string;\n isCompact?: boolean;\n}\n\nconst Mermaid: React.FC<MermaidProps> = (props) => {\n return (\n <Suspense fallback={<LoadingFallback />}>\n <MermaidClient {...props} />\n </Suspense>\n );\n};\n\nexport default Mermaid;\n","/**\n * LottiePlayer - Dynamic Import Wrapper\n *\n * Lazy loads the LottiePlayer component for optimal bundle size\n */\n\n'use client';\n\nimport React, { lazy, Suspense } from 'react';\nimport { LottiePlayerProps } from './types';\n\n// Lazy load the client component\nconst LottiePlayerClient = lazy(() =>\n import('./LottiePlayer.client').then((mod) => ({ default: mod.LottiePlayer }))\n);\n\n// Loading fallback component\nconst LoadingFallback = () => (\n <div className=\"flex items-center justify-center p-8\">\n <div className=\"flex flex-col items-center gap-2\">\n <div className=\"h-8 w-8 animate-spin rounded-full border-4 border-gray-300 border-t-gray-900\" />\n <span className=\"text-sm text-gray-500\">Loading player...</span>\n </div>\n </div>\n);\n\n/**\n * LottiePlayer component wrapper with dynamic import\n *\n * This component automatically handles code splitting and lazy loading\n * of the Lottie player to optimize bundle size.\n *\n * Usage:\n * ```tsx\n * import { LottiePlayer } from '@djangocfg/ui-core/tools';\n *\n * <LottiePlayer\n * src=\"https://example.com/animation.json\"\n * size=\"md\"\n * autoplay\n * loop\n * />\n * ```\n */\nexport function LottiePlayer(props: LottiePlayerProps) {\n return (\n <Suspense fallback={<LoadingFallback />}>\n <LottiePlayerClient {...props} />\n </Suspense>\n );\n}\n\n// Re-export types for convenience\nexport type { LottiePlayerProps, LottieSize, LottieSpeed, LottieDirection } from './types';\nexport { useLottie } from './useLottie';\nexport type { UseLottieOptions, UseLottieReturn } from './useLottie';\n","\"use client\"\n\nimport React from 'react';\n\nimport { Label } from '@djangocfg/ui-core/components';\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { FieldTemplateProps } from '@rjsf/utils';\n\n/**\n * Field template for JSON Schema Form\n * Controls the layout and styling of individual form fields\n */\nexport function FieldTemplate(props: FieldTemplateProps) {\n const {\n id,\n classNames,\n style,\n label,\n help,\n required,\n description,\n errors,\n children,\n displayLabel,\n hidden,\n rawErrors,\n } = props;\n\n if (hidden) {\n return <div className=\"hidden\">{children}</div>;\n }\n\n const hasError = rawErrors && rawErrors.length > 0;\n\n return (\n <div\n className={cn('space-y-2', classNames)}\n style={style}\n >\n {displayLabel && label && (\n <Label htmlFor={id} className={cn(hasError && 'text-destructive')}>\n {label}\n {required && <span className=\"text-destructive ml-1\">*</span>}\n </Label>\n )}\n\n {description && (\n <div className=\"text-sm text-muted-foreground\">{description}</div>\n )}\n\n <div>{children}</div>\n\n {errors && (\n <div className=\"text-sm text-destructive\">{errors}</div>\n )}\n\n {help && (\n <div className=\"text-sm text-muted-foreground\">{help}</div>\n )}\n </div>\n );\n}\n","\"use client\"\n\nimport { ChevronDown } from 'lucide-react';\nimport React, { useState } from 'react';\n\nimport { Collapsible, CollapsibleContent, CollapsibleTrigger } from '@djangocfg/ui-core/components';\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { ObjectFieldTemplateProps } from '@rjsf/utils';\n\n/**\n * Object field template for JSON Schema Form\n *\n * Supports:\n * - Collapsible groups via ui:collapsible option\n * - Grid layout via ui:grid option\n * - Custom styling via ui:className\n *\n * Usage in uiSchema:\n * ```json\n * {\n * \"colors\": {\n * \"ui:collapsible\": true,\n * \"ui:collapsed\": false,\n * \"ui:grid\": 2\n * }\n * }\n * ```\n */\nexport function ObjectFieldTemplate(props: ObjectFieldTemplateProps) {\n const {\n title,\n description,\n properties,\n required,\n uiSchema,\n } = props;\n\n // UI options\n const isCollapsible = uiSchema?.['ui:collapsible'] === true;\n const defaultCollapsed = uiSchema?.['ui:collapsed'] === true;\n const gridCols = uiSchema?.['ui:grid'] as number | undefined;\n const className = uiSchema?.['ui:className'] as string | undefined;\n\n // Collapsible state\n const [isOpen, setIsOpen] = useState(!defaultCollapsed);\n\n // Check if this is root object (no title usually means root)\n const isRoot = !title;\n\n // Grid class based on columns\n const gridClass = gridCols\n ? `grid gap-4 grid-cols-${gridCols}`\n : 'space-y-4';\n\n // Content wrapper\n const content = (\n <div className={cn(gridClass, className)}>\n {properties.map((element) => (\n <div key={element.name} className=\"property-wrapper\">\n {element.content}\n </div>\n ))}\n </div>\n );\n\n // Root object - no wrapper\n if (isRoot) {\n return <div className=\"space-y-6\">{content}</div>;\n }\n\n // Collapsible group\n if (isCollapsible) {\n return (\n <Collapsible open={isOpen} onOpenChange={setIsOpen} className=\"space-y-2\">\n <CollapsibleTrigger className=\"flex w-full items-center justify-between rounded-lg border bg-muted/50 px-4 py-3 text-left hover:bg-muted transition-colors\">\n <div>\n <h3 className=\"text-sm font-semibold\">\n {title}\n {required && <span className=\"text-destructive ml-1\">*</span>}\n </h3>\n {description && (\n <p className=\"text-xs text-muted-foreground mt-0.5\">{description}</p>\n )}\n </div>\n <ChevronDown\n className={cn(\n 'h-4 w-4 text-muted-foreground transition-transform duration-200',\n isOpen && 'rotate-180'\n )}\n />\n </CollapsibleTrigger>\n <CollapsibleContent className=\"pl-1 pr-1 pt-2\">\n {content}\n </CollapsibleContent>\n </Collapsible>\n );\n }\n\n // Regular group with title\n return (\n <div className=\"space-y-4\">\n {title && (\n <div className=\"border-b pb-2\">\n <h3 className=\"text-sm font-semibold\">\n {title}\n {required && <span className=\"text-destructive ml-1\">*</span>}\n </h3>\n {description && (\n <p className=\"text-xs text-muted-foreground mt-1\">{description}</p>\n )}\n </div>\n )}\n {content}\n </div>\n );\n}\n","\"use client\"\n\nimport { Plus } from 'lucide-react';\nimport React from 'react';\n\nimport { Button } from '@djangocfg/ui-core/components';\nimport { ArrayFieldTemplateProps } from '@rjsf/utils';\n\n/**\n * Array field template for JSON Schema Form\n * Renders array items with add/remove controls\n *\n * NOTE: In RJSF v6, `items` is an array of ReactElement (already rendered),\n * NOT an array of objects with {children, hasRemove, etc.}.\n * The actual rendering of each item (including remove buttons) is handled\n * by ArrayFieldItemTemplate.\n */\nexport function ArrayFieldTemplate(props: ArrayFieldTemplateProps) {\n const {\n title,\n items,\n canAdd,\n onAddClick,\n required,\n } = props;\n\n return (\n <div className=\"space-y-4\">\n {title && (\n <div className=\"flex items-center justify-between\">\n <h3 className=\"text-lg font-semibold\">\n {title}\n {required && <span className=\"text-destructive ml-1\">*</span>}\n </h3>\n {canAdd && (\n <Button\n type=\"button\"\n variant=\"outline\"\n size=\"sm\"\n onClick={onAddClick}\n className=\"gap-2\"\n >\n <Plus className=\"h-4 w-4\" />\n Add Item\n </Button>\n )}\n </div>\n )}\n\n {/* In RJSF v6, items is already an array of ReactElements */}\n <div className=\"space-y-3\">\n {items}\n </div>\n\n {items.length === 0 && (\n <div className=\"text-center py-8 text-muted-foreground border-2 border-dashed rounded-md\">\n No items added yet.\n {canAdd && (\n <Button\n type=\"button\"\n variant=\"ghost\"\n size=\"sm\"\n onClick={onAddClick}\n className=\"mt-2 gap-2\"\n >\n <Plus className=\"h-4 w-4\" />\n Add First Item\n </Button>\n )}\n </div>\n )}\n </div>\n );\n}\n","\"use client\"\n\nimport React from 'react';\n\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { ArrayFieldItemTemplateProps, getTemplate, getUiOptions } from '@rjsf/utils';\n\n/**\n * Array field item template for JSON Schema Form\n * Renders individual array items with proper styling and action buttons\n *\n * In RJSF v6, this template is responsible for rendering each item in an array,\n * including the item content (children) and the action buttons (remove, move up/down, copy).\n */\nexport function ArrayFieldItemTemplate(props: ArrayFieldItemTemplateProps) {\n const {\n children,\n className,\n buttonsProps,\n hasToolbar,\n registry,\n uiSchema,\n } = props;\n\n const uiOptions = getUiOptions(uiSchema);\n const ArrayFieldItemButtonsTemplate = getTemplate(\n 'ArrayFieldItemButtonsTemplate',\n registry,\n uiOptions,\n );\n\n return (\n <div\n className={cn(\n 'flex gap-2 items-start p-4 rounded-md border bg-card',\n className\n )}\n >\n <div className=\"flex-1\">{children}</div>\n {hasToolbar && (\n <div className=\"flex items-center gap-1\">\n <ArrayFieldItemButtonsTemplate {...buttonsProps} />\n </div>\n )}\n </div>\n );\n}\n","\"use client\"\n\nimport { AlertCircle } from 'lucide-react';\nimport React from 'react';\n\nimport { Alert, AlertDescription, AlertTitle } from '@djangocfg/ui-core/components';\nimport { ErrorListProps } from '@rjsf/utils';\n\n/**\n * Error list template for JSON Schema Form\n * Displays validation errors at the top of the form\n */\nexport function ErrorListTemplate(props: ErrorListProps) {\n const { errors } = props;\n\n if (!errors || errors.length === 0) {\n return null;\n }\n\n return (\n <Alert variant=\"destructive\" className=\"mb-6\">\n <AlertCircle className=\"h-4 w-4\" />\n <AlertTitle>Validation Errors</AlertTitle>\n <AlertDescription>\n <ul className=\"list-disc list-inside space-y-1 mt-2\">\n {errors.map((error, index) => (\n <li key={index} className=\"text-sm\">\n {error.stack}\n </li>\n ))}\n </ul>\n </AlertDescription>\n </Alert>\n );\n}\n","\"use client\"\n\nimport React, { ChangeEvent, FocusEvent, useCallback, useMemo } from 'react';\n\nimport { Input } from '@djangocfg/ui-core/components';\nimport { getInputProps, WidgetProps } from '@rjsf/utils';\n\n/**\n * Base input template for JSON Schema Form\n *\n * This template is CRITICAL for rendering primitive types (string, number)\n * inside arrays. Without it, array items with primitive types will render\n * as empty containers.\n *\n * RJSF uses this template for:\n * - Array items with primitive types (e.g., array of strings)\n * - Fields without explicit widget mapping\n * - All text-based widgets internally\n *\n * @see https://rjsf-team.github.io/react-jsonschema-form/docs/advanced-customization/custom-templates/#baseinputtemplate\n */\nexport function BaseInputTemplate(props: WidgetProps) {\n const {\n id,\n type,\n value,\n readonly,\n disabled,\n autofocus,\n onBlur,\n onFocus,\n onChange,\n options,\n schema,\n rawErrors,\n placeholder,\n } = props;\n\n // Get input props from RJSF utils (handles step, min, max, etc.)\n const inputProps = useMemo(() => {\n return getInputProps(schema, type, options);\n }, [schema, type, options]);\n\n // Safely convert value to string for input\n const safeValue = useMemo(() => {\n if (value === null || value === undefined) return '';\n return String(value);\n }, [value]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n // Handle text change - transform empty strings based on schema type\n const handleChange = useCallback((event: ChangeEvent<HTMLInputElement>) => {\n const val = event.target.value;\n\n // Empty value handling\n if (val === '') {\n onChange(options?.emptyValue ?? '');\n return;\n }\n\n // Number type conversion\n if (inputProps.type === 'number' || schema.type === 'number' || schema.type === 'integer') {\n const num = Number(val);\n onChange(isNaN(num) ? val : num);\n return;\n }\n\n onChange(val);\n }, [onChange, inputProps.type, schema.type, options?.emptyValue]);\n\n const handleBlur = useCallback((event: FocusEvent<HTMLInputElement>) => {\n onBlur(id, event.target.value);\n }, [id, onBlur]);\n\n const handleFocus = useCallback((event: FocusEvent<HTMLInputElement>) => {\n onFocus(id, event.target.value);\n }, [id, onFocus]);\n\n // Determine input type\n const inputType = useMemo(() => {\n if (inputProps.type) return inputProps.type;\n if (schema.type === 'number' || schema.type === 'integer') return 'number';\n return 'text';\n }, [inputProps.type, schema.type]);\n\n return (\n <Input\n id={id}\n type={inputType}\n value={safeValue}\n disabled={disabled}\n readOnly={readonly}\n autoFocus={autofocus}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n placeholder={placeholder}\n className={hasError ? 'border-destructive' : ''}\n step={inputProps.step}\n min={inputProps.min}\n max={inputProps.max}\n />\n );\n}\n","import consola from 'consola';\n\nimport { RJSFSchema } from '@rjsf/utils';\n\n/**\n * Utility functions for JSON Schema Form\n */\n\n/**\n * Safely validates and normalizes JSON Schema\n * Ensures schema is valid before rendering\n */\nexport function validateSchema(schema: any): RJSFSchema | null {\n if (!schema || typeof schema !== 'object') {\n if (process.env.NODE_ENV === 'development') {\n consola.error('[JsonSchemaForm] Invalid schema: must be an object', schema);\n }\n return null;\n }\n\n // Basic schema validation - more permissive\n // Schema is valid if it has type OR properties OR $ref OR $schema\n const hasValidStructure =\n schema.type ||\n schema.properties ||\n schema.$ref ||\n schema.$schema;\n\n if (!hasValidStructure) {\n if (process.env.NODE_ENV === 'development') {\n consola.error('[JsonSchemaForm] Invalid schema: missing type, properties, $ref, or $schema', schema);\n }\n return null;\n }\n\n if (process.env.NODE_ENV === 'development') {\n consola.success('[JsonSchemaForm] Schema validated successfully:', {\n type: schema.type,\n title: schema.title,\n hasProperties: !!schema.properties,\n hasRequired: !!schema.required,\n });\n }\n\n return schema as RJSFSchema;\n}\n\n/**\n * Safely normalizes form data\n * Removes undefined values and ensures data structure matches schema\n */\nexport function normalizeFormData<T = any>(\n formData: any,\n schema: RJSFSchema\n): T {\n if (formData === null || formData === undefined) {\n return (schema.type === 'object' ? {} : schema.type === 'array' ? [] : null) as T;\n }\n\n // Deep clone to avoid mutations\n const normalized = JSON.parse(JSON.stringify(formData));\n\n // Remove undefined values recursively\n return removeUndefined(normalized) as T;\n}\n\n/**\n * Recursively removes undefined values from an object\n */\nfunction removeUndefined(obj: any): any {\n if (obj === null || obj === undefined) {\n return obj;\n }\n\n if (Array.isArray(obj)) {\n return obj.map(removeUndefined).filter((item) => item !== undefined);\n }\n\n if (typeof obj === 'object') {\n const cleaned: any = {};\n for (const key in obj) {\n if (obj[key] !== undefined) {\n cleaned[key] = removeUndefined(obj[key]);\n }\n }\n return cleaned;\n }\n\n return obj;\n}\n\n/**\n * Merges schema defaults with form data\n */\nexport function mergeDefaults(\n formData: any,\n schema: RJSFSchema\n): any {\n if (!schema) return formData;\n\n const result = { ...formData };\n\n if (schema.type === 'object' && schema.properties) {\n for (const [key, propSchema] of Object.entries(schema.properties)) {\n const prop = propSchema as RJSFSchema;\n\n // Apply default if field is missing\n if (result[key] === undefined && prop.default !== undefined) {\n result[key] = prop.default;\n }\n\n // Recursively merge nested objects\n if (prop.type === 'object' && result[key]) {\n result[key] = mergeDefaults(result[key], prop);\n }\n }\n }\n\n return result;\n}\n\n/**\n * Safely parses JSON string with error handling\n */\nexport function safeJsonParse<T = any>(\n jsonString: string,\n fallback: T\n): T {\n try {\n return JSON.parse(jsonString);\n } catch (error) {\n consola.error('[JsonSchemaForm] JSON parse error:', error);\n return fallback;\n }\n}\n\n/**\n * Safely stringifies object to JSON\n */\nexport function safeJsonStringify(\n obj: any,\n pretty: boolean = true\n): string {\n try {\n return JSON.stringify(obj, null, pretty ? 2 : 0);\n } catch (error) {\n consola.error('[JsonSchemaForm] JSON stringify error:', error);\n return '{}';\n }\n}\n\n/**\n * Checks if schema has required fields\n */\nexport function hasRequiredFields(schema: RJSFSchema): boolean {\n return Array.isArray(schema.required) && schema.required.length > 0;\n}\n\n/**\n * Gets all required field paths from schema\n */\nexport function getRequiredFields(\n schema: RJSFSchema,\n prefix: string = ''\n): string[] {\n const required: string[] = [];\n\n if (schema.required && Array.isArray(schema.required)) {\n required.push(...schema.required.map((field) =>\n prefix ? `${prefix}.${field}` : field\n ));\n }\n\n if (schema.type === 'object' && schema.properties) {\n for (const [key, propSchema] of Object.entries(schema.properties)) {\n const prop = propSchema as RJSFSchema;\n const fieldPath = prefix ? `${prefix}.${key}` : key;\n required.push(...getRequiredFields(prop, fieldPath));\n }\n }\n\n return required;\n}\n\n/**\n * Validates form data against required fields\n */\nexport function validateRequiredFields(\n formData: any,\n schema: RJSFSchema\n): { valid: boolean; missing: string[] } {\n const requiredFields = getRequiredFields(schema);\n const missing: string[] = [];\n\n for (const field of requiredFields) {\n const value = getNestedValue(formData, field);\n if (value === undefined || value === null || value === '') {\n missing.push(field);\n }\n }\n\n return {\n valid: missing.length === 0,\n missing,\n };\n}\n\n/**\n * Gets nested value from object by path\n */\nfunction getNestedValue(obj: any, path: string): any {\n return path.split('.').reduce((current, key) => current?.[key], obj);\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Input } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Text input widget for JSON Schema Form\n * Handles string fields with optional textarea for multiline\n */\nexport function TextWidget(props: WidgetProps) {\n const {\n id,\n placeholder,\n required,\n disabled,\n readonly,\n autofocus,\n value,\n onChange,\n onBlur,\n onFocus,\n options,\n schema,\n rawErrors,\n } = props;\n\n // Memoize widget configuration\n const config = useMemo(() => ({\n isTextarea: options?.widget === 'textarea',\n rows: options?.rows || 3,\n emptyValue: options?.emptyValue,\n }), [options]);\n\n // Ensure value is always a string\n const safeValue = useMemo(() => {\n if (value === null || value === undefined) return '';\n return String(value);\n }, [value]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n const handleChange = useCallback((event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n const newValue = event.target.value;\n onChange(newValue === '' ? config.emptyValue : newValue);\n }, [onChange, config.emptyValue]);\n\n const handleBlur = useCallback((event: React.FocusEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n onBlur(id, event.target.value);\n }, [id, onBlur]);\n\n const handleFocus = useCallback((event: React.FocusEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n onFocus(id, event.target.value);\n }, [id, onFocus]);\n\n if (config.isTextarea) {\n return (\n <textarea\n id={id}\n className={`flex min-h-[80px] w-full rounded-md border ${\n hasError ? 'border-destructive' : 'border-input'\n } bg-transparent px-3 py-2 text-base shadow-sm transition-colors placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm`}\n placeholder={placeholder}\n disabled={disabled || readonly}\n readOnly={readonly}\n autoFocus={autofocus}\n value={safeValue}\n required={required}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n rows={config.rows}\n />\n );\n }\n\n return (\n <Input\n id={id}\n type=\"text\"\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readonly}\n autoFocus={autofocus}\n value={safeValue}\n required={required}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n className={hasError ? 'border-destructive' : ''}\n />\n );\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Input } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Number input widget for JSON Schema Form\n * Handles integer and number fields\n */\nexport function NumberWidget(props: WidgetProps) {\n const {\n id,\n placeholder,\n required,\n disabled,\n readonly,\n autofocus,\n value,\n onChange,\n onBlur,\n onFocus,\n options,\n schema,\n rawErrors,\n } = props;\n\n // Memoize widget configuration\n const config = useMemo(() => ({\n isInteger: schema.type === 'integer',\n step: schema.type === 'integer' ? '1' : 'any',\n min: schema.minimum,\n max: schema.maximum,\n emptyValue: options?.emptyValue,\n }), [schema, options]);\n\n // Ensure value is valid number or empty string\n const safeValue = useMemo(() => {\n if (value === null || value === undefined || value === '') return '';\n if (typeof value === 'number' && !isNaN(value)) return value;\n return '';\n }, [value]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n const handleChange = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = event.target.value;\n if (newValue === '') {\n onChange(config.emptyValue);\n } else {\n const parsedValue = config.isInteger\n ? parseInt(newValue, 10)\n : parseFloat(newValue);\n\n onChange(isNaN(parsedValue) ? config.emptyValue : parsedValue);\n }\n }, [onChange, config]);\n\n const handleBlur = useCallback((event: React.FocusEvent<HTMLInputElement>) => {\n onBlur(id, event.target.value);\n }, [id, onBlur]);\n\n const handleFocus = useCallback((event: React.FocusEvent<HTMLInputElement>) => {\n onFocus(id, event.target.value);\n }, [id, onFocus]);\n\n return (\n <Input\n id={id}\n type=\"number\"\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readonly}\n autoFocus={autofocus}\n value={safeValue}\n required={required}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n step={config.step}\n min={config.min}\n max={config.max}\n className={hasError ? 'border-destructive' : ''}\n />\n );\n}\n","import React from 'react';\n\nimport { Checkbox } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Checkbox widget for JSON Schema Form\n * Handles boolean fields\n */\nexport function CheckboxWidget(props: WidgetProps) {\n const {\n id,\n value,\n disabled,\n readonly,\n autofocus,\n onChange,\n onBlur,\n onFocus,\n } = props;\n\n const handleChange = (checked: boolean) => {\n onChange(checked);\n };\n\n return (\n <Checkbox\n id={id}\n checked={value || false}\n disabled={disabled || readonly}\n autoFocus={autofocus}\n onCheckedChange={handleChange}\n onBlur={() => onBlur(id, value)}\n onFocus={() => onFocus(id, value)}\n />\n );\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport {\n Select, SelectContent, SelectItem, SelectTrigger, SelectValue\n} from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Select dropdown widget for JSON Schema Form\n * Handles enum fields\n */\nexport function SelectWidget(props: WidgetProps) {\n const {\n id,\n options,\n value,\n required,\n disabled,\n readonly,\n autofocus,\n onChange,\n onBlur,\n onFocus,\n placeholder,\n rawErrors,\n } = props;\n\n // Safely extract and validate enum options\n const enumOptions = useMemo(() => {\n const opts = options?.enumOptions;\n if (!Array.isArray(opts)) return [];\n return opts.filter(opt => opt && (opt.value !== undefined));\n }, [options]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n // Ensure value is always a string\n const safeValue = useMemo(() => {\n if (value === null || value === undefined) return '';\n return String(value);\n }, [value]);\n\n const handleChange = useCallback((newValue: string) => {\n onChange(newValue);\n onBlur(id, newValue);\n }, [onChange, onBlur, id]);\n\n // If no enum options, render a text input instead\n // This handles cases like anyOf/oneOf where RJSF might incorrectly use SelectWidget\n if (enumOptions.length === 0) {\n return (\n <input\n id={id}\n type=\"text\"\n value={safeValue}\n onChange={(e) => onChange(e.target.value)}\n onBlur={(e) => onBlur(id, e.target.value)}\n onFocus={(e) => onFocus(id, e.target.value)}\n disabled={disabled || readonly}\n readOnly={readonly}\n className={`flex h-10 w-full rounded-md border ${\n hasError ? 'border-destructive' : 'border-input'\n } bg-transparent px-3 py-2 text-base shadow-sm transition-colors placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm`}\n placeholder={placeholder}\n />\n );\n }\n\n return (\n <Select\n value={safeValue}\n onValueChange={handleChange}\n disabled={disabled || readonly}\n required={required}\n >\n <SelectTrigger\n id={id}\n className={hasError ? 'border-destructive' : ''}\n autoFocus={autofocus}\n onFocus={() => onFocus(id, value)}\n >\n <SelectValue placeholder={placeholder || 'Select an option'} />\n </SelectTrigger>\n <SelectContent>\n {enumOptions.map((option: any) => (\n <SelectItem key={String(option.value)} value={String(option.value)}>\n {option.label || String(option.value)}\n </SelectItem>\n ))}\n </SelectContent>\n </Select>\n );\n}\n","import React from 'react';\n\nimport { Switch } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Switch toggle widget for JSON Schema Form\n * Alternative boolean input\n */\nexport function SwitchWidget(props: WidgetProps) {\n const {\n id,\n value,\n disabled,\n readonly,\n onChange,\n onBlur,\n onFocus,\n } = props;\n\n const handleChange = (checked: boolean) => {\n onChange(checked);\n };\n\n return (\n <Switch\n id={id}\n checked={value || false}\n disabled={disabled || readonly}\n onCheckedChange={handleChange}\n onBlur={() => onBlur(id, value)}\n onFocus={() => onFocus(id, value)}\n />\n );\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo, useRef } from 'react';\n\nimport { Input } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Color input widget for JSON Schema Form\n * Supports HSL format (h s% l%) and HEX format\n * Click on color box to open native color picker directly\n */\nexport function ColorWidget(props: WidgetProps) {\n const {\n id,\n placeholder,\n required,\n disabled,\n readonly,\n autofocus,\n value,\n onChange,\n onBlur,\n onFocus,\n options,\n rawErrors,\n } = props;\n\n const colorInputRef = useRef<HTMLInputElement>(null);\n\n // Determine format from options or auto-detect from value\n const format = useMemo(() => {\n if (options?.format) return options.format as 'hsl' | 'hex';\n if (typeof value === 'string' && value.startsWith('#')) return 'hex';\n return 'hsl';\n }, [options?.format, value]);\n\n // Ensure value is always a string\n const safeValue = useMemo(() => {\n if (value === null || value === undefined) return '';\n return String(value);\n }, [value]);\n\n // Convert HSL string (like \"217 91% 60%\") to CSS hsl() value\n const hslToCss = useCallback((hslValue: string): string => {\n if (!hslValue) return 'transparent';\n if (hslValue.startsWith('#')) return hslValue;\n if (hslValue.startsWith('hsl')) return hslValue;\n // Format: \"h s% l%\" -> \"hsl(h, s%, l%)\"\n const parts = hslValue.split(' ');\n if (parts.length === 3) {\n return `hsl(${parts[0]}, ${parts[1]}, ${parts[2]})`;\n }\n return 'transparent';\n }, []);\n\n // Convert CSS color to preview color\n const previewColor = useMemo(() => {\n return hslToCss(safeValue);\n }, [safeValue, hslToCss]);\n\n // Convert hex to HSL string for internal storage\n const hexToHsl = useCallback((hex: string): string => {\n // Remove # if present\n hex = hex.replace('#', '');\n\n // Parse hex values\n const r = parseInt(hex.substring(0, 2), 16) / 255;\n const g = parseInt(hex.substring(2, 4), 16) / 255;\n const b = parseInt(hex.substring(4, 6), 16) / 255;\n\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n let h = 0;\n let s = 0;\n const l = (max + min) / 2;\n\n if (max !== min) {\n const d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n\n switch (max) {\n case r:\n h = ((g - b) / d + (g < b ? 6 : 0)) / 6;\n break;\n case g:\n h = ((b - r) / d + 2) / 6;\n break;\n case b:\n h = ((r - g) / d + 4) / 6;\n break;\n }\n }\n\n return `${Math.round(h * 360)} ${Math.round(s * 100)}% ${Math.round(l * 100)}%`;\n }, []);\n\n // Convert HSL to hex\n const hslToHex = useCallback((hslValue: string): string => {\n if (!hslValue || hslValue.startsWith('#')) return hslValue || '#000000';\n\n const parts = hslValue.split(' ');\n if (parts.length !== 3) return '#000000';\n\n const h = parseInt(parts[0]) / 360;\n const s = parseInt(parts[1].replace('%', '')) / 100;\n const l = parseInt(parts[2].replace('%', '')) / 100;\n\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1/6) return p + (q - p) * 6 * t;\n if (t < 1/2) return q;\n if (t < 2/3) return p + (q - p) * (2/3 - t) * 6;\n return p;\n };\n\n let r, g, b;\n if (s === 0) {\n r = g = b = l;\n } else {\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n r = hue2rgb(p, q, h + 1/3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1/3);\n }\n\n const toHex = (x: number) => {\n const hex = Math.round(x * 255).toString(16);\n return hex.length === 1 ? '0' + hex : hex;\n };\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n }, []);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n const handleChange = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = event.target.value;\n onChange(newValue);\n }, [onChange]);\n\n const handleColorPickerChange = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const hexValue = event.target.value;\n if (format === 'hsl') {\n onChange(hexToHsl(hexValue));\n } else {\n onChange(hexValue);\n }\n }, [onChange, format, hexToHsl]);\n\n const handleBlur = useCallback((event: React.FocusEvent<HTMLInputElement>) => {\n onBlur(id, event.target.value);\n }, [id, onBlur]);\n\n const handleFocus = useCallback((event: React.FocusEvent<HTMLInputElement>) => {\n onFocus(id, event.target.value);\n }, [id, onFocus]);\n\n // Get hex value for native color picker\n const hexValue = useMemo(() => {\n if (format === 'hex' || safeValue.startsWith('#')) {\n return safeValue || '#000000';\n }\n return hslToHex(safeValue);\n }, [safeValue, format, hslToHex]);\n\n // Click on color box opens native color picker\n const handleColorBoxClick = useCallback(() => {\n if (!disabled && !readonly) {\n colorInputRef.current?.click();\n }\n }, [disabled, readonly]);\n\n return (\n <div className=\"flex items-center gap-2\">\n {/* Color preview box - clicking opens native picker */}\n <div className=\"relative\">\n <button\n type=\"button\"\n onClick={handleColorBoxClick}\n disabled={disabled || readonly}\n className=\"h-10 w-10 shrink-0 rounded-md border-2 border-input cursor-pointer hover:border-ring focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50\"\n style={{ backgroundColor: previewColor }}\n aria-label=\"Pick color\"\n />\n {/* Hidden native color input */}\n <input\n ref={colorInputRef}\n type=\"color\"\n value={hexValue}\n onChange={handleColorPickerChange}\n className=\"absolute inset-0 opacity-0 w-full h-full cursor-pointer\"\n disabled={disabled || readonly}\n tabIndex={-1}\n />\n </div>\n\n {/* Text input for manual HSL/HEX entry */}\n <Input\n id={id}\n type=\"text\"\n placeholder={placeholder || (format === 'hsl' ? '217 91% 60%' : '#3b82f6')}\n disabled={disabled}\n readOnly={readonly}\n autoFocus={autofocus}\n value={safeValue}\n required={required}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n className={`flex-1 font-mono text-sm ${hasError ? 'border-destructive' : ''}`}\n />\n </div>\n );\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Input, Slider } from '@djangocfg/ui-core/components';\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Slider widget for JSON Schema Form\n *\n * Supports:\n * - number/integer types\n * - min/max from schema\n * - step from schema or options\n * - unit suffix (e.g., \"rem\", \"px\", \"%\")\n * - optional text input for precise values\n *\n * Usage in uiSchema:\n * ```json\n * {\n * \"radius\": {\n * \"ui:widget\": \"slider\",\n * \"ui:options\": {\n * \"unit\": \"rem\",\n * \"showInput\": true,\n * \"step\": 0.125\n * }\n * }\n * }\n * ```\n */\nexport function SliderWidget(props: WidgetProps) {\n const {\n id,\n disabled,\n readonly,\n value,\n onChange,\n schema,\n options,\n rawErrors,\n } = props;\n\n // Extract configuration\n const config = useMemo(() => {\n const min = schema.minimum ?? options?.min ?? 0;\n const max = schema.maximum ?? options?.max ?? 100;\n const step = options?.step ?? (schema.type === 'integer' ? 1 : 0.1);\n const unit = options?.unit as string | undefined;\n const showInput = options?.showInput !== false; // default true\n\n return { min, max, step, unit, showInput };\n }, [schema, options]);\n\n // Parse value - handle string values like \"0.5rem\"\n const numericValue = useMemo(() => {\n if (value === null || value === undefined || value === '') {\n return config.min;\n }\n if (typeof value === 'number') {\n return value;\n }\n if (typeof value === 'string') {\n // Extract number from string like \"0.5rem\"\n const parsed = parseFloat(value);\n return isNaN(parsed) ? config.min : parsed;\n }\n return config.min;\n }, [value, config.min]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n // Handle slider change\n const handleSliderChange = useCallback((values: number[]) => {\n const newValue = values[0];\n if (config.unit) {\n onChange(`${newValue}${config.unit}`);\n } else {\n onChange(newValue);\n }\n }, [onChange, config.unit]);\n\n // Handle text input change\n const handleInputChange = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const inputValue = event.target.value;\n\n // If has unit, just store raw value with unit\n if (config.unit) {\n // Remove unit if user typed it, then add it back\n const cleanValue = inputValue.replace(config.unit, '').trim();\n const parsed = parseFloat(cleanValue);\n if (!isNaN(parsed)) {\n onChange(`${parsed}${config.unit}`);\n } else if (inputValue === '') {\n onChange(`${config.min}${config.unit}`);\n }\n } else {\n const parsed = parseFloat(inputValue);\n onChange(isNaN(parsed) ? config.min : parsed);\n }\n }, [onChange, config.unit, config.min]);\n\n // Display value with unit\n const displayValue = useMemo(() => {\n if (config.unit) {\n return `${numericValue}${config.unit}`;\n }\n return String(numericValue);\n }, [numericValue, config.unit]);\n\n return (\n <div className={cn('flex items-center gap-3', hasError && 'text-destructive')}>\n {/* Slider */}\n <Slider\n id={id}\n disabled={disabled || readonly}\n value={[numericValue]}\n onValueChange={handleSliderChange}\n min={config.min}\n max={config.max}\n step={config.step}\n className=\"flex-1\"\n />\n\n {/* Value input or display */}\n {config.showInput ? (\n <Input\n type=\"text\"\n value={displayValue}\n onChange={handleInputChange}\n disabled={disabled}\n readOnly={readonly}\n className={cn(\n 'w-20 text-center font-mono text-sm',\n hasError && 'border-destructive'\n )}\n />\n ) : (\n <span className=\"w-16 text-right font-mono text-sm text-muted-foreground\">\n {displayValue}\n </span>\n )}\n </div>\n );\n}\n","'use client';\n\nimport consola from 'consola';\nimport { AlertCircle } from 'lucide-react';\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Alert, AlertDescription, Button } from '@djangocfg/ui-core/components';\nimport Form from '@rjsf/core';\nimport { RegistryWidgetsType } from '@rjsf/utils';\nimport validator from '@rjsf/validator-ajv8';\n\nimport {\n ArrayFieldItemTemplate, ArrayFieldTemplate, BaseInputTemplate, ErrorListTemplate, FieldTemplate,\n ObjectFieldTemplate\n} from './templates';\nimport { JsonSchemaFormProps } from './types';\nimport { normalizeFormData, validateSchema } from './utils';\nimport {\n CheckboxWidget, ColorWidget, NumberWidget, SelectWidget, SliderWidget, SwitchWidget, TextWidget\n} from './widgets';\n\n/**\n * JSON Schema Form Component\n *\n * A fully-featured form generator that creates forms from JSON Schema.\n * Built on top of react-jsonschema-form with custom widgets and templates\n * using @djangocfg/ui components.\n *\n * @example\n * ```tsx\n * const schema = {\n * type: 'object',\n * required: ['name'],\n * properties: {\n * name: { type: 'string', title: 'Name' },\n * age: { type: 'number', title: 'Age' },\n * active: { type: 'boolean', title: 'Active' }\n * }\n * };\n *\n * <JsonSchemaForm\n * schema={schema}\n * onSubmit={(data) => console.log(data.formData)}\n * />\n * ```\n */\nexport function JsonSchemaForm<T = any>(props: JsonSchemaFormProps<T>) {\n const {\n schema,\n uiSchema,\n formData,\n onSubmit,\n onChange,\n onError,\n showErrorList = 'top',\n liveValidate = false,\n disabled = false,\n readonly = false,\n className,\n showSubmitButton = true,\n submitButtonText = 'Submit',\n ...restProps\n } = props;\n\n // Validate and normalize schema before render\n const validatedSchema = useMemo(() => {\n if (process.env.NODE_ENV === 'development') {\n consola.info('[JsonSchemaForm] Validating schema...', schema);\n }\n const result = validateSchema(schema);\n if (!result && process.env.NODE_ENV === 'development') {\n consola.error('[JsonSchemaForm] Schema validation failed');\n }\n return result;\n }, [schema]);\n\n // Normalize form data before render\n const normalizedFormData = useMemo(() => {\n if (!validatedSchema) {\n if (process.env.NODE_ENV === 'development') {\n consola.warn('[JsonSchemaForm] Cannot normalize formData - invalid schema');\n }\n return null;\n }\n if (process.env.NODE_ENV === 'development') {\n consola.info('[JsonSchemaForm] Normalizing formData...', formData);\n }\n const normalized = normalizeFormData<T>(formData, validatedSchema);\n if (process.env.NODE_ENV === 'development') {\n consola.info('[JsonSchemaForm] Normalized formData:', normalized);\n }\n return normalized;\n }, [formData, validatedSchema]);\n\n // Memoize widgets mapping to prevent recreation on every render\n // IMPORTANT: Widget keys must match RJSF's expected names:\n // - For type: string -> uses 'TextWidget' or 'text'\n // - For type: number/integer -> uses 'updown' or 'range'\n // - For type: boolean -> uses 'checkbox' or 'select'\n // - For enum fields -> uses 'SelectWidget' or 'select'\n const widgets: RegistryWidgetsType = useMemo(() => ({\n // Standard widget names (PascalCase) - used by RJSF internally\n TextWidget,\n NumberWidget,\n CheckboxWidget,\n SelectWidget,\n SwitchWidget,\n ColorWidget,\n SliderWidget,\n // Lowercase aliases - for uiSchema 'ui:widget' references\n text: TextWidget,\n number: NumberWidget,\n checkbox: CheckboxWidget,\n select: SelectWidget,\n switch: SwitchWidget,\n color: ColorWidget,\n slider: SliderWidget,\n range: SliderWidget, // alias\n }), []);\n\n // Memoize templates to prevent recreation on every render\n const templates = useMemo(() => ({\n FieldTemplate,\n ObjectFieldTemplate,\n ArrayFieldTemplate,\n ArrayFieldItemTemplate,\n ErrorListTemplate,\n BaseInputTemplate,\n }), []);\n\n // Memoize callbacks\n const handleSubmit = useCallback((data: any) => {\n if (onSubmit) {\n // Ensure clean data on submit\n const cleanData = {\n ...data,\n formData: normalizeFormData(data.formData, validatedSchema!),\n };\n onSubmit(cleanData);\n }\n }, [onSubmit, validatedSchema]);\n\n const handleChange = useCallback((data: any) => {\n if (onChange) {\n onChange(data);\n }\n }, [onChange]);\n\n const handleError = useCallback((errors: any) => {\n if (onError) {\n onError(errors);\n }\n }, [onError]);\n\n // Early return if schema is invalid\n if (!validatedSchema) {\n return (\n <div className={className}>\n <Alert variant=\"destructive\">\n <AlertCircle className=\"h-4 w-4\" />\n <AlertDescription>\n Invalid schema provided. Please check the schema format.\n </AlertDescription>\n </Alert>\n </div>\n );\n }\n\n return (\n <div className={className}>\n <Form\n schema={validatedSchema}\n uiSchema={uiSchema}\n formData={normalizedFormData}\n validator={validator}\n widgets={widgets}\n templates={templates}\n onSubmit={handleSubmit}\n onChange={handleChange}\n onError={handleError}\n showErrorList={showErrorList}\n liveValidate={liveValidate}\n disabled={disabled}\n readonly={readonly}\n {...restProps}\n >\n {showSubmitButton && (\n <div className=\"mt-6 flex gap-2\">\n <Button type=\"submit\" disabled={disabled}>\n {submitButtonText}\n </Button>\n </div>\n )}\n </Form>\n </div>\n );\n}\n","'use client';\n\nimport React, { lazy, Suspense } from 'react';\nimport { PlaygroundProvider } from './context/PlaygroundContext';\nimport type { PlaygroundConfig } from './types';\n\n// Lazy load the PlaygroundLayout component\nconst PlaygroundLayout = lazy(() =>\n import('./components/PlaygroundLayout').then((mod) => ({ default: mod.PlaygroundLayout }))\n);\n\n// Loading fallback component\nconst LoadingFallback = () => (\n <div className=\"flex items-center justify-center min-h-[400px]\">\n <div className=\"text-muted-foreground\">Loading API Playground...</div>\n </div>\n);\n\nexport interface PlaygroundProps {\n config: PlaygroundConfig;\n}\n\nexport const Playground: React.FC<PlaygroundProps> = ({ config }) => {\n return (\n <PlaygroundProvider config={config}>\n <Suspense fallback={<LoadingFallback />}>\n <PlaygroundLayout />\n </Suspense>\n </PlaygroundProvider>\n );\n};\n\n// Re-export types for convenience\nexport type { PlaygroundConfig, SchemaSource } from './types';\n\n// Default export for dynamic import\nexport default Playground;\n","'use client';\n\nimport { create } from 'zustand';\nimport { persist, devtools } from 'zustand/middleware';\nimport { useShallow } from 'zustand/react/shallow';\nimport { createLogger } from '@djangocfg/ui-core/lib';\n\nconst cacheDebug = createLogger('MediaCache');\n\n// Types\ninterface BlobUrlEntry {\n url: string;\n refCount: number;\n createdAt: number;\n}\n\ninterface ImageDimensions {\n width: number;\n height: number;\n}\n\ninterface VideoMetadata {\n duration: number;\n width: number;\n height: number;\n codec?: string;\n}\n\ninterface EffectConfig {\n opacity: number;\n scale: number;\n blur: string;\n}\n\n/** Video player settings (persisted) */\ninterface VideoPlayerSettings {\n volume: number;\n isLooping: boolean;\n}\n\n// Stream URL TTL (30 seconds - shorter to avoid stale session/token issues)\nconst STREAM_URL_TTL = 30 * 1000;\n\ninterface MediaCacheState {\n // Blob URL cache (shared by Image, Audio, Video)\n blobUrls: Map<string, BlobUrlEntry>;\n\n // Image-specific\n imageDimensions: Map<string, ImageDimensions>;\n\n // Audio-specific\n audioPlaybackPositions: Map<string, number>;\n audioEffectConfigs: Map<string, EffectConfig>;\n\n // Video-specific\n videoStreamUrls: Map<string, { url: string; timestamp: number }>;\n videoPosterUrls: Map<string, string>;\n videoPlaybackPositions: Map<string, number>;\n videoMetadata: Map<string, VideoMetadata>;\n videoPlayerSettings: VideoPlayerSettings;\n}\n\ninterface MediaCacheActions {\n // Blob URL management (shared)\n getOrCreateBlobUrl: (\n key: string,\n content: ArrayBuffer,\n mimeType: string\n ) => string;\n releaseBlobUrl: (key: string) => void;\n hasBlobUrl: (key: string) => boolean;\n\n // Image actions\n cacheDimensions: (src: string, dims: ImageDimensions) => void;\n getDimensions: (src: string) => ImageDimensions | null;\n\n // Audio actions\n saveAudioPosition: (uri: string, time: number) => void;\n getAudioPosition: (uri: string) => number | null;\n getEffectConfig: (key: string) => EffectConfig | null;\n cacheEffectConfig: (key: string, config: EffectConfig) => void;\n\n // Video actions\n getOrCreateStreamUrl: (\n sessionId: string,\n path: string,\n generator: (sessionId: string, path: string) => string\n ) => string;\n getPosterUrl: (title: string) => string | null;\n cachePosterUrl: (title: string, url: string) => void;\n saveVideoPosition: (key: string, time: number) => void;\n getVideoPosition: (key: string) => number | null;\n cacheVideoMetadata: (url: string, meta: VideoMetadata) => void;\n getVideoMetadata: (url: string) => VideoMetadata | null;\n invalidateSession: (sessionId: string) => void;\n getVideoPlayerSettings: () => VideoPlayerSettings;\n saveVideoPlayerSettings: (settings: Partial<VideoPlayerSettings>) => void;\n\n // Global\n clearCache: () => void;\n getCacheStats: () => {\n blobUrls: number;\n dimensions: number;\n audioPositions: number;\n videoPositions: number;\n };\n}\n\ntype MediaCacheStore = MediaCacheState & MediaCacheActions;\n\n// Initial state\nconst DEFAULT_VIDEO_SETTINGS: VideoPlayerSettings = {\n volume: 1,\n isLooping: false,\n};\n\nconst initialState: MediaCacheState = {\n blobUrls: new Map(),\n imageDimensions: new Map(),\n audioPlaybackPositions: new Map(),\n audioEffectConfigs: new Map(),\n videoStreamUrls: new Map(),\n videoPosterUrls: new Map(),\n videoPlaybackPositions: new Map(),\n videoMetadata: new Map(),\n videoPlayerSettings: DEFAULT_VIDEO_SETTINGS,\n};\n\nexport const useMediaCacheStore = create<MediaCacheStore>()(\n devtools(\n persist(\n (set, get) => ({\n ...initialState,\n\n // ========== Blob URL Management ==========\n\n getOrCreateBlobUrl: (key, content, mimeType) => {\n const existing = get().blobUrls.get(key);\n if (existing) {\n // Increment ref count\n cacheDebug.debug(`Blob URL reused: ${key}`, { refCount: existing.refCount + 1 });\n set(\n (state) => ({\n blobUrls: new Map(state.blobUrls).set(key, {\n ...existing,\n refCount: existing.refCount + 1,\n }),\n }),\n false,\n 'blobUrl/incrementRef'\n );\n return existing.url;\n }\n\n // Create new blob URL\n const blob = new Blob([content], { type: mimeType });\n const url = URL.createObjectURL(blob);\n const sizeMB = (content.byteLength / 1024 / 1024).toFixed(2);\n cacheDebug.debug(`Blob URL created: ${key}`, { mimeType, size: `${sizeMB}MB` });\n set(\n (state) => ({\n blobUrls: new Map(state.blobUrls).set(key, {\n url,\n refCount: 1,\n createdAt: Date.now(),\n }),\n }),\n false,\n 'blobUrl/create'\n );\n return url;\n },\n\n releaseBlobUrl: (key) => {\n const entry = get().blobUrls.get(key);\n if (!entry) return;\n\n if (entry.refCount <= 1) {\n // Last reference - revoke and remove\n cacheDebug.debug(`Blob URL revoked: ${key}`);\n URL.revokeObjectURL(entry.url);\n set(\n (state) => {\n const newMap = new Map(state.blobUrls);\n newMap.delete(key);\n return { blobUrls: newMap };\n },\n false,\n 'blobUrl/revoke'\n );\n } else {\n // Decrement ref count\n cacheDebug.debug(`Blob URL released: ${key}`, { refCount: entry.refCount - 1 });\n set(\n (state) => ({\n blobUrls: new Map(state.blobUrls).set(key, {\n ...entry,\n refCount: entry.refCount - 1,\n }),\n }),\n false,\n 'blobUrl/decrementRef'\n );\n }\n },\n\n hasBlobUrl: (key) => get().blobUrls.has(key),\n\n // ========== Image Cache ==========\n\n cacheDimensions: (src, dims) => {\n set(\n (state) => ({\n imageDimensions: new Map(state.imageDimensions).set(src, dims),\n }),\n false,\n 'image/cacheDimensions'\n );\n },\n\n getDimensions: (src) => get().imageDimensions.get(src) ?? null,\n\n // ========== Audio Cache ==========\n\n saveAudioPosition: (uri, time) => {\n set(\n (state) => ({\n audioPlaybackPositions: new Map(state.audioPlaybackPositions).set(\n uri,\n time\n ),\n }),\n false,\n 'audio/savePosition'\n );\n },\n\n getAudioPosition: (uri) =>\n get().audioPlaybackPositions.get(uri) ?? null,\n\n getEffectConfig: (key) => get().audioEffectConfigs.get(key) ?? null,\n\n cacheEffectConfig: (key, config) => {\n set(\n (state) => ({\n audioEffectConfigs: new Map(state.audioEffectConfigs).set(\n key,\n config\n ),\n }),\n false,\n 'audio/cacheEffectConfig'\n );\n },\n\n // ========== Video Cache ==========\n\n getOrCreateStreamUrl: (sessionId, path, generator) => {\n const key = `${sessionId}:${path}`;\n const cached = get().videoStreamUrls.get(key);\n\n // Return if fresh\n if (cached && Date.now() - cached.timestamp < STREAM_URL_TTL) {\n return cached.url;\n }\n\n // Generate and cache\n const url = generator(sessionId, path);\n set(\n (state) => ({\n videoStreamUrls: new Map(state.videoStreamUrls).set(key, {\n url,\n timestamp: Date.now(),\n }),\n }),\n false,\n 'video/cacheStreamUrl'\n );\n return url;\n },\n\n getPosterUrl: (title) => get().videoPosterUrls.get(title) ?? null,\n\n cachePosterUrl: (title, url) => {\n set(\n (state) => ({\n videoPosterUrls: new Map(state.videoPosterUrls).set(title, url),\n }),\n false,\n 'video/cachePosterUrl'\n );\n },\n\n saveVideoPosition: (key, time) => {\n set(\n (state) => ({\n videoPlaybackPositions: new Map(state.videoPlaybackPositions).set(\n key,\n time\n ),\n }),\n false,\n 'video/savePosition'\n );\n },\n\n getVideoPosition: (key) =>\n get().videoPlaybackPositions.get(key) ?? null,\n\n cacheVideoMetadata: (url, meta) => {\n set(\n (state) => ({\n videoMetadata: new Map(state.videoMetadata).set(url, meta),\n }),\n false,\n 'video/cacheMetadata'\n );\n },\n\n getVideoMetadata: (url) => get().videoMetadata.get(url) ?? null,\n\n invalidateSession: (sessionId) => {\n set(\n (state) => {\n const newUrls = new Map(state.videoStreamUrls);\n for (const [key] of newUrls) {\n if (key.startsWith(`${sessionId}:`)) {\n newUrls.delete(key);\n }\n }\n return { videoStreamUrls: newUrls };\n },\n false,\n 'video/invalidateSession'\n );\n },\n\n getVideoPlayerSettings: () => get().videoPlayerSettings,\n\n saveVideoPlayerSettings: (settings) => {\n set(\n (state) => ({\n videoPlayerSettings: { ...state.videoPlayerSettings, ...settings },\n }),\n false,\n 'video/savePlayerSettings'\n );\n },\n\n // ========== Global ==========\n\n clearCache: () => {\n const stats = get().getCacheStats();\n cacheDebug.info('Clearing cache', stats);\n // Revoke all blob URLs before clearing\n get().blobUrls.forEach(({ url }) => URL.revokeObjectURL(url));\n set(initialState, false, 'clearCache');\n },\n\n getCacheStats: () => ({\n blobUrls: get().blobUrls.size,\n dimensions: get().imageDimensions.size,\n audioPositions: get().audioPlaybackPositions.size,\n videoPositions: get().videoPlaybackPositions.size,\n }),\n }),\n {\n name: 'media-cache-storage',\n // Only persist playback positions, poster URLs, and player settings\n partialize: (state) => ({\n audioPlaybackPositions: Array.from(\n state.audioPlaybackPositions.entries()\n ),\n videoPlaybackPositions: Array.from(\n state.videoPlaybackPositions.entries()\n ),\n videoPosterUrls: Array.from(state.videoPosterUrls.entries()),\n videoPlayerSettings: state.videoPlayerSettings,\n }),\n // Rehydrate Maps from arrays\n onRehydrateStorage: () => (state) => {\n if (state) {\n // Type assertion for persisted data\n const persistedAudio = state.audioPlaybackPositions as unknown;\n const persistedVideo = state.videoPlaybackPositions as unknown;\n const persistedPosters = state.videoPosterUrls as unknown;\n const persistedSettings = state.videoPlayerSettings as unknown;\n\n state.audioPlaybackPositions = new Map(\n Array.isArray(persistedAudio)\n ? (persistedAudio as [string, number][])\n : []\n );\n state.videoPlaybackPositions = new Map(\n Array.isArray(persistedVideo)\n ? (persistedVideo as [string, number][])\n : []\n );\n state.videoPosterUrls = new Map(\n Array.isArray(persistedPosters)\n ? (persistedPosters as [string, string][])\n : []\n );\n // Merge persisted settings with defaults (handles missing fields)\n state.videoPlayerSettings = {\n ...DEFAULT_VIDEO_SETTINGS,\n ...(persistedSettings && typeof persistedSettings === 'object'\n ? (persistedSettings as Partial<VideoPlayerSettings>)\n : {}),\n };\n }\n },\n }\n ),\n { name: 'MediaCacheStore' }\n )\n);\n\n// ========== Selective Hooks ==========\n\n/**\n * Hook for image-related cache operations\n * Uses useShallow to prevent infinite re-renders\n */\nexport const useImageCache = () =>\n useMediaCacheStore(\n useShallow((state) => ({\n getOrCreateBlobUrl: state.getOrCreateBlobUrl,\n releaseBlobUrl: state.releaseBlobUrl,\n hasBlobUrl: state.hasBlobUrl,\n cacheDimensions: state.cacheDimensions,\n getDimensions: state.getDimensions,\n }))\n );\n\n/**\n * Hook for audio-related cache operations\n * Uses useShallow to prevent infinite re-renders\n */\nexport const useAudioCache = () =>\n useMediaCacheStore(\n useShallow((state) => ({\n getOrCreateBlobUrl: state.getOrCreateBlobUrl,\n releaseBlobUrl: state.releaseBlobUrl,\n hasBlobUrl: state.hasBlobUrl,\n saveAudioPosition: state.saveAudioPosition,\n getAudioPosition: state.getAudioPosition,\n getEffectConfig: state.getEffectConfig,\n cacheEffectConfig: state.cacheEffectConfig,\n }))\n );\n\n/**\n * Hook for video-related cache operations\n * Uses useShallow to prevent infinite re-renders\n */\nexport const useVideoCache = () =>\n useMediaCacheStore(\n useShallow((state) => ({\n getOrCreateBlobUrl: state.getOrCreateBlobUrl,\n releaseBlobUrl: state.releaseBlobUrl,\n hasBlobUrl: state.hasBlobUrl,\n getOrCreateStreamUrl: state.getOrCreateStreamUrl,\n getPosterUrl: state.getPosterUrl,\n cachePosterUrl: state.cachePosterUrl,\n saveVideoPosition: state.saveVideoPosition,\n getVideoPosition: state.getVideoPosition,\n cacheVideoMetadata: state.cacheVideoMetadata,\n getVideoMetadata: state.getVideoMetadata,\n invalidateSession: state.invalidateSession,\n getVideoPlayerSettings: state.getVideoPlayerSettings,\n saveVideoPlayerSettings: state.saveVideoPlayerSettings,\n }))\n );\n\n/**\n * Hook for video player settings only\n * Returns current settings and save function\n */\nexport const useVideoPlayerSettings = () =>\n useMediaCacheStore(\n useShallow((state) => ({\n settings: state.videoPlayerSettings,\n saveSettings: state.saveVideoPlayerSettings,\n }))\n );\n\n/**\n * Hook for blob URL cleanup on unmount\n */\nexport function useBlobUrlCleanup(key: string | null) {\n const releaseBlobUrl = useMediaCacheStore((s) => s.releaseBlobUrl);\n\n // Using inline effect to avoid importing useEffect in store\n if (typeof window !== 'undefined') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const { useEffect } = require('react');\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useEffect(() => {\n return () => {\n if (key) {\n releaseBlobUrl(key);\n }\n };\n }, [key, releaseBlobUrl]);\n }\n}\n\n// ========== Utilities ==========\n\n/**\n * Generate a cache key from ArrayBuffer content\n * Uses first and last 1KB + length for fast hashing\n */\nexport function generateContentKey(content: ArrayBuffer): string {\n const arr = new Uint8Array(content);\n const len = arr.length;\n\n // Take first 1KB\n const start = arr.slice(0, Math.min(1024, len));\n // Take last 1KB\n const end = arr.slice(Math.max(0, len - 1024));\n\n // Simple hash from bytes\n let hash = len;\n for (let i = 0; i < start.length; i++) {\n hash = ((hash << 5) - hash + start[i]) | 0;\n }\n for (let i = 0; i < end.length; i++) {\n hash = ((hash << 5) - hash + end[i]) | 0;\n }\n\n return `blob-${len}-${hash.toString(16)}`;\n}\n","'use client';\n\n/**\n * VideoPlayer Debug Logger\n *\n * Uses universal logger with media-specific helpers.\n * Logs go to both console (dev) and zustand store (for Console panel).\n */\n\nimport { createMediaLogger } from '@djangocfg/ui-core/lib';\n\nexport const videoDebug = createMediaLogger('VideoPlayer');\n\nexport default videoDebug;\n","/**\n * VidstackProvider - Full-featured video player using Vidstack\n * Supports YouTube, Vimeo, HLS, DASH, and direct URLs\n */\n\n'use client';\n\n// Import Vidstack base styles\nimport '@vidstack/react/player/styles/base.css';\nimport '@vidstack/react/player/styles/default/theme.css';\nimport '@vidstack/react/player/styles/default/layouts/video.css';\n\nimport React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState } from 'react';\n\nimport { cn, generateOgImageUrl } from '@djangocfg/ui-core/lib';\nimport { MediaPlayer, MediaProvider, Poster } from '@vidstack/react';\nimport { defaultLayoutIcons, DefaultVideoLayout } from '@vidstack/react/player/layouts/default';\nimport { useVideoCache } from '../../../stores/mediaCache';\n\nimport type { MediaPlayerInstance, PlayerSrc } from '@vidstack/react';\nimport type { VidstackProviderProps, VideoPlayerRef, ErrorFallbackProps } from '../types';\nimport { videoDebug } from '../utils/debug';\n\n/**\n * Convert source to Vidstack-compatible format\n * Returns object with explicit type for HLS/DASH to ensure proper loader selection\n */\nfunction getVidstackSrc(source: VidstackProviderProps['source']): PlayerSrc {\n switch (source.type) {\n case 'youtube':\n return `youtube/${source.id}`;\n case 'vimeo':\n return `vimeo/${source.id}`;\n case 'hls':\n // Explicit type needed because URL may have query params that hide .m3u8 extension\n return { src: source.url, type: 'application/x-mpegurl' } as PlayerSrc;\n case 'dash':\n return { src: source.url, type: 'application/dash+xml' } as PlayerSrc;\n case 'url':\n return source.url;\n default:\n return '';\n }\n}\n\n/** Default error fallback UI */\nfunction DefaultErrorFallback({ error }: ErrorFallbackProps) {\n return (\n <div className=\"absolute inset-0 flex flex-col items-center justify-center gap-4 text-white bg-black\">\n <svg\n className=\"w-16 h-16 text-muted-foreground\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M15 10l4.553-2.276A1 1 0 0121 8.618v6.764a1 1 0 01-1.447.894L15 14M5 18h8a2 2 0 002-2V8a2 2 0 00-2-2H5a2 2 0 00-2 2v8a2 2 0 002 2z\"\n />\n </svg>\n <p className=\"text-lg\">{error || 'Video cannot be played'}</p>\n </div>\n );\n}\n\nexport const VidstackProvider = forwardRef<VideoPlayerRef, VidstackProviderProps>(\n (\n {\n source,\n aspectRatio = 16 / 9,\n autoPlay = false,\n muted = false,\n loop = false,\n playsInline = true,\n controls = true,\n className,\n showInfo = false,\n theme = 'default',\n errorFallback,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n },\n ref\n ) => {\n const playerRef = useRef<MediaPlayerInstance | null>(null);\n const [hasError, setHasError] = useState(false);\n const [errorMessage, setErrorMessage] = useState<string>('Video cannot be played');\n const lastSavedTimeRef = useRef<number>(0);\n const hasRestoredPositionRef = useRef(false);\n\n // Cache hooks\n const {\n getPosterUrl,\n cachePosterUrl,\n saveVideoPosition,\n getVideoPosition,\n } = useVideoCache();\n\n // Get source key for position caching\n const sourceKey = useMemo(() => {\n switch (source.type) {\n case 'youtube':\n return `youtube:${source.id}`;\n case 'vimeo':\n return `vimeo:${source.id}`;\n case 'hls':\n case 'dash':\n case 'url':\n return `url:${source.url}`;\n default:\n return null;\n }\n }, [source]);\n\n // Generate poster if not provided, with caching\n const posterUrl = useMemo(() => {\n if (source.poster) return source.poster;\n if (!source.title) return undefined;\n\n // Check cache first\n const cached = getPosterUrl(source.title);\n if (cached) return cached;\n\n // Generate and cache\n const url = generateOgImageUrl({ title: source.title });\n cachePosterUrl(source.title, url);\n return url;\n }, [source.poster, source.title, getPosterUrl, cachePosterUrl]);\n\n // Get Vidstack-compatible source URL\n const vidstackSrc = useMemo(() => getVidstackSrc(source), [source]);\n\n // Debug: Log video source\n useEffect(() => {\n const srcString = typeof vidstackSrc === 'string' ? vidstackSrc : (vidstackSrc as { src: string }).src;\n videoDebug.load(srcString, source.type);\n }, [vidstackSrc, source.type]);\n\n // Retry function\n const retry = useCallback(() => {\n setHasError(false);\n setErrorMessage('Video cannot be played');\n // Force reload by updating key would be needed, but for now just reset state\n const player = playerRef.current;\n if (player) {\n player.currentTime = 0;\n player.play();\n }\n }, []);\n\n // Expose player methods via ref\n useImperativeHandle(\n ref,\n () => {\n const player = playerRef.current;\n\n return {\n play: () => player?.play(),\n pause: () => player?.pause(),\n togglePlay: () => {\n if (player) {\n player.paused ? player.play() : player.pause();\n }\n },\n seekTo: (time: number) => {\n if (player) player.currentTime = time;\n },\n setVolume: (volume: number) => {\n if (player) player.volume = Math.max(0, Math.min(1, volume));\n },\n toggleMute: () => {\n if (player) player.muted = !player.muted;\n },\n enterFullscreen: () => player?.enterFullscreen(),\n exitFullscreen: () => player?.exitFullscreen(),\n get currentTime() {\n return player?.currentTime ?? 0;\n },\n get duration() {\n return player?.duration ?? 0;\n },\n get paused() {\n return player?.paused ?? true;\n },\n };\n },\n []\n );\n\n const handlePlay = () => onPlay?.();\n\n const handlePause = useCallback(() => {\n // Save position on pause\n const player = playerRef.current;\n if (sourceKey && player && player.currentTime > 0) {\n saveVideoPosition(sourceKey, player.currentTime);\n lastSavedTimeRef.current = player.currentTime;\n }\n onPause?.();\n }, [sourceKey, saveVideoPosition, onPause]);\n\n const handleEnded = () => onEnded?.();\n\n const handleError = (detail: unknown) => {\n const error = detail as { message?: string };\n const msg = error?.message || 'Video playback error';\n videoDebug.error('Vidstack error', { message: msg });\n setHasError(true);\n setErrorMessage(msg);\n onError?.(msg);\n };\n\n const handleLoadStart = () => onLoadStart?.();\n\n const handleCanPlay = useCallback(() => {\n const player = playerRef.current;\n if (player) {\n videoDebug.state('canplay', { duration: player.duration });\n // Log buffer state if media element is available\n const mediaEl = (player.provider as { media?: HTMLVideoElement } | null)?.media;\n if (mediaEl?.buffered) {\n videoDebug.buffer(mediaEl.buffered, player.duration);\n }\n }\n setHasError(false);\n\n // Restore position from cache (only once per source)\n if (sourceKey && player && !hasRestoredPositionRef.current) {\n const cachedPosition = getVideoPosition(sourceKey);\n if (cachedPosition && cachedPosition > 0) {\n const duration = player.duration;\n // Only restore if position is valid (not at the end)\n if (cachedPosition < duration - 1) {\n videoDebug.debug(`Restoring position: ${cachedPosition}s`);\n player.currentTime = cachedPosition;\n }\n }\n hasRestoredPositionRef.current = true;\n }\n\n onCanPlay?.();\n }, [sourceKey, getVideoPosition, onCanPlay]);\n\n const handleTimeUpdate = useCallback(() => {\n const player = playerRef.current;\n if (!player) return;\n\n // Save position every 5 seconds\n if (sourceKey && player.currentTime > 0) {\n const timeSinceLastSave = player.currentTime - lastSavedTimeRef.current;\n if (timeSinceLastSave >= 5 || timeSinceLastSave < 0) {\n saveVideoPosition(sourceKey, player.currentTime);\n lastSavedTimeRef.current = player.currentTime;\n }\n }\n\n onTimeUpdate?.(player.currentTime, player.duration);\n }, [sourceKey, saveVideoPosition, onTimeUpdate]);\n\n // Reset position restoration flag when source changes\n useEffect(() => {\n hasRestoredPositionRef.current = false;\n lastSavedTimeRef.current = 0;\n }, [sourceKey]);\n\n // Debug: Log player events\n useEffect(() => {\n const player = playerRef.current;\n if (!player) return;\n\n const handleSeeking = () => {\n videoDebug.event('seeking', { currentTime: player.currentTime });\n };\n\n const handleSeeked = () => {\n videoDebug.event('seeked', { currentTime: player.currentTime });\n const mediaEl = (player.provider as { media?: HTMLVideoElement } | null)?.media;\n if (mediaEl?.buffered) {\n videoDebug.buffer(mediaEl.buffered, player.duration);\n }\n };\n\n const handleWaiting = () => {\n videoDebug.warn('WAITING - buffering...');\n const mediaEl = (player.provider as { media?: HTMLVideoElement } | null)?.media;\n if (mediaEl?.buffered) {\n videoDebug.buffer(mediaEl.buffered, player.duration);\n }\n };\n\n const handleStalled = () => {\n videoDebug.warn('STALLED - network issue');\n const mediaEl = (player.provider as { media?: HTMLVideoElement } | null)?.media;\n if (mediaEl?.buffered) {\n videoDebug.buffer(mediaEl.buffered, player.duration);\n }\n };\n\n player.addEventListener('seeking', handleSeeking);\n player.addEventListener('seeked', handleSeeked);\n player.addEventListener('waiting', handleWaiting);\n player.addEventListener('stalled', handleStalled);\n\n return () => {\n player.removeEventListener('seeking', handleSeeking);\n player.removeEventListener('seeked', handleSeeked);\n player.removeEventListener('waiting', handleWaiting);\n player.removeEventListener('stalled', handleStalled);\n };\n }, [vidstackSrc]);\n\n // Determine layout mode\n const isFillMode = aspectRatio === 'fill';\n const computedAspectRatio = aspectRatio === 'auto' || aspectRatio === 'fill' ? undefined : aspectRatio;\n\n // Render error fallback\n const renderErrorFallback = () => {\n const fallbackProps: ErrorFallbackProps = { error: errorMessage, retry };\n\n if (typeof errorFallback === 'function') {\n return errorFallback(fallbackProps);\n }\n\n if (errorFallback) {\n return errorFallback;\n }\n\n return <DefaultErrorFallback {...fallbackProps} />;\n };\n\n // Container styles based on mode\n const containerStyles = isFillMode\n ? { width: '100%', height: '100%' }\n : { aspectRatio: computedAspectRatio };\n\n return (\n <div className={cn(isFillMode ? 'w-full h-full' : 'w-full', className)}>\n <div\n className={cn(\n 'relative w-full rounded-sm bg-black overflow-hidden',\n isFillMode && 'h-full',\n theme === 'minimal' && 'rounded-none',\n theme === 'modern' && 'rounded-xl shadow-2xl'\n )}\n style={containerStyles}\n >\n {hasError ? (\n renderErrorFallback()\n ) : (\n <MediaPlayer\n ref={playerRef}\n title={source.title || 'Video'}\n src={vidstackSrc}\n autoPlay={autoPlay}\n muted={muted}\n loop={loop}\n playsInline={playsInline}\n onPlay={handlePlay}\n onPause={handlePause}\n onEnded={handleEnded}\n onError={handleError}\n onLoadStart={handleLoadStart}\n onCanPlay={handleCanPlay}\n onTimeUpdate={handleTimeUpdate}\n className=\"w-full h-full\"\n >\n <MediaProvider />\n\n {posterUrl && (\n <Poster\n className=\"vds-poster\"\n src={posterUrl}\n alt={source.title || 'Video poster'}\n style={{ objectFit: 'cover' }}\n />\n )}\n\n {controls && <DefaultVideoLayout icons={defaultLayoutIcons} thumbnails={posterUrl} />}\n </MediaPlayer>\n )}\n </div>\n\n {showInfo && source.title && (\n <div className=\"mt-4 space-y-2\">\n <h3 className=\"text-xl font-semibold text-foreground\">{source.title}</h3>\n </div>\n )}\n </div>\n );\n }\n);\n\nVidstackProvider.displayName = 'VidstackProvider';\n","'use client';\n\n/**\n * useVideoPlayerSettings - Hook for persisted video player settings\n *\n * Provides volume and loop settings that persist in localStorage.\n * Use this hook in video player providers to apply saved settings.\n *\n * @example\n * const { settings, updateVolume, updateLoop } = useVideoPlayerSettings();\n *\n * // Apply to video element\n * videoRef.current.volume = settings.volume;\n * videoRef.current.loop = settings.isLooping;\n *\n * // Save when user changes\n * const handleVolumeChange = (vol: number) => {\n * videoRef.current.volume = vol;\n * updateVolume(vol);\n * };\n */\n\nimport { useCallback } from 'react';\nimport { useVideoPlayerSettings as useSettings } from '../../../stores/mediaCache';\n\nexport interface VideoPlayerSettingsReturn {\n /** Current settings */\n settings: {\n volume: number;\n isLooping: boolean;\n };\n /** Update volume (0-1) */\n updateVolume: (volume: number) => void;\n /** Update loop setting */\n updateLoop: (isLooping: boolean) => void;\n /** Update multiple settings at once */\n updateSettings: (settings: { volume?: number; isLooping?: boolean }) => void;\n}\n\nexport function useVideoPlayerSettings(): VideoPlayerSettingsReturn {\n const { settings, saveSettings } = useSettings();\n\n const updateVolume = useCallback(\n (volume: number) => {\n saveSettings({ volume: Math.max(0, Math.min(1, volume)) });\n },\n [saveSettings]\n );\n\n const updateLoop = useCallback(\n (isLooping: boolean) => {\n saveSettings({ isLooping });\n },\n [saveSettings]\n );\n\n const updateSettings = useCallback(\n (newSettings: { volume?: number; isLooping?: boolean }) => {\n saveSettings(newSettings);\n },\n [saveSettings]\n );\n\n return {\n settings,\n updateVolume,\n updateLoop,\n updateSettings,\n };\n}\n","/**\n * NativeProvider - Lightweight native HTML5 video player\n * For demo videos, background videos, autoplay loop muted scenarios\n */\n\n'use client';\n\nimport React, { forwardRef, useEffect, useImperativeHandle, useRef, useState } from 'react';\n\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { Preloader, AspectRatio } from '@djangocfg/ui-core';\nimport { useVideoPlayerSettings } from '../hooks/useVideoPlayerSettings';\n\nimport type { NativeProviderProps, VideoPlayerRef } from '../types';\nimport { videoDebug } from '../utils/debug';\n\n/**\n * Get video URL from source\n */\nfunction getVideoUrl(source: NativeProviderProps['source']): string {\n switch (source.type) {\n case 'url':\n return source.url;\n case 'data-url':\n return source.data;\n default:\n return '';\n }\n}\n\nexport const NativeProvider = forwardRef<VideoPlayerRef, NativeProviderProps>(\n (\n {\n source,\n aspectRatio = 16 / 9,\n autoPlay = true,\n muted = true,\n loop = true,\n playsInline = true,\n preload = 'auto',\n controls = false,\n disableContextMenu = true,\n showPreloader = true,\n preloaderTimeout = 5000,\n className,\n videoClassName,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n },\n ref\n ) => {\n const [isLoading, setIsLoading] = useState(showPreloader);\n const videoRef = useRef<HTMLVideoElement>(null);\n\n // Persisted player settings\n const { settings: savedSettings, updateVolume } = useVideoPlayerSettings();\n\n const videoUrl = getVideoUrl(source);\n\n // Debug: Log video source\n useEffect(() => {\n videoDebug.load(videoUrl, source.type);\n }, [videoUrl, source.type]);\n\n // Expose video element methods via ref\n useImperativeHandle(\n ref,\n () => ({\n play: () => videoRef.current?.play(),\n pause: () => videoRef.current?.pause(),\n togglePlay: () => {\n const video = videoRef.current;\n if (video) {\n video.paused ? video.play() : video.pause();\n }\n },\n seekTo: (time: number) => {\n if (videoRef.current) videoRef.current.currentTime = time;\n },\n setVolume: (volume: number) => {\n if (videoRef.current) videoRef.current.volume = Math.max(0, Math.min(1, volume));\n },\n toggleMute: () => {\n if (videoRef.current) videoRef.current.muted = !videoRef.current.muted;\n },\n enterFullscreen: () => videoRef.current?.requestFullscreen(),\n exitFullscreen: () => document.exitFullscreen(),\n get currentTime() {\n return videoRef.current?.currentTime ?? 0;\n },\n get duration() {\n return videoRef.current?.duration ?? 0;\n },\n get paused() {\n return videoRef.current?.paused ?? true;\n },\n }),\n []\n );\n\n useEffect(() => {\n if (!showPreloader) return;\n\n const video = videoRef.current;\n if (!video) return;\n\n // Check if video is already loaded\n if (video.readyState >= 3) {\n setIsLoading(false);\n return;\n }\n\n const hideLoader = () => setIsLoading(false);\n\n video.addEventListener('canplay', hideLoader);\n video.addEventListener('loadeddata', hideLoader);\n video.addEventListener('playing', hideLoader);\n\n // Fallback: hide loader after timeout\n const timeout = setTimeout(hideLoader, preloaderTimeout);\n\n return () => {\n video.removeEventListener('canplay', hideLoader);\n video.removeEventListener('loadeddata', hideLoader);\n video.removeEventListener('playing', hideLoader);\n clearTimeout(timeout);\n };\n }, [showPreloader, preloaderTimeout]);\n\n // Debug: Log video events\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n const handleLoadedMetadata = () => {\n videoDebug.state('loadedmetadata', { duration: video.duration });\n };\n\n const handleCanPlayDebug = () => {\n videoDebug.state('canplay', { duration: video.duration, buffered: video.buffered.length });\n videoDebug.buffer(video.buffered, video.duration);\n // Apply saved volume\n video.volume = savedSettings.volume;\n };\n\n const handleSeeking = () => {\n videoDebug.event('seeking', { currentTime: video.currentTime });\n };\n\n const handleSeeked = () => {\n videoDebug.event('seeked', { currentTime: video.currentTime });\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n const handleWaiting = () => {\n videoDebug.warn('WAITING - buffering...');\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n const handleStalled = () => {\n videoDebug.warn('STALLED - network issue');\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n video.addEventListener('loadedmetadata', handleLoadedMetadata);\n video.addEventListener('canplay', handleCanPlayDebug);\n video.addEventListener('seeking', handleSeeking);\n video.addEventListener('seeked', handleSeeked);\n video.addEventListener('waiting', handleWaiting);\n video.addEventListener('stalled', handleStalled);\n\n return () => {\n video.removeEventListener('loadedmetadata', handleLoadedMetadata);\n video.removeEventListener('canplay', handleCanPlayDebug);\n video.removeEventListener('seeking', handleSeeking);\n video.removeEventListener('seeked', handleSeeked);\n video.removeEventListener('waiting', handleWaiting);\n video.removeEventListener('stalled', handleStalled);\n };\n }, [savedSettings.volume]);\n\n // Persist volume when user changes it via native controls\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n const handleVolumeChange = () => {\n updateVolume(video.volume);\n };\n\n video.addEventListener('volumechange', handleVolumeChange);\n return () => video.removeEventListener('volumechange', handleVolumeChange);\n }, [updateVolume]);\n\n const handleContextMenu = (e: React.MouseEvent) => {\n if (disableContextMenu) {\n e.preventDefault();\n }\n };\n\n const handleError = (e: React.SyntheticEvent<HTMLVideoElement>) => {\n const video = e.currentTarget;\n const errorMsg = video.error?.message || 'Video playback error';\n videoDebug.error('Video error', { code: video.error?.code, message: errorMsg });\n setIsLoading(false);\n onError?.(errorMsg);\n };\n\n const handleTimeUpdate = () => {\n const video = videoRef.current;\n if (video && onTimeUpdate) {\n onTimeUpdate(video.currentTime, video.duration);\n }\n };\n\n // Determine if we should use AspectRatio wrapper or fill mode\n const isFillMode = aspectRatio === 'fill';\n const computedAspectRatio = aspectRatio === 'auto' || aspectRatio === 'fill' ? undefined : aspectRatio;\n\n // Video content\n const videoContent = (\n <>\n {/* Preloader */}\n {showPreloader && isLoading && (\n <div\n className={cn(\n 'absolute inset-0 flex items-center justify-center bg-muted/30 backdrop-blur-sm z-10'\n )}\n >\n <Preloader size=\"lg\" spinnerClassName=\"text-white\" />\n </div>\n )}\n\n {/* Video */}\n <video\n ref={videoRef}\n className={cn('w-full h-full object-cover', videoClassName)}\n src={videoUrl}\n autoPlay={autoPlay}\n muted={muted}\n loop={loop}\n playsInline={playsInline}\n preload={preload}\n controls={controls}\n poster={source.poster}\n onContextMenu={handleContextMenu}\n onLoadStart={onLoadStart}\n onCanPlay={onCanPlay}\n onPlay={onPlay}\n onPause={onPause}\n onPlaying={() => setIsLoading(false)}\n onEnded={onEnded}\n onError={handleError}\n onTimeUpdate={handleTimeUpdate}\n />\n </>\n );\n\n // Fill mode - no AspectRatio wrapper\n if (isFillMode) {\n return (\n <div className={cn('relative w-full h-full overflow-hidden', className)}>\n {videoContent}\n </div>\n );\n }\n\n // Normal mode with AspectRatio\n return (\n <div className={cn('relative overflow-hidden', className)}>\n <AspectRatio ratio={computedAspectRatio}>\n {videoContent}\n </AspectRatio>\n </div>\n );\n }\n);\n\nNativeProvider.displayName = 'NativeProvider';\n","/**\n * StreamProvider - HTTP Range streaming and Blob video player\n * Supports:\n * - HTTP Range requests with authorization (for large files)\n * - Blob/ArrayBuffer sources\n * - Data URL sources\n * - Fill parent container mode\n * - Custom error fallback\n */\n\n'use client';\n\nimport React, { forwardRef, useCallback, useEffect, useImperativeHandle, useRef, useState } from 'react';\n\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { Preloader, AspectRatio } from '@djangocfg/ui-core';\nimport { useMediaCacheStore, generateContentKey } from '../../../stores/mediaCache';\nimport { useVideoPlayerSettings } from '../hooks/useVideoPlayerSettings';\n\nimport type { StreamProviderProps, VideoPlayerRef, StreamSource, BlobSource, DataUrlSource, ErrorFallbackProps } from '../types';\nimport { videoDebug } from '../utils/debug';\n\n/** Default error fallback UI */\nfunction DefaultErrorFallback({ error }: ErrorFallbackProps) {\n return (\n <div className=\"absolute inset-0 flex flex-col items-center justify-center gap-4 text-white\">\n <svg\n className=\"w-16 h-16 text-muted-foreground\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M15 10l4.553-2.276A1 1 0 0121 8.618v6.764a1 1 0 01-1.447.894L15 14M5 18h8a2 2 0 002-2V8a2 2 0 00-2-2H5a2 2 0 00-2 2v8a2 2 0 002 2z\"\n />\n </svg>\n <p className=\"text-lg\">{error || 'Video cannot be previewed'}</p>\n </div>\n );\n}\n\nexport const StreamProvider = forwardRef<VideoPlayerRef, StreamProviderProps>(\n (\n {\n source,\n aspectRatio = 16 / 9,\n autoPlay = false,\n muted = false,\n loop = false,\n playsInline = true,\n preload = 'metadata',\n controls = true,\n disableContextMenu = false,\n showPreloader = true,\n preloaderTimeout = 10000,\n className,\n videoClassName,\n errorFallback,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n onBufferProgress,\n },\n ref\n ) => {\n const [videoUrl, setVideoUrl] = useState<string | null>(null);\n const [isLoading, setIsLoading] = useState(true);\n const [hasError, setHasError] = useState(false);\n const [errorMessage, setErrorMessage] = useState<string>('Video cannot be previewed');\n const videoRef = useRef<HTMLVideoElement>(null);\n const contentKeyRef = useRef<string | null>(null);\n const lastSavedTimeRef = useRef<number>(0);\n\n // Get stable function references from store (not from hook to avoid re-renders)\n const getOrCreateBlobUrl = useMediaCacheStore.getState().getOrCreateBlobUrl;\n const releaseBlobUrl = useMediaCacheStore.getState().releaseBlobUrl;\n const getOrCreateStreamUrl = useMediaCacheStore.getState().getOrCreateStreamUrl;\n const saveVideoPosition = useMediaCacheStore.getState().saveVideoPosition;\n const getVideoPosition = useMediaCacheStore.getState().getVideoPosition;\n\n // Persisted player settings\n const { settings: savedSettings, updateVolume } = useVideoPlayerSettings();\n\n // Retry function for error fallback\n // Regenerates URL for stream sources to get fresh token/session\n const retry = useCallback(() => {\n setHasError(false);\n setIsLoading(true);\n\n // For stream sources, regenerate URL bypassing cache\n if (source.type === 'stream') {\n const streamSource = source as StreamSource;\n const freshUrl = streamSource.getStreamUrl(streamSource.sessionId, streamSource.path);\n setVideoUrl(freshUrl);\n return;\n }\n\n // For other sources, just reload\n const video = videoRef.current;\n if (video && videoUrl) {\n video.load();\n }\n }, [source, videoUrl]);\n\n // Expose video element methods via ref\n useImperativeHandle(\n ref,\n () => ({\n play: () => videoRef.current?.play(),\n pause: () => videoRef.current?.pause(),\n togglePlay: () => {\n const video = videoRef.current;\n if (video) {\n video.paused ? video.play() : video.pause();\n }\n },\n seekTo: (time: number) => {\n if (videoRef.current) videoRef.current.currentTime = time;\n },\n setVolume: (volume: number) => {\n if (videoRef.current) videoRef.current.volume = Math.max(0, Math.min(1, volume));\n },\n toggleMute: () => {\n if (videoRef.current) videoRef.current.muted = !videoRef.current.muted;\n },\n enterFullscreen: () => videoRef.current?.requestFullscreen(),\n exitFullscreen: () => document.exitFullscreen(),\n get currentTime() {\n return videoRef.current?.currentTime ?? 0;\n },\n get duration() {\n return videoRef.current?.duration ?? 0;\n },\n get paused() {\n return videoRef.current?.paused ?? true;\n },\n }),\n []\n );\n\n // Track unmount for cleanup\n const isMountedRef = useRef(true);\n useEffect(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n // Release blob URL only on actual unmount\n if (contentKeyRef.current) {\n useMediaCacheStore.getState().releaseBlobUrl(contentKeyRef.current);\n contentKeyRef.current = null;\n }\n };\n }, []);\n\n // Create video URL based on source type with caching\n useEffect(() => {\n // Release previous blob URL if source changed\n if (contentKeyRef.current) {\n const newKey = source.type === 'blob'\n ? generateContentKey((source as BlobSource).data)\n : null;\n if (newKey !== contentKeyRef.current) {\n releaseBlobUrl(contentKeyRef.current);\n contentKeyRef.current = null;\n }\n }\n\n setHasError(false);\n setIsLoading(true);\n\n switch (source.type) {\n case 'stream': {\n const streamSource = source as StreamSource;\n // Use cached stream URL\n const url = getOrCreateStreamUrl(\n streamSource.sessionId,\n streamSource.path,\n streamSource.getStreamUrl\n );\n videoDebug.load(url, 'stream');\n setVideoUrl(url);\n break;\n }\n\n case 'blob': {\n const blobSource = source as BlobSource;\n // Generate content key for caching\n const contentKey = generateContentKey(blobSource.data);\n contentKeyRef.current = contentKey;\n // Use cached blob URL\n const url = getOrCreateBlobUrl(\n contentKey,\n blobSource.data,\n blobSource.mimeType || 'video/mp4'\n );\n videoDebug.load(url, 'blob');\n setVideoUrl(url);\n break;\n }\n\n case 'data-url': {\n const dataUrlSource = source as DataUrlSource;\n videoDebug.load(dataUrlSource.data.slice(0, 50) + '...', 'data-url');\n setVideoUrl(dataUrlSource.data);\n break;\n }\n\n default:\n videoDebug.error('Invalid video source type', { type: (source as { type: string }).type });\n setVideoUrl(null);\n setHasError(true);\n setErrorMessage('Invalid video source');\n }\n\n // No cleanup here - cleanup happens in unmount effect above\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [source]);\n\n // Get source key for position caching\n const getSourceKey = useCallback(() => {\n switch (source.type) {\n case 'stream':\n return `stream:${(source as StreamSource).sessionId}:${(source as StreamSource).path}`;\n case 'blob':\n return contentKeyRef.current ? `blob:${contentKeyRef.current}` : null;\n case 'data-url':\n return `data:${(source as DataUrlSource).data.slice(0, 50)}`;\n default:\n return null;\n }\n }, [source]);\n\n // Restore cached playback position and settings when video is ready\n const handleCanPlay = useCallback(() => {\n const video = videoRef.current;\n if (video) {\n videoDebug.state('canplay', { duration: video.duration, buffered: video.buffered.length });\n videoDebug.buffer(video.buffered, video.duration);\n\n // Apply saved volume (user preference)\n video.volume = savedSettings.volume;\n }\n setIsLoading(false);\n\n // Restore position from cache\n const sourceKey = getSourceKey();\n if (sourceKey && video) {\n const cachedPosition = getVideoPosition(sourceKey);\n if (cachedPosition && cachedPosition > 0) {\n const duration = video.duration;\n // Only restore if position is valid (not at the end)\n if (cachedPosition < duration - 1) {\n videoDebug.debug(`Restoring position: ${cachedPosition}s`);\n video.currentTime = cachedPosition;\n }\n }\n }\n\n onCanPlay?.();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [getSourceKey, onCanPlay, savedSettings.volume]);\n\n // Save playback position periodically\n const handleTimeUpdate = useCallback(() => {\n const video = videoRef.current;\n if (!video) return;\n\n // Save position every 5 seconds\n const sourceKey = getSourceKey();\n if (sourceKey && video.currentTime > 0) {\n const timeSinceLastSave = video.currentTime - lastSavedTimeRef.current;\n if (timeSinceLastSave >= 5 || timeSinceLastSave < 0) {\n saveVideoPosition(sourceKey, video.currentTime);\n lastSavedTimeRef.current = video.currentTime;\n }\n }\n\n onTimeUpdate?.(video.currentTime, video.duration);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [getSourceKey, onTimeUpdate]);\n\n // Save position on pause\n const handlePause = useCallback(() => {\n const video = videoRef.current;\n const sourceKey = getSourceKey();\n if (sourceKey && video && video.currentTime > 0) {\n saveVideoPosition(sourceKey, video.currentTime);\n lastSavedTimeRef.current = video.currentTime;\n }\n onPause?.();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [getSourceKey, onPause]);\n\n // Handle buffer progress\n const handleProgress = useCallback(() => {\n const video = videoRef.current;\n if (!video || !onBufferProgress) return;\n\n // Get the buffered time ranges\n if (video.buffered.length > 0) {\n // Get the end of the last buffered range\n const bufferedEnd = video.buffered.end(video.buffered.length - 1);\n const duration = video.duration;\n\n if (duration > 0 && !isNaN(bufferedEnd)) {\n onBufferProgress(bufferedEnd, duration);\n }\n }\n }, [onBufferProgress]);\n\n // Preloader timeout\n useEffect(() => {\n if (!showPreloader || !isLoading) return;\n\n const timeout = setTimeout(() => {\n setIsLoading(false);\n }, preloaderTimeout);\n\n return () => clearTimeout(timeout);\n }, [showPreloader, isLoading, preloaderTimeout]);\n\n const handleContextMenu = (e: React.MouseEvent) => {\n if (disableContextMenu) {\n e.preventDefault();\n }\n };\n\n const handleLoadedData = () => {\n setIsLoading(false);\n };\n\n const handleError = () => {\n const video = videoRef.current;\n if (video) {\n videoDebug.error('Video error', { code: video.error?.code, message: video.error?.message });\n }\n setIsLoading(false);\n setHasError(true);\n setErrorMessage('Failed to load video');\n onError?.('Video playback error');\n };\n\n // Debug: Log video events\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n const handleLoadedMetadata = () => {\n videoDebug.state('loadedmetadata', { duration: video.duration });\n };\n\n const handleSeeking = () => {\n videoDebug.event('seeking', { currentTime: video.currentTime });\n };\n\n const handleSeeked = () => {\n videoDebug.event('seeked', { currentTime: video.currentTime });\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n const handleWaiting = () => {\n videoDebug.warn('WAITING - buffering...');\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n const handleStalled = () => {\n videoDebug.warn('STALLED - network issue');\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n video.addEventListener('loadedmetadata', handleLoadedMetadata);\n video.addEventListener('seeking', handleSeeking);\n video.addEventListener('seeked', handleSeeked);\n video.addEventListener('waiting', handleWaiting);\n video.addEventListener('stalled', handleStalled);\n\n return () => {\n video.removeEventListener('loadedmetadata', handleLoadedMetadata);\n video.removeEventListener('seeking', handleSeeking);\n video.removeEventListener('seeked', handleSeeked);\n video.removeEventListener('waiting', handleWaiting);\n video.removeEventListener('stalled', handleStalled);\n };\n }, [videoUrl]);\n\n // Persist volume when user changes it via native controls\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n const handleVolumeChange = () => {\n updateVolume(video.volume);\n };\n\n video.addEventListener('volumechange', handleVolumeChange);\n return () => video.removeEventListener('volumechange', handleVolumeChange);\n }, [videoUrl, updateVolume]);\n\n // Determine if we should use AspectRatio wrapper or fill mode\n const isFillMode = aspectRatio === 'fill';\n const computedAspectRatio = aspectRatio === 'auto' || aspectRatio === 'fill' ? undefined : aspectRatio;\n\n // Render error fallback\n const renderErrorFallback = () => {\n const fallbackProps: ErrorFallbackProps = { error: errorMessage, retry };\n\n if (typeof errorFallback === 'function') {\n return errorFallback(fallbackProps);\n }\n\n if (errorFallback) {\n return errorFallback;\n }\n\n return <DefaultErrorFallback {...fallbackProps} />;\n };\n\n // Error state\n if (!videoUrl || hasError) {\n if (isFillMode) {\n return (\n <div className={cn('relative w-full h-full overflow-hidden bg-black', className)}>\n {renderErrorFallback()}\n </div>\n );\n }\n\n return (\n <div className={cn('relative overflow-hidden bg-black', className)}>\n <AspectRatio ratio={computedAspectRatio}>\n {renderErrorFallback()}\n </AspectRatio>\n </div>\n );\n }\n\n // Video content\n const videoContent = (\n <>\n {/* Loading indicator */}\n {showPreloader && isLoading && (\n <div className=\"absolute inset-0 flex items-center justify-center bg-black/50 z-10\">\n <Preloader size=\"lg\" spinnerClassName=\"text-white\" />\n </div>\n )}\n\n {/* Video element */}\n <video\n ref={videoRef}\n src={videoUrl}\n className={cn(\n 'w-full h-full object-contain',\n isLoading && 'opacity-0',\n videoClassName\n )}\n autoPlay={autoPlay}\n muted={muted}\n loop={loop}\n playsInline={playsInline}\n preload={preload}\n controls={controls}\n crossOrigin=\"anonymous\"\n poster={source.poster}\n onContextMenu={handleContextMenu}\n onLoadStart={onLoadStart}\n onCanPlay={handleCanPlay}\n onLoadedData={handleLoadedData}\n onPlay={onPlay}\n onPause={handlePause}\n onEnded={onEnded}\n onError={handleError}\n onTimeUpdate={handleTimeUpdate}\n onProgress={handleProgress}\n />\n </>\n );\n\n // Fill mode - no AspectRatio wrapper\n if (isFillMode) {\n return (\n <div className={cn('relative w-full h-full overflow-hidden bg-black', className)}>\n {videoContent}\n </div>\n );\n }\n\n // Normal mode with AspectRatio\n return (\n <div className={cn('relative overflow-hidden bg-black', className)}>\n <AspectRatio ratio={computedAspectRatio}>\n {videoContent}\n </AspectRatio>\n </div>\n );\n }\n);\n\nStreamProvider.displayName = 'StreamProvider';\n","/**\n * VideoPlayerContext - Context for streaming configuration\n * Simplifies streaming API by providing getStreamUrl globally\n */\n\n'use client';\n\nimport React, { createContext, useContext, useMemo } from 'react';\n\nimport type { VideoPlayerContextValue, VideoPlayerProviderProps } from '../types';\n\n// =============================================================================\n// Context\n// =============================================================================\n\nconst VideoPlayerContext = createContext<VideoPlayerContextValue | null>(null);\n\n/**\n * Provider for VideoPlayer streaming configuration\n *\n * @example\n * // In your app layout or FileWorkspace\n * <VideoPlayerProvider\n * sessionId={sessionId}\n * getStreamUrl={terminalClient.terminal_media.streamStreamRetrieveUrl}\n * >\n * <VideoPlayer source={{ type: 'stream', path: '/video.mp4' }} />\n * </VideoPlayerProvider>\n */\nexport function VideoPlayerProvider({\n children,\n getStreamUrl,\n sessionId,\n}: VideoPlayerProviderProps) {\n const value = useMemo(\n () => ({ getStreamUrl, sessionId }),\n [getStreamUrl, sessionId]\n );\n\n return (\n <VideoPlayerContext.Provider value={value}>\n {children}\n </VideoPlayerContext.Provider>\n );\n}\n\n/**\n * Hook to access VideoPlayer context\n */\nexport function useVideoPlayerContext(): VideoPlayerContextValue | null {\n return useContext(VideoPlayerContext);\n}\n","/**\n * Video source and player mode resolvers\n */\n\nimport type { VideoSourceUnion, PlayerMode, SimpleStreamSource, StreamSource, VideoPlayerContextValue } from '../types';\n\n/**\n * Determine which provider to use based on source type\n */\nexport function resolvePlayerMode(\n source: VideoSourceUnion,\n mode: PlayerMode = 'auto'\n): 'vidstack' | 'native' | 'streaming' {\n if (mode !== 'auto') {\n return mode;\n }\n\n switch (source.type) {\n case 'youtube':\n case 'vimeo':\n case 'hls':\n case 'dash':\n return 'vidstack';\n\n case 'stream':\n case 'blob':\n return 'streaming';\n\n case 'data-url':\n case 'url':\n default:\n return 'native';\n }\n}\n\n/**\n * Check if source is a simplified stream source (without getStreamUrl)\n */\nexport function isSimpleStreamSource(\n source: VideoSourceUnion | SimpleStreamSource\n): source is SimpleStreamSource {\n return source.type === 'stream' && !('getStreamUrl' in source);\n}\n\n/**\n * Resolve simplified stream source to full stream source using context\n */\nexport function resolveStreamSource(\n source: SimpleStreamSource,\n context: VideoPlayerContextValue | null\n): StreamSource | null {\n if (!context?.getStreamUrl) {\n console.warn(\n 'VideoPlayer: Stream source requires getStreamUrl. ' +\n 'Either provide it in source or wrap with VideoPlayerProvider.'\n );\n return null;\n }\n\n const sessionId = source.sessionId || context.sessionId;\n if (!sessionId) {\n console.warn('VideoPlayer: Stream source requires sessionId.');\n return null;\n }\n\n return {\n type: 'stream',\n sessionId,\n path: source.path,\n getStreamUrl: context.getStreamUrl,\n mimeType: source.mimeType,\n title: source.title,\n poster: source.poster,\n };\n}\n","/**\n * File source resolution utilities\n */\n\nimport type { VideoSourceUnion, ResolveFileSourceOptions } from '../types';\n\n/**\n * Resolve file content to VideoSourceUnion\n * Useful for FileWorkspace/file manager integrations\n *\n * @example\n * const source = resolveFileSource({\n * content: file.content,\n * path: file.path,\n * mimeType: file.mimeType,\n * sessionId: sessionId,\n * loadMethod: file.loadMethod,\n * getStreamUrl: terminalClient.terminal_media.streamStreamRetrieveUrl\n * });\n *\n * <VideoPlayer source={source} />\n */\nexport function resolveFileSource(options: ResolveFileSourceOptions): VideoSourceUnion | null {\n const {\n content,\n path,\n mimeType,\n sessionId,\n loadMethod,\n getStreamUrl,\n title,\n poster,\n } = options;\n\n const contentSize = content\n ? typeof content === 'string'\n ? content.length\n : content.byteLength\n : 0;\n const hasContent = contentSize > 0;\n\n // Priority 1: HTTP Range streaming for large files\n if (loadMethod === 'http_stream' && !hasContent && sessionId && getStreamUrl) {\n return {\n type: 'stream',\n sessionId,\n path,\n getStreamUrl,\n mimeType,\n title,\n poster,\n };\n }\n\n // Priority 2: Data URL (base64 string)\n if (typeof content === 'string' && hasContent) {\n return {\n type: 'data-url',\n data: content,\n title,\n poster,\n };\n }\n\n // Priority 3: ArrayBuffer → Blob\n if (content instanceof ArrayBuffer && hasContent) {\n return {\n type: 'blob',\n data: content,\n mimeType: mimeType || 'video/mp4',\n title,\n poster,\n };\n }\n\n // No valid content\n return null;\n}\n","/**\n * VideoPlayer - Unified Video Player Component\n *\n * Supports multiple modes:\n * - vidstack: Full-featured player (YouTube, Vimeo, HLS, DASH)\n * - native: Lightweight HTML5 player\n * - streaming: HTTP Range streaming with auth / Blob sources\n *\n * @example\n * // YouTube video\n * <VideoPlayer source={{ type: 'youtube', id: 'dQw4w9WgXcQ' }} />\n *\n * @example\n * // HLS stream\n * <VideoPlayer source={{ type: 'hls', url: 'https://example.com/video.m3u8' }} />\n *\n * @example\n * // HTTP Range streaming with auth (full source)\n * <VideoPlayer\n * source={{\n * type: 'stream',\n * sessionId: 'abc123',\n * path: '/videos/movie.mp4',\n * getStreamUrl: (id, path) => `/api/stream/${id}?path=${path}&token=${token}`\n * }}\n * />\n *\n * @example\n * // HTTP Range streaming (simplified, using VideoPlayerProvider context)\n * <VideoPlayerProvider sessionId={sessionId} getStreamUrl={getStreamUrl}>\n * <VideoPlayer source={{ type: 'stream', path: '/videos/movie.mp4' }} />\n * </VideoPlayerProvider>\n *\n * @example\n * // Blob/ArrayBuffer\n * <VideoPlayer source={{ type: 'blob', data: arrayBuffer, mimeType: 'video/mp4' }} />\n */\n\n'use client';\n\nimport React, { forwardRef, useMemo } from 'react';\n\nimport { VidstackProvider, NativeProvider, StreamProvider } from '../providers';\nimport { useVideoPlayerContext } from '../context';\nimport { resolvePlayerMode, isSimpleStreamSource, resolveStreamSource } from '../utils';\n\nimport type { VideoPlayerProps, VideoPlayerRef, VideoSourceUnion, VidstackProviderProps, NativeProviderProps, StreamProviderProps, SimpleStreamSource } from '../types';\n\nexport const VideoPlayer = forwardRef<VideoPlayerRef, VideoPlayerProps & { source: VideoSourceUnion | SimpleStreamSource }>(\n (\n {\n source: rawSource,\n mode = 'auto',\n aspectRatio = 16 / 9,\n autoPlay = false,\n muted = false,\n loop = false,\n playsInline = true,\n controls = true,\n preload = 'metadata',\n theme = 'default',\n showInfo = false,\n className,\n videoClassName,\n disableContextMenu = false,\n showPreloader = true,\n preloaderTimeout = 5000,\n errorFallback,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n },\n ref\n ) => {\n // Get context for simplified stream sources\n const context = useVideoPlayerContext();\n\n // Resolve simplified stream source to full source using context\n const source = useMemo(() => {\n if (isSimpleStreamSource(rawSource)) {\n const resolved = resolveStreamSource(rawSource, context);\n if (!resolved) {\n // Return a special error source that will trigger error fallback\n return null;\n }\n return resolved;\n }\n return rawSource;\n }, [rawSource, context]);\n\n // Handle unresolved source\n if (!source) {\n // Render error state\n const errorMessage = 'Stream source requires VideoPlayerProvider with getStreamUrl and sessionId';\n\n if (typeof errorFallback === 'function') {\n return (\n <div className={className} style={{ aspectRatio: aspectRatio === 'fill' ? undefined : aspectRatio }}>\n {errorFallback({ error: errorMessage })}\n </div>\n );\n }\n\n if (errorFallback) {\n return (\n <div className={className} style={{ aspectRatio: aspectRatio === 'fill' ? undefined : aspectRatio }}>\n {errorFallback}\n </div>\n );\n }\n\n // Default error UI\n return (\n <div\n className={className}\n style={{\n aspectRatio: aspectRatio === 'fill' ? undefined : aspectRatio,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: 'black',\n color: 'white',\n }}\n >\n <p>{errorMessage}</p>\n </div>\n );\n }\n\n // Determine which provider to use\n const resolvedMode = resolvePlayerMode(source, mode);\n\n // Common props for all providers\n const commonProps = {\n aspectRatio,\n autoPlay,\n muted,\n loop,\n playsInline,\n controls,\n preload,\n className,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n };\n\n // Render appropriate provider\n switch (resolvedMode) {\n case 'vidstack':\n return (\n <VidstackProvider\n ref={ref}\n source={source as VidstackProviderProps['source']}\n theme={theme}\n showInfo={showInfo}\n errorFallback={errorFallback}\n {...commonProps}\n />\n );\n\n case 'streaming':\n return (\n <StreamProvider\n ref={ref}\n source={source as StreamProviderProps['source']}\n videoClassName={videoClassName}\n disableContextMenu={disableContextMenu}\n showPreloader={showPreloader}\n preloaderTimeout={preloaderTimeout}\n errorFallback={errorFallback}\n {...commonProps}\n />\n );\n\n case 'native':\n default:\n return (\n <NativeProvider\n ref={ref}\n source={source as NativeProviderProps['source']}\n videoClassName={videoClassName}\n disableContextMenu={disableContextMenu}\n showPreloader={showPreloader}\n preloaderTimeout={preloaderTimeout}\n {...commonProps}\n />\n );\n }\n }\n);\n\nVideoPlayer.displayName = 'VideoPlayer';\n","/**\n * Custom Video Controls for Vidstack Player\n */\n\n'use client';\n\nimport { Maximize, Minimize, Pause, Play, Volume2, VolumeX } from 'lucide-react';\nimport React from 'react';\n\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { useMediaRemote, useMediaStore } from '@vidstack/react';\n\nimport type { MediaPlayerInstance } from '@vidstack/react';\ninterface VideoControlsProps {\n player: React.RefObject<MediaPlayerInstance | null>;\n className?: string;\n}\n\nexport function VideoControls({ player, className }: VideoControlsProps) {\n const store = useMediaStore(player);\n const remote = useMediaRemote();\n\n const isPaused = store.paused;\n const isMuted = store.muted;\n const isFullscreen = store.fullscreen;\n const currentTime = store.currentTime;\n const duration = store.duration;\n const volume = store.volume;\n\n const formatTime = (seconds: number): string => {\n if (!seconds || seconds < 0) return '0:00';\n const minutes = Math.floor(seconds / 60);\n const secs = Math.floor(seconds % 60);\n return `${minutes}:${secs.toString().padStart(2, '0')}`;\n };\n\n const handleProgressClick = (e: React.MouseEvent<HTMLDivElement>) => {\n if (!duration) return;\n const rect = e.currentTarget.getBoundingClientRect();\n const clickX = e.clientX - rect.left;\n const percentage = clickX / rect.width;\n const newTime = percentage * duration;\n remote.seek(newTime);\n };\n\n const handleVolumeChange = (e: React.MouseEvent<HTMLDivElement>) => {\n const rect = e.currentTarget.getBoundingClientRect();\n const clickX = e.clientX - rect.left;\n const percentage = Math.max(0, Math.min(1, clickX / rect.width));\n remote.changeVolume(percentage);\n if (percentage > 0 && isMuted) {\n remote.toggleMuted();\n }\n };\n\n const progress = duration > 0 ? (currentTime / duration) * 100 : 0;\n\n return (\n <div\n className={cn(\n \"absolute inset-0 flex flex-col justify-end transition-opacity duration-300\",\n \"bg-gradient-to-t from-black/80 via-black/20 to-transparent\",\n \"opacity-0 group-hover:opacity-100 focus-within:opacity-100\",\n \"pointer-events-none group-hover:pointer-events-auto\",\n className\n )}\n >\n {/* Progress Bar */}\n <div className=\"px-4 pb-2 pointer-events-auto\">\n <div\n className=\"h-1.5 bg-white/20 rounded-full cursor-pointer hover:h-2 transition-all group\"\n onClick={handleProgressClick}\n >\n <div\n className=\"h-full bg-primary rounded-full transition-all relative group-hover:bg-primary/90\"\n style={{ width: `${progress}%` }}\n >\n <div className=\"absolute right-0 top-1/2 -translate-y-1/2 w-3 h-3 bg-white rounded-full opacity-0 group-hover:opacity-100 transition-opacity\" />\n </div>\n </div>\n </div>\n\n {/* Control Bar */}\n <div className=\"flex items-center gap-4 px-4 pb-4 pointer-events-auto\">\n {/* Play/Pause */}\n <button\n onClick={() => remote.togglePaused()}\n className=\"text-white hover:text-primary transition-colors p-1.5 hover:bg-white/10 rounded-full\"\n >\n {isPaused ? <Play className=\"h-6 w-6\" /> : <Pause className=\"h-6 w-6\" />}\n </button>\n\n {/* Time */}\n <div className=\"text-white text-sm font-medium\">\n {formatTime(currentTime)} / {formatTime(duration)}\n </div>\n\n <div className=\"flex-1\" />\n\n {/* Volume Control */}\n <div className=\"flex items-center gap-2 group/volume\">\n <button\n onClick={() => remote.toggleMuted()}\n className=\"text-white hover:text-primary transition-colors p-1.5 hover:bg-white/10 rounded-full\"\n >\n {isMuted || volume === 0 ? (\n <VolumeX className=\"h-5 w-5\" />\n ) : (\n <Volume2 className=\"h-5 w-5\" />\n )}\n </button>\n\n <div\n className=\"w-0 group-hover/volume:w-20 transition-all overflow-hidden\"\n >\n <div\n className=\"h-1.5 bg-white/20 rounded-full cursor-pointer hover:h-2 transition-all\"\n onClick={handleVolumeChange}\n >\n <div\n className=\"h-full bg-white rounded-full transition-all\"\n style={{ width: `${volume * 100}%` }}\n />\n </div>\n </div>\n </div>\n\n {/* Fullscreen */}\n <button\n onClick={() => isFullscreen ? remote.exitFullscreen() : remote.enterFullscreen()}\n className=\"text-white hover:text-primary transition-colors p-1.5 hover:bg-white/10 rounded-full\"\n >\n {isFullscreen ? <Minimize className=\"h-5 w-5\" /> : <Maximize className=\"h-5 w-5\" />}\n </button>\n </div>\n </div>\n );\n}\n","/**\n * VideoErrorFallback - Pre-built error fallback with download button\n * For use with VideoPlayer errorFallback prop\n */\n\n'use client';\n\nimport React from 'react';\nimport { FileVideo, RefreshCw } from 'lucide-react';\n\nimport { cn, Button, DownloadButton } from '../../_shared';\n\nimport type { ErrorFallbackProps } from '../types';\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport interface VideoErrorFallbackProps extends ErrorFallbackProps {\n /** URL for download button (if provided, shows download button) */\n downloadUrl?: string;\n /** Filename for download */\n downloadFilename?: string;\n /** File size to display */\n fileSize?: string;\n /** Show retry button */\n showRetry?: boolean;\n /** Custom className */\n className?: string;\n /** Custom icon */\n icon?: React.ReactNode;\n /** Custom title (defaults to error message) */\n title?: string;\n /** Custom description */\n description?: string;\n}\n\n// ============================================================================\n// Component\n// ============================================================================\n\n/**\n * Pre-built error fallback component for VideoPlayer\n *\n * @example\n * // Basic usage\n * <VideoPlayer\n * source={source}\n * errorFallback={(props) => (\n * <VideoErrorFallback\n * {...props}\n * downloadUrl={getDownloadUrl()}\n * downloadFilename=\"video.mp4\"\n * />\n * )}\n * />\n *\n * @example\n * // With file size\n * <VideoErrorFallback\n * error=\"Failed to load video\"\n * downloadUrl=\"/api/download/video.mp4\"\n * fileSize=\"125 MB\"\n * showRetry\n * retry={() => reloadVideo()}\n * />\n */\nexport function VideoErrorFallback({\n error,\n retry,\n downloadUrl,\n downloadFilename,\n fileSize,\n showRetry = true,\n className,\n icon,\n title,\n description,\n}: VideoErrorFallbackProps) {\n const displayTitle = title || error || 'Video cannot be previewed';\n\n return (\n <div\n className={cn(\n 'absolute inset-0 flex flex-col items-center justify-center gap-4 bg-black/90 text-white p-6',\n className\n )}\n >\n {/* Icon */}\n {icon || <FileVideo className=\"w-16 h-16 text-muted-foreground\" />}\n\n {/* Title */}\n <p className=\"text-lg font-medium text-center\">{displayTitle}</p>\n\n {/* Description / File size */}\n {(description || fileSize) && (\n <p className=\"text-sm text-muted-foreground text-center\">\n {description || fileSize}\n </p>\n )}\n\n {/* Actions */}\n <div className=\"flex items-center gap-3 mt-2\">\n {/* Retry button */}\n {showRetry && retry && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={retry}\n className=\"gap-2\"\n >\n <RefreshCw className=\"w-4 h-4\" />\n Retry\n </Button>\n )}\n\n {/* Download button */}\n {downloadUrl && (\n <DownloadButton\n url={downloadUrl}\n filename={downloadFilename}\n variant=\"default\"\n size=\"sm\"\n >\n Download to view\n </DownloadButton>\n )}\n </div>\n </div>\n );\n}\n\n// ============================================================================\n// Factory for common use cases\n// ============================================================================\n\nexport interface CreateVideoErrorFallbackOptions {\n /** Function to get download URL from source */\n getDownloadUrl?: (source: unknown) => string | undefined;\n /** Function to get filename from source */\n getFilename?: (source: unknown) => string | undefined;\n /** Function to get file size from source */\n getFileSize?: (source: unknown) => string | undefined;\n /** Show retry button */\n showRetry?: boolean;\n}\n\n/**\n * Factory to create error fallback function for VideoPlayer\n *\n * @example\n * const errorFallback = createVideoErrorFallback({\n * getDownloadUrl: (source) => source.downloadUrl,\n * getFilename: (source) => source.filename,\n * showRetry: true,\n * });\n *\n * <VideoPlayer source={source} errorFallback={errorFallback} />\n */\nexport function createVideoErrorFallback(\n options: CreateVideoErrorFallbackOptions\n): (props: ErrorFallbackProps, source?: unknown) => React.ReactNode {\n return (props: ErrorFallbackProps, source?: unknown) => (\n <VideoErrorFallback\n {...props}\n downloadUrl={options.getDownloadUrl?.(source)}\n downloadFilename={options.getFilename?.(source)}\n fileSize={options.getFileSize?.(source)}\n showRetry={options.showRetry}\n />\n );\n}\n","'use client';\n\n/**\n * useHybridAudio - Hybrid audio hook combining HTML5 audio + Web Audio API\n *\n * Uses native HTML5 <audio> for playback (no crackling, native streaming)\n * and Web Audio API only for visualization (AnalyserNode).\n *\n * Audio routing:\n * source -> destination (single path for playback)\n * source -> analyser (parallel path for visualization only, no output)\n */\n\nimport { useRef, useState, useCallback, useEffect } from 'react';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface UseHybridAudioOptions {\n src: string;\n autoPlay?: boolean;\n initialVolume?: number;\n loop?: boolean;\n crossOrigin?: 'anonymous' | 'use-credentials';\n onPlay?: () => void;\n onPause?: () => void;\n onEnded?: () => void;\n onTimeUpdate?: (time: number) => void;\n onError?: (error: Error) => void;\n onReady?: () => void;\n}\n\nexport interface HybridAudioState {\n isReady: boolean;\n isPlaying: boolean;\n currentTime: number;\n duration: number;\n volume: number;\n isMuted: boolean;\n isLooping: boolean;\n buffered: TimeRanges | null;\n error: Error | null;\n}\n\nexport interface HybridAudioControls {\n play: () => Promise<void>;\n pause: () => void;\n togglePlay: () => void;\n seek: (time: number) => void;\n seekTo: (progress: number) => void;\n skip: (seconds: number) => void;\n setVolume: (vol: number) => void;\n toggleMute: () => void;\n toggleLoop: () => void;\n setLoop: (enabled: boolean) => void;\n restart: () => void;\n}\n\nexport interface HybridWebAudioAPI {\n context: AudioContext | null;\n analyser: AnalyserNode | null;\n sourceNode: MediaElementAudioSourceNode | null;\n}\n\nexport interface UseHybridAudioReturn {\n audioRef: React.RefObject<HTMLAudioElement | null>;\n state: HybridAudioState;\n controls: HybridAudioControls;\n webAudio: HybridWebAudioAPI;\n}\n\n// =============================================================================\n// HOOK\n// =============================================================================\n\nexport function useHybridAudio(options: UseHybridAudioOptions): UseHybridAudioReturn {\n const {\n src,\n autoPlay = false,\n initialVolume = 1,\n loop = false,\n crossOrigin = 'anonymous',\n onPlay,\n onPause,\n onEnded,\n onTimeUpdate,\n onError,\n onReady,\n } = options;\n\n // Refs\n const audioRef = useRef<HTMLAudioElement | null>(null);\n const audioContextRef = useRef<AudioContext | null>(null);\n const sourceNodeRef = useRef<MediaElementAudioSourceNode | null>(null);\n const analyserRef = useRef<AnalyserNode | null>(null);\n const connectedElementRef = useRef<HTMLMediaElement | null>(null);\n\n // State\n const [state, setState] = useState<HybridAudioState>({\n isReady: false,\n isPlaying: false,\n currentTime: 0,\n duration: 0,\n volume: initialVolume,\n isMuted: false,\n isLooping: loop,\n buffered: null,\n error: null,\n });\n\n // Initialize Web Audio for visualization (lazy, on first play)\n const initWebAudio = useCallback(() => {\n const audio = audioRef.current;\n if (!audio) return;\n\n // Already connected to this element\n if (connectedElementRef.current === audio && audioContextRef.current) {\n return;\n }\n\n try {\n // Create AudioContext if needed\n if (!audioContextRef.current) {\n const AudioContextClass =\n window.AudioContext ||\n (window as unknown as { webkitAudioContext: typeof AudioContext }).webkitAudioContext;\n audioContextRef.current = new AudioContextClass();\n }\n\n const ctx = audioContextRef.current;\n\n // Disconnect old source if any\n if (sourceNodeRef.current) {\n try {\n sourceNodeRef.current.disconnect();\n } catch {\n /* ignore */\n }\n }\n\n // Create source from audio element\n const source = ctx.createMediaElementSource(audio);\n sourceNodeRef.current = source;\n\n // Create analyser for visualization\n const analyser = ctx.createAnalyser();\n analyser.fftSize = 256;\n analyser.smoothingTimeConstant = 0.85;\n analyserRef.current = analyser;\n\n // Audio routing:\n // 1. source -> destination (for playback)\n // 2. source -> analyser (for visualization only - NO output!)\n source.connect(ctx.destination);\n source.connect(analyser);\n // NOTE: analyser does NOT connect to destination - prevents double audio!\n\n connectedElementRef.current = audio;\n } catch (error) {\n console.warn('[useHybridAudio] Web Audio init failed:', error);\n }\n }, []);\n\n // Resume AudioContext on user interaction\n const resumeAudioContext = useCallback(async () => {\n const ctx = audioContextRef.current;\n if (ctx && ctx.state === 'suspended') {\n await ctx.resume();\n }\n }, []);\n\n // Controls\n const play = useCallback(async () => {\n const audio = audioRef.current;\n if (!audio) return;\n\n try {\n initWebAudio();\n await resumeAudioContext();\n await audio.play();\n } catch (error) {\n console.error('[useHybridAudio] Play failed:', error);\n onError?.(error as Error);\n }\n }, [initWebAudio, resumeAudioContext, onError]);\n\n const pause = useCallback(() => {\n audioRef.current?.pause();\n }, []);\n\n const togglePlay = useCallback(() => {\n if (state.isPlaying) {\n pause();\n } else {\n play();\n }\n }, [state.isPlaying, play, pause]);\n\n const seek = useCallback(\n (time: number) => {\n const audio = audioRef.current;\n if (audio && isFinite(time)) {\n audio.currentTime = Math.max(0, Math.min(time, state.duration || audio.duration || 0));\n }\n },\n [state.duration]\n );\n\n const seekTo = useCallback(\n (progress: number) => {\n const duration = state.duration || audioRef.current?.duration || 0;\n seek(duration * Math.max(0, Math.min(1, progress)));\n },\n [state.duration, seek]\n );\n\n const skip = useCallback(\n (seconds: number) => {\n seek(state.currentTime + seconds);\n },\n [state.currentTime, seek]\n );\n\n const setVolume = useCallback((vol: number) => {\n const audio = audioRef.current;\n if (audio) {\n const clampedVol = Math.max(0, Math.min(1, vol));\n audio.volume = clampedVol;\n setState((prev) => ({ ...prev, volume: clampedVol }));\n }\n }, []);\n\n const toggleMute = useCallback(() => {\n const audio = audioRef.current;\n if (audio) {\n audio.muted = !audio.muted;\n setState((prev) => ({ ...prev, isMuted: audio.muted }));\n }\n }, []);\n\n const toggleLoop = useCallback(() => {\n const audio = audioRef.current;\n if (audio) {\n audio.loop = !audio.loop;\n setState((prev) => ({ ...prev, isLooping: audio.loop }));\n }\n }, []);\n\n const setLoop = useCallback((enabled: boolean) => {\n const audio = audioRef.current;\n if (audio) {\n audio.loop = enabled;\n setState((prev) => ({ ...prev, isLooping: enabled }));\n }\n }, []);\n\n const restart = useCallback(() => {\n seek(0);\n play();\n }, [seek, play]);\n\n const controls: HybridAudioControls = {\n play,\n pause,\n togglePlay,\n seek,\n seekTo,\n skip,\n setVolume,\n toggleMute,\n toggleLoop,\n setLoop,\n restart,\n };\n\n // Create audio element on mount\n useEffect(() => {\n const audio = document.createElement('audio');\n audio.preload = 'metadata';\n audio.crossOrigin = crossOrigin;\n audio.volume = initialVolume;\n audio.loop = loop;\n audioRef.current = audio;\n\n return () => {\n audio.pause();\n audio.src = '';\n if (audioContextRef.current) {\n audioContextRef.current.close().catch(() => {});\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n // Event handlers\n useEffect(() => {\n const audio = audioRef.current;\n if (!audio) return;\n\n const handlers = {\n loadedmetadata: () => {\n setState((prev) => ({\n ...prev,\n duration: audio.duration,\n isReady: true,\n }));\n onReady?.();\n },\n canplay: () => {\n setState((prev) => ({ ...prev, isReady: true }));\n if (autoPlay) {\n play();\n }\n },\n play: () => {\n setState((prev) => ({ ...prev, isPlaying: true }));\n onPlay?.();\n },\n pause: () => {\n setState((prev) => ({ ...prev, isPlaying: false }));\n onPause?.();\n },\n ended: () => {\n setState((prev) => ({ ...prev, isPlaying: false }));\n onEnded?.();\n },\n timeupdate: () => {\n setState((prev) => ({ ...prev, currentTime: audio.currentTime }));\n onTimeUpdate?.(audio.currentTime);\n },\n progress: () => {\n setState((prev) => ({ ...prev, buffered: audio.buffered }));\n },\n error: () => {\n const error = new Error(audio.error?.message || 'Audio error');\n setState((prev) => ({ ...prev, error }));\n onError?.(error);\n },\n volumechange: () => {\n setState((prev) => ({\n ...prev,\n volume: audio.volume,\n isMuted: audio.muted,\n }));\n },\n };\n\n Object.entries(handlers).forEach(([event, handler]) => {\n audio.addEventListener(event, handler);\n });\n\n return () => {\n Object.entries(handlers).forEach(([event, handler]) => {\n audio.removeEventListener(event, handler);\n });\n };\n }, [autoPlay, onPlay, onPause, onEnded, onTimeUpdate, onError, onReady, play]);\n\n // Load new source\n useEffect(() => {\n const audio = audioRef.current;\n if (!audio || !src) return;\n\n setState((prev) => ({\n ...prev,\n isReady: false,\n currentTime: 0,\n duration: 0,\n error: null,\n }));\n\n audio.src = src;\n audio.load();\n }, [src]);\n\n return {\n audioRef,\n state,\n controls,\n webAudio: {\n context: audioContextRef.current,\n analyser: analyserRef.current,\n sourceNode: sourceNodeRef.current,\n },\n };\n}\n","'use client';\n\n/**\n * useHybridAudioAnalysis - Audio frequency analysis for hybrid player.\n *\n * Simplified version of useAudioAnalysis that works directly with AnalyserNode\n * instead of SharedWebAudioContext.\n */\n\nimport { useState, useRef, useEffect, useCallback } from 'react';\nimport type { AudioLevels } from '../effects';\n\nexport function useHybridAudioAnalysis(\n analyser: AnalyserNode | null,\n isPlaying: boolean\n): AudioLevels {\n const [levels, setLevels] = useState<AudioLevels>({ bass: 0, mid: 0, high: 0, overall: 0 });\n const animationRef = useRef<number | null>(null);\n const dataArrayRef = useRef<Uint8Array<ArrayBuffer> | null>(null);\n\n const cleanup = useCallback(() => {\n if (animationRef.current) {\n cancelAnimationFrame(animationRef.current);\n animationRef.current = null;\n }\n }, []);\n\n // Initialize data array when analyser is available\n useEffect(() => {\n if (analyser && !dataArrayRef.current) {\n dataArrayRef.current = new Uint8Array(analyser.frequencyBinCount) as Uint8Array<ArrayBuffer>;\n }\n }, [analyser]);\n\n // Animation loop\n useEffect(() => {\n if (!isPlaying || !analyser || !dataArrayRef.current) {\n cleanup();\n // Smooth fade out when stopped\n setLevels((prev) => ({\n bass: prev.bass * 0.95 < 0.01 ? 0 : prev.bass * 0.95,\n mid: prev.mid * 0.95 < 0.01 ? 0 : prev.mid * 0.95,\n high: prev.high * 0.95 < 0.01 ? 0 : prev.high * 0.95,\n overall: prev.overall * 0.95 < 0.01 ? 0 : prev.overall * 0.95,\n }));\n return;\n }\n\n const dataArray = dataArrayRef.current;\n\n const animate = () => {\n analyser.getByteFrequencyData(dataArray);\n const binCount = dataArray.length;\n\n // Bass (0-15% of frequency range)\n const bassEnd = Math.floor(binCount * 0.15);\n let bassSum = 0;\n for (let i = 0; i < bassEnd; i++) bassSum += dataArray[i];\n const bass = bassSum / bassEnd / 255;\n\n // Mids (15-50% of frequency range)\n const midStart = bassEnd;\n const midEnd = Math.floor(binCount * 0.5);\n let midSum = 0;\n for (let i = midStart; i < midEnd; i++) midSum += dataArray[i];\n const mid = midSum / (midEnd - midStart) / 255;\n\n // Highs (50-100% of frequency range)\n const highStart = midEnd;\n let highSum = 0;\n for (let i = highStart; i < binCount; i++) highSum += dataArray[i];\n const high = highSum / (binCount - highStart) / 255;\n\n // Overall\n let totalSum = 0;\n for (let i = 0; i < binCount; i++) totalSum += dataArray[i];\n const overall = totalSum / binCount / 255;\n\n // Smooth with lerp for natural feel\n setLevels((prev) => ({\n bass: prev.bass * 0.7 + bass * 0.3,\n mid: prev.mid * 0.7 + mid * 0.3,\n high: prev.high * 0.7 + high * 0.3,\n overall: prev.overall * 0.7 + overall * 0.3,\n }));\n\n animationRef.current = requestAnimationFrame(animate);\n };\n\n animationRef.current = requestAnimationFrame(animate);\n return cleanup;\n }, [analyser, isPlaying, cleanup]);\n\n return levels;\n}\n","'use client';\n\n/**\n * useVisualization - Hook for managing audio visualization settings\n *\n * Persists settings in localStorage for user preferences\n * Uses React Context for shared state between components\n */\n\nimport { createContext, useContext, useCallback, useMemo, type ReactNode } from 'react';\nimport { useLocalStorage } from '../../_shared';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport type VisualizationVariant = 'glow' | 'orbs' | 'spotlight' | 'mesh' | 'none';\nexport type VisualizationIntensity = 'subtle' | 'medium' | 'strong';\nexport type VisualizationColorScheme = 'primary' | 'vibrant' | 'cool' | 'warm';\n\nexport interface VisualizationSettings {\n /** Enable reactive cover animation */\n enabled: boolean;\n /** Visual effect variant */\n variant: VisualizationVariant;\n /** Effect intensity */\n intensity: VisualizationIntensity;\n /** Color scheme */\n colorScheme: VisualizationColorScheme;\n /** Playback volume (0-1) */\n volume: number;\n /** Loop playback */\n isLooping: boolean;\n}\n\nexport interface UseVisualizationReturn {\n /** Current settings */\n settings: VisualizationSettings;\n /** Toggle visualization on/off */\n toggle: () => void;\n /** Set specific setting */\n setSetting: <K extends keyof VisualizationSettings>(\n key: K,\n value: VisualizationSettings[K]\n ) => void;\n /** Cycle to next variant */\n nextVariant: () => void;\n /** Cycle to next intensity */\n nextIntensity: () => void;\n /** Cycle to next color scheme */\n nextColorScheme: () => void;\n /** Reset to defaults */\n reset: () => void;\n}\n\n// Backward compatibility alias\nexport type UseAudioVisualizationReturn = UseVisualizationReturn;\n\n// =============================================================================\n// CONSTANTS\n// =============================================================================\n\nconst STORAGE_KEY = 'audio-player-settings';\n\nconst DEFAULT_SETTINGS: VisualizationSettings = {\n enabled: true,\n variant: 'spotlight',\n intensity: 'medium',\n colorScheme: 'primary',\n volume: 1,\n isLooping: false,\n};\n\nconst VARIANTS: VisualizationVariant[] = ['spotlight', 'glow', 'orbs', 'mesh', 'none'];\nconst INTENSITIES: VisualizationIntensity[] = ['subtle', 'medium', 'strong'];\nconst COLOR_SCHEMES: VisualizationColorScheme[] = ['primary', 'vibrant', 'cool', 'warm'];\n\n// =============================================================================\n// CONTEXT\n// =============================================================================\n\nconst VisualizationContext = createContext<UseVisualizationReturn | null>(null);\n\n// =============================================================================\n// PROVIDER\n// =============================================================================\n\nexport interface VisualizationProviderProps {\n children: ReactNode;\n}\n\nexport function VisualizationProvider({ children }: VisualizationProviderProps) {\n const value = useVisualizationState();\n return (\n <VisualizationContext.Provider value={value}>\n {children}\n </VisualizationContext.Provider>\n );\n}\n\n// =============================================================================\n// INTERNAL HOOK (creates the actual state)\n// =============================================================================\n\nfunction useVisualizationState(): UseVisualizationReturn {\n const [settings, setSettings] = useLocalStorage<VisualizationSettings>(\n STORAGE_KEY,\n DEFAULT_SETTINGS\n );\n\n const toggle = useCallback(() => {\n setSettings((prev) => ({ ...prev, enabled: !prev.enabled }));\n }, [setSettings]);\n\n const setSetting = useCallback(\n <K extends keyof VisualizationSettings>(\n key: K,\n value: VisualizationSettings[K]\n ) => {\n setSettings((prev) => ({ ...prev, [key]: value }));\n },\n [setSettings]\n );\n\n const nextVariant = useCallback(() => {\n setSettings((prev) => {\n const currentIndex = VARIANTS.indexOf(prev.variant);\n const nextIndex = (currentIndex + 1) % VARIANTS.length;\n return { ...prev, variant: VARIANTS[nextIndex] };\n });\n }, [setSettings]);\n\n const nextIntensity = useCallback(() => {\n setSettings((prev) => {\n const currentIndex = INTENSITIES.indexOf(prev.intensity);\n const nextIndex = (currentIndex + 1) % INTENSITIES.length;\n return { ...prev, intensity: INTENSITIES[nextIndex] };\n });\n }, [setSettings]);\n\n const nextColorScheme = useCallback(() => {\n setSettings((prev) => {\n const currentIndex = COLOR_SCHEMES.indexOf(prev.colorScheme);\n const nextIndex = (currentIndex + 1) % COLOR_SCHEMES.length;\n return { ...prev, colorScheme: COLOR_SCHEMES[nextIndex] };\n });\n }, [setSettings]);\n\n const reset = useCallback(() => {\n setSettings(DEFAULT_SETTINGS);\n }, [setSettings]);\n\n return useMemo(\n () => ({\n settings,\n toggle,\n setSetting,\n nextVariant,\n nextIntensity,\n nextColorScheme,\n reset,\n }),\n [settings, toggle, setSetting, nextVariant, nextIntensity, nextColorScheme, reset]\n );\n}\n\n// =============================================================================\n// HOOK (uses context when available)\n// =============================================================================\n\nexport function useVisualization(): UseVisualizationReturn {\n const context = useContext(VisualizationContext);\n\n // Always call the fallback hooks (React hooks rules require consistent calls)\n const fallbackState = useVisualizationState();\n\n // If inside a provider, use shared context; otherwise use fallback\n return context ?? fallbackState;\n}\n\n// Backward compatibility alias\nexport const useAudioVisualization = useVisualization;\n\n// =============================================================================\n// VARIANT INFO\n// =============================================================================\n\nexport const VARIANT_INFO: Record<VisualizationVariant, { label: string; icon: string }> = {\n spotlight: { label: 'Spotlight', icon: '💫' },\n glow: { label: 'Glow', icon: '✨' },\n orbs: { label: 'Orbs', icon: '🔮' },\n mesh: { label: 'Mesh', icon: '🌈' },\n none: { label: 'Off', icon: '⭕' },\n};\n\nexport const INTENSITY_INFO: Record<VisualizationIntensity, { label: string }> = {\n subtle: { label: 'Subtle' },\n medium: { label: 'Medium' },\n strong: { label: 'Strong' },\n};\n\nexport const COLOR_SCHEME_INFO: Record<VisualizationColorScheme, { label: string; preview: string }> = {\n primary: { label: 'Primary', preview: '🔵' },\n vibrant: { label: 'Vibrant', preview: '🌈' },\n cool: { label: 'Cool', preview: '💙' },\n warm: { label: 'Warm', preview: '🔥' },\n};\n","'use client';\n\n/**\n * HybridAudioProvider - Context provider for hybrid audio player.\n *\n * Provides audio state, controls, and analysis data to child components.\n * Uses native HTML5 audio for playback with Web Audio API for visualization only.\n */\n\nimport { createContext, useContext, useMemo, useEffect, useRef, type ReactNode } from 'react';\nimport {\n useHybridAudio,\n type UseHybridAudioOptions,\n type HybridAudioState,\n type HybridAudioControls,\n type HybridWebAudioAPI,\n} from '../hooks/useHybridAudio';\nimport { useHybridAudioAnalysis } from '../hooks/useHybridAudioAnalysis';\nimport { useVisualization } from '../hooks/useVisualization';\nimport type { AudioLevels } from '../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface HybridAudioContextValue {\n // Audio state\n state: HybridAudioState;\n\n // Controls\n controls: HybridAudioControls;\n\n // Web Audio (for visualizations)\n webAudio: HybridWebAudioAPI;\n\n // Audio levels (for reactive effects)\n audioLevels: AudioLevels;\n\n // Audio element ref (for custom integrations)\n audioRef: React.RefObject<HTMLAudioElement | null>;\n}\n\n// =============================================================================\n// CONTEXT\n// =============================================================================\n\nconst HybridAudioContext = createContext<HybridAudioContextValue | null>(null);\n\n// =============================================================================\n// PROVIDER\n// =============================================================================\n\nexport interface HybridAudioProviderProps extends UseHybridAudioOptions {\n children: ReactNode;\n}\n\nexport function HybridAudioProvider({ children, ...options }: HybridAudioProviderProps) {\n // Load persisted settings (shared with visualization)\n const { settings: savedSettings, setSetting } = useVisualization();\n\n // Use saved settings as initial values\n const effectiveOptions = {\n ...options,\n initialVolume: savedSettings.volume,\n loop: savedSettings.isLooping,\n };\n\n const { audioRef, state, controls, webAudio } = useHybridAudio(effectiveOptions);\n\n // Track if we've applied initial settings\n const hasAppliedInitialSettings = useRef(false);\n\n // Apply saved settings after audio is ready (for hydration timing)\n useEffect(() => {\n if (!state.isReady || hasAppliedInitialSettings.current) return;\n hasAppliedInitialSettings.current = true;\n\n // Apply saved volume and loop settings\n controls.setVolume(savedSettings.volume);\n controls.setLoop(savedSettings.isLooping);\n }, [state.isReady, savedSettings, controls]);\n\n // Persist settings when they change\n useEffect(() => {\n if (!state.isReady) return;\n\n // Only save if values actually changed\n if (state.volume !== savedSettings.volume) {\n setSetting('volume', state.volume);\n }\n if (state.isLooping !== savedSettings.isLooping) {\n setSetting('isLooping', state.isLooping);\n }\n }, [state.isReady, state.volume, state.isLooping, savedSettings, setSetting]);\n\n // Audio analysis for reactive effects\n const audioLevels = useHybridAudioAnalysis(webAudio.analyser, state.isPlaying);\n\n const value = useMemo<HybridAudioContextValue>(\n () => ({\n state,\n controls,\n webAudio,\n audioLevels,\n audioRef,\n }),\n [state, controls, webAudio, audioLevels, audioRef]\n );\n\n return <HybridAudioContext.Provider value={value}>{children}</HybridAudioContext.Provider>;\n}\n\n// =============================================================================\n// HOOKS\n// =============================================================================\n\n/**\n * Access full hybrid audio context\n */\nexport function useHybridAudioContext(): HybridAudioContextValue {\n const context = useContext(HybridAudioContext);\n if (!context) {\n throw new Error('useHybridAudioContext must be used within HybridAudioProvider');\n }\n return context;\n}\n\n/**\n * Access audio state only (read-only)\n */\nexport function useHybridAudioState(): HybridAudioState {\n const { state } = useHybridAudioContext();\n return state;\n}\n\n/**\n * Access audio controls only (no state re-renders)\n */\nexport function useHybridAudioControls(): HybridAudioControls {\n const { controls } = useHybridAudioContext();\n return controls;\n}\n\n/**\n * Access audio levels for reactive effects\n */\nexport function useHybridAudioLevels(): AudioLevels {\n const { audioLevels } = useHybridAudioContext();\n return audioLevels;\n}\n\n/**\n * Access Web Audio API for custom visualizations\n */\nexport function useHybridWebAudio(): HybridWebAudioAPI {\n const { webAudio } = useHybridAudioContext();\n return webAudio;\n}\n","'use client';\n\n/**\n * HybridWaveform - Real-time frequency visualization for hybrid player.\n *\n * Two modes:\n * - 'frequency': Real-time frequency bars (default, requires playing audio)\n * - 'static': Static progress bar (for when no analyser is available)\n *\n * Features:\n * - Shows buffered regions\n * - Click to seek\n * - Responsive width\n */\n\nimport { useRef, useEffect, useCallback, memo } from 'react';\nimport { useHybridAudioContext } from '../context/HybridAudioProvider';\nimport { cn } from '@djangocfg/ui-core/lib';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface HybridWaveformProps {\n /** Visualization mode */\n mode?: 'frequency' | 'static';\n /** Canvas height in pixels */\n height?: number;\n /** Bar width in pixels */\n barWidth?: number;\n /** Gap between bars in pixels */\n barGap?: number;\n /** Bar border radius */\n barRadius?: number;\n /** Color for played portion */\n progressColor?: string;\n /** Color for unplayed portion */\n waveColor?: string;\n /** Color for buffered regions indicator */\n bufferedColor?: string;\n /** Additional CSS class */\n className?: string;\n /** Callback when user seeks */\n onSeek?: (time: number) => void;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport const HybridWaveform = memo(function HybridWaveform({\n mode = 'frequency',\n height = 64,\n barWidth = 3,\n barGap = 2,\n barRadius = 2,\n progressColor = 'hsl(217 91% 60%)',\n waveColor = 'hsl(217 91% 60% / 0.3)',\n bufferedColor = 'hsl(217 91% 60% / 0.15)',\n className,\n onSeek,\n}: HybridWaveformProps) {\n const canvasRef = useRef<HTMLCanvasElement>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const animationRef = useRef<number | null>(null);\n const { state, controls, webAudio } = useHybridAudioContext();\n\n // Handle click to seek\n const handleClick = useCallback(\n (e: React.MouseEvent<HTMLCanvasElement>) => {\n const canvas = canvasRef.current;\n if (!canvas || !state.duration) return;\n\n const rect = canvas.getBoundingClientRect();\n const x = e.clientX - rect.left;\n const progress = x / rect.width;\n const time = state.duration * progress;\n\n controls.seek(time);\n onSeek?.(time);\n },\n [state.duration, controls, onSeek]\n );\n\n // Render frequency bars (real-time visualization)\n const renderFrequency = useCallback(() => {\n const canvas = canvasRef.current;\n const analyser = webAudio.analyser;\n if (!canvas) return;\n\n const ctx = canvas.getContext('2d');\n if (!ctx) return;\n\n const { width, height: canvasHeight } = canvas;\n const dpr = window.devicePixelRatio || 1;\n const displayWidth = width / dpr;\n\n // Get frequency data if analyser is available\n let dataArray: Uint8Array<ArrayBuffer> | null = null;\n if (analyser) {\n dataArray = new Uint8Array(analyser.frequencyBinCount) as Uint8Array<ArrayBuffer>;\n analyser.getByteFrequencyData(dataArray);\n }\n\n ctx.clearRect(0, 0, width, canvasHeight);\n\n // Draw buffered regions at bottom\n if (state.buffered && state.duration > 0) {\n ctx.fillStyle = bufferedColor;\n for (let i = 0; i < state.buffered.length; i++) {\n const start = (state.buffered.start(i) / state.duration) * width;\n const end = (state.buffered.end(i) / state.duration) * width;\n ctx.fillRect(start, canvasHeight - 3 * dpr, end - start, 3 * dpr);\n }\n }\n\n // Calculate bar count based on available width\n const barCount = Math.floor(displayWidth / (barWidth + barGap));\n const progress = state.duration > 0 ? state.currentTime / state.duration : 0;\n const progressX = width * progress;\n\n // Draw bars\n for (let i = 0; i < barCount; i++) {\n let barHeight: number;\n\n if (dataArray && state.isPlaying) {\n // Real-time frequency data\n const step = Math.floor(dataArray.length / barCount);\n const value = dataArray[i * step] / 255;\n barHeight = Math.max(4 * dpr, value * (canvasHeight - 6 * dpr) * 0.9);\n } else {\n // Static fallback - small bars\n barHeight = 8 * dpr;\n }\n\n const x = i * (barWidth + barGap) * dpr;\n const y = (canvasHeight - barHeight) / 2;\n\n ctx.fillStyle = x < progressX ? progressColor : waveColor;\n\n // Draw rounded rect\n const radius = barRadius * dpr;\n const rectWidth = barWidth * dpr;\n ctx.beginPath();\n ctx.roundRect(x, y, rectWidth, barHeight, radius);\n ctx.fill();\n }\n\n // Continue animation if playing\n if (state.isPlaying) {\n animationRef.current = requestAnimationFrame(renderFrequency);\n }\n }, [\n webAudio.analyser,\n state.buffered,\n state.duration,\n state.currentTime,\n state.isPlaying,\n barWidth,\n barGap,\n barRadius,\n progressColor,\n waveColor,\n bufferedColor,\n ]);\n\n // Render static progress bar\n const renderStatic = useCallback(() => {\n const canvas = canvasRef.current;\n if (!canvas) return;\n\n const ctx = canvas.getContext('2d');\n if (!ctx) return;\n\n const { width, height: canvasHeight } = canvas;\n const dpr = window.devicePixelRatio || 1;\n\n ctx.clearRect(0, 0, width, canvasHeight);\n\n // Draw buffered regions\n if (state.buffered && state.duration > 0) {\n ctx.fillStyle = bufferedColor;\n for (let i = 0; i < state.buffered.length; i++) {\n const start = (state.buffered.start(i) / state.duration) * width;\n const end = (state.buffered.end(i) / state.duration) * width;\n ctx.fillRect(start, 0, end - start, canvasHeight);\n }\n }\n\n // Draw progress bar\n const progress = state.duration > 0 ? state.currentTime / state.duration : 0;\n const progressWidth = width * progress;\n\n // Background\n ctx.fillStyle = waveColor;\n ctx.fillRect(0, canvasHeight / 2 - 2 * dpr, width, 4 * dpr);\n\n // Progress\n ctx.fillStyle = progressColor;\n ctx.fillRect(0, canvasHeight / 2 - 2 * dpr, progressWidth, 4 * dpr);\n\n // Handle\n if (progress > 0) {\n ctx.beginPath();\n ctx.arc(progressWidth, canvasHeight / 2, 6 * dpr, 0, Math.PI * 2);\n ctx.fill();\n }\n }, [state.buffered, state.duration, state.currentTime, progressColor, waveColor, bufferedColor]);\n\n // Resize canvas to match container\n useEffect(() => {\n const container = containerRef.current;\n const canvas = canvasRef.current;\n if (!container || !canvas) return;\n\n const resizeObserver = new ResizeObserver((entries) => {\n const entry = entries[0];\n if (!entry) return;\n\n const dpr = window.devicePixelRatio || 1;\n const displayWidth = entry.contentRect.width;\n const displayHeight = height;\n\n canvas.width = displayWidth * dpr;\n canvas.height = displayHeight * dpr;\n canvas.style.width = `${displayWidth}px`;\n canvas.style.height = `${displayHeight}px`;\n\n // Re-render after resize\n if (mode === 'frequency') {\n renderFrequency();\n } else {\n renderStatic();\n }\n });\n\n resizeObserver.observe(container);\n return () => resizeObserver.disconnect();\n }, [height, mode, renderFrequency, renderStatic]);\n\n // Animation loop for frequency mode\n useEffect(() => {\n if (mode === 'frequency') {\n renderFrequency();\n }\n\n return () => {\n if (animationRef.current) {\n cancelAnimationFrame(animationRef.current);\n }\n };\n }, [mode, renderFrequency]);\n\n // Re-render on time change for static mode\n useEffect(() => {\n if (mode === 'static') {\n renderStatic();\n }\n }, [mode, state.currentTime, renderStatic]);\n\n // Re-render frequency when playback state changes\n useEffect(() => {\n if (mode === 'frequency' && !state.isPlaying) {\n // One final render when stopped\n renderFrequency();\n }\n }, [mode, state.isPlaying, renderFrequency]);\n\n return (\n <div ref={containerRef} className={cn('w-full', className)}>\n <canvas\n ref={canvasRef}\n onClick={handleClick}\n className=\"cursor-pointer\"\n style={{ width: '100%', height }}\n />\n </div>\n );\n});\n","/**\n * formatTime - Format seconds to mm:ss string\n */\n\nexport function formatTime(seconds: number): string {\n if (!seconds || !isFinite(seconds) || seconds < 0) return '0:00';\n const mins = Math.floor(seconds / 60);\n const secs = Math.floor(seconds % 60);\n return `${mins}:${secs.toString().padStart(2, '0')}`;\n}\n","'use client';\n\n/**\n * AudioPlayer Debug Logger\n *\n * Uses universal logger with media-specific helpers.\n * Logs go to both console (dev) and zustand store (for Console panel).\n */\n\nimport { createMediaLogger } from '@djangocfg/ui-core/lib';\n\nexport const audioDebug = createMediaLogger('AudioPlayer');\n\nexport default audioDebug;\n","'use client';\n\n/**\n * HybridAudioPlayer - Audio playback controls with frequency visualization\n *\n * Uses HybridAudioContext for state management.\n * Native HTML5 audio for playback, Web Audio API for visualization only.\n *\n * Features:\n * - Real-time frequency visualization\n * - Playback controls (play, pause, skip, restart)\n * - Volume control with mute\n * - Loop toggle\n * - Keyboard shortcuts\n * - Timer display\n */\n\nimport { memo } from 'react';\nimport {\n Play,\n Pause,\n RotateCcw,\n SkipBack,\n SkipForward,\n Volume2,\n VolumeX,\n Loader2,\n Repeat,\n} from 'lucide-react';\nimport { Button, Slider, cn } from '../../_shared';\nimport { useHybridAudioContext } from '../context/HybridAudioProvider';\nimport { HybridWaveform } from './HybridWaveform';\nimport { formatTime } from '../utils';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface HybridAudioPlayerProps {\n /** Show playback controls */\n showControls?: boolean;\n /** Show frequency waveform */\n showWaveform?: boolean;\n /** Waveform visualization mode */\n waveformMode?: 'frequency' | 'static';\n /** Waveform height in pixels */\n waveformHeight?: number;\n /** Show time display */\n showTimer?: boolean;\n /** Show volume control */\n showVolume?: boolean;\n /** Show loop button */\n showLoop?: boolean;\n /** Additional CSS class */\n className?: string;\n /** Inline styles */\n style?: React.CSSProperties;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport const HybridAudioPlayer = memo(function HybridAudioPlayer({\n showControls = true,\n showWaveform = true,\n waveformMode = 'frequency',\n waveformHeight = 64,\n showTimer = true,\n showVolume = true,\n showLoop = true,\n className,\n style,\n}: HybridAudioPlayerProps) {\n const { state, controls } = useHybridAudioContext();\n\n const isLoading = !state.isReady;\n\n const handleVolumeChange = (value: number[]) => {\n controls.setVolume(value[0] / 100);\n };\n\n return (\n <div\n className={cn('flex flex-col gap-3 p-4 rounded-lg bg-card border', className)}\n style={style}\n >\n {/* Frequency Waveform */}\n {showWaveform && (\n <div className=\"relative\">\n <HybridWaveform\n mode={waveformMode}\n height={waveformHeight}\n className={cn(isLoading && 'opacity-50')}\n />\n {isLoading && (\n <div className=\"absolute inset-0 flex items-center justify-center\">\n <Loader2 className=\"h-6 w-6 animate-spin text-primary\" />\n </div>\n )}\n </div>\n )}\n\n {/* Timer */}\n {showTimer && (\n <div className=\"flex justify-between text-xs text-muted-foreground tabular-nums px-1\">\n <span>{formatTime(state.currentTime)}</span>\n <span>{formatTime(state.duration)}</span>\n </div>\n )}\n\n {/* Controls */}\n {showControls && (\n <div className=\"flex items-center justify-center gap-1\">\n {/* Restart */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-9 w-9\"\n onClick={controls.restart}\n disabled={!state.isReady}\n title=\"Restart\"\n >\n <RotateCcw className=\"h-4 w-4\" />\n </Button>\n\n {/* Skip back 5s */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-9 w-9\"\n onClick={() => controls.skip(-5)}\n disabled={!state.isReady}\n title=\"Back 5 seconds\"\n >\n <SkipBack className=\"h-4 w-4\" />\n </Button>\n\n {/* Play/Pause */}\n <Button\n variant=\"default\"\n size=\"icon\"\n className=\"h-12 w-12 rounded-full\"\n onClick={controls.togglePlay}\n disabled={!state.isReady && !isLoading}\n title={state.isPlaying ? 'Pause' : 'Play'}\n >\n {isLoading ? (\n <Loader2 className=\"h-5 w-5 animate-spin\" />\n ) : state.isPlaying ? (\n <Pause className=\"h-5 w-5\" />\n ) : (\n <Play className=\"h-5 w-5 ml-0.5\" />\n )}\n </Button>\n\n {/* Skip forward 5s */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-9 w-9\"\n onClick={() => controls.skip(5)}\n disabled={!state.isReady}\n title=\"Forward 5 seconds\"\n >\n <SkipForward className=\"h-4 w-4\" />\n </Button>\n\n {/* Volume */}\n {showVolume && (\n <>\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-9 w-9\"\n onClick={controls.toggleMute}\n title={state.isMuted ? 'Unmute' : 'Mute'}\n >\n {state.isMuted || state.volume === 0 ? (\n <VolumeX className=\"h-4 w-4\" />\n ) : (\n <Volume2 className=\"h-4 w-4\" />\n )}\n </Button>\n\n <Slider\n value={[state.isMuted ? 0 : state.volume * 100]}\n max={100}\n step={1}\n onValueChange={handleVolumeChange}\n className=\"w-20\"\n aria-label=\"Volume\"\n />\n </>\n )}\n\n {/* Loop/Repeat */}\n {showLoop && (\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className={cn('h-9 w-9', state.isLooping && 'text-primary')}\n onClick={controls.toggleLoop}\n disabled={!state.isReady}\n title={state.isLooping ? 'Disable loop' : 'Enable loop'}\n >\n <Repeat className=\"h-4 w-4\" />\n </Button>\n )}\n </div>\n )}\n </div>\n );\n});\n\nexport default HybridAudioPlayer;\n","/**\n * Audio Reactive Effects - Common utilities and types\n *\n * Provides reusable effect calculations and configurations\n */\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport type EffectVariant = 'glow' | 'orbs' | 'spotlight' | 'mesh';\nexport type EffectIntensity = 'subtle' | 'medium' | 'strong';\nexport type EffectColorScheme = 'primary' | 'vibrant' | 'cool' | 'warm';\n\nexport interface AudioLevels {\n bass: number;\n mid: number;\n high: number;\n overall: number;\n}\n\nexport interface EffectConfig {\n opacity: number;\n scale: number;\n blur: string;\n}\n\nexport interface EffectColors {\n colors: string[];\n hueShift: number;\n}\n\nexport interface EffectLayer {\n inset: number;\n opacity: number;\n scale: number;\n background: string;\n blur: string;\n animation?: string;\n}\n\n// =============================================================================\n// CONSTANTS\n// =============================================================================\n\nexport const INTENSITY_CONFIG: Record<EffectIntensity, EffectConfig> = {\n subtle: { opacity: 0.3, scale: 0.02, blur: 'blur-2xl' },\n medium: { opacity: 0.5, scale: 0.04, blur: 'blur-xl' },\n strong: { opacity: 0.7, scale: 0.06, blur: 'blur-lg' },\n};\n\nexport const COLOR_SCHEMES: Record<EffectColorScheme, string[]> = {\n primary: ['217 91% 60%'],\n vibrant: ['217 91% 60%', '142 76% 36%', '262 83% 58%', '25 95% 53%'],\n cool: ['217 91% 60%', '262 83% 58%', '199 89% 48%'],\n warm: ['25 95% 53%', '0 84% 60%', '38 92% 50%'],\n};\n\n// Default multi-color palette when single color provided\nconst DEFAULT_GLOW_COLORS = [\n '217 91% 60%', // Blue\n '262 83% 58%', // Purple\n '330 81% 60%', // Pink\n '25 95% 53%', // Orange\n];\n\n// =============================================================================\n// UTILITIES\n// =============================================================================\n\n/**\n * Get effect configuration from intensity setting\n */\nexport function getEffectConfig(intensity: EffectIntensity): EffectConfig {\n return INTENSITY_CONFIG[intensity];\n}\n\n/**\n * Get color array from color scheme\n */\nexport function getColors(colorScheme: EffectColorScheme): string[] {\n return COLOR_SCHEMES[colorScheme];\n}\n\n/**\n * Prepare colors with hue shift based on audio levels\n */\nexport function prepareEffectColors(\n colorScheme: EffectColorScheme,\n levels: AudioLevels\n): EffectColors {\n const baseColors = COLOR_SCHEMES[colorScheme];\n const colors = baseColors.length > 1 ? baseColors : DEFAULT_GLOW_COLORS;\n const hueShift = Math.floor(\n (levels.bass * 30) + (levels.mid * 20) + (levels.high * 10)\n );\n\n return { colors, hueShift };\n}\n\n/**\n * Calculate glow layer properties\n */\nexport function calculateGlowLayers(\n levels: AudioLevels,\n config: EffectConfig,\n colors: string[]\n): EffectLayer[] {\n const { bass, mid, high } = levels;\n\n return [\n // Layer 1: Bass glow - bottom\n {\n inset: 60 + bass * 90,\n opacity: 1,\n scale: 1 + bass * 0.5,\n background: `radial-gradient(ellipse 80% 60% at 50% 100%, hsl(${colors[0]} / ${0.4 + bass * 0.4}) 0%, transparent 70%)`,\n blur: 'blur-3xl',\n },\n // Layer 2: Mid glow - top\n {\n inset: 45 + mid * 75,\n opacity: 1,\n scale: 1 + mid * 0.4,\n background: `radial-gradient(ellipse 70% 50% at 50% 0%, hsl(${colors[1] || colors[0]} / ${0.3 + mid * 0.5}) 0%, transparent 70%)`,\n blur: 'blur-2xl',\n },\n // Layer 3: High glow - left\n {\n inset: 30 + high * 60,\n opacity: 1,\n scale: 1 + high * 0.3,\n background: `radial-gradient(ellipse 50% 80% at 0% 50%, hsl(${colors[2] || colors[0]} / ${0.3 + high * 0.4}) 0%, transparent 60%)`,\n blur: 'blur-2xl',\n },\n // Layer 4: High glow - right\n {\n inset: 30 + high * 60,\n opacity: 1,\n scale: 1 + high * 0.3,\n background: `radial-gradient(ellipse 50% 80% at 100% 50%, hsl(${colors[3] || colors[0]} / ${0.3 + high * 0.4}) 0%, transparent 60%)`,\n blur: 'blur-2xl',\n },\n // Layer 5: Center pulsing glow\n {\n inset: 24 + bass * 45,\n opacity: 1,\n scale: 1 + bass * 0.2,\n background: `radial-gradient(circle at 50% 50%, hsl(${colors[0]} / ${0.2 + bass * 0.3}) 0%, hsl(${colors[1] || colors[0]} / ${0.1 + mid * 0.2}) 40%, transparent 70%)`,\n blur: 'blur-xl',\n animation: 'glow-breathe 2s ease-in-out infinite',\n },\n ];\n}\n\n/**\n * Calculate orb positions and properties - highly reactive\n */\nexport function calculateOrbs(\n levels: AudioLevels,\n config: EffectConfig,\n colors: string[],\n baseSize: number = 50\n) {\n const { bass, mid, high, overall } = levels;\n const size = baseSize * 3;\n\n // Dynamic position offsets\n const bassMove = bass * 30;\n const midMove = mid * 25;\n const highMove = high * 20;\n\n return [\n // Bass orb - top left, big pulses\n {\n x: -40 + bassMove,\n y: -40 - bassMove * 0.5,\n size: size * (1 + bass * 1.2),\n color: colors[0],\n opacity: 0.5 + bass * 0.5,\n scale: 1 + bass * 0.6,\n },\n // Mid orb - top right\n {\n x: 130 - midMove * 0.5,\n y: -30 + midMove,\n size: size * (0.9 + mid * 1.0),\n color: colors[1] || colors[0],\n opacity: 0.5 + mid * 0.5,\n scale: 1 + mid * 0.5,\n },\n // High orb - bottom right\n {\n x: 140 + highMove * 0.3,\n y: 120 - highMove,\n size: size * (0.8 + high * 0.8),\n color: colors[2] || colors[0],\n opacity: 0.4 + high * 0.6,\n scale: 1 + high * 0.45,\n },\n // Mid orb 2 - bottom left\n {\n x: -30 - midMove * 0.4,\n y: 130 + midMove * 0.3,\n size: size * (0.9 + mid * 0.9),\n color: colors[3] || colors[0],\n opacity: 0.45 + mid * 0.55,\n scale: 1 + mid * 0.5,\n },\n // Center overall orb\n {\n x: 50,\n y: 50,\n size: size * (0.6 + overall * 1.5),\n color: colors[0],\n opacity: 0.3 + overall * 0.5,\n scale: 1 + overall * 0.7,\n },\n ];\n}\n\n/**\n * Calculate mesh gradient positions - dynamic and reactive\n */\nexport function calculateMeshGradients(\n levels: AudioLevels,\n config: EffectConfig,\n colors: string[]\n) {\n const { bass, mid, high, overall } = levels;\n\n // More aggressive offsets for visible movement\n const bassOffset = bass * 40;\n const midOffset = mid * 30;\n const highOffset = high * 25;\n\n return [\n // Large bass blob - top right, pulses hard\n {\n width: `${200 + bass * 150}%`,\n height: `${200 + bass * 150}%`,\n top: `${-80 + bassOffset}%`,\n right: `${-80 - bassOffset}%`,\n color: colors[0],\n opacity: 0.4 + bass * 0.6,\n scale: 1 + bass * 0.5,\n rotation: bass * 45,\n blur: 'blur-2xl',\n },\n // Mid blob - bottom left\n {\n width: `${180 + mid * 120}%`,\n height: `${180 + mid * 120}%`,\n bottom: `${-60 + midOffset}%`,\n left: `${-60 - midOffset}%`,\n color: colors[1] || colors[0],\n opacity: 0.4 + mid * 0.6,\n scale: 1 + mid * 0.4,\n rotation: -mid * 40,\n blur: 'blur-2xl',\n },\n // High blob - bottom right\n {\n width: `${140 + high * 100}%`,\n height: `${140 + high * 100}%`,\n top: `${70 - highOffset}%`,\n right: `${-50 + highOffset}%`,\n color: colors[2] || colors[0],\n opacity: 0.35 + high * 0.65,\n scale: 1 + high * 0.35,\n rotation: high * 35,\n blur: 'blur-xl',\n },\n // Extra bass reactive blob - top left\n {\n width: `${160 + bass * 140}%`,\n height: `${160 + bass * 140}%`,\n top: `${-60 - bassOffset * 0.8}%`,\n left: `${-60 + bassOffset * 0.8}%`,\n color: colors[3] || colors[1] || colors[0],\n opacity: 0.35 + bass * 0.65,\n scale: 1 + bass * 0.55,\n rotation: -bass * 50,\n blur: 'blur-2xl',\n },\n // Center glow - pulses with overall\n {\n width: `${80 + overall * 150}%`,\n height: `${80 + overall * 150}%`,\n top: '50%',\n left: '50%',\n color: colors[0],\n opacity: 0.3 + overall * 0.5,\n scale: 1 + overall * 0.4,\n rotation: 0,\n isCenter: true,\n blur: 'blur-3xl',\n },\n ];\n}\n\n/**\n * Calculate spotlight effect properties - highly reactive\n */\nexport function calculateSpotlight(\n levels: AudioLevels,\n config: EffectConfig,\n colors: string[],\n rotation: number\n) {\n const { bass, mid, high, overall } = levels;\n\n return {\n // Rotation speed increases with mid frequencies\n rotation: rotation + mid * 180,\n // Border expands with bass\n inset: 12 + bass * 30,\n // Color intensities react to different frequencies\n colors: colors.map((c, i) => ({\n color: c,\n opacity: i === 0\n ? 0.3 + bass * 0.7\n : i === 1\n ? 0.3 + mid * 0.7\n : 0.3 + high * 0.7,\n })),\n // Pulse glow - big and reactive\n pulseInset: 24 + bass * 50,\n pulseOpacity: 0.3 + bass * 0.7,\n pulseScale: 1 + bass * 0.4,\n // Extra glow ring\n ringOpacity: 0.2 + overall * 0.6,\n ringScale: 1 + overall * 0.3,\n };\n}\n\n/**\n * CSS for effect animations - can be injected once\n */\nexport const EFFECT_ANIMATIONS = `\n @keyframes spotlight-spin {\n 0% { transform: rotate(0deg); }\n 100% { transform: rotate(360deg); }\n }\n\n @keyframes orb-float-1 {\n 0%, 100% { transform: translate(-50%, -50%) translateY(0); }\n 50% { transform: translate(-50%, -50%) translateY(-15px); }\n }\n\n @keyframes orb-float-2 {\n 0%, 100% { transform: translate(-50%, -50%) translateX(0); }\n 50% { transform: translate(-50%, -50%) translateX(15px); }\n }\n\n @keyframes orb-float-3 {\n 0%, 100% { transform: translate(-50%, -50%) translate(0, 0); }\n 33% { transform: translate(-50%, -50%) translate(10px, -10px); }\n 66% { transform: translate(-50%, -50%) translate(-10px, 10px); }\n }\n\n @keyframes orb-float-4 {\n 0%, 100% { transform: translate(-50%, -50%) translate(0, 0); }\n 50% { transform: translate(-50%, -50%) translate(-15px, -10px); }\n }\n\n @keyframes mesh-float-1 {\n 0%, 100% { transform: translate(0, 0) scale(1); }\n 25% { transform: translate(-5%, 10%) scale(1.05); }\n 50% { transform: translate(5%, 5%) scale(0.95); }\n 75% { transform: translate(-3%, -5%) scale(1.02); }\n }\n\n @keyframes mesh-float-2 {\n 0%, 100% { transform: translate(0, 0) scale(1); }\n 33% { transform: translate(8%, -8%) scale(1.08); }\n 66% { transform: translate(-6%, 6%) scale(0.92); }\n }\n\n @keyframes mesh-float-3 {\n 0%, 100% { transform: translate(0, 0) scale(1); }\n 50% { transform: translate(10%, 10%) scale(1.1); }\n }\n\n @keyframes mesh-float-4 {\n 0%, 100% { transform: translate(0, 0) scale(1) rotate(0deg); }\n 25% { transform: translate(10%, -5%) scale(1.1) rotate(5deg); }\n 50% { transform: translate(-5%, 10%) scale(0.95) rotate(-5deg); }\n 75% { transform: translate(-10%, -10%) scale(1.05) rotate(3deg); }\n }\n\n @keyframes mesh-pulse {\n 0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 0.3; }\n 50% { transform: translate(-50%, -50%) scale(1.2); opacity: 0.5; }\n }\n\n @keyframes glow-breathe {\n 0%, 100% { opacity: 0.6; transform: scale(1); }\n 50% { opacity: 1; transform: scale(1.05); }\n }\n\n @keyframes glow-rotate {\n 0% { transform: rotate(0deg); }\n 100% { transform: rotate(360deg); }\n }\n\n @keyframes sparkle-move {\n 0% { opacity: 0; transform: scale(0.8); }\n 50% { opacity: 1; }\n 100% { opacity: 0; transform: scale(1.2); }\n }\n`;\n","'use client';\n\n/**\n * GlowEffect - Multi-layer glow effect with pulse rings\n */\n\nimport { cn } from '../../../../_shared';\nimport type { calculateGlowLayers } from '../../../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface GlowEffectData {\n layers: ReturnType<typeof calculateGlowLayers>;\n hueShift: number;\n showPulseRings: boolean;\n showSparkle: boolean;\n}\n\ninterface GlowEffectProps {\n data: GlowEffectData;\n colors: string[];\n isPlaying: boolean;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function GlowEffect({ data, colors, isPlaying }: GlowEffectProps) {\n const { layers, hueShift, showPulseRings, showSparkle } = data;\n\n return (\n <>\n {/* Main glow layers */}\n {layers.map((layer, i) => (\n <div\n key={i}\n className={cn('absolute rounded-2xl -z-10', layer.blur)}\n style={{\n inset: `-${layer.inset}px`,\n background: layer.background,\n opacity: isPlaying ? layer.opacity : 0,\n transform: i < 2 ? `scaleY(${layer.scale})` : `scale(${layer.scale})`,\n animation: isPlaying && layer.animation ? layer.animation : 'none',\n transition: 'opacity 0.3s',\n }}\n />\n ))}\n\n {/* Rotating color sweep */}\n <div\n className=\"absolute rounded-2xl blur-xl overflow-hidden -z-10\"\n style={{\n inset: '-75px',\n opacity: isPlaying ? 0.6 : 0,\n transition: 'opacity 0.5s',\n }}\n >\n <div\n className=\"absolute inset-0\"\n style={{\n background: `conic-gradient(\n from ${hueShift}deg at 50% 50%,\n hsl(${colors[0]} / 0.4) 0deg,\n hsl(${colors[1] || colors[0]} / 0.3) 90deg,\n hsl(${colors[2] || colors[0]} / 0.3) 180deg,\n hsl(${colors[3] || colors[0]} / 0.3) 270deg,\n hsl(${colors[0]} / 0.4) 360deg\n )`,\n animation: isPlaying ? 'glow-rotate 6s linear infinite' : 'none',\n }}\n />\n </div>\n\n {/* Pulse rings on bass hits */}\n {showPulseRings && (\n <>\n <div\n className=\"absolute -inset-6 rounded-xl border-2 animate-ping -z-10\"\n style={{\n borderColor: `hsl(${colors[0]} / 0.4)`,\n animationDuration: '1s',\n }}\n />\n <div\n className=\"absolute -inset-12 rounded-2xl border animate-ping -z-10\"\n style={{\n borderColor: `hsl(${colors[1] || colors[0]} / 0.3)`,\n animationDuration: '1.5s',\n animationDelay: '0.2s',\n }}\n />\n </>\n )}\n\n {/* Sparkle on high frequencies */}\n {showSparkle && (\n <div\n className=\"absolute -inset-18 rounded-3xl -z-10\"\n style={{\n background: `radial-gradient(circle at 50% 30%, hsl(${colors[2] || colors[0]} / 0.5) 0%, transparent 30%)`,\n animation: 'sparkle-move 0.5s ease-out',\n }}\n />\n )}\n </>\n );\n}\n","'use client';\n\n/**\n * OrbsEffect - Floating orb particles that react to audio\n */\n\nimport { cn } from '../../../../_shared';\nimport type { calculateOrbs } from '../../../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\ninterface OrbsEffectProps {\n orbs: ReturnType<typeof calculateOrbs>;\n blur: string;\n isPlaying: boolean;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function OrbsEffect({ orbs, blur, isPlaying }: OrbsEffectProps) {\n return (\n <>\n {orbs.map((orb, i) => (\n <div\n key={i}\n className={cn('absolute rounded-full -z-10', blur)}\n style={{\n width: orb.size,\n height: orb.size,\n left: `${orb.x}%`,\n top: `${orb.y}%`,\n background: `radial-gradient(circle at 30% 30%, hsl(${orb.color}) 0%, hsl(${orb.color} / 0.5) 40%, transparent 70%)`,\n opacity: isPlaying ? orb.opacity : 0,\n transform: `translate(-50%, -50%) scale(${orb.scale})`,\n transition: 'all 0.08s ease-out',\n }}\n />\n ))}\n </>\n );\n}\n","'use client';\n\n/**\n * SpotlightEffect - Rotating spotlight with conic gradients\n */\n\nimport { cn } from '../../../../_shared';\nimport type { calculateSpotlight } from '../../../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\ninterface SpotlightEffectProps {\n data: ReturnType<typeof calculateSpotlight>;\n colors: string[];\n blur: string;\n isPlaying: boolean;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function SpotlightEffect({ data, colors, blur, isPlaying }: SpotlightEffectProps) {\n const inset = 'inset' in data ? data.inset : 12;\n const pulseInset = 'pulseInset' in data ? data.pulseInset : 24;\n const ringOpacity = 'ringOpacity' in data ? data.ringOpacity : 0.3;\n const ringScale = 'ringScale' in data ? data.ringScale : 1;\n\n return (\n <>\n {/* Rotating conic gradient - reactive size */}\n <div\n className={cn('absolute rounded-xl -z-10', blur)}\n style={{\n inset: `-${inset}px`,\n background: `conic-gradient(\n from ${data.rotation}deg,\n hsl(${colors[0]} / ${data.colors[0]?.opacity || 0.5}),\n hsl(${colors[1] || colors[0]} / ${data.colors[1]?.opacity || 0.7}),\n hsl(${colors[2] || colors[0]} / ${data.colors[2]?.opacity || 0.5}),\n hsl(${colors[0]} / ${data.colors[1]?.opacity || 0.7}),\n hsl(${colors[0]} / ${data.colors[0]?.opacity || 0.5})\n )`,\n opacity: isPlaying ? 1 : 0,\n transition: 'all 0.08s ease-out',\n }}\n />\n\n {/* Inner border */}\n <div\n className=\"absolute -inset-1 rounded-lg bg-background -z-10\"\n style={{ opacity: isPlaying ? 1 : 0, transition: 'opacity 0.1s' }}\n />\n\n {/* Bass pulse glow - reactive size */}\n <div\n className={cn('absolute rounded-2xl -z-10', blur)}\n style={{\n inset: `-${pulseInset}px`,\n background: `radial-gradient(circle, hsl(${colors[0]} / 0.7) 0%, hsl(${colors[0]} / 0.3) 50%, transparent 70%)`,\n opacity: isPlaying ? data.pulseOpacity : 0,\n transform: `scale(${data.pulseScale})`,\n transition: 'all 0.08s ease-out',\n }}\n />\n\n {/* Outer ring glow */}\n <div\n className=\"absolute rounded-3xl -z-10 blur-2xl\"\n style={{\n inset: `-${pulseInset + 30}px`,\n background: `radial-gradient(circle, hsl(${colors[1] || colors[0]} / 0.4) 0%, transparent 60%)`,\n opacity: isPlaying ? ringOpacity : 0,\n transform: `scale(${ringScale})`,\n transition: 'all 0.08s ease-out',\n }}\n />\n </>\n );\n}\n","'use client';\n\n/**\n * MeshEffect - Mesh gradient blobs that react to audio\n */\n\nimport { cn } from '../../../../_shared';\nimport type { calculateMeshGradients } from '../../../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\ninterface MeshEffectProps {\n gradients: ReturnType<typeof calculateMeshGradients>;\n blur: string;\n isPlaying: boolean;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function MeshEffect({ gradients, isPlaying }: MeshEffectProps) {\n return (\n <>\n {gradients.map((g, i) => {\n const isCenter = 'isCenter' in g && g.isCenter;\n const scale = 'scale' in g ? g.scale : 1;\n const rotation = 'rotation' in g ? g.rotation : 0;\n const itemBlur = 'blur' in g ? g.blur : 'blur-2xl';\n\n return (\n <div\n key={i}\n className={cn('absolute rounded-full -z-10', itemBlur)}\n style={{\n width: g.width,\n height: g.height,\n top: 'top' in g ? g.top : undefined,\n bottom: 'bottom' in g ? g.bottom : undefined,\n left: 'left' in g ? g.left : undefined,\n right: 'right' in g ? g.right : undefined,\n background: isCenter\n ? `radial-gradient(circle, hsl(${g.color} / 0.6) 0%, hsl(${g.color} / 0.3) 30%, transparent 60%)`\n : `radial-gradient(circle, hsl(${g.color}) 0%, hsl(${g.color} / 0.5) 30%, transparent 65%)`,\n opacity: isPlaying ? g.opacity : 0,\n transform: isCenter\n ? `translate(-50%, -50%) scale(${scale})`\n : `scale(${scale}) rotate(${rotation}deg)`,\n transition: 'all 0.08s ease-out',\n }}\n />\n );\n })}\n </>\n );\n}\n","'use client';\n\n/**\n * AudioReactiveCover - Album art with audio-reactive animations\n *\n * Uses effects utilities for clean data preparation before render.\n * Click on cover to switch between effect variants.\n *\n * Must be used within HybridAudioProvider context.\n */\n\nimport { type ReactNode } from 'react';\nimport { cn } from '../../../_shared';\nimport { useHybridAudioLevels, useHybridAudioState } from '../../context/HybridAudioProvider';\nimport {\n type EffectVariant,\n type EffectIntensity,\n type EffectColorScheme,\n getEffectConfig,\n prepareEffectColors,\n calculateGlowLayers,\n calculateOrbs,\n calculateMeshGradients,\n calculateSpotlight,\n EFFECT_ANIMATIONS,\n} from '../../effects';\nimport { GlowEffect, OrbsEffect, SpotlightEffect, MeshEffect, type GlowEffectData } from './effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface AudioReactiveCoverProps {\n children: ReactNode;\n size?: 'sm' | 'md' | 'lg';\n variant?: EffectVariant;\n intensity?: EffectIntensity;\n colorScheme?: EffectColorScheme;\n onClick?: () => void;\n className?: string;\n}\n\n// =============================================================================\n// CONSTANTS\n// =============================================================================\n\nconst SIZES = {\n sm: { container: 'w-32 h-32', orbBase: 40 },\n md: { container: 'w-40 h-40', orbBase: 50 },\n lg: { container: 'w-48 h-48', orbBase: 60 },\n};\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function AudioReactiveCover({\n children,\n size = 'lg',\n variant = 'spotlight',\n intensity = 'medium',\n colorScheme = 'primary',\n onClick,\n className,\n}: AudioReactiveCoverProps) {\n // Get audio state from HybridAudioProvider context\n const { isPlaying } = useHybridAudioState();\n const levels = useHybridAudioLevels();\n\n // =========================================================================\n // PREPARE DATA BEFORE RENDER\n // =========================================================================\n\n const sizeConfig = SIZES[size];\n const effectConfig = getEffectConfig(intensity);\n const { colors, hueShift } = prepareEffectColors(colorScheme, levels);\n\n // Calculate scale based on overall level\n const containerScale = 1 + levels.overall * effectConfig.scale;\n\n // Prepare effect-specific data - NO memoization for real-time reactivity\n const glowData: GlowEffectData | null = variant === 'glow' ? {\n layers: calculateGlowLayers(levels, effectConfig, colors),\n hueShift,\n showPulseRings: levels.bass > 0.5,\n showSparkle: levels.high > 0.4,\n } : null;\n\n const orbsData = variant === 'orbs'\n ? calculateOrbs(levels, effectConfig, colors, sizeConfig.orbBase)\n : null;\n\n const meshData = variant === 'mesh'\n ? calculateMeshGradients(levels, effectConfig, colors)\n : null;\n\n const spotlightData = variant === 'spotlight'\n ? calculateSpotlight(levels, effectConfig, colors, levels.mid * 360)\n : null;\n\n // =========================================================================\n // RENDER\n // =========================================================================\n\n return (\n <div\n className={cn('relative', sizeConfig.container, className)}\n style={{\n transform: `scale(${containerScale})`,\n transition: 'transform 0.1s ease-out',\n }}\n >\n {/* Effect layers container - under cover, non-interactive */}\n <div className=\"absolute inset-0 z-0 pointer-events-none overflow-visible\">\n {glowData && (\n <GlowEffect data={glowData} colors={colors} isPlaying={isPlaying} />\n )}\n\n {orbsData && (\n <OrbsEffect orbs={orbsData} blur={effectConfig.blur} isPlaying={isPlaying} />\n )}\n\n {spotlightData && (\n <SpotlightEffect data={spotlightData} colors={colors} blur={effectConfig.blur} isPlaying={isPlaying} />\n )}\n\n {meshData && (\n <MeshEffect gradients={meshData} blur={effectConfig.blur} isPlaying={isPlaying} />\n )}\n </div>\n\n {/* Content (cover art) */}\n <div\n className=\"relative w-full h-full rounded-lg overflow-hidden shadow-2xl z-10 bg-background cursor-pointer\"\n onClick={onClick}\n role={onClick ? 'button' : undefined}\n tabIndex={onClick ? 0 : undefined}\n onKeyDown={onClick ? (e) => e.key === 'Enter' && onClick() : undefined}\n >\n {children}\n </div>\n\n {/* Inject animations once */}\n <style dangerouslySetInnerHTML={{ __html: EFFECT_ANIMATIONS }} />\n </div>\n );\n}\n\nexport default AudioReactiveCover;\n","'use client';\n\n/**\n * HybridSimplePlayer - Easy-to-use hybrid audio player wrapper\n *\n * Combines HybridAudioProvider + HybridAudioPlayer + optional reactive cover\n * in a single component with sensible defaults.\n *\n * Uses native HTML5 audio for playback (no crackling) with Web Audio API\n * for visualization only.\n *\n * @example\n * // Minimal usage\n * <HybridSimplePlayer src=\"https://example.com/audio.mp3\" />\n *\n * @example\n * // With cover art and reactive effects\n * <HybridSimplePlayer\n * src={audioUrl}\n * title=\"Track Title\"\n * artist=\"Artist Name\"\n * coverArt=\"/path/to/cover.jpg\"\n * reactiveCover\n * variant=\"spotlight\"\n * />\n */\n\nimport { type ReactNode } from 'react';\nimport { Music } from 'lucide-react';\nimport { cn } from '@djangocfg/ui-core';\n\nimport { HybridAudioProvider } from '../context/HybridAudioProvider';\nimport { HybridAudioPlayer } from './HybridAudioPlayer';\nimport { AudioReactiveCover } from './ReactiveCover';\nimport { VisualizationProvider, useVisualization } from '../hooks';\nimport type { EffectIntensity, EffectColorScheme } from '../effects';\nimport type { VisualizationVariant } from '../hooks';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface HybridSimplePlayerProps {\n /** Audio source URL */\n src: string;\n\n /** Track title */\n title?: string;\n\n /** Artist name */\n artist?: string;\n\n /** Cover art URL or ReactNode */\n coverArt?: string | ReactNode;\n\n /** Cover art size */\n coverSize?: 'sm' | 'md' | 'lg';\n\n /** Show frequency waveform */\n showWaveform?: boolean;\n\n /** Waveform visualization mode */\n waveformMode?: 'frequency' | 'static';\n\n /** Waveform height in pixels */\n waveformHeight?: number;\n\n /** Show timer */\n showTimer?: boolean;\n\n /** Show volume control */\n showVolume?: boolean;\n\n /** Show loop/repeat button */\n showLoop?: boolean;\n\n /** Enable audio-reactive cover effects */\n reactiveCover?: boolean;\n\n /** Reactive effect variant */\n variant?: VisualizationVariant;\n\n /** Reactive effect intensity */\n intensity?: EffectIntensity;\n\n /** Reactive effect color scheme */\n colorScheme?: EffectColorScheme;\n\n /** Auto-play on load */\n autoPlay?: boolean;\n\n /** Loop playback */\n loop?: boolean;\n\n /** Initial volume (0-1) */\n initialVolume?: number;\n\n /** Layout direction */\n layout?: 'vertical' | 'horizontal';\n\n /** Additional class name */\n className?: string;\n\n /** Callbacks */\n onPlay?: () => void;\n onPause?: () => void;\n onEnded?: () => void;\n onError?: (error: Error) => void;\n}\n\n// =============================================================================\n// CONSTANTS\n// =============================================================================\n\nconst COVER_SIZES = {\n sm: 'w-24 h-24',\n md: 'w-32 h-32',\n lg: 'w-48 h-48',\n};\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function HybridSimplePlayer(props: HybridSimplePlayerProps) {\n return (\n <VisualizationProvider>\n <HybridSimplePlayerContent {...props} />\n </VisualizationProvider>\n );\n}\n\nfunction HybridSimplePlayerContent({\n src,\n title,\n artist,\n coverArt,\n coverSize = 'md',\n showWaveform = true,\n waveformMode = 'frequency',\n waveformHeight = 64,\n showTimer = true,\n showVolume = true,\n showLoop = true,\n reactiveCover = true,\n variant,\n intensity,\n colorScheme,\n autoPlay = false,\n loop = false,\n initialVolume = 1,\n layout = 'vertical',\n className,\n onPlay,\n onPause,\n onEnded,\n onError,\n}: HybridSimplePlayerProps) {\n const { settings: vizSettings, nextVariant } = useVisualization();\n\n // Determine effective variant (from props or localStorage settings)\n const effectiveVariant =\n variant ?? (vizSettings.variant !== 'none' ? vizSettings.variant : 'spotlight');\n const effectiveIntensity = intensity ?? vizSettings.intensity;\n const effectiveColorScheme = colorScheme ?? vizSettings.colorScheme;\n\n // Show reactive cover if enabled and variant is not 'none'\n const showReactiveCover = reactiveCover && effectiveVariant !== 'none';\n\n // Render cover art content\n const renderCoverContent = () => {\n if (typeof coverArt === 'string') {\n return (\n <img src={coverArt} alt={title || 'Album cover'} className=\"w-full h-full object-cover\" />\n );\n }\n\n if (coverArt) {\n return coverArt;\n }\n\n // Default placeholder\n return (\n <div className=\"w-full h-full bg-muted/30 flex items-center justify-center\">\n <Music className=\"w-1/3 h-1/3 text-muted-foreground/50\" />\n </div>\n );\n };\n\n const isHorizontal = layout === 'horizontal';\n\n return (\n <HybridAudioProvider\n src={src}\n autoPlay={autoPlay}\n loop={loop}\n initialVolume={initialVolume}\n onPlay={onPlay}\n onPause={onPause}\n onEnded={onEnded}\n onError={onError}\n >\n <div\n className={cn(\n 'flex gap-4',\n isHorizontal ? 'flex-row items-center' : 'flex-col items-center',\n className\n )}\n >\n {/* Cover Art */}\n {(coverArt || reactiveCover) && (\n <div className=\"flex flex-col items-center gap-2 shrink-0\">\n {showReactiveCover ? (\n <AudioReactiveCover\n size={coverSize}\n variant={effectiveVariant as 'glow' | 'orbs' | 'spotlight' | 'mesh'}\n intensity={effectiveIntensity}\n colorScheme={effectiveColorScheme}\n onClick={nextVariant}\n >\n <div className={cn('rounded-lg overflow-hidden', COVER_SIZES[coverSize])}>\n {renderCoverContent()}\n </div>\n </AudioReactiveCover>\n ) : (\n <div\n className={cn(\n 'rounded-lg overflow-hidden shadow-lg cursor-pointer',\n COVER_SIZES[coverSize]\n )}\n onClick={nextVariant}\n role=\"button\"\n tabIndex={0}\n onKeyDown={(e) => e.key === 'Enter' && nextVariant()}\n >\n {renderCoverContent()}\n </div>\n )}\n\n {/* Effect indicator */}\n {reactiveCover && (\n <span className=\"text-[10px] uppercase tracking-wider text-muted-foreground/50 select-none\">\n {vizSettings.variant === 'none' ? 'off' : vizSettings.variant}\n </span>\n )}\n </div>\n )}\n\n {/* Track Info + Player */}\n <div\n className={cn('flex flex-col gap-3', isHorizontal ? 'flex-1 min-w-0' : 'w-full max-w-md')}\n >\n {/* Track Info */}\n {(title || artist) && (\n <div className={cn('text-center', isHorizontal && 'text-left')}>\n {title && (\n <h3 className=\"text-base font-medium text-foreground truncate\">{title}</h3>\n )}\n {artist && <p className=\"text-sm text-muted-foreground truncate\">{artist}</p>}\n </div>\n )}\n\n {/* Audio Player */}\n <HybridAudioPlayer\n showControls\n showWaveform={showWaveform}\n waveformMode={waveformMode}\n waveformHeight={waveformHeight}\n showTimer={showTimer}\n showVolume={showVolume}\n showLoop={showLoop}\n className=\"border-0 bg-transparent\"\n />\n </div>\n </div>\n </HybridAudioProvider>\n );\n}\n\nexport default HybridSimplePlayer;\n","/**\n * ImageViewer constants\n */\n\nimport type { ZoomPreset, ImageTransform } from '../types';\n\n// =============================================================================\n// SIZE LIMITS\n// =============================================================================\n\n/** Maximum image size before blocking (50MB) */\nexport const MAX_IMAGE_SIZE = 50 * 1024 * 1024;\n\n/** Image size threshold for warning (10MB) */\nexport const WARNING_IMAGE_SIZE = 10 * 1024 * 1024;\n\n/** Progressive loading threshold - use LQIP for images > 500KB */\nexport const PROGRESSIVE_LOADING_THRESHOLD = 500 * 1024;\n\n// =============================================================================\n// LQIP CONFIGURATION\n// =============================================================================\n\n/** Low-quality placeholder size (32x32) */\nexport const LQIP_SIZE = 32;\n\n/** LQIP JPEG quality */\nexport const LQIP_QUALITY = 0.5;\n\n// =============================================================================\n// ZOOM CONFIGURATION\n// =============================================================================\n\n/** Minimum zoom level */\nexport const MIN_ZOOM = 0.1;\n\n/** Maximum zoom level */\nexport const MAX_ZOOM = 8;\n\n/** Available zoom presets */\nexport const ZOOM_PRESETS: readonly ZoomPreset[] = [\n { label: 'Fit', value: 'fit' },\n { label: '25%', value: 0.25 },\n { label: '50%', value: 0.5 },\n { label: '100%', value: 1 },\n { label: '200%', value: 2 },\n { label: '400%', value: 4 },\n] as const;\n\n// =============================================================================\n// DEFAULT VALUES\n// =============================================================================\n\n/** Default transform state */\nexport const DEFAULT_TRANSFORM: ImageTransform = {\n rotation: 0,\n flipH: false,\n flipV: false,\n};\n","/**\n * LQIP (Low-Quality Image Placeholder) generator\n *\n * Creates a tiny blurred preview image for progressive loading.\n */\n\nimport { LQIP_SIZE, LQIP_QUALITY } from './constants';\n\n/**\n * Create a low-quality image placeholder from source URL\n *\n * @param imageSrc - Full quality image URL\n * @returns Data URL of tiny preview, or null on error\n */\nexport async function createLQIP(imageSrc: string): Promise<string | null> {\n try {\n // Load the full image\n const img = new Image();\n img.crossOrigin = 'anonymous';\n\n await new Promise<void>((resolve, reject) => {\n img.onload = () => resolve();\n img.onerror = () => reject(new Error('Failed to load image for LQIP'));\n img.src = imageSrc;\n });\n\n // Calculate aspect ratio preserving dimensions\n const aspect = img.naturalWidth / img.naturalHeight;\n const width = aspect >= 1 ? LQIP_SIZE : Math.round(LQIP_SIZE * aspect);\n const height = aspect >= 1 ? Math.round(LQIP_SIZE / aspect) : LQIP_SIZE;\n\n // Create canvas for downscaling\n const canvas = document.createElement('canvas');\n canvas.width = width;\n canvas.height = height;\n const ctx = canvas.getContext('2d');\n if (!ctx) return null;\n\n // Draw scaled down image\n ctx.drawImage(img, 0, 0, width, height);\n\n // Return as data URL (very small, ~1-2KB)\n return canvas.toDataURL('image/jpeg', LQIP_QUALITY);\n } catch {\n return null;\n }\n}\n","'use client';\n\n/**\n * ImageViewer Debug Logger\n *\n * Uses universal logger with media-specific helpers.\n * Logs go to both console (dev) and zustand store (for Console panel).\n */\n\nimport { createMediaLogger } from '@djangocfg/ui-core/lib';\n\nexport const imageDebug = createMediaLogger('ImageViewer');\n\nexport default imageDebug;\n","'use client';\n\n/**\n * ImageToolbar - Floating toolbar for image controls\n */\n\nimport { useMemo, useCallback } from 'react';\nimport { ZoomIn, ZoomOut, RotateCw, FlipHorizontal, FlipVertical, Maximize2, Expand } from 'lucide-react';\nimport { useControls } from 'react-zoom-pan-pinch';\nimport { Button, DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from '@djangocfg/ui-core/components';\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { ZOOM_PRESETS } from '../utils';\nimport type { ImageToolbarProps } from '../types';\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function ImageToolbar({\n scale,\n transform,\n onRotate,\n onFlipH,\n onFlipV,\n onZoomPreset,\n onExpand,\n}: ImageToolbarProps) {\n const { zoomIn, zoomOut, resetTransform } = useControls();\n\n const zoomLabel = useMemo(() => {\n const percent = Math.round(scale * 100);\n return `${percent}%`;\n }, [scale]);\n\n return (\n <div className=\"absolute bottom-4 left-1/2 -translate-x-1/2 z-10 flex items-center gap-0.5 bg-background/90 backdrop-blur-sm border rounded-lg p-1 shadow-lg\">\n {/* Zoom controls */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={() => zoomOut()}\n title=\"Zoom out\"\n >\n <ZoomOut className=\"h-3.5 w-3.5\" />\n </Button>\n\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <Button variant=\"ghost\" size=\"sm\" className=\"h-7 px-2 min-w-[52px] font-mono text-xs\">\n {zoomLabel}\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent align=\"center\" className=\"min-w-[80px]\">\n {ZOOM_PRESETS.map((preset) => (\n <DropdownMenuItem\n key={preset.label}\n onClick={() => onZoomPreset(preset.value)}\n className=\"text-xs justify-center\"\n >\n {preset.label}\n </DropdownMenuItem>\n ))}\n </DropdownMenuContent>\n </DropdownMenu>\n\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={() => zoomIn()}\n title=\"Zoom in\"\n >\n <ZoomIn className=\"h-3.5 w-3.5\" />\n </Button>\n\n <div className=\"w-px h-4 bg-border mx-1\" />\n\n {/* Fit to view */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={() => resetTransform()}\n title=\"Fit to view\"\n >\n <Maximize2 className=\"h-3.5 w-3.5\" />\n </Button>\n\n <div className=\"w-px h-4 bg-border mx-1\" />\n\n {/* Transform controls */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className={cn('h-7 w-7', transform.flipH && 'bg-accent')}\n onClick={onFlipH}\n title=\"Flip horizontal\"\n >\n <FlipHorizontal className=\"h-3.5 w-3.5\" />\n </Button>\n\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className={cn('h-7 w-7', transform.flipV && 'bg-accent')}\n onClick={onFlipV}\n title=\"Flip vertical\"\n >\n <FlipVertical className=\"h-3.5 w-3.5\" />\n </Button>\n\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={onRotate}\n title=\"Rotate 90°\"\n >\n <RotateCw className=\"h-3.5 w-3.5\" />\n </Button>\n\n {transform.rotation !== 0 && (\n <span className=\"text-[10px] text-muted-foreground font-mono pl-1\">\n {transform.rotation}°\n </span>\n )}\n\n {onExpand && (\n <>\n <div className=\"w-px h-4 bg-border mx-1\" />\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={onExpand}\n title=\"Open in fullscreen\"\n >\n <Expand className=\"h-3.5 w-3.5\" />\n </Button>\n </>\n )}\n </div>\n );\n}\n","'use client';\n\n/**\n * ImageInfo - Displays image dimensions badge\n */\n\nimport { useEffect, useState } from 'react';\nimport { useImageCache } from '../../../stores/mediaCache';\nimport type { ImageInfoProps } from '../types';\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function ImageInfo({ src }: ImageInfoProps) {\n const { getDimensions, cacheDimensions } = useImageCache();\n const [dimensions, setDimensions] = useState<{ w: number; h: number } | null>(null);\n\n useEffect(() => {\n // Check cache first\n const cached = getDimensions(src);\n if (cached) {\n setDimensions({ w: cached.width, h: cached.height });\n return;\n }\n\n // Load and cache dimensions\n const img = new Image();\n img.onload = () => {\n const dims = { w: img.naturalWidth, h: img.naturalHeight };\n setDimensions(dims);\n cacheDimensions(src, { width: dims.w, height: dims.h });\n };\n img.src = src;\n }, [src, getDimensions, cacheDimensions]);\n\n if (!dimensions) return null;\n\n return (\n <div className=\"absolute top-3 right-3 z-10 px-2 py-1 bg-background/80 backdrop-blur-sm border rounded text-[10px] text-muted-foreground font-mono\">\n {dimensions.w} × {dimensions.h}\n </div>\n );\n}\n","'use client';\n\n/**\n * useImageTransform - Manages image rotation and flip state\n */\n\nimport { useState, useCallback, useEffect, useMemo } from 'react';\nimport type { ImageTransform } from '../types';\nimport { DEFAULT_TRANSFORM } from '../utils';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface UseImageTransformOptions {\n /** Reset transform when this key changes */\n resetKey?: string;\n}\n\nexport interface UseImageTransformReturn {\n /** Current transform state */\n transform: ImageTransform;\n /** Rotate 90 degrees clockwise */\n rotate: () => void;\n /** Toggle horizontal flip */\n flipH: () => void;\n /** Toggle vertical flip */\n flipV: () => void;\n /** Reset all transforms */\n reset: () => void;\n /** CSS transform string for applying to image */\n transformStyle: string;\n}\n\n// =============================================================================\n// HOOK\n// =============================================================================\n\nexport function useImageTransform(\n options: UseImageTransformOptions = {}\n): UseImageTransformReturn {\n const { resetKey } = options;\n\n const [transform, setTransform] = useState<ImageTransform>(DEFAULT_TRANSFORM);\n\n // Reset transform when key changes\n useEffect(() => {\n setTransform(DEFAULT_TRANSFORM);\n }, [resetKey]);\n\n const rotate = useCallback(() => {\n setTransform((prev) => ({\n ...prev,\n rotation: (prev.rotation + 90) % 360,\n }));\n }, []);\n\n const flipH = useCallback(() => {\n setTransform((prev) => ({\n ...prev,\n flipH: !prev.flipH,\n }));\n }, []);\n\n const flipV = useCallback(() => {\n setTransform((prev) => ({\n ...prev,\n flipV: !prev.flipV,\n }));\n }, []);\n\n const reset = useCallback(() => {\n setTransform(DEFAULT_TRANSFORM);\n }, []);\n\n // Build CSS transform string\n const transformStyle = useMemo(() => {\n const transforms: string[] = [];\n\n if (transform.rotation !== 0) {\n transforms.push(`rotate(${transform.rotation}deg)`);\n }\n if (transform.flipH) {\n transforms.push('scaleX(-1)');\n }\n if (transform.flipV) {\n transforms.push('scaleY(-1)');\n }\n\n return transforms.join(' ') || 'none';\n }, [transform]);\n\n return {\n transform,\n rotate,\n flipH,\n flipV,\n reset,\n transformStyle,\n };\n}\n","'use client';\n\n/**\n * useImageLoading - Manages image loading state with LQIP\n */\n\nimport { useState, useEffect, useRef } from 'react';\nimport { useMediaCacheStore, generateContentKey } from '../../../stores/mediaCache';\nimport { createLQIP, MAX_IMAGE_SIZE, WARNING_IMAGE_SIZE, PROGRESSIVE_LOADING_THRESHOLD, imageDebug } from '../utils';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface UseImageLoadingOptions {\n /** Image content (ArrayBuffer or string) */\n content: string | ArrayBuffer;\n /** MIME type for blob creation */\n mimeType?: string;\n /**\n * Direct image URL (bypasses content→blob conversion).\n * When provided, content is ignored and URL is used directly.\n */\n src?: string;\n}\n\nexport interface UseImageLoadingReturn {\n /** Blob URL source for the image */\n src: string | null;\n /** Low-quality placeholder URL */\n lqip: string | null;\n /** Whether full image is loaded */\n isFullyLoaded: boolean;\n /** Whether to use progressive loading */\n useProgressiveLoading: boolean;\n /** Error message if any */\n error: string | null;\n /** Content key for caching */\n contentKey: string | null;\n /** Image size in bytes */\n size: number;\n /** Whether content exists */\n hasContent: boolean;\n}\n\n// =============================================================================\n// HOOK\n// =============================================================================\n\nexport function useImageLoading(options: UseImageLoadingOptions): UseImageLoadingReturn {\n const { content, mimeType, src: directSrc } = options;\n\n // Get stable function references from store (not from hook to avoid re-renders)\n const getOrCreateBlobUrl = useMediaCacheStore.getState().getOrCreateBlobUrl;\n const releaseBlobUrl = useMediaCacheStore.getState().releaseBlobUrl;\n\n const [src, setSrc] = useState<string | null>(null);\n const [lqip, setLqip] = useState<string | null>(null);\n const [isFullyLoaded, setIsFullyLoaded] = useState(false);\n const [error, setError] = useState<string | null>(null);\n\n const contentKeyRef = useRef<string | null>(null);\n const isMountedRef = useRef(true);\n\n // Calculate size and flags\n const size = content ? (typeof content === 'string' ? content.length : content.byteLength) : 0;\n // When directSrc is provided, we have content (the URL itself)\n const hasContent = directSrc ? true : size > 0;\n const useProgressiveLoading = directSrc ? false : size > PROGRESSIVE_LOADING_THRESHOLD;\n\n // Track unmount for cleanup\n useEffect(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n // Release blob URL only on actual unmount\n if (contentKeyRef.current) {\n useMediaCacheStore.getState().releaseBlobUrl(contentKeyRef.current);\n contentKeyRef.current = null;\n }\n };\n }, []);\n\n // Create blob URL with caching and size validation\n useEffect(() => {\n // Reset error state\n setError(null);\n\n // Direct URL mode - use as-is without blob conversion\n if (directSrc) {\n imageDebug.load(directSrc, 'url');\n setSrc(directSrc);\n setIsFullyLoaded(true);\n return;\n }\n\n if (!hasContent) {\n setSrc(null);\n return;\n }\n\n // Size validation - reject oversized images\n if (size > MAX_IMAGE_SIZE) {\n const sizeMB = (size / 1024 / 1024).toFixed(1);\n const errorMsg = `Image too large: ${sizeMB}MB (maximum: 50MB)`;\n imageDebug.error(errorMsg, { size, sizeMB, maxSize: MAX_IMAGE_SIZE });\n setError(errorMsg);\n setSrc(null);\n return;\n }\n\n // Warn about large images\n if (size > WARNING_IMAGE_SIZE) {\n const sizeMB = (size / 1024 / 1024).toFixed(1);\n imageDebug.warn(`Large image: ${sizeMB}MB - may impact performance`);\n }\n\n // Handle string content (data URLs or binary strings)\n if (typeof content === 'string') {\n // Pass through data URLs directly\n if (content.startsWith('data:')) {\n imageDebug.load(content.slice(0, 50) + '...', 'data-url');\n setSrc(content);\n return;\n }\n\n // Convert binary string to ArrayBuffer and use Blob URL\n const encoder = new TextEncoder();\n const buffer = encoder.encode(content).buffer;\n const contentKey = generateContentKey(buffer);\n\n // Release previous blob URL if content changed\n if (contentKeyRef.current && contentKeyRef.current !== contentKey) {\n releaseBlobUrl(contentKeyRef.current);\n }\n\n contentKeyRef.current = contentKey;\n const url = getOrCreateBlobUrl(contentKey, buffer, mimeType || 'image/png');\n imageDebug.load(url, 'blob');\n imageDebug.state('loaded', { size, mimeType, contentKey });\n setSrc(url);\n return;\n }\n\n // Handle ArrayBuffer with cached blob URL\n const contentKey = generateContentKey(content);\n\n // Release previous blob URL if content changed\n if (contentKeyRef.current && contentKeyRef.current !== contentKey) {\n releaseBlobUrl(contentKeyRef.current);\n }\n\n contentKeyRef.current = contentKey;\n const url = getOrCreateBlobUrl(contentKey, content, mimeType || 'image/png');\n imageDebug.load(url, 'blob');\n imageDebug.state('loaded', { size, mimeType, contentKey });\n setSrc(url);\n\n // No cleanup here - cleanup happens in unmount effect above\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [content, mimeType, hasContent, size, directSrc]);\n\n // Create LQIP for progressive loading\n useEffect(() => {\n if (!src || !useProgressiveLoading) {\n setLqip(null);\n setIsFullyLoaded(true);\n return;\n }\n\n setIsFullyLoaded(false);\n imageDebug.state('progressive loading', { size });\n\n // Create low-quality placeholder\n createLQIP(src).then((placeholder) => {\n if (placeholder) {\n imageDebug.debug('LQIP created');\n setLqip(placeholder);\n }\n });\n\n // Pre-load full image\n const img = new Image();\n img.onload = () => {\n imageDebug.state('fully loaded');\n setIsFullyLoaded(true);\n };\n img.onerror = () => {\n imageDebug.error('Failed to load full image');\n };\n img.src = src;\n }, [src, useProgressiveLoading, size]);\n\n return {\n src,\n lqip,\n isFullyLoaded,\n useProgressiveLoading,\n error,\n contentKey: contentKeyRef.current,\n size,\n hasContent,\n };\n}\n","'use client';\n\n/**\n * ImageViewer - Image viewer with zoom, pan, rotate, flip\n *\n * Features:\n * - Zoom with mouse wheel and presets\n * - Pan with drag\n * - Rotate 90°\n * - Flip horizontal/vertical\n * - Fullscreen dialog\n * - Keyboard shortcuts (+/-, 0, r)\n */\n\nimport { useEffect, useState, useRef, useCallback } from 'react';\nimport { ImageIcon, AlertCircle } from 'lucide-react';\nimport { TransformWrapper, TransformComponent, useControls } from 'react-zoom-pan-pinch';\nimport { cn, Dialog, DialogContent, DialogTitle, Alert, AlertDescription } from '@djangocfg/ui-core';\n\nimport { ImageToolbar } from './ImageToolbar';\nimport { ImageInfo } from './ImageInfo';\nimport { useImageTransform, useImageLoading } from '../hooks';\nimport type { ImageViewerProps } from '../types';\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function ImageViewer({ file, content, src: directSrc, inDialog = false }: ImageViewerProps) {\n const [scale, setScale] = useState(1);\n const [dialogOpen, setDialogOpen] = useState(false);\n const [loadError, setLoadError] = useState(false);\n const containerRef = useRef<HTMLDivElement>(null);\n const controlsRef = useRef<ReturnType<typeof useControls> | null>(null);\n\n // Loading state\n const {\n src,\n lqip,\n isFullyLoaded,\n useProgressiveLoading,\n error,\n hasContent,\n } = useImageLoading({ content, mimeType: file.mimeType, src: directSrc });\n\n // Reset load error when src changes\n useEffect(() => {\n setLoadError(false);\n }, [src]);\n\n // Transform state\n const { transform, rotate, flipH, flipV, transformStyle } = useImageTransform({\n resetKey: file.path,\n });\n\n // Zoom preset handler\n const handleZoomPreset = useCallback((value: number | 'fit') => {\n if (!controlsRef.current) return;\n if (value === 'fit') {\n controlsRef.current.resetTransform();\n } else {\n controlsRef.current.setTransform(0, 0, value);\n }\n }, []);\n\n // Expand to fullscreen\n const handleExpand = useCallback(() => {\n setDialogOpen(true);\n }, []);\n\n // Keyboard shortcuts\n useEffect(() => {\n const handleKeyDown = (e: KeyboardEvent) => {\n if (!containerRef.current?.contains(document.activeElement) &&\n document.activeElement !== containerRef.current) {\n return;\n }\n\n const controls = controlsRef.current;\n if (!controls) return;\n\n switch (e.key) {\n case '+':\n case '=':\n e.preventDefault();\n controls.zoomIn();\n break;\n case '-':\n e.preventDefault();\n controls.zoomOut();\n break;\n case '0':\n e.preventDefault();\n controls.resetTransform();\n break;\n case 'r':\n if (!e.metaKey && !e.ctrlKey) {\n e.preventDefault();\n rotate();\n }\n break;\n }\n };\n\n window.addEventListener('keydown', handleKeyDown);\n return () => window.removeEventListener('keydown', handleKeyDown);\n }, [rotate]);\n\n // Show error for oversized images or load errors\n if (error || loadError) {\n return (\n <div className=\"flex-1 flex flex-col items-center justify-center gap-3 bg-muted/30 p-4\">\n <AlertCircle className=\"w-12 h-12 text-destructive/70\" />\n <Alert variant=\"destructive\" className=\"max-w-md\">\n <AlertCircle className=\"h-4 w-4\" />\n <AlertDescription>{error || 'Failed to load image'}</AlertDescription>\n </Alert>\n </div>\n );\n }\n\n // No content\n if (!hasContent) {\n return (\n <div className=\"flex-1 flex flex-col items-center justify-center gap-2 bg-muted/30\">\n <ImageIcon className=\"w-12 h-12 text-muted-foreground/50\" />\n <p className=\"text-sm text-muted-foreground\">No image content</p>\n </div>\n );\n }\n\n return (\n <div\n ref={containerRef}\n tabIndex={0}\n className={cn(\n 'flex-1 h-full relative overflow-hidden outline-none',\n 'bg-[length:16px_16px]',\n '[background-color:hsl(var(--muted)/0.2)]',\n '[background-image:linear-gradient(45deg,hsl(var(--muted)/0.4)_25%,transparent_25%),linear-gradient(-45deg,hsl(var(--muted)/0.4)_25%,transparent_25%),linear-gradient(45deg,transparent_75%,hsl(var(--muted)/0.4)_75%),linear-gradient(-45deg,transparent_75%,hsl(var(--muted)/0.4)_75%)]',\n '[background-position:0_0,0_8px,8px_-8px,-8px_0px]'\n )}\n >\n {src && <ImageInfo src={src} />}\n\n {/* Progressive loading indicator */}\n {useProgressiveLoading && !isFullyLoaded && (\n <div className=\"absolute top-3 left-3 z-10 px-2 py-1 bg-background/80 backdrop-blur-sm border rounded text-[10px] text-muted-foreground font-mono flex items-center gap-1.5\">\n <div className=\"w-2 h-2 bg-blue-500 rounded-full animate-pulse\" />\n Loading...\n </div>\n )}\n\n <TransformWrapper\n initialScale={1}\n minScale={0.1}\n maxScale={8}\n centerOnInit\n centerZoomedOut\n onTransformed={(ref, state) => {\n setScale(state.scale);\n controlsRef.current = ref;\n }}\n onInit={(ref) => {\n controlsRef.current = ref;\n }}\n wheel={{ step: 0.1 }}\n doubleClick={{ mode: 'toggle', step: 2 }}\n panning={{ velocityDisabled: false }}\n >\n <ImageToolbar\n scale={scale}\n transform={transform}\n onRotate={rotate}\n onFlipH={flipH}\n onFlipV={flipV}\n onZoomPreset={handleZoomPreset}\n onExpand={!inDialog ? handleExpand : undefined}\n />\n\n <TransformComponent\n wrapperClass=\"!w-full !h-full cursor-grab active:cursor-grabbing\"\n contentClass=\"!w-full !h-full flex items-center justify-center\"\n >\n <div className=\"relative\">\n {/* LQIP Placeholder (blurred, shown while loading) */}\n {useProgressiveLoading && lqip && !isFullyLoaded && (\n <img\n src={lqip}\n alt=\"\"\n aria-hidden=\"true\"\n className=\"absolute inset-0 max-w-full max-h-full object-contain select-none\"\n style={{\n transform: transformStyle,\n filter: 'blur(20px)',\n transition: 'opacity 0.3s ease-out',\n opacity: isFullyLoaded ? 0 : 1,\n }}\n draggable={false}\n />\n )}\n\n {/* Full Image */}\n {src && (\n <img\n src={src}\n alt={file.name}\n className=\"max-w-full max-h-full object-contain select-none\"\n style={{\n transform: transformStyle,\n transition: useProgressiveLoading\n ? 'transform 0.15s ease-out, opacity 0.3s ease-out'\n : 'transform 0.15s ease-out',\n opacity: useProgressiveLoading && !isFullyLoaded ? 0 : 1,\n }}\n draggable={false}\n crossOrigin=\"anonymous\"\n onError={() => setLoadError(true)}\n />\n )}\n </div>\n </TransformComponent>\n </TransformWrapper>\n\n {/* Fullscreen dialog */}\n {!inDialog && (\n <Dialog open={dialogOpen} onOpenChange={setDialogOpen}>\n <DialogContent className=\"max-w-[95vw] max-h-[95vh] w-[95vw] h-[95vh] p-0 overflow-hidden [&>button]:hidden flex flex-col\">\n <DialogTitle className=\"sr-only\">{file.name}</DialogTitle>\n <div className=\"flex items-center justify-between px-4 py-2 border-b shrink-0\">\n <span className=\"text-sm font-medium truncate\">{file.name}</span>\n </div>\n <div className=\"flex-1 min-h-0\">\n <ImageViewer file={file} content={content} src={directSrc} inDialog />\n </div>\n </DialogContent>\n </Dialog>\n )}\n </div>\n );\n}\n","'use client';\n\nimport React from 'react';\nimport ReactMarkdown from 'react-markdown';\nimport remarkGfm from 'remark-gfm';\n\nimport { CopyButton } from '@djangocfg/ui-core/components';\nimport { useResolvedTheme } from '@djangocfg/ui-core/hooks';\n\nimport Mermaid from '../../tools/Mermaid';\nimport PrettyCode from '../../tools/PrettyCode';\n\nimport type { Components } from 'react-markdown';\n\n// Helper function to extract text content from React children\nconst extractTextFromChildren = (children: React.ReactNode): string => {\n if (typeof children === 'string') {\n return children;\n }\n\n if (typeof children === 'number') {\n return String(children);\n }\n\n if (React.isValidElement(children)) {\n const props = children.props as { children?: React.ReactNode };\n return extractTextFromChildren(props.children);\n }\n\n if (Array.isArray(children)) {\n return children.map(extractTextFromChildren).join('');\n }\n\n return '';\n};\n\nexport interface MarkdownMessageProps {\n /** Markdown content to render */\n content: string;\n /** Additional CSS classes */\n className?: string;\n /** Whether the message is from the user (affects styling) */\n isUser?: boolean;\n /** Use compact size (text-xs instead of text-sm) */\n isCompact?: boolean;\n}\n\n// Code block component with copy functionality\ninterface CodeBlockProps {\n code: string;\n language: string;\n isUser: boolean;\n isCompact?: boolean;\n}\n\nconst CodeBlock: React.FC<CodeBlockProps> = ({ code, language, isUser, isCompact = false }) => {\n const theme = useResolvedTheme();\n\n return (\n <div className=\"relative group my-3\">\n {/* Copy button */}\n <CopyButton\n value={code}\n variant=\"ghost\"\n className={`\n absolute top-2 right-2 z-10 opacity-0 group-hover:opacity-100 transition-opacity\n h-8 w-8\n ${isUser\n ? 'hover:bg-white/20 text-white'\n : 'hover:bg-muted-foreground/20 text-muted-foreground hover:text-foreground'\n }\n `}\n title=\"Copy code\"\n />\n\n {/* Code content */}\n <PrettyCode\n data={code}\n language={language}\n className={isCompact ? 'text-xs' : 'text-sm'}\n customBg={isUser ? \"bg-white/10\" : \"bg-muted dark:bg-muted\"}\n mode={theme}\n isCompact={isCompact}\n />\n </div>\n );\n};\n\n// Custom components for markdown in chat\n// Base size: text-sm (14px) for normal, text-xs (12px) for compact\nconst createMarkdownComponents = (isUser: boolean = false, isCompact: boolean = false): Components => {\n // Text size classes based on compact mode\n const textSize = isCompact ? 'text-xs' : 'text-sm';\n const headingBase = isCompact ? 'text-sm' : 'text-base';\n const headingSm = isCompact ? 'text-xs' : 'text-sm';\n\n return {\n // Headings - scaled for chat context\n h1: ({ children }) => (\n <h1 className={`${headingBase} font-bold mb-2 mt-3 first:mt-0`}>{children}</h1>\n ),\n h2: ({ children }) => (\n <h2 className={`${headingSm} font-bold mb-2 mt-3 first:mt-0`}>{children}</h2>\n ),\n h3: ({ children }) => (\n <h3 className={`${headingSm} font-semibold mb-1 mt-2 first:mt-0`}>{children}</h3>\n ),\n h4: ({ children }) => (\n <h4 className={`${headingSm} font-semibold mb-1 mt-2 first:mt-0`}>{children}</h4>\n ),\n h5: ({ children }) => (\n <h5 className={`${headingSm} font-medium mb-1 mt-2 first:mt-0`}>{children}</h5>\n ),\n h6: ({ children }) => (\n <h6 className={`${headingSm} font-medium mb-1 mt-2 first:mt-0`}>{children}</h6>\n ),\n\n // Paragraphs - compact spacing for chat\n p: ({ children }) => (\n <p className={`${textSize} mb-2 last:mb-0 leading-relaxed break-words`}>{children}</p>\n ),\n\n // Lists - compact\n ul: ({ children }) => (\n <ul className={`list-disc list-inside mb-2 space-y-1 ${textSize}`}>{children}</ul>\n ),\n ol: ({ children }) => (\n <ol className={`list-decimal list-inside mb-2 space-y-1 ${textSize}`}>{children}</ol>\n ),\n li: ({ children }) => (\n <li className=\"break-words\">{children}</li>\n ),\n\n // Links - appropriate for chat context\n a: ({ href, children }) => (\n <a\n href={href}\n className={`${textSize} text-primary underline hover:text-primary/80 transition-colors break-all`}\n target={href?.startsWith('http') ? '_blank' : undefined}\n rel={href?.startsWith('http') ? 'noopener noreferrer' : undefined}\n >\n {children}\n </a>\n ),\n\n // Code blocks - using CodeBlock component with copy functionality\n pre: ({ children }) => {\n // Extract code content and language\n let codeContent = '';\n let language = 'plaintext';\n\n if (React.isValidElement(children)) {\n const child = children;\n\n if (child.type === 'code' || (typeof child.type === 'function' && child.type.name === 'code')) {\n const codeProps = child.props as { className?: string; children?: React.ReactNode };\n const rawClassName = codeProps.className;\n language = rawClassName?.replace(/language-/, '').trim() || 'plaintext';\n codeContent = extractTextFromChildren(codeProps.children).trim();\n } else {\n codeContent = extractTextFromChildren(children).trim();\n }\n } else {\n codeContent = extractTextFromChildren(children).trim();\n }\n\n // If still no content, show placeholder\n if (!codeContent) {\n return (\n <div className=\"my-3 p-3 bg-muted rounded text-sm text-muted-foreground\">\n No content available\n </div>\n );\n }\n\n // Handle Mermaid diagrams separately\n if (language === 'mermaid') {\n return (\n <div className=\"my-3 max-w-full overflow-x-auto\">\n <Mermaid chart={codeContent} className=\"max-w-[600px] mx-auto\" isCompact={isCompact} />\n </div>\n );\n }\n\n // Try to use CodeBlock component, fallback to simple pre if it fails\n try {\n return <CodeBlock code={codeContent} language={language} isUser={isUser} isCompact={isCompact} />;\n } catch (error) {\n // Fallback to simple pre element with copy button\n console.warn('CodeBlock failed, using fallback:', error);\n return (\n <div className=\"relative group my-3\">\n <CopyButton\n value={codeContent}\n variant=\"ghost\"\n className={`\n absolute top-2 right-2 z-10 opacity-0 group-hover:opacity-100 transition-opacity\n h-8 w-8\n ${isUser\n ? 'hover:bg-white/20 text-white'\n : 'hover:bg-muted-foreground/20 text-muted-foreground hover:text-foreground'\n }\n `}\n title=\"Copy code\"\n />\n <pre className={`\n p-3 rounded text-xs font-mono overflow-x-auto\n ${isUser\n ? 'bg-white/10 text-white'\n : 'bg-muted text-foreground'\n }\n `}>\n <code>{codeContent}</code>\n </pre>\n </div>\n );\n }\n },\n\n // Inline code\n code: ({ children, className }) => {\n // If it's inside a pre tag, let pre handle it\n if (className?.includes('language-')) {\n return <code className={className}>{children}</code>;\n }\n\n // Extract text content safely\n const codeContent = extractTextFromChildren(children);\n\n // Inline code styling\n return (\n <code className=\"px-1.5 py-0.5 rounded text-xs font-mono bg-muted text-foreground break-all\">\n {codeContent}\n </code>\n );\n },\n\n // Blockquotes\n blockquote: ({ children }) => (\n <blockquote className={`${textSize} border-l-2 border-border pl-3 my-2 italic text-muted-foreground break-words`}>\n {children}\n </blockquote>\n ),\n\n // Tables - compact for chat\n table: ({ children }) => (\n <div className=\"overflow-x-auto my-3\">\n <table className={`min-w-full ${textSize} border-collapse`}>\n {children}\n </table>\n </div>\n ),\n thead: ({ children }) => (\n <thead className=\"bg-muted/50\">\n {children}\n </thead>\n ),\n tbody: ({ children }) => (\n <tbody>{children}</tbody>\n ),\n tr: ({ children }) => (\n <tr className=\"border-b border-border/50\">{children}</tr>\n ),\n th: ({ children }) => (\n <th className=\"px-2 py-1 text-left font-medium break-words\">{children}</th>\n ),\n td: ({ children }) => (\n <td className=\"px-2 py-1 break-words\">{children}</td>\n ),\n\n // Horizontal rule\n hr: () => (\n <hr className=\"my-3 border-0 h-px bg-border\" />\n ),\n\n // Strong and emphasis\n strong: ({ children }) => (\n <strong className=\"font-semibold\">{children}</strong>\n ),\n em: ({ children }) => (\n <em className=\"italic\">{children}</em>\n ),\n};};\n\n// Check if content contains markdown syntax or line breaks\nconst hasMarkdownSyntax = (text: string): boolean => {\n // If there are line breaks (after trim), treat as markdown for proper paragraph rendering\n if (text.trim().includes('\\n')) {\n return true;\n }\n\n // Common markdown patterns\n const markdownPatterns = [\n /^#{1,6}\\s/m, // Headers\n /\\*\\*[^*]+\\*\\*/, // Bold\n /\\*[^*]+\\*/, // Italic\n /__[^_]+__/, // Bold (underscore)\n /_[^_]+_/, // Italic (underscore)\n /\\[.+\\]\\(.+\\)/, // Links\n /!\\[.*\\]\\(.+\\)/, // Images\n /```[\\s\\S]*```/, // Code blocks\n /`[^`]+`/, // Inline code\n /^\\s*[-*+]\\s/m, // Unordered lists\n /^\\s*\\d+\\.\\s/m, // Ordered lists\n /^\\s*>/m, // Blockquotes\n /\\|.+\\|/, // Tables\n /^---+$/m, // Horizontal rules\n /~~[^~]+~~/, // Strikethrough\n ];\n\n return markdownPatterns.some(pattern => pattern.test(text));\n};\n\n/**\n * MarkdownMessage - Renders markdown content with syntax highlighting and GFM support\n *\n * Features:\n * - GitHub Flavored Markdown (GFM) support\n * - Syntax highlighted code blocks with copy button\n * - Mermaid diagram rendering\n * - Tables, lists, blockquotes\n * - User/assistant styling modes\n * - Plain text optimization (skips ReactMarkdown for simple text)\n *\n * @example\n * ```tsx\n * <MarkdownMessage content=\"# Hello\\n\\nThis is **bold** text.\" />\n *\n * // User message styling\n * <MarkdownMessage content=\"Some content\" isUser />\n * ```\n */\nexport const MarkdownMessage: React.FC<MarkdownMessageProps> = ({\n content,\n className = \"\",\n isUser = false,\n isCompact = false,\n}) => {\n // Trim content to remove leading/trailing whitespace and empty lines\n const trimmedContent = content.trim();\n\n const components = React.useMemo(() => createMarkdownComponents(isUser, isCompact), [isUser, isCompact]);\n\n const textSizeClass = isCompact ? 'text-xs' : 'text-sm';\n const proseClass = isCompact ? 'prose-xs' : 'prose-sm';\n\n // For plain text without markdown, render directly without ReactMarkdown\n const isPlainText = !hasMarkdownSyntax(trimmedContent);\n\n if (isPlainText) {\n return (\n <span className={`${textSizeClass} leading-relaxed break-words ${className}`}>\n {trimmedContent}\n </span>\n );\n }\n\n return (\n <div\n className={`\n prose ${proseClass} max-w-none break-words overflow-hidden ${textSizeClass}\n ${isUser ? 'prose-invert' : 'dark:prose-invert'}\n ${className}\n `}\n style={{\n // Inherit colors from parent - fixes issues with external CSS variables\n '--tw-prose-body': 'inherit',\n '--tw-prose-headings': 'inherit',\n '--tw-prose-bold': 'inherit',\n '--tw-prose-links': 'inherit',\n color: 'inherit',\n } as React.CSSProperties}\n >\n <ReactMarkdown\n remarkPlugins={[remarkGfm]}\n components={components}\n >\n {trimmedContent}\n </ReactMarkdown>\n </div>\n );\n};\n\nexport default MarkdownMessage;\n"]}
1
+ {"version":3,"sources":["../src/tools/Mermaid/index.tsx","../src/tools/LottiePlayer/index.tsx","../src/tools/JsonForm/templates/FieldTemplate.tsx","../src/tools/JsonForm/templates/ObjectFieldTemplate.tsx","../src/tools/JsonForm/templates/ArrayFieldTemplate.tsx","../src/tools/JsonForm/templates/ArrayFieldItemTemplate.tsx","../src/tools/JsonForm/templates/ErrorListTemplate.tsx","../src/tools/JsonForm/templates/BaseInputTemplate.tsx","../src/tools/JsonForm/utils.ts","../src/tools/JsonForm/widgets/TextWidget.tsx","../src/tools/JsonForm/widgets/NumberWidget.tsx","../src/tools/JsonForm/widgets/CheckboxWidget.tsx","../src/tools/JsonForm/widgets/SelectWidget.tsx","../src/tools/JsonForm/widgets/SwitchWidget.tsx","../src/tools/JsonForm/widgets/ColorWidget.tsx","../src/tools/JsonForm/widgets/SliderWidget.tsx","../src/tools/JsonForm/JsonSchemaForm.tsx","../src/tools/OpenapiViewer/index.tsx","../src/stores/mediaCache.ts","../src/tools/VideoPlayer/utils/debug.ts","../src/tools/VideoPlayer/providers/VidstackProvider.tsx","../src/tools/VideoPlayer/hooks/useVideoPlayerSettings.ts","../src/tools/VideoPlayer/providers/NativeProvider.tsx","../src/tools/VideoPlayer/providers/StreamProvider.tsx","../src/tools/VideoPlayer/context/VideoPlayerContext.tsx","../src/tools/VideoPlayer/utils/resolvers.ts","../src/tools/VideoPlayer/utils/fileSource.ts","../src/tools/VideoPlayer/components/VideoPlayer.tsx","../src/tools/VideoPlayer/components/VideoControls.tsx","../src/tools/VideoPlayer/components/VideoErrorFallback.tsx","../src/tools/AudioPlayer/hooks/useHybridAudio.ts","../src/tools/AudioPlayer/hooks/useHybridAudioAnalysis.ts","../src/tools/AudioPlayer/hooks/useVisualization.tsx","../src/tools/AudioPlayer/context/HybridAudioProvider.tsx","../src/tools/AudioPlayer/components/HybridWaveform.tsx","../src/tools/AudioPlayer/utils/formatTime.ts","../src/tools/AudioPlayer/utils/debug.ts","../src/tools/AudioPlayer/components/HybridAudioPlayer.tsx","../src/tools/AudioPlayer/effects/index.ts","../src/tools/AudioPlayer/components/ReactiveCover/effects/GlowEffect.tsx","../src/tools/AudioPlayer/components/ReactiveCover/effects/OrbsEffect.tsx","../src/tools/AudioPlayer/components/ReactiveCover/effects/SpotlightEffect.tsx","../src/tools/AudioPlayer/components/ReactiveCover/effects/MeshEffect.tsx","../src/tools/AudioPlayer/components/ReactiveCover/AudioReactiveCover.tsx","../src/tools/AudioPlayer/components/HybridSimplePlayer.tsx","../src/tools/ImageViewer/utils/constants.ts","../src/tools/ImageViewer/utils/lqip.ts","../src/tools/ImageViewer/utils/debug.ts","../src/tools/ImageViewer/components/ImageToolbar.tsx","../src/tools/ImageViewer/components/ImageInfo.tsx","../src/tools/ImageViewer/hooks/useImageTransform.ts","../src/tools/ImageViewer/hooks/useImageLoading.ts","../src/tools/ImageViewer/components/ImageViewer.tsx","../src/components/markdown/useCollapsibleContent.ts","../src/components/markdown/MarkdownMessage.tsx"],"names":["lazy","LoadingFallback","jsx","jsxs","Suspense","cn","useMemo","useCallback","Input","hexValue","consola","Alert","AlertCircle","AlertDescription","Button","useEffect","useRef","useState","useVideoPlayerSettings","forwardRef","useImperativeHandle","DefaultErrorFallback","AspectRatio","Fragment","Preloader","formatTime","createContext","useContext","HybridWaveform","createMediaLogger","memo","HybridAudioPlayer","Pause","Play","VolumeX","Volume2","Slider","COLOR_SCHEMES","DropdownMenu","DropdownMenuTrigger","DropdownMenuContent","DropdownMenuItem","contentKey","url","React","useResolvedTheme"],"mappings":"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","file":"index.mjs","sourcesContent":["/**\n * Mermaid Component - Dynamic Import Wrapper\n *\n * Lazy loads the heavy Mermaid library (~800KB) only when needed.\n * This significantly reduces the initial bundle size.\n */\n\n'use client';\n\nimport React, { lazy, Suspense } from 'react';\n\n// Lazy load the client component\nconst MermaidClient = lazy(() => import('./Mermaid.client'));\n\n// Loading fallback component\nconst LoadingFallback = () => (\n <div className=\"relative bg-card rounded-sm border border-border overflow-hidden\">\n <div className=\"p-4 border-b border-border bg-muted/50\">\n <h6 className=\"text-sm font-semibold text-foreground\">Diagram</h6>\n <p className=\"text-xs text-muted-foreground mt-1\">Loading...</p>\n </div>\n <div className=\"p-4\">\n <div className=\"flex justify-center items-center min-h-[200px]\">\n <div className=\"animate-spin rounded-full h-8 w-8 border-b-2 border-primary\"></div>\n </div>\n </div>\n </div>\n);\n\ninterface MermaidProps {\n chart: string;\n className?: string;\n isCompact?: boolean;\n}\n\nconst Mermaid: React.FC<MermaidProps> = (props) => {\n return (\n <Suspense fallback={<LoadingFallback />}>\n <MermaidClient {...props} />\n </Suspense>\n );\n};\n\nexport default Mermaid;\n","/**\n * LottiePlayer - Dynamic Import Wrapper\n *\n * Lazy loads the LottiePlayer component for optimal bundle size\n */\n\n'use client';\n\nimport React, { lazy, Suspense } from 'react';\nimport { LottiePlayerProps } from './types';\n\n// Lazy load the client component\nconst LottiePlayerClient = lazy(() =>\n import('./LottiePlayer.client').then((mod) => ({ default: mod.LottiePlayer }))\n);\n\n// Loading fallback component\nconst LoadingFallback = () => (\n <div className=\"flex items-center justify-center p-8\">\n <div className=\"flex flex-col items-center gap-2\">\n <div className=\"h-8 w-8 animate-spin rounded-full border-4 border-gray-300 border-t-gray-900\" />\n <span className=\"text-sm text-gray-500\">Loading player...</span>\n </div>\n </div>\n);\n\n/**\n * LottiePlayer component wrapper with dynamic import\n *\n * This component automatically handles code splitting and lazy loading\n * of the Lottie player to optimize bundle size.\n *\n * Usage:\n * ```tsx\n * import { LottiePlayer } from '@djangocfg/ui-core/tools';\n *\n * <LottiePlayer\n * src=\"https://example.com/animation.json\"\n * size=\"md\"\n * autoplay\n * loop\n * />\n * ```\n */\nexport function LottiePlayer(props: LottiePlayerProps) {\n return (\n <Suspense fallback={<LoadingFallback />}>\n <LottiePlayerClient {...props} />\n </Suspense>\n );\n}\n\n// Re-export types for convenience\nexport type { LottiePlayerProps, LottieSize, LottieSpeed, LottieDirection } from './types';\nexport { useLottie } from './useLottie';\nexport type { UseLottieOptions, UseLottieReturn } from './useLottie';\n","\"use client\"\n\nimport React from 'react';\n\nimport { Label } from '@djangocfg/ui-core/components';\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { FieldTemplateProps } from '@rjsf/utils';\n\n/**\n * Field template for JSON Schema Form\n * Controls the layout and styling of individual form fields\n */\nexport function FieldTemplate(props: FieldTemplateProps) {\n const {\n id,\n classNames,\n style,\n label,\n help,\n required,\n description,\n errors,\n children,\n displayLabel,\n hidden,\n rawErrors,\n } = props;\n\n if (hidden) {\n return <div className=\"hidden\">{children}</div>;\n }\n\n const hasError = rawErrors && rawErrors.length > 0;\n\n return (\n <div\n className={cn('space-y-2', classNames)}\n style={style}\n >\n {displayLabel && label && (\n <Label htmlFor={id} className={cn(hasError && 'text-destructive')}>\n {label}\n {required && <span className=\"text-destructive ml-1\">*</span>}\n </Label>\n )}\n\n {description && (\n <div className=\"text-sm text-muted-foreground\">{description}</div>\n )}\n\n <div>{children}</div>\n\n {errors && (\n <div className=\"text-sm text-destructive\">{errors}</div>\n )}\n\n {help && (\n <div className=\"text-sm text-muted-foreground\">{help}</div>\n )}\n </div>\n );\n}\n","\"use client\"\n\nimport { ChevronDown } from 'lucide-react';\nimport React, { useState } from 'react';\n\nimport { Collapsible, CollapsibleContent, CollapsibleTrigger } from '@djangocfg/ui-core/components';\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { ObjectFieldTemplateProps } from '@rjsf/utils';\n\n/**\n * Object field template for JSON Schema Form\n *\n * Supports:\n * - Collapsible groups via ui:collapsible option\n * - Grid layout via ui:grid option\n * - Custom styling via ui:className\n *\n * Usage in uiSchema:\n * ```json\n * {\n * \"colors\": {\n * \"ui:collapsible\": true,\n * \"ui:collapsed\": false,\n * \"ui:grid\": 2\n * }\n * }\n * ```\n */\nexport function ObjectFieldTemplate(props: ObjectFieldTemplateProps) {\n const {\n title,\n description,\n properties,\n required,\n uiSchema,\n } = props;\n\n // UI options\n const isCollapsible = uiSchema?.['ui:collapsible'] === true;\n const defaultCollapsed = uiSchema?.['ui:collapsed'] === true;\n const gridCols = uiSchema?.['ui:grid'] as number | undefined;\n const className = uiSchema?.['ui:className'] as string | undefined;\n\n // Collapsible state\n const [isOpen, setIsOpen] = useState(!defaultCollapsed);\n\n // Check if this is root object (no title usually means root)\n const isRoot = !title;\n\n // Grid class based on columns\n const gridClass = gridCols\n ? `grid gap-4 grid-cols-${gridCols}`\n : 'space-y-4';\n\n // Content wrapper\n const content = (\n <div className={cn(gridClass, className)}>\n {properties.map((element) => (\n <div key={element.name} className=\"property-wrapper\">\n {element.content}\n </div>\n ))}\n </div>\n );\n\n // Root object - no wrapper\n if (isRoot) {\n return <div className=\"space-y-6\">{content}</div>;\n }\n\n // Collapsible group\n if (isCollapsible) {\n return (\n <Collapsible open={isOpen} onOpenChange={setIsOpen} className=\"space-y-2\">\n <CollapsibleTrigger className=\"flex w-full items-center justify-between rounded-lg border bg-muted/50 px-4 py-3 text-left hover:bg-muted transition-colors\">\n <div>\n <h3 className=\"text-sm font-semibold\">\n {title}\n {required && <span className=\"text-destructive ml-1\">*</span>}\n </h3>\n {description && (\n <p className=\"text-xs text-muted-foreground mt-0.5\">{description}</p>\n )}\n </div>\n <ChevronDown\n className={cn(\n 'h-4 w-4 text-muted-foreground transition-transform duration-200',\n isOpen && 'rotate-180'\n )}\n />\n </CollapsibleTrigger>\n <CollapsibleContent className=\"pl-1 pr-1 pt-2\">\n {content}\n </CollapsibleContent>\n </Collapsible>\n );\n }\n\n // Regular group with title\n return (\n <div className=\"space-y-4\">\n {title && (\n <div className=\"border-b pb-2\">\n <h3 className=\"text-sm font-semibold\">\n {title}\n {required && <span className=\"text-destructive ml-1\">*</span>}\n </h3>\n {description && (\n <p className=\"text-xs text-muted-foreground mt-1\">{description}</p>\n )}\n </div>\n )}\n {content}\n </div>\n );\n}\n","\"use client\"\n\nimport { Plus } from 'lucide-react';\nimport React from 'react';\n\nimport { Button } from '@djangocfg/ui-core/components';\nimport { ArrayFieldTemplateProps } from '@rjsf/utils';\n\n/**\n * Array field template for JSON Schema Form\n * Renders array items with add/remove controls\n *\n * NOTE: In RJSF v6, `items` is an array of ReactElement (already rendered),\n * NOT an array of objects with {children, hasRemove, etc.}.\n * The actual rendering of each item (including remove buttons) is handled\n * by ArrayFieldItemTemplate.\n */\nexport function ArrayFieldTemplate(props: ArrayFieldTemplateProps) {\n const {\n title,\n items,\n canAdd,\n onAddClick,\n required,\n } = props;\n\n return (\n <div className=\"space-y-4\">\n {title && (\n <div className=\"flex items-center justify-between\">\n <h3 className=\"text-lg font-semibold\">\n {title}\n {required && <span className=\"text-destructive ml-1\">*</span>}\n </h3>\n {canAdd && (\n <Button\n type=\"button\"\n variant=\"outline\"\n size=\"sm\"\n onClick={onAddClick}\n className=\"gap-2\"\n >\n <Plus className=\"h-4 w-4\" />\n Add Item\n </Button>\n )}\n </div>\n )}\n\n {/* In RJSF v6, items is already an array of ReactElements */}\n <div className=\"space-y-3\">\n {items}\n </div>\n\n {items.length === 0 && (\n <div className=\"text-center py-8 text-muted-foreground border-2 border-dashed rounded-md\">\n No items added yet.\n {canAdd && (\n <Button\n type=\"button\"\n variant=\"ghost\"\n size=\"sm\"\n onClick={onAddClick}\n className=\"mt-2 gap-2\"\n >\n <Plus className=\"h-4 w-4\" />\n Add First Item\n </Button>\n )}\n </div>\n )}\n </div>\n );\n}\n","\"use client\"\n\nimport React from 'react';\n\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { ArrayFieldItemTemplateProps, getTemplate, getUiOptions } from '@rjsf/utils';\n\n/**\n * Array field item template for JSON Schema Form\n * Renders individual array items with proper styling and action buttons\n *\n * In RJSF v6, this template is responsible for rendering each item in an array,\n * including the item content (children) and the action buttons (remove, move up/down, copy).\n */\nexport function ArrayFieldItemTemplate(props: ArrayFieldItemTemplateProps) {\n const {\n children,\n className,\n buttonsProps,\n hasToolbar,\n registry,\n uiSchema,\n } = props;\n\n const uiOptions = getUiOptions(uiSchema);\n const ArrayFieldItemButtonsTemplate = getTemplate(\n 'ArrayFieldItemButtonsTemplate',\n registry,\n uiOptions,\n );\n\n return (\n <div\n className={cn(\n 'flex gap-2 items-start p-4 rounded-md border bg-card',\n className\n )}\n >\n <div className=\"flex-1\">{children}</div>\n {hasToolbar && (\n <div className=\"flex items-center gap-1\">\n <ArrayFieldItemButtonsTemplate {...buttonsProps} />\n </div>\n )}\n </div>\n );\n}\n","\"use client\"\n\nimport { AlertCircle } from 'lucide-react';\nimport React from 'react';\n\nimport { Alert, AlertDescription, AlertTitle } from '@djangocfg/ui-core/components';\nimport { ErrorListProps } from '@rjsf/utils';\n\n/**\n * Error list template for JSON Schema Form\n * Displays validation errors at the top of the form\n */\nexport function ErrorListTemplate(props: ErrorListProps) {\n const { errors } = props;\n\n if (!errors || errors.length === 0) {\n return null;\n }\n\n return (\n <Alert variant=\"destructive\" className=\"mb-6\">\n <AlertCircle className=\"h-4 w-4\" />\n <AlertTitle>Validation Errors</AlertTitle>\n <AlertDescription>\n <ul className=\"list-disc list-inside space-y-1 mt-2\">\n {errors.map((error, index) => (\n <li key={index} className=\"text-sm\">\n {error.stack}\n </li>\n ))}\n </ul>\n </AlertDescription>\n </Alert>\n );\n}\n","\"use client\"\n\nimport React, { ChangeEvent, FocusEvent, useCallback, useMemo } from 'react';\n\nimport { Input } from '@djangocfg/ui-core/components';\nimport { getInputProps, WidgetProps } from '@rjsf/utils';\n\n/**\n * Base input template for JSON Schema Form\n *\n * This template is CRITICAL for rendering primitive types (string, number)\n * inside arrays. Without it, array items with primitive types will render\n * as empty containers.\n *\n * RJSF uses this template for:\n * - Array items with primitive types (e.g., array of strings)\n * - Fields without explicit widget mapping\n * - All text-based widgets internally\n *\n * @see https://rjsf-team.github.io/react-jsonschema-form/docs/advanced-customization/custom-templates/#baseinputtemplate\n */\nexport function BaseInputTemplate(props: WidgetProps) {\n const {\n id,\n type,\n value,\n readonly,\n disabled,\n autofocus,\n onBlur,\n onFocus,\n onChange,\n options,\n schema,\n rawErrors,\n placeholder,\n } = props;\n\n // Get input props from RJSF utils (handles step, min, max, etc.)\n const inputProps = useMemo(() => {\n return getInputProps(schema, type, options);\n }, [schema, type, options]);\n\n // Safely convert value to string for input\n const safeValue = useMemo(() => {\n if (value === null || value === undefined) return '';\n return String(value);\n }, [value]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n // Handle text change - transform empty strings based on schema type\n const handleChange = useCallback((event: ChangeEvent<HTMLInputElement>) => {\n const val = event.target.value;\n\n // Empty value handling\n if (val === '') {\n onChange(options?.emptyValue ?? '');\n return;\n }\n\n // Number type conversion\n if (inputProps.type === 'number' || schema.type === 'number' || schema.type === 'integer') {\n const num = Number(val);\n onChange(isNaN(num) ? val : num);\n return;\n }\n\n onChange(val);\n }, [onChange, inputProps.type, schema.type, options?.emptyValue]);\n\n const handleBlur = useCallback((event: FocusEvent<HTMLInputElement>) => {\n onBlur(id, event.target.value);\n }, [id, onBlur]);\n\n const handleFocus = useCallback((event: FocusEvent<HTMLInputElement>) => {\n onFocus(id, event.target.value);\n }, [id, onFocus]);\n\n // Determine input type\n const inputType = useMemo(() => {\n if (inputProps.type) return inputProps.type;\n if (schema.type === 'number' || schema.type === 'integer') return 'number';\n return 'text';\n }, [inputProps.type, schema.type]);\n\n return (\n <Input\n id={id}\n type={inputType}\n value={safeValue}\n disabled={disabled}\n readOnly={readonly}\n autoFocus={autofocus}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n placeholder={placeholder}\n className={hasError ? 'border-destructive' : ''}\n step={inputProps.step}\n min={inputProps.min}\n max={inputProps.max}\n />\n );\n}\n","import consola from 'consola';\n\nimport { RJSFSchema } from '@rjsf/utils';\n\n/**\n * Utility functions for JSON Schema Form\n */\n\n/**\n * Safely validates and normalizes JSON Schema\n * Ensures schema is valid before rendering\n */\nexport function validateSchema(schema: any): RJSFSchema | null {\n if (!schema || typeof schema !== 'object') {\n if (process.env.NODE_ENV === 'development') {\n consola.error('[JsonSchemaForm] Invalid schema: must be an object', schema);\n }\n return null;\n }\n\n // Basic schema validation - more permissive\n // Schema is valid if it has type OR properties OR $ref OR $schema\n const hasValidStructure =\n schema.type ||\n schema.properties ||\n schema.$ref ||\n schema.$schema;\n\n if (!hasValidStructure) {\n if (process.env.NODE_ENV === 'development') {\n consola.error('[JsonSchemaForm] Invalid schema: missing type, properties, $ref, or $schema', schema);\n }\n return null;\n }\n\n if (process.env.NODE_ENV === 'development') {\n consola.success('[JsonSchemaForm] Schema validated successfully:', {\n type: schema.type,\n title: schema.title,\n hasProperties: !!schema.properties,\n hasRequired: !!schema.required,\n });\n }\n\n return schema as RJSFSchema;\n}\n\n/**\n * Safely normalizes form data\n * Removes undefined values and ensures data structure matches schema\n */\nexport function normalizeFormData<T = any>(\n formData: any,\n schema: RJSFSchema\n): T {\n if (formData === null || formData === undefined) {\n return (schema.type === 'object' ? {} : schema.type === 'array' ? [] : null) as T;\n }\n\n // Deep clone to avoid mutations\n const normalized = JSON.parse(JSON.stringify(formData));\n\n // Remove undefined values recursively\n return removeUndefined(normalized) as T;\n}\n\n/**\n * Recursively removes undefined values from an object\n */\nfunction removeUndefined(obj: any): any {\n if (obj === null || obj === undefined) {\n return obj;\n }\n\n if (Array.isArray(obj)) {\n return obj.map(removeUndefined).filter((item) => item !== undefined);\n }\n\n if (typeof obj === 'object') {\n const cleaned: any = {};\n for (const key in obj) {\n if (obj[key] !== undefined) {\n cleaned[key] = removeUndefined(obj[key]);\n }\n }\n return cleaned;\n }\n\n return obj;\n}\n\n/**\n * Merges schema defaults with form data\n */\nexport function mergeDefaults(\n formData: any,\n schema: RJSFSchema\n): any {\n if (!schema) return formData;\n\n const result = { ...formData };\n\n if (schema.type === 'object' && schema.properties) {\n for (const [key, propSchema] of Object.entries(schema.properties)) {\n const prop = propSchema as RJSFSchema;\n\n // Apply default if field is missing\n if (result[key] === undefined && prop.default !== undefined) {\n result[key] = prop.default;\n }\n\n // Recursively merge nested objects\n if (prop.type === 'object' && result[key]) {\n result[key] = mergeDefaults(result[key], prop);\n }\n }\n }\n\n return result;\n}\n\n/**\n * Safely parses JSON string with error handling\n */\nexport function safeJsonParse<T = any>(\n jsonString: string,\n fallback: T\n): T {\n try {\n return JSON.parse(jsonString);\n } catch (error) {\n consola.error('[JsonSchemaForm] JSON parse error:', error);\n return fallback;\n }\n}\n\n/**\n * Safely stringifies object to JSON\n */\nexport function safeJsonStringify(\n obj: any,\n pretty: boolean = true\n): string {\n try {\n return JSON.stringify(obj, null, pretty ? 2 : 0);\n } catch (error) {\n consola.error('[JsonSchemaForm] JSON stringify error:', error);\n return '{}';\n }\n}\n\n/**\n * Checks if schema has required fields\n */\nexport function hasRequiredFields(schema: RJSFSchema): boolean {\n return Array.isArray(schema.required) && schema.required.length > 0;\n}\n\n/**\n * Gets all required field paths from schema\n */\nexport function getRequiredFields(\n schema: RJSFSchema,\n prefix: string = ''\n): string[] {\n const required: string[] = [];\n\n if (schema.required && Array.isArray(schema.required)) {\n required.push(...schema.required.map((field) =>\n prefix ? `${prefix}.${field}` : field\n ));\n }\n\n if (schema.type === 'object' && schema.properties) {\n for (const [key, propSchema] of Object.entries(schema.properties)) {\n const prop = propSchema as RJSFSchema;\n const fieldPath = prefix ? `${prefix}.${key}` : key;\n required.push(...getRequiredFields(prop, fieldPath));\n }\n }\n\n return required;\n}\n\n/**\n * Validates form data against required fields\n */\nexport function validateRequiredFields(\n formData: any,\n schema: RJSFSchema\n): { valid: boolean; missing: string[] } {\n const requiredFields = getRequiredFields(schema);\n const missing: string[] = [];\n\n for (const field of requiredFields) {\n const value = getNestedValue(formData, field);\n if (value === undefined || value === null || value === '') {\n missing.push(field);\n }\n }\n\n return {\n valid: missing.length === 0,\n missing,\n };\n}\n\n/**\n * Gets nested value from object by path\n */\nfunction getNestedValue(obj: any, path: string): any {\n return path.split('.').reduce((current, key) => current?.[key], obj);\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Input } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Text input widget for JSON Schema Form\n * Handles string fields with optional textarea for multiline\n */\nexport function TextWidget(props: WidgetProps) {\n const {\n id,\n placeholder,\n required,\n disabled,\n readonly,\n autofocus,\n value,\n onChange,\n onBlur,\n onFocus,\n options,\n schema,\n rawErrors,\n } = props;\n\n // Memoize widget configuration\n const config = useMemo(() => ({\n isTextarea: options?.widget === 'textarea',\n rows: options?.rows || 3,\n emptyValue: options?.emptyValue,\n }), [options]);\n\n // Ensure value is always a string\n const safeValue = useMemo(() => {\n if (value === null || value === undefined) return '';\n return String(value);\n }, [value]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n const handleChange = useCallback((event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n const newValue = event.target.value;\n onChange(newValue === '' ? config.emptyValue : newValue);\n }, [onChange, config.emptyValue]);\n\n const handleBlur = useCallback((event: React.FocusEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n onBlur(id, event.target.value);\n }, [id, onBlur]);\n\n const handleFocus = useCallback((event: React.FocusEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n onFocus(id, event.target.value);\n }, [id, onFocus]);\n\n if (config.isTextarea) {\n return (\n <textarea\n id={id}\n className={`flex min-h-[80px] w-full rounded-md border ${\n hasError ? 'border-destructive' : 'border-input'\n } bg-transparent px-3 py-2 text-base shadow-sm transition-colors placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm`}\n placeholder={placeholder}\n disabled={disabled || readonly}\n readOnly={readonly}\n autoFocus={autofocus}\n value={safeValue}\n required={required}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n rows={config.rows}\n />\n );\n }\n\n return (\n <Input\n id={id}\n type=\"text\"\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readonly}\n autoFocus={autofocus}\n value={safeValue}\n required={required}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n className={hasError ? 'border-destructive' : ''}\n />\n );\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Input } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Number input widget for JSON Schema Form\n * Handles integer and number fields\n */\nexport function NumberWidget(props: WidgetProps) {\n const {\n id,\n placeholder,\n required,\n disabled,\n readonly,\n autofocus,\n value,\n onChange,\n onBlur,\n onFocus,\n options,\n schema,\n rawErrors,\n } = props;\n\n // Memoize widget configuration\n const config = useMemo(() => ({\n isInteger: schema.type === 'integer',\n step: schema.type === 'integer' ? '1' : 'any',\n min: schema.minimum,\n max: schema.maximum,\n emptyValue: options?.emptyValue,\n }), [schema, options]);\n\n // Ensure value is valid number or empty string\n const safeValue = useMemo(() => {\n if (value === null || value === undefined || value === '') return '';\n if (typeof value === 'number' && !isNaN(value)) return value;\n return '';\n }, [value]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n const handleChange = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = event.target.value;\n if (newValue === '') {\n onChange(config.emptyValue);\n } else {\n const parsedValue = config.isInteger\n ? parseInt(newValue, 10)\n : parseFloat(newValue);\n\n onChange(isNaN(parsedValue) ? config.emptyValue : parsedValue);\n }\n }, [onChange, config]);\n\n const handleBlur = useCallback((event: React.FocusEvent<HTMLInputElement>) => {\n onBlur(id, event.target.value);\n }, [id, onBlur]);\n\n const handleFocus = useCallback((event: React.FocusEvent<HTMLInputElement>) => {\n onFocus(id, event.target.value);\n }, [id, onFocus]);\n\n return (\n <Input\n id={id}\n type=\"number\"\n placeholder={placeholder}\n disabled={disabled}\n readOnly={readonly}\n autoFocus={autofocus}\n value={safeValue}\n required={required}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n step={config.step}\n min={config.min}\n max={config.max}\n className={hasError ? 'border-destructive' : ''}\n />\n );\n}\n","import React from 'react';\n\nimport { Checkbox } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Checkbox widget for JSON Schema Form\n * Handles boolean fields\n */\nexport function CheckboxWidget(props: WidgetProps) {\n const {\n id,\n value,\n disabled,\n readonly,\n autofocus,\n onChange,\n onBlur,\n onFocus,\n } = props;\n\n const handleChange = (checked: boolean) => {\n onChange(checked);\n };\n\n return (\n <Checkbox\n id={id}\n checked={value || false}\n disabled={disabled || readonly}\n autoFocus={autofocus}\n onCheckedChange={handleChange}\n onBlur={() => onBlur(id, value)}\n onFocus={() => onFocus(id, value)}\n />\n );\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport {\n Select, SelectContent, SelectItem, SelectTrigger, SelectValue\n} from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Select dropdown widget for JSON Schema Form\n * Handles enum fields\n */\nexport function SelectWidget(props: WidgetProps) {\n const {\n id,\n options,\n value,\n required,\n disabled,\n readonly,\n autofocus,\n onChange,\n onBlur,\n onFocus,\n placeholder,\n rawErrors,\n } = props;\n\n // Safely extract and validate enum options\n const enumOptions = useMemo(() => {\n const opts = options?.enumOptions;\n if (!Array.isArray(opts)) return [];\n return opts.filter(opt => opt && (opt.value !== undefined));\n }, [options]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n // Ensure value is always a string\n const safeValue = useMemo(() => {\n if (value === null || value === undefined) return '';\n return String(value);\n }, [value]);\n\n const handleChange = useCallback((newValue: string) => {\n onChange(newValue);\n onBlur(id, newValue);\n }, [onChange, onBlur, id]);\n\n // If no enum options, render a text input instead\n // This handles cases like anyOf/oneOf where RJSF might incorrectly use SelectWidget\n if (enumOptions.length === 0) {\n return (\n <input\n id={id}\n type=\"text\"\n value={safeValue}\n onChange={(e) => onChange(e.target.value)}\n onBlur={(e) => onBlur(id, e.target.value)}\n onFocus={(e) => onFocus(id, e.target.value)}\n disabled={disabled || readonly}\n readOnly={readonly}\n className={`flex h-10 w-full rounded-md border ${\n hasError ? 'border-destructive' : 'border-input'\n } bg-transparent px-3 py-2 text-base shadow-sm transition-colors placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 md:text-sm`}\n placeholder={placeholder}\n />\n );\n }\n\n return (\n <Select\n value={safeValue}\n onValueChange={handleChange}\n disabled={disabled || readonly}\n required={required}\n >\n <SelectTrigger\n id={id}\n className={hasError ? 'border-destructive' : ''}\n autoFocus={autofocus}\n onFocus={() => onFocus(id, value)}\n >\n <SelectValue placeholder={placeholder || 'Select an option'} />\n </SelectTrigger>\n <SelectContent>\n {enumOptions.map((option: any) => (\n <SelectItem key={String(option.value)} value={String(option.value)}>\n {option.label || String(option.value)}\n </SelectItem>\n ))}\n </SelectContent>\n </Select>\n );\n}\n","import React from 'react';\n\nimport { Switch } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Switch toggle widget for JSON Schema Form\n * Alternative boolean input\n */\nexport function SwitchWidget(props: WidgetProps) {\n const {\n id,\n value,\n disabled,\n readonly,\n onChange,\n onBlur,\n onFocus,\n } = props;\n\n const handleChange = (checked: boolean) => {\n onChange(checked);\n };\n\n return (\n <Switch\n id={id}\n checked={value || false}\n disabled={disabled || readonly}\n onCheckedChange={handleChange}\n onBlur={() => onBlur(id, value)}\n onFocus={() => onFocus(id, value)}\n />\n );\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo, useRef } from 'react';\n\nimport { Input } from '@djangocfg/ui-core/components';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Color input widget for JSON Schema Form\n * Supports HSL format (h s% l%) and HEX format\n * Click on color box to open native color picker directly\n */\nexport function ColorWidget(props: WidgetProps) {\n const {\n id,\n placeholder,\n required,\n disabled,\n readonly,\n autofocus,\n value,\n onChange,\n onBlur,\n onFocus,\n options,\n rawErrors,\n } = props;\n\n const colorInputRef = useRef<HTMLInputElement>(null);\n\n // Determine format from options or auto-detect from value\n const format = useMemo(() => {\n if (options?.format) return options.format as 'hsl' | 'hex';\n if (typeof value === 'string' && value.startsWith('#')) return 'hex';\n return 'hsl';\n }, [options?.format, value]);\n\n // Ensure value is always a string\n const safeValue = useMemo(() => {\n if (value === null || value === undefined) return '';\n return String(value);\n }, [value]);\n\n // Convert HSL string (like \"217 91% 60%\") to CSS hsl() value\n const hslToCss = useCallback((hslValue: string): string => {\n if (!hslValue) return 'transparent';\n if (hslValue.startsWith('#')) return hslValue;\n if (hslValue.startsWith('hsl')) return hslValue;\n // Format: \"h s% l%\" -> \"hsl(h, s%, l%)\"\n const parts = hslValue.split(' ');\n if (parts.length === 3) {\n return `hsl(${parts[0]}, ${parts[1]}, ${parts[2]})`;\n }\n return 'transparent';\n }, []);\n\n // Convert CSS color to preview color\n const previewColor = useMemo(() => {\n return hslToCss(safeValue);\n }, [safeValue, hslToCss]);\n\n // Convert hex to HSL string for internal storage\n const hexToHsl = useCallback((hex: string): string => {\n // Remove # if present\n hex = hex.replace('#', '');\n\n // Parse hex values\n const r = parseInt(hex.substring(0, 2), 16) / 255;\n const g = parseInt(hex.substring(2, 4), 16) / 255;\n const b = parseInt(hex.substring(4, 6), 16) / 255;\n\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n let h = 0;\n let s = 0;\n const l = (max + min) / 2;\n\n if (max !== min) {\n const d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n\n switch (max) {\n case r:\n h = ((g - b) / d + (g < b ? 6 : 0)) / 6;\n break;\n case g:\n h = ((b - r) / d + 2) / 6;\n break;\n case b:\n h = ((r - g) / d + 4) / 6;\n break;\n }\n }\n\n return `${Math.round(h * 360)} ${Math.round(s * 100)}% ${Math.round(l * 100)}%`;\n }, []);\n\n // Convert HSL to hex\n const hslToHex = useCallback((hslValue: string): string => {\n if (!hslValue || hslValue.startsWith('#')) return hslValue || '#000000';\n\n const parts = hslValue.split(' ');\n if (parts.length !== 3) return '#000000';\n\n const h = parseInt(parts[0]) / 360;\n const s = parseInt(parts[1].replace('%', '')) / 100;\n const l = parseInt(parts[2].replace('%', '')) / 100;\n\n const hue2rgb = (p: number, q: number, t: number) => {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1/6) return p + (q - p) * 6 * t;\n if (t < 1/2) return q;\n if (t < 2/3) return p + (q - p) * (2/3 - t) * 6;\n return p;\n };\n\n let r, g, b;\n if (s === 0) {\n r = g = b = l;\n } else {\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n r = hue2rgb(p, q, h + 1/3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1/3);\n }\n\n const toHex = (x: number) => {\n const hex = Math.round(x * 255).toString(16);\n return hex.length === 1 ? '0' + hex : hex;\n };\n\n return `#${toHex(r)}${toHex(g)}${toHex(b)}`;\n }, []);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n const handleChange = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const newValue = event.target.value;\n onChange(newValue);\n }, [onChange]);\n\n const handleColorPickerChange = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const hexValue = event.target.value;\n if (format === 'hsl') {\n onChange(hexToHsl(hexValue));\n } else {\n onChange(hexValue);\n }\n }, [onChange, format, hexToHsl]);\n\n const handleBlur = useCallback((event: React.FocusEvent<HTMLInputElement>) => {\n onBlur(id, event.target.value);\n }, [id, onBlur]);\n\n const handleFocus = useCallback((event: React.FocusEvent<HTMLInputElement>) => {\n onFocus(id, event.target.value);\n }, [id, onFocus]);\n\n // Get hex value for native color picker\n const hexValue = useMemo(() => {\n if (format === 'hex' || safeValue.startsWith('#')) {\n return safeValue || '#000000';\n }\n return hslToHex(safeValue);\n }, [safeValue, format, hslToHex]);\n\n // Click on color box opens native color picker\n const handleColorBoxClick = useCallback(() => {\n if (!disabled && !readonly) {\n colorInputRef.current?.click();\n }\n }, [disabled, readonly]);\n\n return (\n <div className=\"flex items-center gap-2\">\n {/* Color preview box - clicking opens native picker */}\n <div className=\"relative\">\n <button\n type=\"button\"\n onClick={handleColorBoxClick}\n disabled={disabled || readonly}\n className=\"h-10 w-10 shrink-0 rounded-md border-2 border-input cursor-pointer hover:border-ring focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50\"\n style={{ backgroundColor: previewColor }}\n aria-label=\"Pick color\"\n />\n {/* Hidden native color input */}\n <input\n ref={colorInputRef}\n type=\"color\"\n value={hexValue}\n onChange={handleColorPickerChange}\n className=\"absolute inset-0 opacity-0 w-full h-full cursor-pointer\"\n disabled={disabled || readonly}\n tabIndex={-1}\n />\n </div>\n\n {/* Text input for manual HSL/HEX entry */}\n <Input\n id={id}\n type=\"text\"\n placeholder={placeholder || (format === 'hsl' ? '217 91% 60%' : '#3b82f6')}\n disabled={disabled}\n readOnly={readonly}\n autoFocus={autofocus}\n value={safeValue}\n required={required}\n onChange={handleChange}\n onBlur={handleBlur}\n onFocus={handleFocus}\n className={`flex-1 font-mono text-sm ${hasError ? 'border-destructive' : ''}`}\n />\n </div>\n );\n}\n","\"use client\"\n\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Input, Slider } from '@djangocfg/ui-core/components';\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { WidgetProps } from '@rjsf/utils';\n\n/**\n * Slider widget for JSON Schema Form\n *\n * Supports:\n * - number/integer types\n * - min/max from schema\n * - step from schema or options\n * - unit suffix (e.g., \"rem\", \"px\", \"%\")\n * - optional text input for precise values\n *\n * Usage in uiSchema:\n * ```json\n * {\n * \"radius\": {\n * \"ui:widget\": \"slider\",\n * \"ui:options\": {\n * \"unit\": \"rem\",\n * \"showInput\": true,\n * \"step\": 0.125\n * }\n * }\n * }\n * ```\n */\nexport function SliderWidget(props: WidgetProps) {\n const {\n id,\n disabled,\n readonly,\n value,\n onChange,\n schema,\n options,\n rawErrors,\n } = props;\n\n // Extract configuration\n const config = useMemo(() => {\n const min = schema.minimum ?? options?.min ?? 0;\n const max = schema.maximum ?? options?.max ?? 100;\n const step = options?.step ?? (schema.type === 'integer' ? 1 : 0.1);\n const unit = options?.unit as string | undefined;\n const showInput = options?.showInput !== false; // default true\n\n return { min, max, step, unit, showInput };\n }, [schema, options]);\n\n // Parse value - handle string values like \"0.5rem\"\n const numericValue = useMemo(() => {\n if (value === null || value === undefined || value === '') {\n return config.min;\n }\n if (typeof value === 'number') {\n return value;\n }\n if (typeof value === 'string') {\n // Extract number from string like \"0.5rem\"\n const parsed = parseFloat(value);\n return isNaN(parsed) ? config.min : parsed;\n }\n return config.min;\n }, [value, config.min]);\n\n const hasError = useMemo(() => {\n return rawErrors && rawErrors.length > 0;\n }, [rawErrors]);\n\n // Handle slider change\n const handleSliderChange = useCallback((values: number[]) => {\n const newValue = values[0];\n if (config.unit) {\n onChange(`${newValue}${config.unit}`);\n } else {\n onChange(newValue);\n }\n }, [onChange, config.unit]);\n\n // Handle text input change\n const handleInputChange = useCallback((event: React.ChangeEvent<HTMLInputElement>) => {\n const inputValue = event.target.value;\n\n // If has unit, just store raw value with unit\n if (config.unit) {\n // Remove unit if user typed it, then add it back\n const cleanValue = inputValue.replace(config.unit, '').trim();\n const parsed = parseFloat(cleanValue);\n if (!isNaN(parsed)) {\n onChange(`${parsed}${config.unit}`);\n } else if (inputValue === '') {\n onChange(`${config.min}${config.unit}`);\n }\n } else {\n const parsed = parseFloat(inputValue);\n onChange(isNaN(parsed) ? config.min : parsed);\n }\n }, [onChange, config.unit, config.min]);\n\n // Display value with unit\n const displayValue = useMemo(() => {\n if (config.unit) {\n return `${numericValue}${config.unit}`;\n }\n return String(numericValue);\n }, [numericValue, config.unit]);\n\n return (\n <div className={cn('flex items-center gap-3', hasError && 'text-destructive')}>\n {/* Slider */}\n <Slider\n id={id}\n disabled={disabled || readonly}\n value={[numericValue]}\n onValueChange={handleSliderChange}\n min={config.min}\n max={config.max}\n step={config.step}\n className=\"flex-1\"\n />\n\n {/* Value input or display */}\n {config.showInput ? (\n <Input\n type=\"text\"\n value={displayValue}\n onChange={handleInputChange}\n disabled={disabled}\n readOnly={readonly}\n className={cn(\n 'w-20 text-center font-mono text-sm',\n hasError && 'border-destructive'\n )}\n />\n ) : (\n <span className=\"w-16 text-right font-mono text-sm text-muted-foreground\">\n {displayValue}\n </span>\n )}\n </div>\n );\n}\n","'use client';\n\nimport consola from 'consola';\nimport { AlertCircle } from 'lucide-react';\nimport React, { useCallback, useMemo } from 'react';\n\nimport { Alert, AlertDescription, Button } from '@djangocfg/ui-core/components';\nimport Form from '@rjsf/core';\nimport { RegistryWidgetsType } from '@rjsf/utils';\nimport validator from '@rjsf/validator-ajv8';\n\nimport {\n ArrayFieldItemTemplate, ArrayFieldTemplate, BaseInputTemplate, ErrorListTemplate, FieldTemplate,\n ObjectFieldTemplate\n} from './templates';\nimport { JsonSchemaFormProps } from './types';\nimport { normalizeFormData, validateSchema } from './utils';\nimport {\n CheckboxWidget, ColorWidget, NumberWidget, SelectWidget, SliderWidget, SwitchWidget, TextWidget\n} from './widgets';\n\n/**\n * JSON Schema Form Component\n *\n * A fully-featured form generator that creates forms from JSON Schema.\n * Built on top of react-jsonschema-form with custom widgets and templates\n * using @djangocfg/ui components.\n *\n * @example\n * ```tsx\n * const schema = {\n * type: 'object',\n * required: ['name'],\n * properties: {\n * name: { type: 'string', title: 'Name' },\n * age: { type: 'number', title: 'Age' },\n * active: { type: 'boolean', title: 'Active' }\n * }\n * };\n *\n * <JsonSchemaForm\n * schema={schema}\n * onSubmit={(data) => console.log(data.formData)}\n * />\n * ```\n */\nexport function JsonSchemaForm<T = any>(props: JsonSchemaFormProps<T>) {\n const {\n schema,\n uiSchema,\n formData,\n onSubmit,\n onChange,\n onError,\n showErrorList = 'top',\n liveValidate = false,\n disabled = false,\n readonly = false,\n className,\n showSubmitButton = true,\n submitButtonText = 'Submit',\n ...restProps\n } = props;\n\n // Validate and normalize schema before render\n const validatedSchema = useMemo(() => {\n if (process.env.NODE_ENV === 'development') {\n consola.info('[JsonSchemaForm] Validating schema...', schema);\n }\n const result = validateSchema(schema);\n if (!result && process.env.NODE_ENV === 'development') {\n consola.error('[JsonSchemaForm] Schema validation failed');\n }\n return result;\n }, [schema]);\n\n // Normalize form data before render\n const normalizedFormData = useMemo(() => {\n if (!validatedSchema) {\n if (process.env.NODE_ENV === 'development') {\n consola.warn('[JsonSchemaForm] Cannot normalize formData - invalid schema');\n }\n return null;\n }\n if (process.env.NODE_ENV === 'development') {\n consola.info('[JsonSchemaForm] Normalizing formData...', formData);\n }\n const normalized = normalizeFormData<T>(formData, validatedSchema);\n if (process.env.NODE_ENV === 'development') {\n consola.info('[JsonSchemaForm] Normalized formData:', normalized);\n }\n return normalized;\n }, [formData, validatedSchema]);\n\n // Memoize widgets mapping to prevent recreation on every render\n // IMPORTANT: Widget keys must match RJSF's expected names:\n // - For type: string -> uses 'TextWidget' or 'text'\n // - For type: number/integer -> uses 'updown' or 'range'\n // - For type: boolean -> uses 'checkbox' or 'select'\n // - For enum fields -> uses 'SelectWidget' or 'select'\n const widgets: RegistryWidgetsType = useMemo(() => ({\n // Standard widget names (PascalCase) - used by RJSF internally\n TextWidget,\n NumberWidget,\n CheckboxWidget,\n SelectWidget,\n SwitchWidget,\n ColorWidget,\n SliderWidget,\n // Lowercase aliases - for uiSchema 'ui:widget' references\n text: TextWidget,\n number: NumberWidget,\n checkbox: CheckboxWidget,\n select: SelectWidget,\n switch: SwitchWidget,\n color: ColorWidget,\n slider: SliderWidget,\n range: SliderWidget, // alias\n }), []);\n\n // Memoize templates to prevent recreation on every render\n const templates = useMemo(() => ({\n FieldTemplate,\n ObjectFieldTemplate,\n ArrayFieldTemplate,\n ArrayFieldItemTemplate,\n ErrorListTemplate,\n BaseInputTemplate,\n }), []);\n\n // Memoize callbacks\n const handleSubmit = useCallback((data: any) => {\n if (onSubmit) {\n // Ensure clean data on submit\n const cleanData = {\n ...data,\n formData: normalizeFormData(data.formData, validatedSchema!),\n };\n onSubmit(cleanData);\n }\n }, [onSubmit, validatedSchema]);\n\n const handleChange = useCallback((data: any) => {\n if (onChange) {\n onChange(data);\n }\n }, [onChange]);\n\n const handleError = useCallback((errors: any) => {\n if (onError) {\n onError(errors);\n }\n }, [onError]);\n\n // Early return if schema is invalid\n if (!validatedSchema) {\n return (\n <div className={className}>\n <Alert variant=\"destructive\">\n <AlertCircle className=\"h-4 w-4\" />\n <AlertDescription>\n Invalid schema provided. Please check the schema format.\n </AlertDescription>\n </Alert>\n </div>\n );\n }\n\n return (\n <div className={className}>\n <Form\n schema={validatedSchema}\n uiSchema={uiSchema}\n formData={normalizedFormData}\n validator={validator}\n widgets={widgets}\n templates={templates}\n onSubmit={handleSubmit}\n onChange={handleChange}\n onError={handleError}\n showErrorList={showErrorList}\n liveValidate={liveValidate}\n disabled={disabled}\n readonly={readonly}\n {...restProps}\n >\n {showSubmitButton && (\n <div className=\"mt-6 flex gap-2\">\n <Button type=\"submit\" disabled={disabled}>\n {submitButtonText}\n </Button>\n </div>\n )}\n </Form>\n </div>\n );\n}\n","'use client';\n\nimport React, { lazy, Suspense } from 'react';\nimport { PlaygroundProvider } from './context/PlaygroundContext';\nimport type { PlaygroundConfig } from './types';\n\n// Lazy load the PlaygroundLayout component\nconst PlaygroundLayout = lazy(() =>\n import('./components/PlaygroundLayout').then((mod) => ({ default: mod.PlaygroundLayout }))\n);\n\n// Loading fallback component\nconst LoadingFallback = () => (\n <div className=\"flex items-center justify-center min-h-[400px]\">\n <div className=\"text-muted-foreground\">Loading API Playground...</div>\n </div>\n);\n\nexport interface PlaygroundProps {\n config: PlaygroundConfig;\n}\n\nexport const Playground: React.FC<PlaygroundProps> = ({ config }) => {\n return (\n <PlaygroundProvider config={config}>\n <Suspense fallback={<LoadingFallback />}>\n <PlaygroundLayout />\n </Suspense>\n </PlaygroundProvider>\n );\n};\n\n// Re-export types for convenience\nexport type { PlaygroundConfig, SchemaSource } from './types';\n\n// Default export for dynamic import\nexport default Playground;\n","'use client';\n\nimport { create } from 'zustand';\nimport { persist, devtools } from 'zustand/middleware';\nimport { useShallow } from 'zustand/react/shallow';\nimport { createLogger } from '@djangocfg/ui-core/lib';\n\nconst cacheDebug = createLogger('MediaCache');\n\n// Types\ninterface BlobUrlEntry {\n url: string;\n refCount: number;\n createdAt: number;\n}\n\ninterface ImageDimensions {\n width: number;\n height: number;\n}\n\ninterface VideoMetadata {\n duration: number;\n width: number;\n height: number;\n codec?: string;\n}\n\ninterface EffectConfig {\n opacity: number;\n scale: number;\n blur: string;\n}\n\n/** Video player settings (persisted) */\ninterface VideoPlayerSettings {\n volume: number;\n isLooping: boolean;\n}\n\n// Stream URL TTL (30 seconds - shorter to avoid stale session/token issues)\nconst STREAM_URL_TTL = 30 * 1000;\n\ninterface MediaCacheState {\n // Blob URL cache (shared by Image, Audio, Video)\n blobUrls: Map<string, BlobUrlEntry>;\n\n // Image-specific\n imageDimensions: Map<string, ImageDimensions>;\n\n // Audio-specific\n audioPlaybackPositions: Map<string, number>;\n audioEffectConfigs: Map<string, EffectConfig>;\n\n // Video-specific\n videoStreamUrls: Map<string, { url: string; timestamp: number }>;\n videoPosterUrls: Map<string, string>;\n videoPlaybackPositions: Map<string, number>;\n videoMetadata: Map<string, VideoMetadata>;\n videoPlayerSettings: VideoPlayerSettings;\n}\n\ninterface MediaCacheActions {\n // Blob URL management (shared)\n getOrCreateBlobUrl: (\n key: string,\n content: ArrayBuffer,\n mimeType: string\n ) => string;\n releaseBlobUrl: (key: string) => void;\n hasBlobUrl: (key: string) => boolean;\n\n // Image actions\n cacheDimensions: (src: string, dims: ImageDimensions) => void;\n getDimensions: (src: string) => ImageDimensions | null;\n\n // Audio actions\n saveAudioPosition: (uri: string, time: number) => void;\n getAudioPosition: (uri: string) => number | null;\n getEffectConfig: (key: string) => EffectConfig | null;\n cacheEffectConfig: (key: string, config: EffectConfig) => void;\n\n // Video actions\n getOrCreateStreamUrl: (\n sessionId: string,\n path: string,\n generator: (sessionId: string, path: string) => string\n ) => string;\n getPosterUrl: (title: string) => string | null;\n cachePosterUrl: (title: string, url: string) => void;\n saveVideoPosition: (key: string, time: number) => void;\n getVideoPosition: (key: string) => number | null;\n cacheVideoMetadata: (url: string, meta: VideoMetadata) => void;\n getVideoMetadata: (url: string) => VideoMetadata | null;\n invalidateSession: (sessionId: string) => void;\n getVideoPlayerSettings: () => VideoPlayerSettings;\n saveVideoPlayerSettings: (settings: Partial<VideoPlayerSettings>) => void;\n\n // Global\n clearCache: () => void;\n getCacheStats: () => {\n blobUrls: number;\n dimensions: number;\n audioPositions: number;\n videoPositions: number;\n };\n}\n\ntype MediaCacheStore = MediaCacheState & MediaCacheActions;\n\n// Initial state\nconst DEFAULT_VIDEO_SETTINGS: VideoPlayerSettings = {\n volume: 1,\n isLooping: false,\n};\n\nconst initialState: MediaCacheState = {\n blobUrls: new Map(),\n imageDimensions: new Map(),\n audioPlaybackPositions: new Map(),\n audioEffectConfigs: new Map(),\n videoStreamUrls: new Map(),\n videoPosterUrls: new Map(),\n videoPlaybackPositions: new Map(),\n videoMetadata: new Map(),\n videoPlayerSettings: DEFAULT_VIDEO_SETTINGS,\n};\n\nexport const useMediaCacheStore = create<MediaCacheStore>()(\n devtools(\n persist(\n (set, get) => ({\n ...initialState,\n\n // ========== Blob URL Management ==========\n\n getOrCreateBlobUrl: (key, content, mimeType) => {\n const existing = get().blobUrls.get(key);\n if (existing) {\n // Increment ref count\n cacheDebug.debug(`Blob URL reused: ${key}`, { refCount: existing.refCount + 1 });\n set(\n (state) => ({\n blobUrls: new Map(state.blobUrls).set(key, {\n ...existing,\n refCount: existing.refCount + 1,\n }),\n }),\n false,\n 'blobUrl/incrementRef'\n );\n return existing.url;\n }\n\n // Create new blob URL\n const blob = new Blob([content], { type: mimeType });\n const url = URL.createObjectURL(blob);\n const sizeMB = (content.byteLength / 1024 / 1024).toFixed(2);\n cacheDebug.debug(`Blob URL created: ${key}`, { mimeType, size: `${sizeMB}MB` });\n set(\n (state) => ({\n blobUrls: new Map(state.blobUrls).set(key, {\n url,\n refCount: 1,\n createdAt: Date.now(),\n }),\n }),\n false,\n 'blobUrl/create'\n );\n return url;\n },\n\n releaseBlobUrl: (key) => {\n const entry = get().blobUrls.get(key);\n if (!entry) return;\n\n if (entry.refCount <= 1) {\n // Last reference - revoke and remove\n cacheDebug.debug(`Blob URL revoked: ${key}`);\n URL.revokeObjectURL(entry.url);\n set(\n (state) => {\n const newMap = new Map(state.blobUrls);\n newMap.delete(key);\n return { blobUrls: newMap };\n },\n false,\n 'blobUrl/revoke'\n );\n } else {\n // Decrement ref count\n cacheDebug.debug(`Blob URL released: ${key}`, { refCount: entry.refCount - 1 });\n set(\n (state) => ({\n blobUrls: new Map(state.blobUrls).set(key, {\n ...entry,\n refCount: entry.refCount - 1,\n }),\n }),\n false,\n 'blobUrl/decrementRef'\n );\n }\n },\n\n hasBlobUrl: (key) => get().blobUrls.has(key),\n\n // ========== Image Cache ==========\n\n cacheDimensions: (src, dims) => {\n set(\n (state) => ({\n imageDimensions: new Map(state.imageDimensions).set(src, dims),\n }),\n false,\n 'image/cacheDimensions'\n );\n },\n\n getDimensions: (src) => get().imageDimensions.get(src) ?? null,\n\n // ========== Audio Cache ==========\n\n saveAudioPosition: (uri, time) => {\n set(\n (state) => ({\n audioPlaybackPositions: new Map(state.audioPlaybackPositions).set(\n uri,\n time\n ),\n }),\n false,\n 'audio/savePosition'\n );\n },\n\n getAudioPosition: (uri) =>\n get().audioPlaybackPositions.get(uri) ?? null,\n\n getEffectConfig: (key) => get().audioEffectConfigs.get(key) ?? null,\n\n cacheEffectConfig: (key, config) => {\n set(\n (state) => ({\n audioEffectConfigs: new Map(state.audioEffectConfigs).set(\n key,\n config\n ),\n }),\n false,\n 'audio/cacheEffectConfig'\n );\n },\n\n // ========== Video Cache ==========\n\n getOrCreateStreamUrl: (sessionId, path, generator) => {\n const key = `${sessionId}:${path}`;\n const cached = get().videoStreamUrls.get(key);\n\n // Return if fresh\n if (cached && Date.now() - cached.timestamp < STREAM_URL_TTL) {\n return cached.url;\n }\n\n // Generate and cache\n const url = generator(sessionId, path);\n set(\n (state) => ({\n videoStreamUrls: new Map(state.videoStreamUrls).set(key, {\n url,\n timestamp: Date.now(),\n }),\n }),\n false,\n 'video/cacheStreamUrl'\n );\n return url;\n },\n\n getPosterUrl: (title) => get().videoPosterUrls.get(title) ?? null,\n\n cachePosterUrl: (title, url) => {\n set(\n (state) => ({\n videoPosterUrls: new Map(state.videoPosterUrls).set(title, url),\n }),\n false,\n 'video/cachePosterUrl'\n );\n },\n\n saveVideoPosition: (key, time) => {\n set(\n (state) => ({\n videoPlaybackPositions: new Map(state.videoPlaybackPositions).set(\n key,\n time\n ),\n }),\n false,\n 'video/savePosition'\n );\n },\n\n getVideoPosition: (key) =>\n get().videoPlaybackPositions.get(key) ?? null,\n\n cacheVideoMetadata: (url, meta) => {\n set(\n (state) => ({\n videoMetadata: new Map(state.videoMetadata).set(url, meta),\n }),\n false,\n 'video/cacheMetadata'\n );\n },\n\n getVideoMetadata: (url) => get().videoMetadata.get(url) ?? null,\n\n invalidateSession: (sessionId) => {\n set(\n (state) => {\n const newUrls = new Map(state.videoStreamUrls);\n for (const [key] of newUrls) {\n if (key.startsWith(`${sessionId}:`)) {\n newUrls.delete(key);\n }\n }\n return { videoStreamUrls: newUrls };\n },\n false,\n 'video/invalidateSession'\n );\n },\n\n getVideoPlayerSettings: () => get().videoPlayerSettings,\n\n saveVideoPlayerSettings: (settings) => {\n set(\n (state) => ({\n videoPlayerSettings: { ...state.videoPlayerSettings, ...settings },\n }),\n false,\n 'video/savePlayerSettings'\n );\n },\n\n // ========== Global ==========\n\n clearCache: () => {\n const stats = get().getCacheStats();\n cacheDebug.info('Clearing cache', stats);\n // Revoke all blob URLs before clearing\n get().blobUrls.forEach(({ url }) => URL.revokeObjectURL(url));\n set(initialState, false, 'clearCache');\n },\n\n getCacheStats: () => ({\n blobUrls: get().blobUrls.size,\n dimensions: get().imageDimensions.size,\n audioPositions: get().audioPlaybackPositions.size,\n videoPositions: get().videoPlaybackPositions.size,\n }),\n }),\n {\n name: 'media-cache-storage',\n // Only persist playback positions, poster URLs, and player settings\n partialize: (state) => ({\n audioPlaybackPositions: Array.from(\n state.audioPlaybackPositions.entries()\n ),\n videoPlaybackPositions: Array.from(\n state.videoPlaybackPositions.entries()\n ),\n videoPosterUrls: Array.from(state.videoPosterUrls.entries()),\n videoPlayerSettings: state.videoPlayerSettings,\n }),\n // Rehydrate Maps from arrays\n onRehydrateStorage: () => (state) => {\n if (state) {\n // Type assertion for persisted data\n const persistedAudio = state.audioPlaybackPositions as unknown;\n const persistedVideo = state.videoPlaybackPositions as unknown;\n const persistedPosters = state.videoPosterUrls as unknown;\n const persistedSettings = state.videoPlayerSettings as unknown;\n\n state.audioPlaybackPositions = new Map(\n Array.isArray(persistedAudio)\n ? (persistedAudio as [string, number][])\n : []\n );\n state.videoPlaybackPositions = new Map(\n Array.isArray(persistedVideo)\n ? (persistedVideo as [string, number][])\n : []\n );\n state.videoPosterUrls = new Map(\n Array.isArray(persistedPosters)\n ? (persistedPosters as [string, string][])\n : []\n );\n // Merge persisted settings with defaults (handles missing fields)\n state.videoPlayerSettings = {\n ...DEFAULT_VIDEO_SETTINGS,\n ...(persistedSettings && typeof persistedSettings === 'object'\n ? (persistedSettings as Partial<VideoPlayerSettings>)\n : {}),\n };\n }\n },\n }\n ),\n { name: 'MediaCacheStore' }\n )\n);\n\n// ========== Selective Hooks ==========\n\n/**\n * Hook for image-related cache operations\n * Uses useShallow to prevent infinite re-renders\n */\nexport const useImageCache = () =>\n useMediaCacheStore(\n useShallow((state) => ({\n getOrCreateBlobUrl: state.getOrCreateBlobUrl,\n releaseBlobUrl: state.releaseBlobUrl,\n hasBlobUrl: state.hasBlobUrl,\n cacheDimensions: state.cacheDimensions,\n getDimensions: state.getDimensions,\n }))\n );\n\n/**\n * Hook for audio-related cache operations\n * Uses useShallow to prevent infinite re-renders\n */\nexport const useAudioCache = () =>\n useMediaCacheStore(\n useShallow((state) => ({\n getOrCreateBlobUrl: state.getOrCreateBlobUrl,\n releaseBlobUrl: state.releaseBlobUrl,\n hasBlobUrl: state.hasBlobUrl,\n saveAudioPosition: state.saveAudioPosition,\n getAudioPosition: state.getAudioPosition,\n getEffectConfig: state.getEffectConfig,\n cacheEffectConfig: state.cacheEffectConfig,\n }))\n );\n\n/**\n * Hook for video-related cache operations\n * Uses useShallow to prevent infinite re-renders\n */\nexport const useVideoCache = () =>\n useMediaCacheStore(\n useShallow((state) => ({\n getOrCreateBlobUrl: state.getOrCreateBlobUrl,\n releaseBlobUrl: state.releaseBlobUrl,\n hasBlobUrl: state.hasBlobUrl,\n getOrCreateStreamUrl: state.getOrCreateStreamUrl,\n getPosterUrl: state.getPosterUrl,\n cachePosterUrl: state.cachePosterUrl,\n saveVideoPosition: state.saveVideoPosition,\n getVideoPosition: state.getVideoPosition,\n cacheVideoMetadata: state.cacheVideoMetadata,\n getVideoMetadata: state.getVideoMetadata,\n invalidateSession: state.invalidateSession,\n getVideoPlayerSettings: state.getVideoPlayerSettings,\n saveVideoPlayerSettings: state.saveVideoPlayerSettings,\n }))\n );\n\n/**\n * Hook for video player settings only\n * Returns current settings and save function\n */\nexport const useVideoPlayerSettings = () =>\n useMediaCacheStore(\n useShallow((state) => ({\n settings: state.videoPlayerSettings,\n saveSettings: state.saveVideoPlayerSettings,\n }))\n );\n\n/**\n * Hook for blob URL cleanup on unmount\n */\nexport function useBlobUrlCleanup(key: string | null) {\n const releaseBlobUrl = useMediaCacheStore((s) => s.releaseBlobUrl);\n\n // Using inline effect to avoid importing useEffect in store\n if (typeof window !== 'undefined') {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const { useEffect } = require('react');\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useEffect(() => {\n return () => {\n if (key) {\n releaseBlobUrl(key);\n }\n };\n }, [key, releaseBlobUrl]);\n }\n}\n\n// ========== Utilities ==========\n\n/**\n * Generate a cache key from ArrayBuffer content\n * Uses first and last 1KB + length for fast hashing\n */\nexport function generateContentKey(content: ArrayBuffer): string {\n const arr = new Uint8Array(content);\n const len = arr.length;\n\n // Take first 1KB\n const start = arr.slice(0, Math.min(1024, len));\n // Take last 1KB\n const end = arr.slice(Math.max(0, len - 1024));\n\n // Simple hash from bytes\n let hash = len;\n for (let i = 0; i < start.length; i++) {\n hash = ((hash << 5) - hash + start[i]) | 0;\n }\n for (let i = 0; i < end.length; i++) {\n hash = ((hash << 5) - hash + end[i]) | 0;\n }\n\n return `blob-${len}-${hash.toString(16)}`;\n}\n","'use client';\n\n/**\n * VideoPlayer Debug Logger\n *\n * Uses universal logger with media-specific helpers.\n * Logs go to both console (dev) and zustand store (for Console panel).\n */\n\nimport { createMediaLogger } from '@djangocfg/ui-core/lib';\n\nexport const videoDebug = createMediaLogger('VideoPlayer');\n\nexport default videoDebug;\n","/**\n * VidstackProvider - Full-featured video player using Vidstack\n * Supports YouTube, Vimeo, HLS, DASH, and direct URLs\n */\n\n'use client';\n\n// Import Vidstack base styles\nimport '@vidstack/react/player/styles/base.css';\nimport '@vidstack/react/player/styles/default/theme.css';\nimport '@vidstack/react/player/styles/default/layouts/video.css';\n\nimport React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState } from 'react';\n\nimport { cn, generateOgImageUrl } from '@djangocfg/ui-core/lib';\nimport { MediaPlayer, MediaProvider, Poster } from '@vidstack/react';\nimport { defaultLayoutIcons, DefaultVideoLayout } from '@vidstack/react/player/layouts/default';\nimport { useVideoCache } from '../../../stores/mediaCache';\n\nimport type { MediaPlayerInstance, PlayerSrc } from '@vidstack/react';\nimport type { VidstackProviderProps, VideoPlayerRef, ErrorFallbackProps } from '../types';\nimport { videoDebug } from '../utils/debug';\n\n/**\n * Convert source to Vidstack-compatible format\n * Returns object with explicit type for HLS/DASH to ensure proper loader selection\n */\nfunction getVidstackSrc(source: VidstackProviderProps['source']): PlayerSrc {\n switch (source.type) {\n case 'youtube':\n return `youtube/${source.id}`;\n case 'vimeo':\n return `vimeo/${source.id}`;\n case 'hls':\n // Explicit type needed because URL may have query params that hide .m3u8 extension\n return { src: source.url, type: 'application/x-mpegurl' } as PlayerSrc;\n case 'dash':\n return { src: source.url, type: 'application/dash+xml' } as PlayerSrc;\n case 'url':\n return source.url;\n default:\n return '';\n }\n}\n\n/** Default error fallback UI */\nfunction DefaultErrorFallback({ error }: ErrorFallbackProps) {\n return (\n <div className=\"absolute inset-0 flex flex-col items-center justify-center gap-4 text-white bg-black\">\n <svg\n className=\"w-16 h-16 text-muted-foreground\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M15 10l4.553-2.276A1 1 0 0121 8.618v6.764a1 1 0 01-1.447.894L15 14M5 18h8a2 2 0 002-2V8a2 2 0 00-2-2H5a2 2 0 00-2 2v8a2 2 0 002 2z\"\n />\n </svg>\n <p className=\"text-lg\">{error || 'Video cannot be played'}</p>\n </div>\n );\n}\n\nexport const VidstackProvider = forwardRef<VideoPlayerRef, VidstackProviderProps>(\n (\n {\n source,\n aspectRatio = 16 / 9,\n autoPlay = false,\n muted = false,\n loop = false,\n playsInline = true,\n controls = true,\n className,\n showInfo = false,\n theme = 'default',\n errorFallback,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n },\n ref\n ) => {\n const playerRef = useRef<MediaPlayerInstance | null>(null);\n const [hasError, setHasError] = useState(false);\n const [errorMessage, setErrorMessage] = useState<string>('Video cannot be played');\n const lastSavedTimeRef = useRef<number>(0);\n const hasRestoredPositionRef = useRef(false);\n\n // Cache hooks\n const {\n getPosterUrl,\n cachePosterUrl,\n saveVideoPosition,\n getVideoPosition,\n } = useVideoCache();\n\n // Get source key for position caching\n const sourceKey = useMemo(() => {\n switch (source.type) {\n case 'youtube':\n return `youtube:${source.id}`;\n case 'vimeo':\n return `vimeo:${source.id}`;\n case 'hls':\n case 'dash':\n case 'url':\n return `url:${source.url}`;\n default:\n return null;\n }\n }, [source]);\n\n // Generate poster if not provided, with caching\n const posterUrl = useMemo(() => {\n if (source.poster) return source.poster;\n if (!source.title) return undefined;\n\n // Check cache first\n const cached = getPosterUrl(source.title);\n if (cached) return cached;\n\n // Generate and cache\n const url = generateOgImageUrl({ title: source.title });\n cachePosterUrl(source.title, url);\n return url;\n }, [source.poster, source.title, getPosterUrl, cachePosterUrl]);\n\n // Get Vidstack-compatible source URL\n const vidstackSrc = useMemo(() => getVidstackSrc(source), [source]);\n\n // Debug: Log video source\n useEffect(() => {\n const srcString = typeof vidstackSrc === 'string' ? vidstackSrc : (vidstackSrc as { src: string }).src;\n videoDebug.load(srcString, source.type);\n }, [vidstackSrc, source.type]);\n\n // Retry function\n const retry = useCallback(() => {\n setHasError(false);\n setErrorMessage('Video cannot be played');\n // Force reload by updating key would be needed, but for now just reset state\n const player = playerRef.current;\n if (player) {\n player.currentTime = 0;\n player.play();\n }\n }, []);\n\n // Expose player methods via ref\n useImperativeHandle(\n ref,\n () => {\n const player = playerRef.current;\n\n return {\n play: () => player?.play(),\n pause: () => player?.pause(),\n togglePlay: () => {\n if (player) {\n player.paused ? player.play() : player.pause();\n }\n },\n seekTo: (time: number) => {\n if (player) player.currentTime = time;\n },\n setVolume: (volume: number) => {\n if (player) player.volume = Math.max(0, Math.min(1, volume));\n },\n toggleMute: () => {\n if (player) player.muted = !player.muted;\n },\n enterFullscreen: () => player?.enterFullscreen(),\n exitFullscreen: () => player?.exitFullscreen(),\n get currentTime() {\n return player?.currentTime ?? 0;\n },\n get duration() {\n return player?.duration ?? 0;\n },\n get paused() {\n return player?.paused ?? true;\n },\n };\n },\n []\n );\n\n const handlePlay = () => onPlay?.();\n\n const handlePause = useCallback(() => {\n // Save position on pause\n const player = playerRef.current;\n if (sourceKey && player && player.currentTime > 0) {\n saveVideoPosition(sourceKey, player.currentTime);\n lastSavedTimeRef.current = player.currentTime;\n }\n onPause?.();\n }, [sourceKey, saveVideoPosition, onPause]);\n\n const handleEnded = () => onEnded?.();\n\n const handleError = (detail: unknown) => {\n const error = detail as { message?: string };\n const msg = error?.message || 'Video playback error';\n videoDebug.error('Vidstack error', { message: msg });\n setHasError(true);\n setErrorMessage(msg);\n onError?.(msg);\n };\n\n const handleLoadStart = () => onLoadStart?.();\n\n const handleCanPlay = useCallback(() => {\n const player = playerRef.current;\n if (player) {\n videoDebug.state('canplay', { duration: player.duration });\n // Log buffer state if media element is available\n const mediaEl = (player.provider as { media?: HTMLVideoElement } | null)?.media;\n if (mediaEl?.buffered) {\n videoDebug.buffer(mediaEl.buffered, player.duration);\n }\n }\n setHasError(false);\n\n // Restore position from cache (only once per source)\n if (sourceKey && player && !hasRestoredPositionRef.current) {\n const cachedPosition = getVideoPosition(sourceKey);\n if (cachedPosition && cachedPosition > 0) {\n const duration = player.duration;\n // Only restore if position is valid (not at the end)\n if (cachedPosition < duration - 1) {\n videoDebug.debug(`Restoring position: ${cachedPosition}s`);\n player.currentTime = cachedPosition;\n }\n }\n hasRestoredPositionRef.current = true;\n }\n\n onCanPlay?.();\n }, [sourceKey, getVideoPosition, onCanPlay]);\n\n const handleTimeUpdate = useCallback(() => {\n const player = playerRef.current;\n if (!player) return;\n\n // Save position every 5 seconds\n if (sourceKey && player.currentTime > 0) {\n const timeSinceLastSave = player.currentTime - lastSavedTimeRef.current;\n if (timeSinceLastSave >= 5 || timeSinceLastSave < 0) {\n saveVideoPosition(sourceKey, player.currentTime);\n lastSavedTimeRef.current = player.currentTime;\n }\n }\n\n onTimeUpdate?.(player.currentTime, player.duration);\n }, [sourceKey, saveVideoPosition, onTimeUpdate]);\n\n // Reset position restoration flag when source changes\n useEffect(() => {\n hasRestoredPositionRef.current = false;\n lastSavedTimeRef.current = 0;\n }, [sourceKey]);\n\n // Debug: Log player events\n useEffect(() => {\n const player = playerRef.current;\n if (!player) return;\n\n const handleSeeking = () => {\n videoDebug.event('seeking', { currentTime: player.currentTime });\n };\n\n const handleSeeked = () => {\n videoDebug.event('seeked', { currentTime: player.currentTime });\n const mediaEl = (player.provider as { media?: HTMLVideoElement } | null)?.media;\n if (mediaEl?.buffered) {\n videoDebug.buffer(mediaEl.buffered, player.duration);\n }\n };\n\n const handleWaiting = () => {\n videoDebug.warn('WAITING - buffering...');\n const mediaEl = (player.provider as { media?: HTMLVideoElement } | null)?.media;\n if (mediaEl?.buffered) {\n videoDebug.buffer(mediaEl.buffered, player.duration);\n }\n };\n\n const handleStalled = () => {\n videoDebug.warn('STALLED - network issue');\n const mediaEl = (player.provider as { media?: HTMLVideoElement } | null)?.media;\n if (mediaEl?.buffered) {\n videoDebug.buffer(mediaEl.buffered, player.duration);\n }\n };\n\n player.addEventListener('seeking', handleSeeking);\n player.addEventListener('seeked', handleSeeked);\n player.addEventListener('waiting', handleWaiting);\n player.addEventListener('stalled', handleStalled);\n\n return () => {\n player.removeEventListener('seeking', handleSeeking);\n player.removeEventListener('seeked', handleSeeked);\n player.removeEventListener('waiting', handleWaiting);\n player.removeEventListener('stalled', handleStalled);\n };\n }, [vidstackSrc]);\n\n // Determine layout mode\n const isFillMode = aspectRatio === 'fill';\n const computedAspectRatio = aspectRatio === 'auto' || aspectRatio === 'fill' ? undefined : aspectRatio;\n\n // Render error fallback\n const renderErrorFallback = () => {\n const fallbackProps: ErrorFallbackProps = { error: errorMessage, retry };\n\n if (typeof errorFallback === 'function') {\n return errorFallback(fallbackProps);\n }\n\n if (errorFallback) {\n return errorFallback;\n }\n\n return <DefaultErrorFallback {...fallbackProps} />;\n };\n\n // Container styles based on mode\n const containerStyles = isFillMode\n ? { width: '100%', height: '100%' }\n : { aspectRatio: computedAspectRatio };\n\n return (\n <div className={cn(isFillMode ? 'w-full h-full' : 'w-full', className)}>\n <div\n className={cn(\n 'relative w-full rounded-sm bg-black overflow-hidden',\n isFillMode && 'h-full',\n theme === 'minimal' && 'rounded-none',\n theme === 'modern' && 'rounded-xl shadow-2xl'\n )}\n style={containerStyles}\n >\n {hasError ? (\n renderErrorFallback()\n ) : (\n <MediaPlayer\n ref={playerRef}\n title={source.title || 'Video'}\n src={vidstackSrc}\n autoPlay={autoPlay}\n muted={muted}\n loop={loop}\n playsInline={playsInline}\n onPlay={handlePlay}\n onPause={handlePause}\n onEnded={handleEnded}\n onError={handleError}\n onLoadStart={handleLoadStart}\n onCanPlay={handleCanPlay}\n onTimeUpdate={handleTimeUpdate}\n className=\"w-full h-full\"\n >\n <MediaProvider />\n\n {posterUrl && (\n <Poster\n className=\"vds-poster\"\n src={posterUrl}\n alt={source.title || 'Video poster'}\n style={{ objectFit: 'cover' }}\n />\n )}\n\n {controls && <DefaultVideoLayout icons={defaultLayoutIcons} thumbnails={posterUrl} />}\n </MediaPlayer>\n )}\n </div>\n\n {showInfo && source.title && (\n <div className=\"mt-4 space-y-2\">\n <h3 className=\"text-xl font-semibold text-foreground\">{source.title}</h3>\n </div>\n )}\n </div>\n );\n }\n);\n\nVidstackProvider.displayName = 'VidstackProvider';\n","'use client';\n\n/**\n * useVideoPlayerSettings - Hook for persisted video player settings\n *\n * Provides volume and loop settings that persist in localStorage.\n * Use this hook in video player providers to apply saved settings.\n *\n * @example\n * const { settings, updateVolume, updateLoop } = useVideoPlayerSettings();\n *\n * // Apply to video element\n * videoRef.current.volume = settings.volume;\n * videoRef.current.loop = settings.isLooping;\n *\n * // Save when user changes\n * const handleVolumeChange = (vol: number) => {\n * videoRef.current.volume = vol;\n * updateVolume(vol);\n * };\n */\n\nimport { useCallback } from 'react';\nimport { useVideoPlayerSettings as useSettings } from '../../../stores/mediaCache';\n\nexport interface VideoPlayerSettingsReturn {\n /** Current settings */\n settings: {\n volume: number;\n isLooping: boolean;\n };\n /** Update volume (0-1) */\n updateVolume: (volume: number) => void;\n /** Update loop setting */\n updateLoop: (isLooping: boolean) => void;\n /** Update multiple settings at once */\n updateSettings: (settings: { volume?: number; isLooping?: boolean }) => void;\n}\n\nexport function useVideoPlayerSettings(): VideoPlayerSettingsReturn {\n const { settings, saveSettings } = useSettings();\n\n const updateVolume = useCallback(\n (volume: number) => {\n saveSettings({ volume: Math.max(0, Math.min(1, volume)) });\n },\n [saveSettings]\n );\n\n const updateLoop = useCallback(\n (isLooping: boolean) => {\n saveSettings({ isLooping });\n },\n [saveSettings]\n );\n\n const updateSettings = useCallback(\n (newSettings: { volume?: number; isLooping?: boolean }) => {\n saveSettings(newSettings);\n },\n [saveSettings]\n );\n\n return {\n settings,\n updateVolume,\n updateLoop,\n updateSettings,\n };\n}\n","/**\n * NativeProvider - Lightweight native HTML5 video player\n * For demo videos, background videos, autoplay loop muted scenarios\n */\n\n'use client';\n\nimport React, { forwardRef, useEffect, useImperativeHandle, useRef, useState } from 'react';\n\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { Preloader, AspectRatio } from '@djangocfg/ui-core';\nimport { useVideoPlayerSettings } from '../hooks/useVideoPlayerSettings';\n\nimport type { NativeProviderProps, VideoPlayerRef } from '../types';\nimport { videoDebug } from '../utils/debug';\n\n/**\n * Get video URL from source\n */\nfunction getVideoUrl(source: NativeProviderProps['source']): string {\n switch (source.type) {\n case 'url':\n return source.url;\n case 'data-url':\n return source.data;\n default:\n return '';\n }\n}\n\nexport const NativeProvider = forwardRef<VideoPlayerRef, NativeProviderProps>(\n (\n {\n source,\n aspectRatio = 16 / 9,\n autoPlay = true,\n muted = true,\n loop = true,\n playsInline = true,\n preload = 'auto',\n controls = false,\n disableContextMenu = true,\n showPreloader = true,\n preloaderTimeout = 5000,\n className,\n videoClassName,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n },\n ref\n ) => {\n const [isLoading, setIsLoading] = useState(showPreloader);\n const videoRef = useRef<HTMLVideoElement>(null);\n\n // Persisted player settings\n const { settings: savedSettings, updateVolume } = useVideoPlayerSettings();\n\n const videoUrl = getVideoUrl(source);\n\n // Debug: Log video source\n useEffect(() => {\n videoDebug.load(videoUrl, source.type);\n }, [videoUrl, source.type]);\n\n // Expose video element methods via ref\n useImperativeHandle(\n ref,\n () => ({\n play: () => videoRef.current?.play(),\n pause: () => videoRef.current?.pause(),\n togglePlay: () => {\n const video = videoRef.current;\n if (video) {\n video.paused ? video.play() : video.pause();\n }\n },\n seekTo: (time: number) => {\n if (videoRef.current) videoRef.current.currentTime = time;\n },\n setVolume: (volume: number) => {\n if (videoRef.current) videoRef.current.volume = Math.max(0, Math.min(1, volume));\n },\n toggleMute: () => {\n if (videoRef.current) videoRef.current.muted = !videoRef.current.muted;\n },\n enterFullscreen: () => videoRef.current?.requestFullscreen(),\n exitFullscreen: () => document.exitFullscreen(),\n get currentTime() {\n return videoRef.current?.currentTime ?? 0;\n },\n get duration() {\n return videoRef.current?.duration ?? 0;\n },\n get paused() {\n return videoRef.current?.paused ?? true;\n },\n }),\n []\n );\n\n useEffect(() => {\n if (!showPreloader) return;\n\n const video = videoRef.current;\n if (!video) return;\n\n // Check if video is already loaded\n if (video.readyState >= 3) {\n setIsLoading(false);\n return;\n }\n\n const hideLoader = () => setIsLoading(false);\n\n video.addEventListener('canplay', hideLoader);\n video.addEventListener('loadeddata', hideLoader);\n video.addEventListener('playing', hideLoader);\n\n // Fallback: hide loader after timeout\n const timeout = setTimeout(hideLoader, preloaderTimeout);\n\n return () => {\n video.removeEventListener('canplay', hideLoader);\n video.removeEventListener('loadeddata', hideLoader);\n video.removeEventListener('playing', hideLoader);\n clearTimeout(timeout);\n };\n }, [showPreloader, preloaderTimeout]);\n\n // Debug: Log video events\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n const handleLoadedMetadata = () => {\n videoDebug.state('loadedmetadata', { duration: video.duration });\n };\n\n const handleCanPlayDebug = () => {\n videoDebug.state('canplay', { duration: video.duration, buffered: video.buffered.length });\n videoDebug.buffer(video.buffered, video.duration);\n // Apply saved volume\n video.volume = savedSettings.volume;\n };\n\n const handleSeeking = () => {\n videoDebug.event('seeking', { currentTime: video.currentTime });\n };\n\n const handleSeeked = () => {\n videoDebug.event('seeked', { currentTime: video.currentTime });\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n const handleWaiting = () => {\n videoDebug.warn('WAITING - buffering...');\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n const handleStalled = () => {\n videoDebug.warn('STALLED - network issue');\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n video.addEventListener('loadedmetadata', handleLoadedMetadata);\n video.addEventListener('canplay', handleCanPlayDebug);\n video.addEventListener('seeking', handleSeeking);\n video.addEventListener('seeked', handleSeeked);\n video.addEventListener('waiting', handleWaiting);\n video.addEventListener('stalled', handleStalled);\n\n return () => {\n video.removeEventListener('loadedmetadata', handleLoadedMetadata);\n video.removeEventListener('canplay', handleCanPlayDebug);\n video.removeEventListener('seeking', handleSeeking);\n video.removeEventListener('seeked', handleSeeked);\n video.removeEventListener('waiting', handleWaiting);\n video.removeEventListener('stalled', handleStalled);\n };\n }, [savedSettings.volume]);\n\n // Persist volume when user changes it via native controls\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n const handleVolumeChange = () => {\n updateVolume(video.volume);\n };\n\n video.addEventListener('volumechange', handleVolumeChange);\n return () => video.removeEventListener('volumechange', handleVolumeChange);\n }, [updateVolume]);\n\n const handleContextMenu = (e: React.MouseEvent) => {\n if (disableContextMenu) {\n e.preventDefault();\n }\n };\n\n const handleError = (e: React.SyntheticEvent<HTMLVideoElement>) => {\n const video = e.currentTarget;\n const errorMsg = video.error?.message || 'Video playback error';\n videoDebug.error('Video error', { code: video.error?.code, message: errorMsg });\n setIsLoading(false);\n onError?.(errorMsg);\n };\n\n const handleTimeUpdate = () => {\n const video = videoRef.current;\n if (video && onTimeUpdate) {\n onTimeUpdate(video.currentTime, video.duration);\n }\n };\n\n // Determine if we should use AspectRatio wrapper or fill mode\n const isFillMode = aspectRatio === 'fill';\n const computedAspectRatio = aspectRatio === 'auto' || aspectRatio === 'fill' ? undefined : aspectRatio;\n\n // Video content\n const videoContent = (\n <>\n {/* Preloader */}\n {showPreloader && isLoading && (\n <div\n className={cn(\n 'absolute inset-0 flex items-center justify-center bg-muted/30 backdrop-blur-sm z-10'\n )}\n >\n <Preloader size=\"lg\" spinnerClassName=\"text-white\" />\n </div>\n )}\n\n {/* Video */}\n <video\n ref={videoRef}\n className={cn('w-full h-full object-cover', videoClassName)}\n src={videoUrl}\n autoPlay={autoPlay}\n muted={muted}\n loop={loop}\n playsInline={playsInline}\n preload={preload}\n controls={controls}\n poster={source.poster}\n onContextMenu={handleContextMenu}\n onLoadStart={onLoadStart}\n onCanPlay={onCanPlay}\n onPlay={onPlay}\n onPause={onPause}\n onPlaying={() => setIsLoading(false)}\n onEnded={onEnded}\n onError={handleError}\n onTimeUpdate={handleTimeUpdate}\n />\n </>\n );\n\n // Fill mode - no AspectRatio wrapper\n if (isFillMode) {\n return (\n <div className={cn('relative w-full h-full overflow-hidden', className)}>\n {videoContent}\n </div>\n );\n }\n\n // Normal mode with AspectRatio\n return (\n <div className={cn('relative overflow-hidden', className)}>\n <AspectRatio ratio={computedAspectRatio}>\n {videoContent}\n </AspectRatio>\n </div>\n );\n }\n);\n\nNativeProvider.displayName = 'NativeProvider';\n","/**\n * StreamProvider - HTTP Range streaming and Blob video player\n * Supports:\n * - HTTP Range requests with authorization (for large files)\n * - Blob/ArrayBuffer sources\n * - Data URL sources\n * - Fill parent container mode\n * - Custom error fallback\n */\n\n'use client';\n\nimport React, { forwardRef, useCallback, useEffect, useImperativeHandle, useRef, useState } from 'react';\n\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { Preloader, AspectRatio } from '@djangocfg/ui-core';\nimport { useMediaCacheStore, generateContentKey } from '../../../stores/mediaCache';\nimport { useVideoPlayerSettings } from '../hooks/useVideoPlayerSettings';\n\nimport type { StreamProviderProps, VideoPlayerRef, StreamSource, BlobSource, DataUrlSource, ErrorFallbackProps } from '../types';\nimport { videoDebug } from '../utils/debug';\n\n/** Default error fallback UI */\nfunction DefaultErrorFallback({ error }: ErrorFallbackProps) {\n return (\n <div className=\"absolute inset-0 flex flex-col items-center justify-center gap-4 text-white\">\n <svg\n className=\"w-16 h-16 text-muted-foreground\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M15 10l4.553-2.276A1 1 0 0121 8.618v6.764a1 1 0 01-1.447.894L15 14M5 18h8a2 2 0 002-2V8a2 2 0 00-2-2H5a2 2 0 00-2 2v8a2 2 0 002 2z\"\n />\n </svg>\n <p className=\"text-lg\">{error || 'Video cannot be previewed'}</p>\n </div>\n );\n}\n\nexport const StreamProvider = forwardRef<VideoPlayerRef, StreamProviderProps>(\n (\n {\n source,\n aspectRatio = 16 / 9,\n autoPlay = false,\n muted = false,\n loop = false,\n playsInline = true,\n preload = 'metadata',\n controls = true,\n disableContextMenu = false,\n showPreloader = true,\n preloaderTimeout = 10000,\n className,\n videoClassName,\n errorFallback,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n onBufferProgress,\n },\n ref\n ) => {\n const [videoUrl, setVideoUrl] = useState<string | null>(null);\n const [isLoading, setIsLoading] = useState(true);\n const [hasError, setHasError] = useState(false);\n const [errorMessage, setErrorMessage] = useState<string>('Video cannot be previewed');\n const videoRef = useRef<HTMLVideoElement>(null);\n const contentKeyRef = useRef<string | null>(null);\n const lastSavedTimeRef = useRef<number>(0);\n\n // Get stable function references from store (not from hook to avoid re-renders)\n const getOrCreateBlobUrl = useMediaCacheStore.getState().getOrCreateBlobUrl;\n const releaseBlobUrl = useMediaCacheStore.getState().releaseBlobUrl;\n const getOrCreateStreamUrl = useMediaCacheStore.getState().getOrCreateStreamUrl;\n const saveVideoPosition = useMediaCacheStore.getState().saveVideoPosition;\n const getVideoPosition = useMediaCacheStore.getState().getVideoPosition;\n\n // Persisted player settings\n const { settings: savedSettings, updateVolume } = useVideoPlayerSettings();\n\n // Retry function for error fallback\n // Regenerates URL for stream sources to get fresh token/session\n const retry = useCallback(() => {\n setHasError(false);\n setIsLoading(true);\n\n // For stream sources, regenerate URL bypassing cache\n if (source.type === 'stream') {\n const streamSource = source as StreamSource;\n const freshUrl = streamSource.getStreamUrl(streamSource.sessionId, streamSource.path);\n setVideoUrl(freshUrl);\n return;\n }\n\n // For other sources, just reload\n const video = videoRef.current;\n if (video && videoUrl) {\n video.load();\n }\n }, [source, videoUrl]);\n\n // Expose video element methods via ref\n useImperativeHandle(\n ref,\n () => ({\n play: () => videoRef.current?.play(),\n pause: () => videoRef.current?.pause(),\n togglePlay: () => {\n const video = videoRef.current;\n if (video) {\n video.paused ? video.play() : video.pause();\n }\n },\n seekTo: (time: number) => {\n if (videoRef.current) videoRef.current.currentTime = time;\n },\n setVolume: (volume: number) => {\n if (videoRef.current) videoRef.current.volume = Math.max(0, Math.min(1, volume));\n },\n toggleMute: () => {\n if (videoRef.current) videoRef.current.muted = !videoRef.current.muted;\n },\n enterFullscreen: () => videoRef.current?.requestFullscreen(),\n exitFullscreen: () => document.exitFullscreen(),\n get currentTime() {\n return videoRef.current?.currentTime ?? 0;\n },\n get duration() {\n return videoRef.current?.duration ?? 0;\n },\n get paused() {\n return videoRef.current?.paused ?? true;\n },\n }),\n []\n );\n\n // Track unmount for cleanup\n const isMountedRef = useRef(true);\n useEffect(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n // Release blob URL only on actual unmount\n if (contentKeyRef.current) {\n useMediaCacheStore.getState().releaseBlobUrl(contentKeyRef.current);\n contentKeyRef.current = null;\n }\n };\n }, []);\n\n // Create video URL based on source type with caching\n useEffect(() => {\n // Release previous blob URL if source changed\n if (contentKeyRef.current) {\n const newKey = source.type === 'blob'\n ? generateContentKey((source as BlobSource).data)\n : null;\n if (newKey !== contentKeyRef.current) {\n releaseBlobUrl(contentKeyRef.current);\n contentKeyRef.current = null;\n }\n }\n\n setHasError(false);\n setIsLoading(true);\n\n switch (source.type) {\n case 'stream': {\n const streamSource = source as StreamSource;\n // Use cached stream URL\n const url = getOrCreateStreamUrl(\n streamSource.sessionId,\n streamSource.path,\n streamSource.getStreamUrl\n );\n videoDebug.load(url, 'stream');\n setVideoUrl(url);\n break;\n }\n\n case 'blob': {\n const blobSource = source as BlobSource;\n // Generate content key for caching\n const contentKey = generateContentKey(blobSource.data);\n contentKeyRef.current = contentKey;\n // Use cached blob URL\n const url = getOrCreateBlobUrl(\n contentKey,\n blobSource.data,\n blobSource.mimeType || 'video/mp4'\n );\n videoDebug.load(url, 'blob');\n setVideoUrl(url);\n break;\n }\n\n case 'data-url': {\n const dataUrlSource = source as DataUrlSource;\n videoDebug.load(dataUrlSource.data.slice(0, 50) + '...', 'data-url');\n setVideoUrl(dataUrlSource.data);\n break;\n }\n\n default:\n videoDebug.error('Invalid video source type', { type: (source as { type: string }).type });\n setVideoUrl(null);\n setHasError(true);\n setErrorMessage('Invalid video source');\n }\n\n // No cleanup here - cleanup happens in unmount effect above\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [source]);\n\n // Get source key for position caching\n const getSourceKey = useCallback(() => {\n switch (source.type) {\n case 'stream':\n return `stream:${(source as StreamSource).sessionId}:${(source as StreamSource).path}`;\n case 'blob':\n return contentKeyRef.current ? `blob:${contentKeyRef.current}` : null;\n case 'data-url':\n return `data:${(source as DataUrlSource).data.slice(0, 50)}`;\n default:\n return null;\n }\n }, [source]);\n\n // Restore cached playback position and settings when video is ready\n const handleCanPlay = useCallback(() => {\n const video = videoRef.current;\n if (video) {\n videoDebug.state('canplay', { duration: video.duration, buffered: video.buffered.length });\n videoDebug.buffer(video.buffered, video.duration);\n\n // Apply saved volume (user preference)\n video.volume = savedSettings.volume;\n }\n setIsLoading(false);\n\n // Restore position from cache\n const sourceKey = getSourceKey();\n if (sourceKey && video) {\n const cachedPosition = getVideoPosition(sourceKey);\n if (cachedPosition && cachedPosition > 0) {\n const duration = video.duration;\n // Only restore if position is valid (not at the end)\n if (cachedPosition < duration - 1) {\n videoDebug.debug(`Restoring position: ${cachedPosition}s`);\n video.currentTime = cachedPosition;\n }\n }\n }\n\n onCanPlay?.();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [getSourceKey, onCanPlay, savedSettings.volume]);\n\n // Save playback position periodically\n const handleTimeUpdate = useCallback(() => {\n const video = videoRef.current;\n if (!video) return;\n\n // Save position every 5 seconds\n const sourceKey = getSourceKey();\n if (sourceKey && video.currentTime > 0) {\n const timeSinceLastSave = video.currentTime - lastSavedTimeRef.current;\n if (timeSinceLastSave >= 5 || timeSinceLastSave < 0) {\n saveVideoPosition(sourceKey, video.currentTime);\n lastSavedTimeRef.current = video.currentTime;\n }\n }\n\n onTimeUpdate?.(video.currentTime, video.duration);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [getSourceKey, onTimeUpdate]);\n\n // Save position on pause\n const handlePause = useCallback(() => {\n const video = videoRef.current;\n const sourceKey = getSourceKey();\n if (sourceKey && video && video.currentTime > 0) {\n saveVideoPosition(sourceKey, video.currentTime);\n lastSavedTimeRef.current = video.currentTime;\n }\n onPause?.();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [getSourceKey, onPause]);\n\n // Handle buffer progress\n const handleProgress = useCallback(() => {\n const video = videoRef.current;\n if (!video || !onBufferProgress) return;\n\n // Get the buffered time ranges\n if (video.buffered.length > 0) {\n // Get the end of the last buffered range\n const bufferedEnd = video.buffered.end(video.buffered.length - 1);\n const duration = video.duration;\n\n if (duration > 0 && !isNaN(bufferedEnd)) {\n onBufferProgress(bufferedEnd, duration);\n }\n }\n }, [onBufferProgress]);\n\n // Preloader timeout\n useEffect(() => {\n if (!showPreloader || !isLoading) return;\n\n const timeout = setTimeout(() => {\n setIsLoading(false);\n }, preloaderTimeout);\n\n return () => clearTimeout(timeout);\n }, [showPreloader, isLoading, preloaderTimeout]);\n\n const handleContextMenu = (e: React.MouseEvent) => {\n if (disableContextMenu) {\n e.preventDefault();\n }\n };\n\n const handleLoadedData = () => {\n setIsLoading(false);\n };\n\n const handleError = () => {\n const video = videoRef.current;\n if (video) {\n videoDebug.error('Video error', { code: video.error?.code, message: video.error?.message });\n }\n setIsLoading(false);\n setHasError(true);\n setErrorMessage('Failed to load video');\n onError?.('Video playback error');\n };\n\n // Debug: Log video events\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n const handleLoadedMetadata = () => {\n videoDebug.state('loadedmetadata', { duration: video.duration });\n };\n\n const handleSeeking = () => {\n videoDebug.event('seeking', { currentTime: video.currentTime });\n };\n\n const handleSeeked = () => {\n videoDebug.event('seeked', { currentTime: video.currentTime });\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n const handleWaiting = () => {\n videoDebug.warn('WAITING - buffering...');\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n const handleStalled = () => {\n videoDebug.warn('STALLED - network issue');\n videoDebug.buffer(video.buffered, video.duration);\n };\n\n video.addEventListener('loadedmetadata', handleLoadedMetadata);\n video.addEventListener('seeking', handleSeeking);\n video.addEventListener('seeked', handleSeeked);\n video.addEventListener('waiting', handleWaiting);\n video.addEventListener('stalled', handleStalled);\n\n return () => {\n video.removeEventListener('loadedmetadata', handleLoadedMetadata);\n video.removeEventListener('seeking', handleSeeking);\n video.removeEventListener('seeked', handleSeeked);\n video.removeEventListener('waiting', handleWaiting);\n video.removeEventListener('stalled', handleStalled);\n };\n }, [videoUrl]);\n\n // Persist volume when user changes it via native controls\n useEffect(() => {\n const video = videoRef.current;\n if (!video) return;\n\n const handleVolumeChange = () => {\n updateVolume(video.volume);\n };\n\n video.addEventListener('volumechange', handleVolumeChange);\n return () => video.removeEventListener('volumechange', handleVolumeChange);\n }, [videoUrl, updateVolume]);\n\n // Determine if we should use AspectRatio wrapper or fill mode\n const isFillMode = aspectRatio === 'fill';\n const computedAspectRatio = aspectRatio === 'auto' || aspectRatio === 'fill' ? undefined : aspectRatio;\n\n // Render error fallback\n const renderErrorFallback = () => {\n const fallbackProps: ErrorFallbackProps = { error: errorMessage, retry };\n\n if (typeof errorFallback === 'function') {\n return errorFallback(fallbackProps);\n }\n\n if (errorFallback) {\n return errorFallback;\n }\n\n return <DefaultErrorFallback {...fallbackProps} />;\n };\n\n // Error state\n if (!videoUrl || hasError) {\n if (isFillMode) {\n return (\n <div className={cn('relative w-full h-full overflow-hidden bg-black', className)}>\n {renderErrorFallback()}\n </div>\n );\n }\n\n return (\n <div className={cn('relative overflow-hidden bg-black', className)}>\n <AspectRatio ratio={computedAspectRatio}>\n {renderErrorFallback()}\n </AspectRatio>\n </div>\n );\n }\n\n // Video content\n const videoContent = (\n <>\n {/* Loading indicator */}\n {showPreloader && isLoading && (\n <div className=\"absolute inset-0 flex items-center justify-center bg-black/50 z-10\">\n <Preloader size=\"lg\" spinnerClassName=\"text-white\" />\n </div>\n )}\n\n {/* Video element */}\n <video\n ref={videoRef}\n src={videoUrl}\n className={cn(\n 'w-full h-full object-contain',\n isLoading && 'opacity-0',\n videoClassName\n )}\n autoPlay={autoPlay}\n muted={muted}\n loop={loop}\n playsInline={playsInline}\n preload={preload}\n controls={controls}\n crossOrigin=\"anonymous\"\n poster={source.poster}\n onContextMenu={handleContextMenu}\n onLoadStart={onLoadStart}\n onCanPlay={handleCanPlay}\n onLoadedData={handleLoadedData}\n onPlay={onPlay}\n onPause={handlePause}\n onEnded={onEnded}\n onError={handleError}\n onTimeUpdate={handleTimeUpdate}\n onProgress={handleProgress}\n />\n </>\n );\n\n // Fill mode - no AspectRatio wrapper\n if (isFillMode) {\n return (\n <div className={cn('relative w-full h-full overflow-hidden bg-black', className)}>\n {videoContent}\n </div>\n );\n }\n\n // Normal mode with AspectRatio\n return (\n <div className={cn('relative overflow-hidden bg-black', className)}>\n <AspectRatio ratio={computedAspectRatio}>\n {videoContent}\n </AspectRatio>\n </div>\n );\n }\n);\n\nStreamProvider.displayName = 'StreamProvider';\n","/**\n * VideoPlayerContext - Context for streaming configuration\n * Simplifies streaming API by providing getStreamUrl globally\n */\n\n'use client';\n\nimport React, { createContext, useContext, useMemo } from 'react';\n\nimport type { VideoPlayerContextValue, VideoPlayerProviderProps } from '../types';\n\n// =============================================================================\n// Context\n// =============================================================================\n\nconst VideoPlayerContext = createContext<VideoPlayerContextValue | null>(null);\n\n/**\n * Provider for VideoPlayer streaming configuration\n *\n * @example\n * // In your app layout or FileWorkspace\n * <VideoPlayerProvider\n * sessionId={sessionId}\n * getStreamUrl={terminalClient.terminal_media.streamStreamRetrieveUrl}\n * >\n * <VideoPlayer source={{ type: 'stream', path: '/video.mp4' }} />\n * </VideoPlayerProvider>\n */\nexport function VideoPlayerProvider({\n children,\n getStreamUrl,\n sessionId,\n}: VideoPlayerProviderProps) {\n const value = useMemo(\n () => ({ getStreamUrl, sessionId }),\n [getStreamUrl, sessionId]\n );\n\n return (\n <VideoPlayerContext.Provider value={value}>\n {children}\n </VideoPlayerContext.Provider>\n );\n}\n\n/**\n * Hook to access VideoPlayer context\n */\nexport function useVideoPlayerContext(): VideoPlayerContextValue | null {\n return useContext(VideoPlayerContext);\n}\n","/**\n * Video source and player mode resolvers\n */\n\nimport type { VideoSourceUnion, PlayerMode, SimpleStreamSource, StreamSource, VideoPlayerContextValue } from '../types';\n\n/**\n * Determine which provider to use based on source type\n */\nexport function resolvePlayerMode(\n source: VideoSourceUnion,\n mode: PlayerMode = 'auto'\n): 'vidstack' | 'native' | 'streaming' {\n if (mode !== 'auto') {\n return mode;\n }\n\n switch (source.type) {\n case 'youtube':\n case 'vimeo':\n case 'hls':\n case 'dash':\n return 'vidstack';\n\n case 'stream':\n case 'blob':\n return 'streaming';\n\n case 'data-url':\n case 'url':\n default:\n return 'native';\n }\n}\n\n/**\n * Check if source is a simplified stream source (without getStreamUrl)\n */\nexport function isSimpleStreamSource(\n source: VideoSourceUnion | SimpleStreamSource\n): source is SimpleStreamSource {\n return source.type === 'stream' && !('getStreamUrl' in source);\n}\n\n/**\n * Resolve simplified stream source to full stream source using context\n */\nexport function resolveStreamSource(\n source: SimpleStreamSource,\n context: VideoPlayerContextValue | null\n): StreamSource | null {\n if (!context?.getStreamUrl) {\n console.warn(\n 'VideoPlayer: Stream source requires getStreamUrl. ' +\n 'Either provide it in source or wrap with VideoPlayerProvider.'\n );\n return null;\n }\n\n const sessionId = source.sessionId || context.sessionId;\n if (!sessionId) {\n console.warn('VideoPlayer: Stream source requires sessionId.');\n return null;\n }\n\n return {\n type: 'stream',\n sessionId,\n path: source.path,\n getStreamUrl: context.getStreamUrl,\n mimeType: source.mimeType,\n title: source.title,\n poster: source.poster,\n };\n}\n","/**\n * File source resolution utilities\n */\n\nimport type { VideoSourceUnion, ResolveFileSourceOptions } from '../types';\n\n/**\n * Resolve file content to VideoSourceUnion\n * Useful for FileWorkspace/file manager integrations\n *\n * @example\n * const source = resolveFileSource({\n * content: file.content,\n * path: file.path,\n * mimeType: file.mimeType,\n * sessionId: sessionId,\n * loadMethod: file.loadMethod,\n * getStreamUrl: terminalClient.terminal_media.streamStreamRetrieveUrl\n * });\n *\n * <VideoPlayer source={source} />\n */\nexport function resolveFileSource(options: ResolveFileSourceOptions): VideoSourceUnion | null {\n const {\n content,\n path,\n mimeType,\n sessionId,\n loadMethod,\n getStreamUrl,\n title,\n poster,\n } = options;\n\n const contentSize = content\n ? typeof content === 'string'\n ? content.length\n : content.byteLength\n : 0;\n const hasContent = contentSize > 0;\n\n // Priority 1: HTTP Range streaming for large files\n if (loadMethod === 'http_stream' && !hasContent && sessionId && getStreamUrl) {\n return {\n type: 'stream',\n sessionId,\n path,\n getStreamUrl,\n mimeType,\n title,\n poster,\n };\n }\n\n // Priority 2: Data URL (base64 string)\n if (typeof content === 'string' && hasContent) {\n return {\n type: 'data-url',\n data: content,\n title,\n poster,\n };\n }\n\n // Priority 3: ArrayBuffer → Blob\n if (content instanceof ArrayBuffer && hasContent) {\n return {\n type: 'blob',\n data: content,\n mimeType: mimeType || 'video/mp4',\n title,\n poster,\n };\n }\n\n // No valid content\n return null;\n}\n","/**\n * VideoPlayer - Unified Video Player Component\n *\n * Supports multiple modes:\n * - vidstack: Full-featured player (YouTube, Vimeo, HLS, DASH)\n * - native: Lightweight HTML5 player\n * - streaming: HTTP Range streaming with auth / Blob sources\n *\n * @example\n * // YouTube video\n * <VideoPlayer source={{ type: 'youtube', id: 'dQw4w9WgXcQ' }} />\n *\n * @example\n * // HLS stream\n * <VideoPlayer source={{ type: 'hls', url: 'https://example.com/video.m3u8' }} />\n *\n * @example\n * // HTTP Range streaming with auth (full source)\n * <VideoPlayer\n * source={{\n * type: 'stream',\n * sessionId: 'abc123',\n * path: '/videos/movie.mp4',\n * getStreamUrl: (id, path) => `/api/stream/${id}?path=${path}&token=${token}`\n * }}\n * />\n *\n * @example\n * // HTTP Range streaming (simplified, using VideoPlayerProvider context)\n * <VideoPlayerProvider sessionId={sessionId} getStreamUrl={getStreamUrl}>\n * <VideoPlayer source={{ type: 'stream', path: '/videos/movie.mp4' }} />\n * </VideoPlayerProvider>\n *\n * @example\n * // Blob/ArrayBuffer\n * <VideoPlayer source={{ type: 'blob', data: arrayBuffer, mimeType: 'video/mp4' }} />\n */\n\n'use client';\n\nimport React, { forwardRef, useMemo } from 'react';\n\nimport { VidstackProvider, NativeProvider, StreamProvider } from '../providers';\nimport { useVideoPlayerContext } from '../context';\nimport { resolvePlayerMode, isSimpleStreamSource, resolveStreamSource } from '../utils';\n\nimport type { VideoPlayerProps, VideoPlayerRef, VideoSourceUnion, VidstackProviderProps, NativeProviderProps, StreamProviderProps, SimpleStreamSource } from '../types';\n\nexport const VideoPlayer = forwardRef<VideoPlayerRef, VideoPlayerProps & { source: VideoSourceUnion | SimpleStreamSource }>(\n (\n {\n source: rawSource,\n mode = 'auto',\n aspectRatio = 16 / 9,\n autoPlay = false,\n muted = false,\n loop = false,\n playsInline = true,\n controls = true,\n preload = 'metadata',\n theme = 'default',\n showInfo = false,\n className,\n videoClassName,\n disableContextMenu = false,\n showPreloader = true,\n preloaderTimeout = 5000,\n errorFallback,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n },\n ref\n ) => {\n // Get context for simplified stream sources\n const context = useVideoPlayerContext();\n\n // Resolve simplified stream source to full source using context\n const source = useMemo(() => {\n if (isSimpleStreamSource(rawSource)) {\n const resolved = resolveStreamSource(rawSource, context);\n if (!resolved) {\n // Return a special error source that will trigger error fallback\n return null;\n }\n return resolved;\n }\n return rawSource;\n }, [rawSource, context]);\n\n // Handle unresolved source\n if (!source) {\n // Render error state\n const errorMessage = 'Stream source requires VideoPlayerProvider with getStreamUrl and sessionId';\n\n if (typeof errorFallback === 'function') {\n return (\n <div className={className} style={{ aspectRatio: aspectRatio === 'fill' ? undefined : aspectRatio }}>\n {errorFallback({ error: errorMessage })}\n </div>\n );\n }\n\n if (errorFallback) {\n return (\n <div className={className} style={{ aspectRatio: aspectRatio === 'fill' ? undefined : aspectRatio }}>\n {errorFallback}\n </div>\n );\n }\n\n // Default error UI\n return (\n <div\n className={className}\n style={{\n aspectRatio: aspectRatio === 'fill' ? undefined : aspectRatio,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: 'black',\n color: 'white',\n }}\n >\n <p>{errorMessage}</p>\n </div>\n );\n }\n\n // Determine which provider to use\n const resolvedMode = resolvePlayerMode(source, mode);\n\n // Common props for all providers\n const commonProps = {\n aspectRatio,\n autoPlay,\n muted,\n loop,\n playsInline,\n controls,\n preload,\n className,\n onPlay,\n onPause,\n onEnded,\n onError,\n onLoadStart,\n onCanPlay,\n onTimeUpdate,\n };\n\n // Render appropriate provider\n switch (resolvedMode) {\n case 'vidstack':\n return (\n <VidstackProvider\n ref={ref}\n source={source as VidstackProviderProps['source']}\n theme={theme}\n showInfo={showInfo}\n errorFallback={errorFallback}\n {...commonProps}\n />\n );\n\n case 'streaming':\n return (\n <StreamProvider\n ref={ref}\n source={source as StreamProviderProps['source']}\n videoClassName={videoClassName}\n disableContextMenu={disableContextMenu}\n showPreloader={showPreloader}\n preloaderTimeout={preloaderTimeout}\n errorFallback={errorFallback}\n {...commonProps}\n />\n );\n\n case 'native':\n default:\n return (\n <NativeProvider\n ref={ref}\n source={source as NativeProviderProps['source']}\n videoClassName={videoClassName}\n disableContextMenu={disableContextMenu}\n showPreloader={showPreloader}\n preloaderTimeout={preloaderTimeout}\n {...commonProps}\n />\n );\n }\n }\n);\n\nVideoPlayer.displayName = 'VideoPlayer';\n","/**\n * Custom Video Controls for Vidstack Player\n */\n\n'use client';\n\nimport { Maximize, Minimize, Pause, Play, Volume2, VolumeX } from 'lucide-react';\nimport React from 'react';\n\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { useMediaRemote, useMediaStore } from '@vidstack/react';\n\nimport type { MediaPlayerInstance } from '@vidstack/react';\ninterface VideoControlsProps {\n player: React.RefObject<MediaPlayerInstance | null>;\n className?: string;\n}\n\nexport function VideoControls({ player, className }: VideoControlsProps) {\n const store = useMediaStore(player);\n const remote = useMediaRemote();\n\n const isPaused = store.paused;\n const isMuted = store.muted;\n const isFullscreen = store.fullscreen;\n const currentTime = store.currentTime;\n const duration = store.duration;\n const volume = store.volume;\n\n const formatTime = (seconds: number): string => {\n if (!seconds || seconds < 0) return '0:00';\n const minutes = Math.floor(seconds / 60);\n const secs = Math.floor(seconds % 60);\n return `${minutes}:${secs.toString().padStart(2, '0')}`;\n };\n\n const handleProgressClick = (e: React.MouseEvent<HTMLDivElement>) => {\n if (!duration) return;\n const rect = e.currentTarget.getBoundingClientRect();\n const clickX = e.clientX - rect.left;\n const percentage = clickX / rect.width;\n const newTime = percentage * duration;\n remote.seek(newTime);\n };\n\n const handleVolumeChange = (e: React.MouseEvent<HTMLDivElement>) => {\n const rect = e.currentTarget.getBoundingClientRect();\n const clickX = e.clientX - rect.left;\n const percentage = Math.max(0, Math.min(1, clickX / rect.width));\n remote.changeVolume(percentage);\n if (percentage > 0 && isMuted) {\n remote.toggleMuted();\n }\n };\n\n const progress = duration > 0 ? (currentTime / duration) * 100 : 0;\n\n return (\n <div\n className={cn(\n \"absolute inset-0 flex flex-col justify-end transition-opacity duration-300\",\n \"bg-gradient-to-t from-black/80 via-black/20 to-transparent\",\n \"opacity-0 group-hover:opacity-100 focus-within:opacity-100\",\n \"pointer-events-none group-hover:pointer-events-auto\",\n className\n )}\n >\n {/* Progress Bar */}\n <div className=\"px-4 pb-2 pointer-events-auto\">\n <div\n className=\"h-1.5 bg-white/20 rounded-full cursor-pointer hover:h-2 transition-all group\"\n onClick={handleProgressClick}\n >\n <div\n className=\"h-full bg-primary rounded-full transition-all relative group-hover:bg-primary/90\"\n style={{ width: `${progress}%` }}\n >\n <div className=\"absolute right-0 top-1/2 -translate-y-1/2 w-3 h-3 bg-white rounded-full opacity-0 group-hover:opacity-100 transition-opacity\" />\n </div>\n </div>\n </div>\n\n {/* Control Bar */}\n <div className=\"flex items-center gap-4 px-4 pb-4 pointer-events-auto\">\n {/* Play/Pause */}\n <button\n onClick={() => remote.togglePaused()}\n className=\"text-white hover:text-primary transition-colors p-1.5 hover:bg-white/10 rounded-full\"\n >\n {isPaused ? <Play className=\"h-6 w-6\" /> : <Pause className=\"h-6 w-6\" />}\n </button>\n\n {/* Time */}\n <div className=\"text-white text-sm font-medium\">\n {formatTime(currentTime)} / {formatTime(duration)}\n </div>\n\n <div className=\"flex-1\" />\n\n {/* Volume Control */}\n <div className=\"flex items-center gap-2 group/volume\">\n <button\n onClick={() => remote.toggleMuted()}\n className=\"text-white hover:text-primary transition-colors p-1.5 hover:bg-white/10 rounded-full\"\n >\n {isMuted || volume === 0 ? (\n <VolumeX className=\"h-5 w-5\" />\n ) : (\n <Volume2 className=\"h-5 w-5\" />\n )}\n </button>\n\n <div\n className=\"w-0 group-hover/volume:w-20 transition-all overflow-hidden\"\n >\n <div\n className=\"h-1.5 bg-white/20 rounded-full cursor-pointer hover:h-2 transition-all\"\n onClick={handleVolumeChange}\n >\n <div\n className=\"h-full bg-white rounded-full transition-all\"\n style={{ width: `${volume * 100}%` }}\n />\n </div>\n </div>\n </div>\n\n {/* Fullscreen */}\n <button\n onClick={() => isFullscreen ? remote.exitFullscreen() : remote.enterFullscreen()}\n className=\"text-white hover:text-primary transition-colors p-1.5 hover:bg-white/10 rounded-full\"\n >\n {isFullscreen ? <Minimize className=\"h-5 w-5\" /> : <Maximize className=\"h-5 w-5\" />}\n </button>\n </div>\n </div>\n );\n}\n","/**\n * VideoErrorFallback - Pre-built error fallback with download button\n * For use with VideoPlayer errorFallback prop\n */\n\n'use client';\n\nimport React from 'react';\nimport { FileVideo, RefreshCw } from 'lucide-react';\n\nimport { cn, Button, DownloadButton } from '../../_shared';\n\nimport type { ErrorFallbackProps } from '../types';\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport interface VideoErrorFallbackProps extends ErrorFallbackProps {\n /** URL for download button (if provided, shows download button) */\n downloadUrl?: string;\n /** Filename for download */\n downloadFilename?: string;\n /** File size to display */\n fileSize?: string;\n /** Show retry button */\n showRetry?: boolean;\n /** Custom className */\n className?: string;\n /** Custom icon */\n icon?: React.ReactNode;\n /** Custom title (defaults to error message) */\n title?: string;\n /** Custom description */\n description?: string;\n}\n\n// ============================================================================\n// Component\n// ============================================================================\n\n/**\n * Pre-built error fallback component for VideoPlayer\n *\n * @example\n * // Basic usage\n * <VideoPlayer\n * source={source}\n * errorFallback={(props) => (\n * <VideoErrorFallback\n * {...props}\n * downloadUrl={getDownloadUrl()}\n * downloadFilename=\"video.mp4\"\n * />\n * )}\n * />\n *\n * @example\n * // With file size\n * <VideoErrorFallback\n * error=\"Failed to load video\"\n * downloadUrl=\"/api/download/video.mp4\"\n * fileSize=\"125 MB\"\n * showRetry\n * retry={() => reloadVideo()}\n * />\n */\nexport function VideoErrorFallback({\n error,\n retry,\n downloadUrl,\n downloadFilename,\n fileSize,\n showRetry = true,\n className,\n icon,\n title,\n description,\n}: VideoErrorFallbackProps) {\n const displayTitle = title || error || 'Video cannot be previewed';\n\n return (\n <div\n className={cn(\n 'absolute inset-0 flex flex-col items-center justify-center gap-4 bg-black/90 text-white p-6',\n className\n )}\n >\n {/* Icon */}\n {icon || <FileVideo className=\"w-16 h-16 text-muted-foreground\" />}\n\n {/* Title */}\n <p className=\"text-lg font-medium text-center\">{displayTitle}</p>\n\n {/* Description / File size */}\n {(description || fileSize) && (\n <p className=\"text-sm text-muted-foreground text-center\">\n {description || fileSize}\n </p>\n )}\n\n {/* Actions */}\n <div className=\"flex items-center gap-3 mt-2\">\n {/* Retry button */}\n {showRetry && retry && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={retry}\n className=\"gap-2\"\n >\n <RefreshCw className=\"w-4 h-4\" />\n Retry\n </Button>\n )}\n\n {/* Download button */}\n {downloadUrl && (\n <DownloadButton\n url={downloadUrl}\n filename={downloadFilename}\n variant=\"default\"\n size=\"sm\"\n >\n Download to view\n </DownloadButton>\n )}\n </div>\n </div>\n );\n}\n\n// ============================================================================\n// Factory for common use cases\n// ============================================================================\n\nexport interface CreateVideoErrorFallbackOptions {\n /** Function to get download URL from source */\n getDownloadUrl?: (source: unknown) => string | undefined;\n /** Function to get filename from source */\n getFilename?: (source: unknown) => string | undefined;\n /** Function to get file size from source */\n getFileSize?: (source: unknown) => string | undefined;\n /** Show retry button */\n showRetry?: boolean;\n}\n\n/**\n * Factory to create error fallback function for VideoPlayer\n *\n * @example\n * const errorFallback = createVideoErrorFallback({\n * getDownloadUrl: (source) => source.downloadUrl,\n * getFilename: (source) => source.filename,\n * showRetry: true,\n * });\n *\n * <VideoPlayer source={source} errorFallback={errorFallback} />\n */\nexport function createVideoErrorFallback(\n options: CreateVideoErrorFallbackOptions\n): (props: ErrorFallbackProps, source?: unknown) => React.ReactNode {\n return (props: ErrorFallbackProps, source?: unknown) => (\n <VideoErrorFallback\n {...props}\n downloadUrl={options.getDownloadUrl?.(source)}\n downloadFilename={options.getFilename?.(source)}\n fileSize={options.getFileSize?.(source)}\n showRetry={options.showRetry}\n />\n );\n}\n","'use client';\n\n/**\n * useHybridAudio - Hybrid audio hook combining HTML5 audio + Web Audio API\n *\n * Uses native HTML5 <audio> for playback (no crackling, native streaming)\n * and Web Audio API only for visualization (AnalyserNode).\n *\n * Audio routing:\n * source -> destination (single path for playback)\n * source -> analyser (parallel path for visualization only, no output)\n */\n\nimport { useRef, useState, useCallback, useEffect } from 'react';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface UseHybridAudioOptions {\n src: string;\n autoPlay?: boolean;\n initialVolume?: number;\n loop?: boolean;\n crossOrigin?: 'anonymous' | 'use-credentials';\n onPlay?: () => void;\n onPause?: () => void;\n onEnded?: () => void;\n onTimeUpdate?: (time: number) => void;\n onError?: (error: Error) => void;\n onReady?: () => void;\n}\n\nexport interface HybridAudioState {\n isReady: boolean;\n isPlaying: boolean;\n currentTime: number;\n duration: number;\n volume: number;\n isMuted: boolean;\n isLooping: boolean;\n buffered: TimeRanges | null;\n error: Error | null;\n}\n\nexport interface HybridAudioControls {\n play: () => Promise<void>;\n pause: () => void;\n togglePlay: () => void;\n seek: (time: number) => void;\n seekTo: (progress: number) => void;\n skip: (seconds: number) => void;\n setVolume: (vol: number) => void;\n toggleMute: () => void;\n toggleLoop: () => void;\n setLoop: (enabled: boolean) => void;\n restart: () => void;\n}\n\nexport interface HybridWebAudioAPI {\n context: AudioContext | null;\n analyser: AnalyserNode | null;\n sourceNode: MediaElementAudioSourceNode | null;\n}\n\nexport interface UseHybridAudioReturn {\n audioRef: React.RefObject<HTMLAudioElement | null>;\n state: HybridAudioState;\n controls: HybridAudioControls;\n webAudio: HybridWebAudioAPI;\n}\n\n// =============================================================================\n// HOOK\n// =============================================================================\n\nexport function useHybridAudio(options: UseHybridAudioOptions): UseHybridAudioReturn {\n const {\n src,\n autoPlay = false,\n initialVolume = 1,\n loop = false,\n crossOrigin = 'anonymous',\n onPlay,\n onPause,\n onEnded,\n onTimeUpdate,\n onError,\n onReady,\n } = options;\n\n // Refs\n const audioRef = useRef<HTMLAudioElement | null>(null);\n const audioContextRef = useRef<AudioContext | null>(null);\n const sourceNodeRef = useRef<MediaElementAudioSourceNode | null>(null);\n const analyserRef = useRef<AnalyserNode | null>(null);\n const connectedElementRef = useRef<HTMLMediaElement | null>(null);\n\n // State\n const [state, setState] = useState<HybridAudioState>({\n isReady: false,\n isPlaying: false,\n currentTime: 0,\n duration: 0,\n volume: initialVolume,\n isMuted: false,\n isLooping: loop,\n buffered: null,\n error: null,\n });\n\n // Initialize Web Audio for visualization (lazy, on first play)\n const initWebAudio = useCallback(() => {\n const audio = audioRef.current;\n if (!audio) return;\n\n // Already connected to this element\n if (connectedElementRef.current === audio && audioContextRef.current) {\n return;\n }\n\n try {\n // Create AudioContext if needed\n if (!audioContextRef.current) {\n const AudioContextClass =\n window.AudioContext ||\n (window as unknown as { webkitAudioContext: typeof AudioContext }).webkitAudioContext;\n audioContextRef.current = new AudioContextClass();\n }\n\n const ctx = audioContextRef.current;\n\n // Disconnect old source if any\n if (sourceNodeRef.current) {\n try {\n sourceNodeRef.current.disconnect();\n } catch {\n /* ignore */\n }\n }\n\n // Create source from audio element\n const source = ctx.createMediaElementSource(audio);\n sourceNodeRef.current = source;\n\n // Create analyser for visualization\n const analyser = ctx.createAnalyser();\n analyser.fftSize = 256;\n analyser.smoothingTimeConstant = 0.85;\n analyserRef.current = analyser;\n\n // Audio routing:\n // 1. source -> destination (for playback)\n // 2. source -> analyser (for visualization only - NO output!)\n source.connect(ctx.destination);\n source.connect(analyser);\n // NOTE: analyser does NOT connect to destination - prevents double audio!\n\n connectedElementRef.current = audio;\n } catch (error) {\n console.warn('[useHybridAudio] Web Audio init failed:', error);\n }\n }, []);\n\n // Resume AudioContext on user interaction\n const resumeAudioContext = useCallback(async () => {\n const ctx = audioContextRef.current;\n if (ctx && ctx.state === 'suspended') {\n await ctx.resume();\n }\n }, []);\n\n // Controls\n const play = useCallback(async () => {\n const audio = audioRef.current;\n if (!audio) return;\n\n try {\n initWebAudio();\n await resumeAudioContext();\n await audio.play();\n } catch (error) {\n console.error('[useHybridAudio] Play failed:', error);\n onError?.(error as Error);\n }\n }, [initWebAudio, resumeAudioContext, onError]);\n\n const pause = useCallback(() => {\n audioRef.current?.pause();\n }, []);\n\n const togglePlay = useCallback(() => {\n if (state.isPlaying) {\n pause();\n } else {\n play();\n }\n }, [state.isPlaying, play, pause]);\n\n const seek = useCallback(\n (time: number) => {\n const audio = audioRef.current;\n if (audio && isFinite(time)) {\n audio.currentTime = Math.max(0, Math.min(time, state.duration || audio.duration || 0));\n }\n },\n [state.duration]\n );\n\n const seekTo = useCallback(\n (progress: number) => {\n const duration = state.duration || audioRef.current?.duration || 0;\n seek(duration * Math.max(0, Math.min(1, progress)));\n },\n [state.duration, seek]\n );\n\n const skip = useCallback(\n (seconds: number) => {\n seek(state.currentTime + seconds);\n },\n [state.currentTime, seek]\n );\n\n const setVolume = useCallback((vol: number) => {\n const audio = audioRef.current;\n if (audio) {\n const clampedVol = Math.max(0, Math.min(1, vol));\n audio.volume = clampedVol;\n setState((prev) => ({ ...prev, volume: clampedVol }));\n }\n }, []);\n\n const toggleMute = useCallback(() => {\n const audio = audioRef.current;\n if (audio) {\n audio.muted = !audio.muted;\n setState((prev) => ({ ...prev, isMuted: audio.muted }));\n }\n }, []);\n\n const toggleLoop = useCallback(() => {\n const audio = audioRef.current;\n if (audio) {\n audio.loop = !audio.loop;\n setState((prev) => ({ ...prev, isLooping: audio.loop }));\n }\n }, []);\n\n const setLoop = useCallback((enabled: boolean) => {\n const audio = audioRef.current;\n if (audio) {\n audio.loop = enabled;\n setState((prev) => ({ ...prev, isLooping: enabled }));\n }\n }, []);\n\n const restart = useCallback(() => {\n seek(0);\n play();\n }, [seek, play]);\n\n const controls: HybridAudioControls = {\n play,\n pause,\n togglePlay,\n seek,\n seekTo,\n skip,\n setVolume,\n toggleMute,\n toggleLoop,\n setLoop,\n restart,\n };\n\n // Create audio element on mount\n useEffect(() => {\n const audio = document.createElement('audio');\n audio.preload = 'metadata';\n audio.crossOrigin = crossOrigin;\n audio.volume = initialVolume;\n audio.loop = loop;\n audioRef.current = audio;\n\n return () => {\n audio.pause();\n audio.src = '';\n if (audioContextRef.current) {\n audioContextRef.current.close().catch(() => {});\n }\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n // Event handlers\n useEffect(() => {\n const audio = audioRef.current;\n if (!audio) return;\n\n const handlers = {\n loadedmetadata: () => {\n setState((prev) => ({\n ...prev,\n duration: audio.duration,\n isReady: true,\n }));\n onReady?.();\n },\n canplay: () => {\n setState((prev) => ({ ...prev, isReady: true }));\n if (autoPlay) {\n play();\n }\n },\n play: () => {\n setState((prev) => ({ ...prev, isPlaying: true }));\n onPlay?.();\n },\n pause: () => {\n setState((prev) => ({ ...prev, isPlaying: false }));\n onPause?.();\n },\n ended: () => {\n setState((prev) => ({ ...prev, isPlaying: false }));\n onEnded?.();\n },\n timeupdate: () => {\n setState((prev) => ({ ...prev, currentTime: audio.currentTime }));\n onTimeUpdate?.(audio.currentTime);\n },\n progress: () => {\n setState((prev) => ({ ...prev, buffered: audio.buffered }));\n },\n error: () => {\n const error = new Error(audio.error?.message || 'Audio error');\n setState((prev) => ({ ...prev, error }));\n onError?.(error);\n },\n volumechange: () => {\n setState((prev) => ({\n ...prev,\n volume: audio.volume,\n isMuted: audio.muted,\n }));\n },\n };\n\n Object.entries(handlers).forEach(([event, handler]) => {\n audio.addEventListener(event, handler);\n });\n\n return () => {\n Object.entries(handlers).forEach(([event, handler]) => {\n audio.removeEventListener(event, handler);\n });\n };\n }, [autoPlay, onPlay, onPause, onEnded, onTimeUpdate, onError, onReady, play]);\n\n // Load new source\n useEffect(() => {\n const audio = audioRef.current;\n if (!audio || !src) return;\n\n setState((prev) => ({\n ...prev,\n isReady: false,\n currentTime: 0,\n duration: 0,\n error: null,\n }));\n\n audio.src = src;\n audio.load();\n }, [src]);\n\n return {\n audioRef,\n state,\n controls,\n webAudio: {\n context: audioContextRef.current,\n analyser: analyserRef.current,\n sourceNode: sourceNodeRef.current,\n },\n };\n}\n","'use client';\n\n/**\n * useHybridAudioAnalysis - Audio frequency analysis for hybrid player.\n *\n * Simplified version of useAudioAnalysis that works directly with AnalyserNode\n * instead of SharedWebAudioContext.\n */\n\nimport { useState, useRef, useEffect, useCallback } from 'react';\nimport type { AudioLevels } from '../effects';\n\nexport function useHybridAudioAnalysis(\n analyser: AnalyserNode | null,\n isPlaying: boolean\n): AudioLevels {\n const [levels, setLevels] = useState<AudioLevels>({ bass: 0, mid: 0, high: 0, overall: 0 });\n const animationRef = useRef<number | null>(null);\n const dataArrayRef = useRef<Uint8Array<ArrayBuffer> | null>(null);\n\n const cleanup = useCallback(() => {\n if (animationRef.current) {\n cancelAnimationFrame(animationRef.current);\n animationRef.current = null;\n }\n }, []);\n\n // Initialize data array when analyser is available\n useEffect(() => {\n if (analyser && !dataArrayRef.current) {\n dataArrayRef.current = new Uint8Array(analyser.frequencyBinCount) as Uint8Array<ArrayBuffer>;\n }\n }, [analyser]);\n\n // Animation loop\n useEffect(() => {\n if (!isPlaying || !analyser || !dataArrayRef.current) {\n cleanup();\n // Smooth fade out when stopped\n setLevels((prev) => ({\n bass: prev.bass * 0.95 < 0.01 ? 0 : prev.bass * 0.95,\n mid: prev.mid * 0.95 < 0.01 ? 0 : prev.mid * 0.95,\n high: prev.high * 0.95 < 0.01 ? 0 : prev.high * 0.95,\n overall: prev.overall * 0.95 < 0.01 ? 0 : prev.overall * 0.95,\n }));\n return;\n }\n\n const dataArray = dataArrayRef.current;\n\n const animate = () => {\n analyser.getByteFrequencyData(dataArray);\n const binCount = dataArray.length;\n\n // Bass (0-15% of frequency range)\n const bassEnd = Math.floor(binCount * 0.15);\n let bassSum = 0;\n for (let i = 0; i < bassEnd; i++) bassSum += dataArray[i];\n const bass = bassSum / bassEnd / 255;\n\n // Mids (15-50% of frequency range)\n const midStart = bassEnd;\n const midEnd = Math.floor(binCount * 0.5);\n let midSum = 0;\n for (let i = midStart; i < midEnd; i++) midSum += dataArray[i];\n const mid = midSum / (midEnd - midStart) / 255;\n\n // Highs (50-100% of frequency range)\n const highStart = midEnd;\n let highSum = 0;\n for (let i = highStart; i < binCount; i++) highSum += dataArray[i];\n const high = highSum / (binCount - highStart) / 255;\n\n // Overall\n let totalSum = 0;\n for (let i = 0; i < binCount; i++) totalSum += dataArray[i];\n const overall = totalSum / binCount / 255;\n\n // Smooth with lerp for natural feel\n setLevels((prev) => ({\n bass: prev.bass * 0.7 + bass * 0.3,\n mid: prev.mid * 0.7 + mid * 0.3,\n high: prev.high * 0.7 + high * 0.3,\n overall: prev.overall * 0.7 + overall * 0.3,\n }));\n\n animationRef.current = requestAnimationFrame(animate);\n };\n\n animationRef.current = requestAnimationFrame(animate);\n return cleanup;\n }, [analyser, isPlaying, cleanup]);\n\n return levels;\n}\n","'use client';\n\n/**\n * useVisualization - Hook for managing audio visualization settings\n *\n * Persists settings in localStorage for user preferences\n * Uses React Context for shared state between components\n */\n\nimport { createContext, useContext, useCallback, useMemo, type ReactNode } from 'react';\nimport { useLocalStorage } from '../../_shared';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport type VisualizationVariant = 'glow' | 'orbs' | 'spotlight' | 'mesh' | 'none';\nexport type VisualizationIntensity = 'subtle' | 'medium' | 'strong';\nexport type VisualizationColorScheme = 'primary' | 'vibrant' | 'cool' | 'warm';\n\nexport interface VisualizationSettings {\n /** Enable reactive cover animation */\n enabled: boolean;\n /** Visual effect variant */\n variant: VisualizationVariant;\n /** Effect intensity */\n intensity: VisualizationIntensity;\n /** Color scheme */\n colorScheme: VisualizationColorScheme;\n /** Playback volume (0-1) */\n volume: number;\n /** Loop playback */\n isLooping: boolean;\n}\n\nexport interface UseVisualizationReturn {\n /** Current settings */\n settings: VisualizationSettings;\n /** Toggle visualization on/off */\n toggle: () => void;\n /** Set specific setting */\n setSetting: <K extends keyof VisualizationSettings>(\n key: K,\n value: VisualizationSettings[K]\n ) => void;\n /** Cycle to next variant */\n nextVariant: () => void;\n /** Cycle to next intensity */\n nextIntensity: () => void;\n /** Cycle to next color scheme */\n nextColorScheme: () => void;\n /** Reset to defaults */\n reset: () => void;\n}\n\n// Backward compatibility alias\nexport type UseAudioVisualizationReturn = UseVisualizationReturn;\n\n// =============================================================================\n// CONSTANTS\n// =============================================================================\n\nconst STORAGE_KEY = 'audio-player-settings';\n\nconst DEFAULT_SETTINGS: VisualizationSettings = {\n enabled: true,\n variant: 'spotlight',\n intensity: 'medium',\n colorScheme: 'primary',\n volume: 1,\n isLooping: false,\n};\n\nconst VARIANTS: VisualizationVariant[] = ['spotlight', 'glow', 'orbs', 'mesh', 'none'];\nconst INTENSITIES: VisualizationIntensity[] = ['subtle', 'medium', 'strong'];\nconst COLOR_SCHEMES: VisualizationColorScheme[] = ['primary', 'vibrant', 'cool', 'warm'];\n\n// =============================================================================\n// CONTEXT\n// =============================================================================\n\nconst VisualizationContext = createContext<UseVisualizationReturn | null>(null);\n\n// =============================================================================\n// PROVIDER\n// =============================================================================\n\nexport interface VisualizationProviderProps {\n children: ReactNode;\n}\n\nexport function VisualizationProvider({ children }: VisualizationProviderProps) {\n const value = useVisualizationState();\n return (\n <VisualizationContext.Provider value={value}>\n {children}\n </VisualizationContext.Provider>\n );\n}\n\n// =============================================================================\n// INTERNAL HOOK (creates the actual state)\n// =============================================================================\n\nfunction useVisualizationState(): UseVisualizationReturn {\n const [settings, setSettings] = useLocalStorage<VisualizationSettings>(\n STORAGE_KEY,\n DEFAULT_SETTINGS\n );\n\n const toggle = useCallback(() => {\n setSettings((prev) => ({ ...prev, enabled: !prev.enabled }));\n }, [setSettings]);\n\n const setSetting = useCallback(\n <K extends keyof VisualizationSettings>(\n key: K,\n value: VisualizationSettings[K]\n ) => {\n setSettings((prev) => ({ ...prev, [key]: value }));\n },\n [setSettings]\n );\n\n const nextVariant = useCallback(() => {\n setSettings((prev) => {\n const currentIndex = VARIANTS.indexOf(prev.variant);\n const nextIndex = (currentIndex + 1) % VARIANTS.length;\n return { ...prev, variant: VARIANTS[nextIndex] };\n });\n }, [setSettings]);\n\n const nextIntensity = useCallback(() => {\n setSettings((prev) => {\n const currentIndex = INTENSITIES.indexOf(prev.intensity);\n const nextIndex = (currentIndex + 1) % INTENSITIES.length;\n return { ...prev, intensity: INTENSITIES[nextIndex] };\n });\n }, [setSettings]);\n\n const nextColorScheme = useCallback(() => {\n setSettings((prev) => {\n const currentIndex = COLOR_SCHEMES.indexOf(prev.colorScheme);\n const nextIndex = (currentIndex + 1) % COLOR_SCHEMES.length;\n return { ...prev, colorScheme: COLOR_SCHEMES[nextIndex] };\n });\n }, [setSettings]);\n\n const reset = useCallback(() => {\n setSettings(DEFAULT_SETTINGS);\n }, [setSettings]);\n\n return useMemo(\n () => ({\n settings,\n toggle,\n setSetting,\n nextVariant,\n nextIntensity,\n nextColorScheme,\n reset,\n }),\n [settings, toggle, setSetting, nextVariant, nextIntensity, nextColorScheme, reset]\n );\n}\n\n// =============================================================================\n// HOOK (uses context when available)\n// =============================================================================\n\nexport function useVisualization(): UseVisualizationReturn {\n const context = useContext(VisualizationContext);\n\n // Always call the fallback hooks (React hooks rules require consistent calls)\n const fallbackState = useVisualizationState();\n\n // If inside a provider, use shared context; otherwise use fallback\n return context ?? fallbackState;\n}\n\n// Backward compatibility alias\nexport const useAudioVisualization = useVisualization;\n\n// =============================================================================\n// VARIANT INFO\n// =============================================================================\n\nexport const VARIANT_INFO: Record<VisualizationVariant, { label: string; icon: string }> = {\n spotlight: { label: 'Spotlight', icon: '💫' },\n glow: { label: 'Glow', icon: '✨' },\n orbs: { label: 'Orbs', icon: '🔮' },\n mesh: { label: 'Mesh', icon: '🌈' },\n none: { label: 'Off', icon: '⭕' },\n};\n\nexport const INTENSITY_INFO: Record<VisualizationIntensity, { label: string }> = {\n subtle: { label: 'Subtle' },\n medium: { label: 'Medium' },\n strong: { label: 'Strong' },\n};\n\nexport const COLOR_SCHEME_INFO: Record<VisualizationColorScheme, { label: string; preview: string }> = {\n primary: { label: 'Primary', preview: '🔵' },\n vibrant: { label: 'Vibrant', preview: '🌈' },\n cool: { label: 'Cool', preview: '💙' },\n warm: { label: 'Warm', preview: '🔥' },\n};\n","'use client';\n\n/**\n * HybridAudioProvider - Context provider for hybrid audio player.\n *\n * Provides audio state, controls, and analysis data to child components.\n * Uses native HTML5 audio for playback with Web Audio API for visualization only.\n */\n\nimport { createContext, useContext, useMemo, useEffect, useRef, type ReactNode } from 'react';\nimport {\n useHybridAudio,\n type UseHybridAudioOptions,\n type HybridAudioState,\n type HybridAudioControls,\n type HybridWebAudioAPI,\n} from '../hooks/useHybridAudio';\nimport { useHybridAudioAnalysis } from '../hooks/useHybridAudioAnalysis';\nimport { useVisualization } from '../hooks/useVisualization';\nimport type { AudioLevels } from '../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface HybridAudioContextValue {\n // Audio state\n state: HybridAudioState;\n\n // Controls\n controls: HybridAudioControls;\n\n // Web Audio (for visualizations)\n webAudio: HybridWebAudioAPI;\n\n // Audio levels (for reactive effects)\n audioLevels: AudioLevels;\n\n // Audio element ref (for custom integrations)\n audioRef: React.RefObject<HTMLAudioElement | null>;\n}\n\n// =============================================================================\n// CONTEXT\n// =============================================================================\n\nconst HybridAudioContext = createContext<HybridAudioContextValue | null>(null);\n\n// =============================================================================\n// PROVIDER\n// =============================================================================\n\nexport interface HybridAudioProviderProps extends UseHybridAudioOptions {\n children: ReactNode;\n}\n\nexport function HybridAudioProvider({ children, ...options }: HybridAudioProviderProps) {\n // Load persisted settings (shared with visualization)\n const { settings: savedSettings, setSetting } = useVisualization();\n\n // Use saved settings as initial values\n const effectiveOptions = {\n ...options,\n initialVolume: savedSettings.volume,\n loop: savedSettings.isLooping,\n };\n\n const { audioRef, state, controls, webAudio } = useHybridAudio(effectiveOptions);\n\n // Track if we've applied initial settings\n const hasAppliedInitialSettings = useRef(false);\n\n // Apply saved settings after audio is ready (for hydration timing)\n useEffect(() => {\n if (!state.isReady || hasAppliedInitialSettings.current) return;\n hasAppliedInitialSettings.current = true;\n\n // Apply saved volume and loop settings\n controls.setVolume(savedSettings.volume);\n controls.setLoop(savedSettings.isLooping);\n }, [state.isReady, savedSettings, controls]);\n\n // Persist settings when they change\n useEffect(() => {\n if (!state.isReady) return;\n\n // Only save if values actually changed\n if (state.volume !== savedSettings.volume) {\n setSetting('volume', state.volume);\n }\n if (state.isLooping !== savedSettings.isLooping) {\n setSetting('isLooping', state.isLooping);\n }\n }, [state.isReady, state.volume, state.isLooping, savedSettings, setSetting]);\n\n // Audio analysis for reactive effects\n const audioLevels = useHybridAudioAnalysis(webAudio.analyser, state.isPlaying);\n\n const value = useMemo<HybridAudioContextValue>(\n () => ({\n state,\n controls,\n webAudio,\n audioLevels,\n audioRef,\n }),\n [state, controls, webAudio, audioLevels, audioRef]\n );\n\n return <HybridAudioContext.Provider value={value}>{children}</HybridAudioContext.Provider>;\n}\n\n// =============================================================================\n// HOOKS\n// =============================================================================\n\n/**\n * Access full hybrid audio context\n */\nexport function useHybridAudioContext(): HybridAudioContextValue {\n const context = useContext(HybridAudioContext);\n if (!context) {\n throw new Error('useHybridAudioContext must be used within HybridAudioProvider');\n }\n return context;\n}\n\n/**\n * Access audio state only (read-only)\n */\nexport function useHybridAudioState(): HybridAudioState {\n const { state } = useHybridAudioContext();\n return state;\n}\n\n/**\n * Access audio controls only (no state re-renders)\n */\nexport function useHybridAudioControls(): HybridAudioControls {\n const { controls } = useHybridAudioContext();\n return controls;\n}\n\n/**\n * Access audio levels for reactive effects\n */\nexport function useHybridAudioLevels(): AudioLevels {\n const { audioLevels } = useHybridAudioContext();\n return audioLevels;\n}\n\n/**\n * Access Web Audio API for custom visualizations\n */\nexport function useHybridWebAudio(): HybridWebAudioAPI {\n const { webAudio } = useHybridAudioContext();\n return webAudio;\n}\n","'use client';\n\n/**\n * HybridWaveform - Real-time frequency visualization for hybrid player.\n *\n * Two modes:\n * - 'frequency': Real-time frequency bars (default, requires playing audio)\n * - 'static': Static progress bar (for when no analyser is available)\n *\n * Features:\n * - Shows buffered regions\n * - Click to seek\n * - Responsive width\n */\n\nimport { useRef, useEffect, useCallback, memo } from 'react';\nimport { useHybridAudioContext } from '../context/HybridAudioProvider';\nimport { cn } from '@djangocfg/ui-core/lib';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface HybridWaveformProps {\n /** Visualization mode */\n mode?: 'frequency' | 'static';\n /** Canvas height in pixels */\n height?: number;\n /** Bar width in pixels */\n barWidth?: number;\n /** Gap between bars in pixels */\n barGap?: number;\n /** Bar border radius */\n barRadius?: number;\n /** Color for played portion */\n progressColor?: string;\n /** Color for unplayed portion */\n waveColor?: string;\n /** Color for buffered regions indicator */\n bufferedColor?: string;\n /** Additional CSS class */\n className?: string;\n /** Callback when user seeks */\n onSeek?: (time: number) => void;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport const HybridWaveform = memo(function HybridWaveform({\n mode = 'frequency',\n height = 64,\n barWidth = 3,\n barGap = 2,\n barRadius = 2,\n progressColor = 'hsl(217 91% 60%)',\n waveColor = 'hsl(217 91% 60% / 0.3)',\n bufferedColor = 'hsl(217 91% 60% / 0.15)',\n className,\n onSeek,\n}: HybridWaveformProps) {\n const canvasRef = useRef<HTMLCanvasElement>(null);\n const containerRef = useRef<HTMLDivElement>(null);\n const animationRef = useRef<number | null>(null);\n const { state, controls, webAudio } = useHybridAudioContext();\n\n // Handle click to seek\n const handleClick = useCallback(\n (e: React.MouseEvent<HTMLCanvasElement>) => {\n const canvas = canvasRef.current;\n if (!canvas || !state.duration) return;\n\n const rect = canvas.getBoundingClientRect();\n const x = e.clientX - rect.left;\n const progress = x / rect.width;\n const time = state.duration * progress;\n\n controls.seek(time);\n onSeek?.(time);\n },\n [state.duration, controls, onSeek]\n );\n\n // Render frequency bars (real-time visualization)\n const renderFrequency = useCallback(() => {\n const canvas = canvasRef.current;\n const analyser = webAudio.analyser;\n if (!canvas) return;\n\n const ctx = canvas.getContext('2d');\n if (!ctx) return;\n\n const { width, height: canvasHeight } = canvas;\n const dpr = window.devicePixelRatio || 1;\n const displayWidth = width / dpr;\n\n // Get frequency data if analyser is available\n let dataArray: Uint8Array<ArrayBuffer> | null = null;\n if (analyser) {\n dataArray = new Uint8Array(analyser.frequencyBinCount) as Uint8Array<ArrayBuffer>;\n analyser.getByteFrequencyData(dataArray);\n }\n\n ctx.clearRect(0, 0, width, canvasHeight);\n\n // Draw buffered regions at bottom\n if (state.buffered && state.duration > 0) {\n ctx.fillStyle = bufferedColor;\n for (let i = 0; i < state.buffered.length; i++) {\n const start = (state.buffered.start(i) / state.duration) * width;\n const end = (state.buffered.end(i) / state.duration) * width;\n ctx.fillRect(start, canvasHeight - 3 * dpr, end - start, 3 * dpr);\n }\n }\n\n // Calculate bar count based on available width\n const barCount = Math.floor(displayWidth / (barWidth + barGap));\n const progress = state.duration > 0 ? state.currentTime / state.duration : 0;\n const progressX = width * progress;\n\n // Draw bars\n for (let i = 0; i < barCount; i++) {\n let barHeight: number;\n\n if (dataArray && state.isPlaying) {\n // Real-time frequency data\n const step = Math.floor(dataArray.length / barCount);\n const value = dataArray[i * step] / 255;\n barHeight = Math.max(4 * dpr, value * (canvasHeight - 6 * dpr) * 0.9);\n } else {\n // Static fallback - small bars\n barHeight = 8 * dpr;\n }\n\n const x = i * (barWidth + barGap) * dpr;\n const y = (canvasHeight - barHeight) / 2;\n\n ctx.fillStyle = x < progressX ? progressColor : waveColor;\n\n // Draw rounded rect\n const radius = barRadius * dpr;\n const rectWidth = barWidth * dpr;\n ctx.beginPath();\n ctx.roundRect(x, y, rectWidth, barHeight, radius);\n ctx.fill();\n }\n\n // Continue animation if playing\n if (state.isPlaying) {\n animationRef.current = requestAnimationFrame(renderFrequency);\n }\n }, [\n webAudio.analyser,\n state.buffered,\n state.duration,\n state.currentTime,\n state.isPlaying,\n barWidth,\n barGap,\n barRadius,\n progressColor,\n waveColor,\n bufferedColor,\n ]);\n\n // Render static progress bar\n const renderStatic = useCallback(() => {\n const canvas = canvasRef.current;\n if (!canvas) return;\n\n const ctx = canvas.getContext('2d');\n if (!ctx) return;\n\n const { width, height: canvasHeight } = canvas;\n const dpr = window.devicePixelRatio || 1;\n\n ctx.clearRect(0, 0, width, canvasHeight);\n\n // Draw buffered regions\n if (state.buffered && state.duration > 0) {\n ctx.fillStyle = bufferedColor;\n for (let i = 0; i < state.buffered.length; i++) {\n const start = (state.buffered.start(i) / state.duration) * width;\n const end = (state.buffered.end(i) / state.duration) * width;\n ctx.fillRect(start, 0, end - start, canvasHeight);\n }\n }\n\n // Draw progress bar\n const progress = state.duration > 0 ? state.currentTime / state.duration : 0;\n const progressWidth = width * progress;\n\n // Background\n ctx.fillStyle = waveColor;\n ctx.fillRect(0, canvasHeight / 2 - 2 * dpr, width, 4 * dpr);\n\n // Progress\n ctx.fillStyle = progressColor;\n ctx.fillRect(0, canvasHeight / 2 - 2 * dpr, progressWidth, 4 * dpr);\n\n // Handle\n if (progress > 0) {\n ctx.beginPath();\n ctx.arc(progressWidth, canvasHeight / 2, 6 * dpr, 0, Math.PI * 2);\n ctx.fill();\n }\n }, [state.buffered, state.duration, state.currentTime, progressColor, waveColor, bufferedColor]);\n\n // Resize canvas to match container\n useEffect(() => {\n const container = containerRef.current;\n const canvas = canvasRef.current;\n if (!container || !canvas) return;\n\n const resizeObserver = new ResizeObserver((entries) => {\n const entry = entries[0];\n if (!entry) return;\n\n const dpr = window.devicePixelRatio || 1;\n const displayWidth = entry.contentRect.width;\n const displayHeight = height;\n\n canvas.width = displayWidth * dpr;\n canvas.height = displayHeight * dpr;\n canvas.style.width = `${displayWidth}px`;\n canvas.style.height = `${displayHeight}px`;\n\n // Re-render after resize\n if (mode === 'frequency') {\n renderFrequency();\n } else {\n renderStatic();\n }\n });\n\n resizeObserver.observe(container);\n return () => resizeObserver.disconnect();\n }, [height, mode, renderFrequency, renderStatic]);\n\n // Animation loop for frequency mode\n useEffect(() => {\n if (mode === 'frequency') {\n renderFrequency();\n }\n\n return () => {\n if (animationRef.current) {\n cancelAnimationFrame(animationRef.current);\n }\n };\n }, [mode, renderFrequency]);\n\n // Re-render on time change for static mode\n useEffect(() => {\n if (mode === 'static') {\n renderStatic();\n }\n }, [mode, state.currentTime, renderStatic]);\n\n // Re-render frequency when playback state changes\n useEffect(() => {\n if (mode === 'frequency' && !state.isPlaying) {\n // One final render when stopped\n renderFrequency();\n }\n }, [mode, state.isPlaying, renderFrequency]);\n\n return (\n <div ref={containerRef} className={cn('w-full', className)}>\n <canvas\n ref={canvasRef}\n onClick={handleClick}\n className=\"cursor-pointer\"\n style={{ width: '100%', height }}\n />\n </div>\n );\n});\n","/**\n * formatTime - Format seconds to mm:ss string\n */\n\nexport function formatTime(seconds: number): string {\n if (!seconds || !isFinite(seconds) || seconds < 0) return '0:00';\n const mins = Math.floor(seconds / 60);\n const secs = Math.floor(seconds % 60);\n return `${mins}:${secs.toString().padStart(2, '0')}`;\n}\n","'use client';\n\n/**\n * AudioPlayer Debug Logger\n *\n * Uses universal logger with media-specific helpers.\n * Logs go to both console (dev) and zustand store (for Console panel).\n */\n\nimport { createMediaLogger } from '@djangocfg/ui-core/lib';\n\nexport const audioDebug = createMediaLogger('AudioPlayer');\n\nexport default audioDebug;\n","'use client';\n\n/**\n * HybridAudioPlayer - Audio playback controls with frequency visualization\n *\n * Uses HybridAudioContext for state management.\n * Native HTML5 audio for playback, Web Audio API for visualization only.\n *\n * Features:\n * - Real-time frequency visualization\n * - Playback controls (play, pause, skip, restart)\n * - Volume control with mute\n * - Loop toggle\n * - Keyboard shortcuts\n * - Timer display\n */\n\nimport { memo } from 'react';\nimport {\n Play,\n Pause,\n RotateCcw,\n SkipBack,\n SkipForward,\n Volume2,\n VolumeX,\n Loader2,\n Repeat,\n} from 'lucide-react';\nimport { Button, Slider, cn } from '../../_shared';\nimport { useHybridAudioContext } from '../context/HybridAudioProvider';\nimport { HybridWaveform } from './HybridWaveform';\nimport { formatTime } from '../utils';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface HybridAudioPlayerProps {\n /** Show playback controls */\n showControls?: boolean;\n /** Show frequency waveform */\n showWaveform?: boolean;\n /** Waveform visualization mode */\n waveformMode?: 'frequency' | 'static';\n /** Waveform height in pixels */\n waveformHeight?: number;\n /** Show time display */\n showTimer?: boolean;\n /** Show volume control */\n showVolume?: boolean;\n /** Show loop button */\n showLoop?: boolean;\n /** Additional CSS class */\n className?: string;\n /** Inline styles */\n style?: React.CSSProperties;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport const HybridAudioPlayer = memo(function HybridAudioPlayer({\n showControls = true,\n showWaveform = true,\n waveformMode = 'frequency',\n waveformHeight = 64,\n showTimer = true,\n showVolume = true,\n showLoop = true,\n className,\n style,\n}: HybridAudioPlayerProps) {\n const { state, controls } = useHybridAudioContext();\n\n const isLoading = !state.isReady;\n\n const handleVolumeChange = (value: number[]) => {\n controls.setVolume(value[0] / 100);\n };\n\n return (\n <div\n className={cn('flex flex-col gap-3 p-4 rounded-lg bg-card border', className)}\n style={style}\n >\n {/* Frequency Waveform */}\n {showWaveform && (\n <div className=\"relative\">\n <HybridWaveform\n mode={waveformMode}\n height={waveformHeight}\n className={cn(isLoading && 'opacity-50')}\n />\n {isLoading && (\n <div className=\"absolute inset-0 flex items-center justify-center\">\n <Loader2 className=\"h-6 w-6 animate-spin text-primary\" />\n </div>\n )}\n </div>\n )}\n\n {/* Timer */}\n {showTimer && (\n <div className=\"flex justify-between text-xs text-muted-foreground tabular-nums px-1\">\n <span>{formatTime(state.currentTime)}</span>\n <span>{formatTime(state.duration)}</span>\n </div>\n )}\n\n {/* Controls */}\n {showControls && (\n <div className=\"flex items-center justify-center gap-1\">\n {/* Restart */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-9 w-9\"\n onClick={controls.restart}\n disabled={!state.isReady}\n title=\"Restart\"\n >\n <RotateCcw className=\"h-4 w-4\" />\n </Button>\n\n {/* Skip back 5s */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-9 w-9\"\n onClick={() => controls.skip(-5)}\n disabled={!state.isReady}\n title=\"Back 5 seconds\"\n >\n <SkipBack className=\"h-4 w-4\" />\n </Button>\n\n {/* Play/Pause */}\n <Button\n variant=\"default\"\n size=\"icon\"\n className=\"h-12 w-12 rounded-full\"\n onClick={controls.togglePlay}\n disabled={!state.isReady && !isLoading}\n title={state.isPlaying ? 'Pause' : 'Play'}\n >\n {isLoading ? (\n <Loader2 className=\"h-5 w-5 animate-spin\" />\n ) : state.isPlaying ? (\n <Pause className=\"h-5 w-5\" />\n ) : (\n <Play className=\"h-5 w-5 ml-0.5\" />\n )}\n </Button>\n\n {/* Skip forward 5s */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-9 w-9\"\n onClick={() => controls.skip(5)}\n disabled={!state.isReady}\n title=\"Forward 5 seconds\"\n >\n <SkipForward className=\"h-4 w-4\" />\n </Button>\n\n {/* Volume */}\n {showVolume && (\n <>\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-9 w-9\"\n onClick={controls.toggleMute}\n title={state.isMuted ? 'Unmute' : 'Mute'}\n >\n {state.isMuted || state.volume === 0 ? (\n <VolumeX className=\"h-4 w-4\" />\n ) : (\n <Volume2 className=\"h-4 w-4\" />\n )}\n </Button>\n\n <Slider\n value={[state.isMuted ? 0 : state.volume * 100]}\n max={100}\n step={1}\n onValueChange={handleVolumeChange}\n className=\"w-20\"\n aria-label=\"Volume\"\n />\n </>\n )}\n\n {/* Loop/Repeat */}\n {showLoop && (\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className={cn('h-9 w-9', state.isLooping && 'text-primary')}\n onClick={controls.toggleLoop}\n disabled={!state.isReady}\n title={state.isLooping ? 'Disable loop' : 'Enable loop'}\n >\n <Repeat className=\"h-4 w-4\" />\n </Button>\n )}\n </div>\n )}\n </div>\n );\n});\n\nexport default HybridAudioPlayer;\n","/**\n * Audio Reactive Effects - Common utilities and types\n *\n * Provides reusable effect calculations and configurations\n */\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport type EffectVariant = 'glow' | 'orbs' | 'spotlight' | 'mesh';\nexport type EffectIntensity = 'subtle' | 'medium' | 'strong';\nexport type EffectColorScheme = 'primary' | 'vibrant' | 'cool' | 'warm';\n\nexport interface AudioLevels {\n bass: number;\n mid: number;\n high: number;\n overall: number;\n}\n\nexport interface EffectConfig {\n opacity: number;\n scale: number;\n blur: string;\n}\n\nexport interface EffectColors {\n colors: string[];\n hueShift: number;\n}\n\nexport interface EffectLayer {\n inset: number;\n opacity: number;\n scale: number;\n background: string;\n blur: string;\n animation?: string;\n}\n\n// =============================================================================\n// CONSTANTS\n// =============================================================================\n\nexport const INTENSITY_CONFIG: Record<EffectIntensity, EffectConfig> = {\n subtle: { opacity: 0.3, scale: 0.02, blur: 'blur-2xl' },\n medium: { opacity: 0.5, scale: 0.04, blur: 'blur-xl' },\n strong: { opacity: 0.7, scale: 0.06, blur: 'blur-lg' },\n};\n\nexport const COLOR_SCHEMES: Record<EffectColorScheme, string[]> = {\n primary: ['217 91% 60%'],\n vibrant: ['217 91% 60%', '142 76% 36%', '262 83% 58%', '25 95% 53%'],\n cool: ['217 91% 60%', '262 83% 58%', '199 89% 48%'],\n warm: ['25 95% 53%', '0 84% 60%', '38 92% 50%'],\n};\n\n// Default multi-color palette when single color provided\nconst DEFAULT_GLOW_COLORS = [\n '217 91% 60%', // Blue\n '262 83% 58%', // Purple\n '330 81% 60%', // Pink\n '25 95% 53%', // Orange\n];\n\n// =============================================================================\n// UTILITIES\n// =============================================================================\n\n/**\n * Get effect configuration from intensity setting\n */\nexport function getEffectConfig(intensity: EffectIntensity): EffectConfig {\n return INTENSITY_CONFIG[intensity];\n}\n\n/**\n * Get color array from color scheme\n */\nexport function getColors(colorScheme: EffectColorScheme): string[] {\n return COLOR_SCHEMES[colorScheme];\n}\n\n/**\n * Prepare colors with hue shift based on audio levels\n */\nexport function prepareEffectColors(\n colorScheme: EffectColorScheme,\n levels: AudioLevels\n): EffectColors {\n const baseColors = COLOR_SCHEMES[colorScheme];\n const colors = baseColors.length > 1 ? baseColors : DEFAULT_GLOW_COLORS;\n const hueShift = Math.floor(\n (levels.bass * 30) + (levels.mid * 20) + (levels.high * 10)\n );\n\n return { colors, hueShift };\n}\n\n/**\n * Calculate glow layer properties\n */\nexport function calculateGlowLayers(\n levels: AudioLevels,\n config: EffectConfig,\n colors: string[]\n): EffectLayer[] {\n const { bass, mid, high } = levels;\n\n return [\n // Layer 1: Bass glow - bottom\n {\n inset: 60 + bass * 90,\n opacity: 1,\n scale: 1 + bass * 0.5,\n background: `radial-gradient(ellipse 80% 60% at 50% 100%, hsl(${colors[0]} / ${0.4 + bass * 0.4}) 0%, transparent 70%)`,\n blur: 'blur-3xl',\n },\n // Layer 2: Mid glow - top\n {\n inset: 45 + mid * 75,\n opacity: 1,\n scale: 1 + mid * 0.4,\n background: `radial-gradient(ellipse 70% 50% at 50% 0%, hsl(${colors[1] || colors[0]} / ${0.3 + mid * 0.5}) 0%, transparent 70%)`,\n blur: 'blur-2xl',\n },\n // Layer 3: High glow - left\n {\n inset: 30 + high * 60,\n opacity: 1,\n scale: 1 + high * 0.3,\n background: `radial-gradient(ellipse 50% 80% at 0% 50%, hsl(${colors[2] || colors[0]} / ${0.3 + high * 0.4}) 0%, transparent 60%)`,\n blur: 'blur-2xl',\n },\n // Layer 4: High glow - right\n {\n inset: 30 + high * 60,\n opacity: 1,\n scale: 1 + high * 0.3,\n background: `radial-gradient(ellipse 50% 80% at 100% 50%, hsl(${colors[3] || colors[0]} / ${0.3 + high * 0.4}) 0%, transparent 60%)`,\n blur: 'blur-2xl',\n },\n // Layer 5: Center pulsing glow\n {\n inset: 24 + bass * 45,\n opacity: 1,\n scale: 1 + bass * 0.2,\n background: `radial-gradient(circle at 50% 50%, hsl(${colors[0]} / ${0.2 + bass * 0.3}) 0%, hsl(${colors[1] || colors[0]} / ${0.1 + mid * 0.2}) 40%, transparent 70%)`,\n blur: 'blur-xl',\n animation: 'glow-breathe 2s ease-in-out infinite',\n },\n ];\n}\n\n/**\n * Calculate orb positions and properties - highly reactive\n */\nexport function calculateOrbs(\n levels: AudioLevels,\n config: EffectConfig,\n colors: string[],\n baseSize: number = 50\n) {\n const { bass, mid, high, overall } = levels;\n const size = baseSize * 3;\n\n // Dynamic position offsets\n const bassMove = bass * 30;\n const midMove = mid * 25;\n const highMove = high * 20;\n\n return [\n // Bass orb - top left, big pulses\n {\n x: -40 + bassMove,\n y: -40 - bassMove * 0.5,\n size: size * (1 + bass * 1.2),\n color: colors[0],\n opacity: 0.5 + bass * 0.5,\n scale: 1 + bass * 0.6,\n },\n // Mid orb - top right\n {\n x: 130 - midMove * 0.5,\n y: -30 + midMove,\n size: size * (0.9 + mid * 1.0),\n color: colors[1] || colors[0],\n opacity: 0.5 + mid * 0.5,\n scale: 1 + mid * 0.5,\n },\n // High orb - bottom right\n {\n x: 140 + highMove * 0.3,\n y: 120 - highMove,\n size: size * (0.8 + high * 0.8),\n color: colors[2] || colors[0],\n opacity: 0.4 + high * 0.6,\n scale: 1 + high * 0.45,\n },\n // Mid orb 2 - bottom left\n {\n x: -30 - midMove * 0.4,\n y: 130 + midMove * 0.3,\n size: size * (0.9 + mid * 0.9),\n color: colors[3] || colors[0],\n opacity: 0.45 + mid * 0.55,\n scale: 1 + mid * 0.5,\n },\n // Center overall orb\n {\n x: 50,\n y: 50,\n size: size * (0.6 + overall * 1.5),\n color: colors[0],\n opacity: 0.3 + overall * 0.5,\n scale: 1 + overall * 0.7,\n },\n ];\n}\n\n/**\n * Calculate mesh gradient positions - dynamic and reactive\n */\nexport function calculateMeshGradients(\n levels: AudioLevels,\n config: EffectConfig,\n colors: string[]\n) {\n const { bass, mid, high, overall } = levels;\n\n // More aggressive offsets for visible movement\n const bassOffset = bass * 40;\n const midOffset = mid * 30;\n const highOffset = high * 25;\n\n return [\n // Large bass blob - top right, pulses hard\n {\n width: `${200 + bass * 150}%`,\n height: `${200 + bass * 150}%`,\n top: `${-80 + bassOffset}%`,\n right: `${-80 - bassOffset}%`,\n color: colors[0],\n opacity: 0.4 + bass * 0.6,\n scale: 1 + bass * 0.5,\n rotation: bass * 45,\n blur: 'blur-2xl',\n },\n // Mid blob - bottom left\n {\n width: `${180 + mid * 120}%`,\n height: `${180 + mid * 120}%`,\n bottom: `${-60 + midOffset}%`,\n left: `${-60 - midOffset}%`,\n color: colors[1] || colors[0],\n opacity: 0.4 + mid * 0.6,\n scale: 1 + mid * 0.4,\n rotation: -mid * 40,\n blur: 'blur-2xl',\n },\n // High blob - bottom right\n {\n width: `${140 + high * 100}%`,\n height: `${140 + high * 100}%`,\n top: `${70 - highOffset}%`,\n right: `${-50 + highOffset}%`,\n color: colors[2] || colors[0],\n opacity: 0.35 + high * 0.65,\n scale: 1 + high * 0.35,\n rotation: high * 35,\n blur: 'blur-xl',\n },\n // Extra bass reactive blob - top left\n {\n width: `${160 + bass * 140}%`,\n height: `${160 + bass * 140}%`,\n top: `${-60 - bassOffset * 0.8}%`,\n left: `${-60 + bassOffset * 0.8}%`,\n color: colors[3] || colors[1] || colors[0],\n opacity: 0.35 + bass * 0.65,\n scale: 1 + bass * 0.55,\n rotation: -bass * 50,\n blur: 'blur-2xl',\n },\n // Center glow - pulses with overall\n {\n width: `${80 + overall * 150}%`,\n height: `${80 + overall * 150}%`,\n top: '50%',\n left: '50%',\n color: colors[0],\n opacity: 0.3 + overall * 0.5,\n scale: 1 + overall * 0.4,\n rotation: 0,\n isCenter: true,\n blur: 'blur-3xl',\n },\n ];\n}\n\n/**\n * Calculate spotlight effect properties - highly reactive\n */\nexport function calculateSpotlight(\n levels: AudioLevels,\n config: EffectConfig,\n colors: string[],\n rotation: number\n) {\n const { bass, mid, high, overall } = levels;\n\n return {\n // Rotation speed increases with mid frequencies\n rotation: rotation + mid * 180,\n // Border expands with bass\n inset: 12 + bass * 30,\n // Color intensities react to different frequencies\n colors: colors.map((c, i) => ({\n color: c,\n opacity: i === 0\n ? 0.3 + bass * 0.7\n : i === 1\n ? 0.3 + mid * 0.7\n : 0.3 + high * 0.7,\n })),\n // Pulse glow - big and reactive\n pulseInset: 24 + bass * 50,\n pulseOpacity: 0.3 + bass * 0.7,\n pulseScale: 1 + bass * 0.4,\n // Extra glow ring\n ringOpacity: 0.2 + overall * 0.6,\n ringScale: 1 + overall * 0.3,\n };\n}\n\n/**\n * CSS for effect animations - can be injected once\n */\nexport const EFFECT_ANIMATIONS = `\n @keyframes spotlight-spin {\n 0% { transform: rotate(0deg); }\n 100% { transform: rotate(360deg); }\n }\n\n @keyframes orb-float-1 {\n 0%, 100% { transform: translate(-50%, -50%) translateY(0); }\n 50% { transform: translate(-50%, -50%) translateY(-15px); }\n }\n\n @keyframes orb-float-2 {\n 0%, 100% { transform: translate(-50%, -50%) translateX(0); }\n 50% { transform: translate(-50%, -50%) translateX(15px); }\n }\n\n @keyframes orb-float-3 {\n 0%, 100% { transform: translate(-50%, -50%) translate(0, 0); }\n 33% { transform: translate(-50%, -50%) translate(10px, -10px); }\n 66% { transform: translate(-50%, -50%) translate(-10px, 10px); }\n }\n\n @keyframes orb-float-4 {\n 0%, 100% { transform: translate(-50%, -50%) translate(0, 0); }\n 50% { transform: translate(-50%, -50%) translate(-15px, -10px); }\n }\n\n @keyframes mesh-float-1 {\n 0%, 100% { transform: translate(0, 0) scale(1); }\n 25% { transform: translate(-5%, 10%) scale(1.05); }\n 50% { transform: translate(5%, 5%) scale(0.95); }\n 75% { transform: translate(-3%, -5%) scale(1.02); }\n }\n\n @keyframes mesh-float-2 {\n 0%, 100% { transform: translate(0, 0) scale(1); }\n 33% { transform: translate(8%, -8%) scale(1.08); }\n 66% { transform: translate(-6%, 6%) scale(0.92); }\n }\n\n @keyframes mesh-float-3 {\n 0%, 100% { transform: translate(0, 0) scale(1); }\n 50% { transform: translate(10%, 10%) scale(1.1); }\n }\n\n @keyframes mesh-float-4 {\n 0%, 100% { transform: translate(0, 0) scale(1) rotate(0deg); }\n 25% { transform: translate(10%, -5%) scale(1.1) rotate(5deg); }\n 50% { transform: translate(-5%, 10%) scale(0.95) rotate(-5deg); }\n 75% { transform: translate(-10%, -10%) scale(1.05) rotate(3deg); }\n }\n\n @keyframes mesh-pulse {\n 0%, 100% { transform: translate(-50%, -50%) scale(1); opacity: 0.3; }\n 50% { transform: translate(-50%, -50%) scale(1.2); opacity: 0.5; }\n }\n\n @keyframes glow-breathe {\n 0%, 100% { opacity: 0.6; transform: scale(1); }\n 50% { opacity: 1; transform: scale(1.05); }\n }\n\n @keyframes glow-rotate {\n 0% { transform: rotate(0deg); }\n 100% { transform: rotate(360deg); }\n }\n\n @keyframes sparkle-move {\n 0% { opacity: 0; transform: scale(0.8); }\n 50% { opacity: 1; }\n 100% { opacity: 0; transform: scale(1.2); }\n }\n`;\n","'use client';\n\n/**\n * GlowEffect - Multi-layer glow effect with pulse rings\n */\n\nimport { cn } from '../../../../_shared';\nimport type { calculateGlowLayers } from '../../../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface GlowEffectData {\n layers: ReturnType<typeof calculateGlowLayers>;\n hueShift: number;\n showPulseRings: boolean;\n showSparkle: boolean;\n}\n\ninterface GlowEffectProps {\n data: GlowEffectData;\n colors: string[];\n isPlaying: boolean;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function GlowEffect({ data, colors, isPlaying }: GlowEffectProps) {\n const { layers, hueShift, showPulseRings, showSparkle } = data;\n\n return (\n <>\n {/* Main glow layers */}\n {layers.map((layer, i) => (\n <div\n key={i}\n className={cn('absolute rounded-2xl -z-10', layer.blur)}\n style={{\n inset: `-${layer.inset}px`,\n background: layer.background,\n opacity: isPlaying ? layer.opacity : 0,\n transform: i < 2 ? `scaleY(${layer.scale})` : `scale(${layer.scale})`,\n animation: isPlaying && layer.animation ? layer.animation : 'none',\n transition: 'opacity 0.3s',\n }}\n />\n ))}\n\n {/* Rotating color sweep */}\n <div\n className=\"absolute rounded-2xl blur-xl overflow-hidden -z-10\"\n style={{\n inset: '-75px',\n opacity: isPlaying ? 0.6 : 0,\n transition: 'opacity 0.5s',\n }}\n >\n <div\n className=\"absolute inset-0\"\n style={{\n background: `conic-gradient(\n from ${hueShift}deg at 50% 50%,\n hsl(${colors[0]} / 0.4) 0deg,\n hsl(${colors[1] || colors[0]} / 0.3) 90deg,\n hsl(${colors[2] || colors[0]} / 0.3) 180deg,\n hsl(${colors[3] || colors[0]} / 0.3) 270deg,\n hsl(${colors[0]} / 0.4) 360deg\n )`,\n animation: isPlaying ? 'glow-rotate 6s linear infinite' : 'none',\n }}\n />\n </div>\n\n {/* Pulse rings on bass hits */}\n {showPulseRings && (\n <>\n <div\n className=\"absolute -inset-6 rounded-xl border-2 animate-ping -z-10\"\n style={{\n borderColor: `hsl(${colors[0]} / 0.4)`,\n animationDuration: '1s',\n }}\n />\n <div\n className=\"absolute -inset-12 rounded-2xl border animate-ping -z-10\"\n style={{\n borderColor: `hsl(${colors[1] || colors[0]} / 0.3)`,\n animationDuration: '1.5s',\n animationDelay: '0.2s',\n }}\n />\n </>\n )}\n\n {/* Sparkle on high frequencies */}\n {showSparkle && (\n <div\n className=\"absolute -inset-18 rounded-3xl -z-10\"\n style={{\n background: `radial-gradient(circle at 50% 30%, hsl(${colors[2] || colors[0]} / 0.5) 0%, transparent 30%)`,\n animation: 'sparkle-move 0.5s ease-out',\n }}\n />\n )}\n </>\n );\n}\n","'use client';\n\n/**\n * OrbsEffect - Floating orb particles that react to audio\n */\n\nimport { cn } from '../../../../_shared';\nimport type { calculateOrbs } from '../../../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\ninterface OrbsEffectProps {\n orbs: ReturnType<typeof calculateOrbs>;\n blur: string;\n isPlaying: boolean;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function OrbsEffect({ orbs, blur, isPlaying }: OrbsEffectProps) {\n return (\n <>\n {orbs.map((orb, i) => (\n <div\n key={i}\n className={cn('absolute rounded-full -z-10', blur)}\n style={{\n width: orb.size,\n height: orb.size,\n left: `${orb.x}%`,\n top: `${orb.y}%`,\n background: `radial-gradient(circle at 30% 30%, hsl(${orb.color}) 0%, hsl(${orb.color} / 0.5) 40%, transparent 70%)`,\n opacity: isPlaying ? orb.opacity : 0,\n transform: `translate(-50%, -50%) scale(${orb.scale})`,\n transition: 'all 0.08s ease-out',\n }}\n />\n ))}\n </>\n );\n}\n","'use client';\n\n/**\n * SpotlightEffect - Rotating spotlight with conic gradients\n */\n\nimport { cn } from '../../../../_shared';\nimport type { calculateSpotlight } from '../../../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\ninterface SpotlightEffectProps {\n data: ReturnType<typeof calculateSpotlight>;\n colors: string[];\n blur: string;\n isPlaying: boolean;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function SpotlightEffect({ data, colors, blur, isPlaying }: SpotlightEffectProps) {\n const inset = 'inset' in data ? data.inset : 12;\n const pulseInset = 'pulseInset' in data ? data.pulseInset : 24;\n const ringOpacity = 'ringOpacity' in data ? data.ringOpacity : 0.3;\n const ringScale = 'ringScale' in data ? data.ringScale : 1;\n\n return (\n <>\n {/* Rotating conic gradient - reactive size */}\n <div\n className={cn('absolute rounded-xl -z-10', blur)}\n style={{\n inset: `-${inset}px`,\n background: `conic-gradient(\n from ${data.rotation}deg,\n hsl(${colors[0]} / ${data.colors[0]?.opacity || 0.5}),\n hsl(${colors[1] || colors[0]} / ${data.colors[1]?.opacity || 0.7}),\n hsl(${colors[2] || colors[0]} / ${data.colors[2]?.opacity || 0.5}),\n hsl(${colors[0]} / ${data.colors[1]?.opacity || 0.7}),\n hsl(${colors[0]} / ${data.colors[0]?.opacity || 0.5})\n )`,\n opacity: isPlaying ? 1 : 0,\n transition: 'all 0.08s ease-out',\n }}\n />\n\n {/* Inner border */}\n <div\n className=\"absolute -inset-1 rounded-lg bg-background -z-10\"\n style={{ opacity: isPlaying ? 1 : 0, transition: 'opacity 0.1s' }}\n />\n\n {/* Bass pulse glow - reactive size */}\n <div\n className={cn('absolute rounded-2xl -z-10', blur)}\n style={{\n inset: `-${pulseInset}px`,\n background: `radial-gradient(circle, hsl(${colors[0]} / 0.7) 0%, hsl(${colors[0]} / 0.3) 50%, transparent 70%)`,\n opacity: isPlaying ? data.pulseOpacity : 0,\n transform: `scale(${data.pulseScale})`,\n transition: 'all 0.08s ease-out',\n }}\n />\n\n {/* Outer ring glow */}\n <div\n className=\"absolute rounded-3xl -z-10 blur-2xl\"\n style={{\n inset: `-${pulseInset + 30}px`,\n background: `radial-gradient(circle, hsl(${colors[1] || colors[0]} / 0.4) 0%, transparent 60%)`,\n opacity: isPlaying ? ringOpacity : 0,\n transform: `scale(${ringScale})`,\n transition: 'all 0.08s ease-out',\n }}\n />\n </>\n );\n}\n","'use client';\n\n/**\n * MeshEffect - Mesh gradient blobs that react to audio\n */\n\nimport { cn } from '../../../../_shared';\nimport type { calculateMeshGradients } from '../../../effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\ninterface MeshEffectProps {\n gradients: ReturnType<typeof calculateMeshGradients>;\n blur: string;\n isPlaying: boolean;\n}\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function MeshEffect({ gradients, isPlaying }: MeshEffectProps) {\n return (\n <>\n {gradients.map((g, i) => {\n const isCenter = 'isCenter' in g && g.isCenter;\n const scale = 'scale' in g ? g.scale : 1;\n const rotation = 'rotation' in g ? g.rotation : 0;\n const itemBlur = 'blur' in g ? g.blur : 'blur-2xl';\n\n return (\n <div\n key={i}\n className={cn('absolute rounded-full -z-10', itemBlur)}\n style={{\n width: g.width,\n height: g.height,\n top: 'top' in g ? g.top : undefined,\n bottom: 'bottom' in g ? g.bottom : undefined,\n left: 'left' in g ? g.left : undefined,\n right: 'right' in g ? g.right : undefined,\n background: isCenter\n ? `radial-gradient(circle, hsl(${g.color} / 0.6) 0%, hsl(${g.color} / 0.3) 30%, transparent 60%)`\n : `radial-gradient(circle, hsl(${g.color}) 0%, hsl(${g.color} / 0.5) 30%, transparent 65%)`,\n opacity: isPlaying ? g.opacity : 0,\n transform: isCenter\n ? `translate(-50%, -50%) scale(${scale})`\n : `scale(${scale}) rotate(${rotation}deg)`,\n transition: 'all 0.08s ease-out',\n }}\n />\n );\n })}\n </>\n );\n}\n","'use client';\n\n/**\n * AudioReactiveCover - Album art with audio-reactive animations\n *\n * Uses effects utilities for clean data preparation before render.\n * Click on cover to switch between effect variants.\n *\n * Must be used within HybridAudioProvider context.\n */\n\nimport { type ReactNode } from 'react';\nimport { cn } from '../../../_shared';\nimport { useHybridAudioLevels, useHybridAudioState } from '../../context/HybridAudioProvider';\nimport {\n type EffectVariant,\n type EffectIntensity,\n type EffectColorScheme,\n getEffectConfig,\n prepareEffectColors,\n calculateGlowLayers,\n calculateOrbs,\n calculateMeshGradients,\n calculateSpotlight,\n EFFECT_ANIMATIONS,\n} from '../../effects';\nimport { GlowEffect, OrbsEffect, SpotlightEffect, MeshEffect, type GlowEffectData } from './effects';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface AudioReactiveCoverProps {\n children: ReactNode;\n size?: 'sm' | 'md' | 'lg';\n variant?: EffectVariant;\n intensity?: EffectIntensity;\n colorScheme?: EffectColorScheme;\n onClick?: () => void;\n className?: string;\n}\n\n// =============================================================================\n// CONSTANTS\n// =============================================================================\n\nconst SIZES = {\n sm: { container: 'w-32 h-32', orbBase: 40 },\n md: { container: 'w-40 h-40', orbBase: 50 },\n lg: { container: 'w-48 h-48', orbBase: 60 },\n};\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function AudioReactiveCover({\n children,\n size = 'lg',\n variant = 'spotlight',\n intensity = 'medium',\n colorScheme = 'primary',\n onClick,\n className,\n}: AudioReactiveCoverProps) {\n // Get audio state from HybridAudioProvider context\n const { isPlaying } = useHybridAudioState();\n const levels = useHybridAudioLevels();\n\n // =========================================================================\n // PREPARE DATA BEFORE RENDER\n // =========================================================================\n\n const sizeConfig = SIZES[size];\n const effectConfig = getEffectConfig(intensity);\n const { colors, hueShift } = prepareEffectColors(colorScheme, levels);\n\n // Calculate scale based on overall level\n const containerScale = 1 + levels.overall * effectConfig.scale;\n\n // Prepare effect-specific data - NO memoization for real-time reactivity\n const glowData: GlowEffectData | null = variant === 'glow' ? {\n layers: calculateGlowLayers(levels, effectConfig, colors),\n hueShift,\n showPulseRings: levels.bass > 0.5,\n showSparkle: levels.high > 0.4,\n } : null;\n\n const orbsData = variant === 'orbs'\n ? calculateOrbs(levels, effectConfig, colors, sizeConfig.orbBase)\n : null;\n\n const meshData = variant === 'mesh'\n ? calculateMeshGradients(levels, effectConfig, colors)\n : null;\n\n const spotlightData = variant === 'spotlight'\n ? calculateSpotlight(levels, effectConfig, colors, levels.mid * 360)\n : null;\n\n // =========================================================================\n // RENDER\n // =========================================================================\n\n return (\n <div\n className={cn('relative', sizeConfig.container, className)}\n style={{\n transform: `scale(${containerScale})`,\n transition: 'transform 0.1s ease-out',\n }}\n >\n {/* Effect layers container - under cover, non-interactive */}\n <div className=\"absolute inset-0 z-0 pointer-events-none overflow-visible\">\n {glowData && (\n <GlowEffect data={glowData} colors={colors} isPlaying={isPlaying} />\n )}\n\n {orbsData && (\n <OrbsEffect orbs={orbsData} blur={effectConfig.blur} isPlaying={isPlaying} />\n )}\n\n {spotlightData && (\n <SpotlightEffect data={spotlightData} colors={colors} blur={effectConfig.blur} isPlaying={isPlaying} />\n )}\n\n {meshData && (\n <MeshEffect gradients={meshData} blur={effectConfig.blur} isPlaying={isPlaying} />\n )}\n </div>\n\n {/* Content (cover art) */}\n <div\n className=\"relative w-full h-full rounded-lg overflow-hidden shadow-2xl z-10 bg-background cursor-pointer\"\n onClick={onClick}\n role={onClick ? 'button' : undefined}\n tabIndex={onClick ? 0 : undefined}\n onKeyDown={onClick ? (e) => e.key === 'Enter' && onClick() : undefined}\n >\n {children}\n </div>\n\n {/* Inject animations once */}\n <style dangerouslySetInnerHTML={{ __html: EFFECT_ANIMATIONS }} />\n </div>\n );\n}\n\nexport default AudioReactiveCover;\n","'use client';\n\n/**\n * HybridSimplePlayer - Easy-to-use hybrid audio player wrapper\n *\n * Combines HybridAudioProvider + HybridAudioPlayer + optional reactive cover\n * in a single component with sensible defaults.\n *\n * Uses native HTML5 audio for playback (no crackling) with Web Audio API\n * for visualization only.\n *\n * @example\n * // Minimal usage\n * <HybridSimplePlayer src=\"https://example.com/audio.mp3\" />\n *\n * @example\n * // With cover art and reactive effects\n * <HybridSimplePlayer\n * src={audioUrl}\n * title=\"Track Title\"\n * artist=\"Artist Name\"\n * coverArt=\"/path/to/cover.jpg\"\n * reactiveCover\n * variant=\"spotlight\"\n * />\n */\n\nimport { type ReactNode } from 'react';\nimport { Music } from 'lucide-react';\nimport { cn } from '@djangocfg/ui-core';\n\nimport { HybridAudioProvider } from '../context/HybridAudioProvider';\nimport { HybridAudioPlayer } from './HybridAudioPlayer';\nimport { AudioReactiveCover } from './ReactiveCover';\nimport { VisualizationProvider, useVisualization } from '../hooks';\nimport type { EffectIntensity, EffectColorScheme } from '../effects';\nimport type { VisualizationVariant } from '../hooks';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface HybridSimplePlayerProps {\n /** Audio source URL */\n src: string;\n\n /** Track title */\n title?: string;\n\n /** Artist name */\n artist?: string;\n\n /** Cover art URL or ReactNode */\n coverArt?: string | ReactNode;\n\n /** Cover art size */\n coverSize?: 'sm' | 'md' | 'lg';\n\n /** Show frequency waveform */\n showWaveform?: boolean;\n\n /** Waveform visualization mode */\n waveformMode?: 'frequency' | 'static';\n\n /** Waveform height in pixels */\n waveformHeight?: number;\n\n /** Show timer */\n showTimer?: boolean;\n\n /** Show volume control */\n showVolume?: boolean;\n\n /** Show loop/repeat button */\n showLoop?: boolean;\n\n /** Enable audio-reactive cover effects */\n reactiveCover?: boolean;\n\n /** Reactive effect variant */\n variant?: VisualizationVariant;\n\n /** Reactive effect intensity */\n intensity?: EffectIntensity;\n\n /** Reactive effect color scheme */\n colorScheme?: EffectColorScheme;\n\n /** Auto-play on load */\n autoPlay?: boolean;\n\n /** Loop playback */\n loop?: boolean;\n\n /** Initial volume (0-1) */\n initialVolume?: number;\n\n /** Layout direction */\n layout?: 'vertical' | 'horizontal';\n\n /** Additional class name */\n className?: string;\n\n /** Callbacks */\n onPlay?: () => void;\n onPause?: () => void;\n onEnded?: () => void;\n onError?: (error: Error) => void;\n}\n\n// =============================================================================\n// CONSTANTS\n// =============================================================================\n\nconst COVER_SIZES = {\n sm: 'w-24 h-24',\n md: 'w-32 h-32',\n lg: 'w-48 h-48',\n};\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function HybridSimplePlayer(props: HybridSimplePlayerProps) {\n return (\n <VisualizationProvider>\n <HybridSimplePlayerContent {...props} />\n </VisualizationProvider>\n );\n}\n\nfunction HybridSimplePlayerContent({\n src,\n title,\n artist,\n coverArt,\n coverSize = 'md',\n showWaveform = true,\n waveformMode = 'frequency',\n waveformHeight = 64,\n showTimer = true,\n showVolume = true,\n showLoop = true,\n reactiveCover = true,\n variant,\n intensity,\n colorScheme,\n autoPlay = false,\n loop = false,\n initialVolume = 1,\n layout = 'vertical',\n className,\n onPlay,\n onPause,\n onEnded,\n onError,\n}: HybridSimplePlayerProps) {\n const { settings: vizSettings, nextVariant } = useVisualization();\n\n // Determine effective variant (from props or localStorage settings)\n const effectiveVariant =\n variant ?? (vizSettings.variant !== 'none' ? vizSettings.variant : 'spotlight');\n const effectiveIntensity = intensity ?? vizSettings.intensity;\n const effectiveColorScheme = colorScheme ?? vizSettings.colorScheme;\n\n // Show reactive cover if enabled and variant is not 'none'\n const showReactiveCover = reactiveCover && effectiveVariant !== 'none';\n\n // Render cover art content\n const renderCoverContent = () => {\n if (typeof coverArt === 'string') {\n return (\n <img src={coverArt} alt={title || 'Album cover'} className=\"w-full h-full object-cover\" />\n );\n }\n\n if (coverArt) {\n return coverArt;\n }\n\n // Default placeholder\n return (\n <div className=\"w-full h-full bg-muted/30 flex items-center justify-center\">\n <Music className=\"w-1/3 h-1/3 text-muted-foreground/50\" />\n </div>\n );\n };\n\n const isHorizontal = layout === 'horizontal';\n\n return (\n <HybridAudioProvider\n src={src}\n autoPlay={autoPlay}\n loop={loop}\n initialVolume={initialVolume}\n onPlay={onPlay}\n onPause={onPause}\n onEnded={onEnded}\n onError={onError}\n >\n <div\n className={cn(\n 'flex gap-4',\n isHorizontal ? 'flex-row items-center' : 'flex-col items-center',\n className\n )}\n >\n {/* Cover Art */}\n {(coverArt || reactiveCover) && (\n <div className=\"flex flex-col items-center gap-2 shrink-0\">\n {showReactiveCover ? (\n <AudioReactiveCover\n size={coverSize}\n variant={effectiveVariant as 'glow' | 'orbs' | 'spotlight' | 'mesh'}\n intensity={effectiveIntensity}\n colorScheme={effectiveColorScheme}\n onClick={nextVariant}\n >\n <div className={cn('rounded-lg overflow-hidden', COVER_SIZES[coverSize])}>\n {renderCoverContent()}\n </div>\n </AudioReactiveCover>\n ) : (\n <div\n className={cn(\n 'rounded-lg overflow-hidden shadow-lg cursor-pointer',\n COVER_SIZES[coverSize]\n )}\n onClick={nextVariant}\n role=\"button\"\n tabIndex={0}\n onKeyDown={(e) => e.key === 'Enter' && nextVariant()}\n >\n {renderCoverContent()}\n </div>\n )}\n\n {/* Effect indicator */}\n {reactiveCover && (\n <span className=\"text-[10px] uppercase tracking-wider text-muted-foreground/50 select-none\">\n {vizSettings.variant === 'none' ? 'off' : vizSettings.variant}\n </span>\n )}\n </div>\n )}\n\n {/* Track Info + Player */}\n <div\n className={cn('flex flex-col gap-3', isHorizontal ? 'flex-1 min-w-0' : 'w-full max-w-md')}\n >\n {/* Track Info */}\n {(title || artist) && (\n <div className={cn('text-center', isHorizontal && 'text-left')}>\n {title && (\n <h3 className=\"text-base font-medium text-foreground truncate\">{title}</h3>\n )}\n {artist && <p className=\"text-sm text-muted-foreground truncate\">{artist}</p>}\n </div>\n )}\n\n {/* Audio Player */}\n <HybridAudioPlayer\n showControls\n showWaveform={showWaveform}\n waveformMode={waveformMode}\n waveformHeight={waveformHeight}\n showTimer={showTimer}\n showVolume={showVolume}\n showLoop={showLoop}\n className=\"border-0 bg-transparent\"\n />\n </div>\n </div>\n </HybridAudioProvider>\n );\n}\n\nexport default HybridSimplePlayer;\n","/**\n * ImageViewer constants\n */\n\nimport type { ZoomPreset, ImageTransform } from '../types';\n\n// =============================================================================\n// SIZE LIMITS\n// =============================================================================\n\n/** Maximum image size before blocking (50MB) */\nexport const MAX_IMAGE_SIZE = 50 * 1024 * 1024;\n\n/** Image size threshold for warning (10MB) */\nexport const WARNING_IMAGE_SIZE = 10 * 1024 * 1024;\n\n/** Progressive loading threshold - use LQIP for images > 500KB */\nexport const PROGRESSIVE_LOADING_THRESHOLD = 500 * 1024;\n\n// =============================================================================\n// LQIP CONFIGURATION\n// =============================================================================\n\n/** Low-quality placeholder size (32x32) */\nexport const LQIP_SIZE = 32;\n\n/** LQIP JPEG quality */\nexport const LQIP_QUALITY = 0.5;\n\n// =============================================================================\n// ZOOM CONFIGURATION\n// =============================================================================\n\n/** Minimum zoom level */\nexport const MIN_ZOOM = 0.1;\n\n/** Maximum zoom level */\nexport const MAX_ZOOM = 8;\n\n/** Available zoom presets */\nexport const ZOOM_PRESETS: readonly ZoomPreset[] = [\n { label: 'Fit', value: 'fit' },\n { label: '25%', value: 0.25 },\n { label: '50%', value: 0.5 },\n { label: '100%', value: 1 },\n { label: '200%', value: 2 },\n { label: '400%', value: 4 },\n] as const;\n\n// =============================================================================\n// DEFAULT VALUES\n// =============================================================================\n\n/** Default transform state */\nexport const DEFAULT_TRANSFORM: ImageTransform = {\n rotation: 0,\n flipH: false,\n flipV: false,\n};\n","/**\n * LQIP (Low-Quality Image Placeholder) generator\n *\n * Creates a tiny blurred preview image for progressive loading.\n */\n\nimport { LQIP_SIZE, LQIP_QUALITY } from './constants';\n\n/**\n * Create a low-quality image placeholder from source URL\n *\n * @param imageSrc - Full quality image URL\n * @returns Data URL of tiny preview, or null on error\n */\nexport async function createLQIP(imageSrc: string): Promise<string | null> {\n try {\n // Load the full image\n const img = new Image();\n img.crossOrigin = 'anonymous';\n\n await new Promise<void>((resolve, reject) => {\n img.onload = () => resolve();\n img.onerror = () => reject(new Error('Failed to load image for LQIP'));\n img.src = imageSrc;\n });\n\n // Calculate aspect ratio preserving dimensions\n const aspect = img.naturalWidth / img.naturalHeight;\n const width = aspect >= 1 ? LQIP_SIZE : Math.round(LQIP_SIZE * aspect);\n const height = aspect >= 1 ? Math.round(LQIP_SIZE / aspect) : LQIP_SIZE;\n\n // Create canvas for downscaling\n const canvas = document.createElement('canvas');\n canvas.width = width;\n canvas.height = height;\n const ctx = canvas.getContext('2d');\n if (!ctx) return null;\n\n // Draw scaled down image\n ctx.drawImage(img, 0, 0, width, height);\n\n // Return as data URL (very small, ~1-2KB)\n return canvas.toDataURL('image/jpeg', LQIP_QUALITY);\n } catch {\n return null;\n }\n}\n","'use client';\n\n/**\n * ImageViewer Debug Logger\n *\n * Uses universal logger with media-specific helpers.\n * Logs go to both console (dev) and zustand store (for Console panel).\n */\n\nimport { createMediaLogger } from '@djangocfg/ui-core/lib';\n\nexport const imageDebug = createMediaLogger('ImageViewer');\n\nexport default imageDebug;\n","'use client';\n\n/**\n * ImageToolbar - Floating toolbar for image controls\n */\n\nimport { useMemo, useCallback } from 'react';\nimport { ZoomIn, ZoomOut, RotateCw, FlipHorizontal, FlipVertical, Maximize2, Expand } from 'lucide-react';\nimport { useControls } from 'react-zoom-pan-pinch';\nimport { Button, DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from '@djangocfg/ui-core/components';\nimport { cn } from '@djangocfg/ui-core/lib';\nimport { ZOOM_PRESETS } from '../utils';\nimport type { ImageToolbarProps } from '../types';\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function ImageToolbar({\n scale,\n transform,\n onRotate,\n onFlipH,\n onFlipV,\n onZoomPreset,\n onExpand,\n}: ImageToolbarProps) {\n const { zoomIn, zoomOut, resetTransform } = useControls();\n\n const zoomLabel = useMemo(() => {\n const percent = Math.round(scale * 100);\n return `${percent}%`;\n }, [scale]);\n\n return (\n <div className=\"absolute bottom-4 left-1/2 -translate-x-1/2 z-10 flex items-center gap-0.5 bg-background/90 backdrop-blur-sm border rounded-lg p-1 shadow-lg\">\n {/* Zoom controls */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={() => zoomOut()}\n title=\"Zoom out\"\n >\n <ZoomOut className=\"h-3.5 w-3.5\" />\n </Button>\n\n <DropdownMenu>\n <DropdownMenuTrigger asChild>\n <Button variant=\"ghost\" size=\"sm\" className=\"h-7 px-2 min-w-[52px] font-mono text-xs\">\n {zoomLabel}\n </Button>\n </DropdownMenuTrigger>\n <DropdownMenuContent align=\"center\" className=\"min-w-[80px]\">\n {ZOOM_PRESETS.map((preset) => (\n <DropdownMenuItem\n key={preset.label}\n onClick={() => onZoomPreset(preset.value)}\n className=\"text-xs justify-center\"\n >\n {preset.label}\n </DropdownMenuItem>\n ))}\n </DropdownMenuContent>\n </DropdownMenu>\n\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={() => zoomIn()}\n title=\"Zoom in\"\n >\n <ZoomIn className=\"h-3.5 w-3.5\" />\n </Button>\n\n <div className=\"w-px h-4 bg-border mx-1\" />\n\n {/* Fit to view */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={() => resetTransform()}\n title=\"Fit to view\"\n >\n <Maximize2 className=\"h-3.5 w-3.5\" />\n </Button>\n\n <div className=\"w-px h-4 bg-border mx-1\" />\n\n {/* Transform controls */}\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className={cn('h-7 w-7', transform.flipH && 'bg-accent')}\n onClick={onFlipH}\n title=\"Flip horizontal\"\n >\n <FlipHorizontal className=\"h-3.5 w-3.5\" />\n </Button>\n\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className={cn('h-7 w-7', transform.flipV && 'bg-accent')}\n onClick={onFlipV}\n title=\"Flip vertical\"\n >\n <FlipVertical className=\"h-3.5 w-3.5\" />\n </Button>\n\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={onRotate}\n title=\"Rotate 90°\"\n >\n <RotateCw className=\"h-3.5 w-3.5\" />\n </Button>\n\n {transform.rotation !== 0 && (\n <span className=\"text-[10px] text-muted-foreground font-mono pl-1\">\n {transform.rotation}°\n </span>\n )}\n\n {onExpand && (\n <>\n <div className=\"w-px h-4 bg-border mx-1\" />\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-7 w-7\"\n onClick={onExpand}\n title=\"Open in fullscreen\"\n >\n <Expand className=\"h-3.5 w-3.5\" />\n </Button>\n </>\n )}\n </div>\n );\n}\n","'use client';\n\n/**\n * ImageInfo - Displays image dimensions badge\n */\n\nimport { useEffect, useState } from 'react';\nimport { useImageCache } from '../../../stores/mediaCache';\nimport type { ImageInfoProps } from '../types';\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function ImageInfo({ src }: ImageInfoProps) {\n const { getDimensions, cacheDimensions } = useImageCache();\n const [dimensions, setDimensions] = useState<{ w: number; h: number } | null>(null);\n\n useEffect(() => {\n // Check cache first\n const cached = getDimensions(src);\n if (cached) {\n setDimensions({ w: cached.width, h: cached.height });\n return;\n }\n\n // Load and cache dimensions\n const img = new Image();\n img.onload = () => {\n const dims = { w: img.naturalWidth, h: img.naturalHeight };\n setDimensions(dims);\n cacheDimensions(src, { width: dims.w, height: dims.h });\n };\n img.src = src;\n }, [src, getDimensions, cacheDimensions]);\n\n if (!dimensions) return null;\n\n return (\n <div className=\"absolute top-3 right-3 z-10 px-2 py-1 bg-background/80 backdrop-blur-sm border rounded text-[10px] text-muted-foreground font-mono\">\n {dimensions.w} × {dimensions.h}\n </div>\n );\n}\n","'use client';\n\n/**\n * useImageTransform - Manages image rotation and flip state\n */\n\nimport { useState, useCallback, useEffect, useMemo } from 'react';\nimport type { ImageTransform } from '../types';\nimport { DEFAULT_TRANSFORM } from '../utils';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface UseImageTransformOptions {\n /** Reset transform when this key changes */\n resetKey?: string;\n}\n\nexport interface UseImageTransformReturn {\n /** Current transform state */\n transform: ImageTransform;\n /** Rotate 90 degrees clockwise */\n rotate: () => void;\n /** Toggle horizontal flip */\n flipH: () => void;\n /** Toggle vertical flip */\n flipV: () => void;\n /** Reset all transforms */\n reset: () => void;\n /** CSS transform string for applying to image */\n transformStyle: string;\n}\n\n// =============================================================================\n// HOOK\n// =============================================================================\n\nexport function useImageTransform(\n options: UseImageTransformOptions = {}\n): UseImageTransformReturn {\n const { resetKey } = options;\n\n const [transform, setTransform] = useState<ImageTransform>(DEFAULT_TRANSFORM);\n\n // Reset transform when key changes\n useEffect(() => {\n setTransform(DEFAULT_TRANSFORM);\n }, [resetKey]);\n\n const rotate = useCallback(() => {\n setTransform((prev) => ({\n ...prev,\n rotation: (prev.rotation + 90) % 360,\n }));\n }, []);\n\n const flipH = useCallback(() => {\n setTransform((prev) => ({\n ...prev,\n flipH: !prev.flipH,\n }));\n }, []);\n\n const flipV = useCallback(() => {\n setTransform((prev) => ({\n ...prev,\n flipV: !prev.flipV,\n }));\n }, []);\n\n const reset = useCallback(() => {\n setTransform(DEFAULT_TRANSFORM);\n }, []);\n\n // Build CSS transform string\n const transformStyle = useMemo(() => {\n const transforms: string[] = [];\n\n if (transform.rotation !== 0) {\n transforms.push(`rotate(${transform.rotation}deg)`);\n }\n if (transform.flipH) {\n transforms.push('scaleX(-1)');\n }\n if (transform.flipV) {\n transforms.push('scaleY(-1)');\n }\n\n return transforms.join(' ') || 'none';\n }, [transform]);\n\n return {\n transform,\n rotate,\n flipH,\n flipV,\n reset,\n transformStyle,\n };\n}\n","'use client';\n\n/**\n * useImageLoading - Manages image loading state with LQIP\n */\n\nimport { useState, useEffect, useRef } from 'react';\nimport { useMediaCacheStore, generateContentKey } from '../../../stores/mediaCache';\nimport { createLQIP, MAX_IMAGE_SIZE, WARNING_IMAGE_SIZE, PROGRESSIVE_LOADING_THRESHOLD, imageDebug } from '../utils';\n\n// =============================================================================\n// TYPES\n// =============================================================================\n\nexport interface UseImageLoadingOptions {\n /** Image content (ArrayBuffer or string) */\n content: string | ArrayBuffer;\n /** MIME type for blob creation */\n mimeType?: string;\n /**\n * Direct image URL (bypasses content→blob conversion).\n * When provided, content is ignored and URL is used directly.\n */\n src?: string;\n}\n\nexport interface UseImageLoadingReturn {\n /** Blob URL source for the image */\n src: string | null;\n /** Low-quality placeholder URL */\n lqip: string | null;\n /** Whether full image is loaded */\n isFullyLoaded: boolean;\n /** Whether to use progressive loading */\n useProgressiveLoading: boolean;\n /** Error message if any */\n error: string | null;\n /** Content key for caching */\n contentKey: string | null;\n /** Image size in bytes */\n size: number;\n /** Whether content exists */\n hasContent: boolean;\n}\n\n// =============================================================================\n// HOOK\n// =============================================================================\n\nexport function useImageLoading(options: UseImageLoadingOptions): UseImageLoadingReturn {\n const { content, mimeType, src: directSrc } = options;\n\n // Get stable function references from store (not from hook to avoid re-renders)\n const getOrCreateBlobUrl = useMediaCacheStore.getState().getOrCreateBlobUrl;\n const releaseBlobUrl = useMediaCacheStore.getState().releaseBlobUrl;\n\n const [src, setSrc] = useState<string | null>(null);\n const [lqip, setLqip] = useState<string | null>(null);\n const [isFullyLoaded, setIsFullyLoaded] = useState(false);\n const [error, setError] = useState<string | null>(null);\n\n const contentKeyRef = useRef<string | null>(null);\n const isMountedRef = useRef(true);\n\n // Calculate size and flags\n const size = content ? (typeof content === 'string' ? content.length : content.byteLength) : 0;\n // When directSrc is provided, we have content (the URL itself)\n const hasContent = directSrc ? true : size > 0;\n const useProgressiveLoading = directSrc ? false : size > PROGRESSIVE_LOADING_THRESHOLD;\n\n // Track unmount for cleanup\n useEffect(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n // Release blob URL only on actual unmount\n if (contentKeyRef.current) {\n useMediaCacheStore.getState().releaseBlobUrl(contentKeyRef.current);\n contentKeyRef.current = null;\n }\n };\n }, []);\n\n // Create blob URL with caching and size validation\n useEffect(() => {\n // Reset error state\n setError(null);\n\n // Direct URL mode - use as-is without blob conversion\n if (directSrc) {\n imageDebug.load(directSrc, 'url');\n setSrc(directSrc);\n setIsFullyLoaded(true);\n return;\n }\n\n if (!hasContent) {\n setSrc(null);\n return;\n }\n\n // Size validation - reject oversized images\n if (size > MAX_IMAGE_SIZE) {\n const sizeMB = (size / 1024 / 1024).toFixed(1);\n const errorMsg = `Image too large: ${sizeMB}MB (maximum: 50MB)`;\n imageDebug.error(errorMsg, { size, sizeMB, maxSize: MAX_IMAGE_SIZE });\n setError(errorMsg);\n setSrc(null);\n return;\n }\n\n // Warn about large images\n if (size > WARNING_IMAGE_SIZE) {\n const sizeMB = (size / 1024 / 1024).toFixed(1);\n imageDebug.warn(`Large image: ${sizeMB}MB - may impact performance`);\n }\n\n // Handle string content (data URLs or binary strings)\n if (typeof content === 'string') {\n // Pass through data URLs directly\n if (content.startsWith('data:')) {\n imageDebug.load(content.slice(0, 50) + '...', 'data-url');\n setSrc(content);\n return;\n }\n\n // Convert binary string to ArrayBuffer and use Blob URL\n const encoder = new TextEncoder();\n const buffer = encoder.encode(content).buffer;\n const contentKey = generateContentKey(buffer);\n\n // Release previous blob URL if content changed\n if (contentKeyRef.current && contentKeyRef.current !== contentKey) {\n releaseBlobUrl(contentKeyRef.current);\n }\n\n contentKeyRef.current = contentKey;\n const url = getOrCreateBlobUrl(contentKey, buffer, mimeType || 'image/png');\n imageDebug.load(url, 'blob');\n imageDebug.state('loaded', { size, mimeType, contentKey });\n setSrc(url);\n return;\n }\n\n // Handle ArrayBuffer with cached blob URL\n const contentKey = generateContentKey(content);\n\n // Release previous blob URL if content changed\n if (contentKeyRef.current && contentKeyRef.current !== contentKey) {\n releaseBlobUrl(contentKeyRef.current);\n }\n\n contentKeyRef.current = contentKey;\n const url = getOrCreateBlobUrl(contentKey, content, mimeType || 'image/png');\n imageDebug.load(url, 'blob');\n imageDebug.state('loaded', { size, mimeType, contentKey });\n setSrc(url);\n\n // No cleanup here - cleanup happens in unmount effect above\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [content, mimeType, hasContent, size, directSrc]);\n\n // Create LQIP for progressive loading\n useEffect(() => {\n if (!src || !useProgressiveLoading) {\n setLqip(null);\n setIsFullyLoaded(true);\n return;\n }\n\n setIsFullyLoaded(false);\n imageDebug.state('progressive loading', { size });\n\n // Create low-quality placeholder\n createLQIP(src).then((placeholder) => {\n if (placeholder) {\n imageDebug.debug('LQIP created');\n setLqip(placeholder);\n }\n });\n\n // Pre-load full image\n const img = new Image();\n img.onload = () => {\n imageDebug.state('fully loaded');\n setIsFullyLoaded(true);\n };\n img.onerror = () => {\n imageDebug.error('Failed to load full image');\n };\n img.src = src;\n }, [src, useProgressiveLoading, size]);\n\n return {\n src,\n lqip,\n isFullyLoaded,\n useProgressiveLoading,\n error,\n contentKey: contentKeyRef.current,\n size,\n hasContent,\n };\n}\n","'use client';\n\n/**\n * ImageViewer - Image viewer with zoom, pan, rotate, flip\n *\n * Features:\n * - Zoom with mouse wheel and presets\n * - Pan with drag\n * - Rotate 90°\n * - Flip horizontal/vertical\n * - Fullscreen dialog\n * - Keyboard shortcuts (+/-, 0, r)\n */\n\nimport { useEffect, useState, useRef, useCallback } from 'react';\nimport { ImageIcon, AlertCircle } from 'lucide-react';\nimport { TransformWrapper, TransformComponent, useControls } from 'react-zoom-pan-pinch';\nimport { cn, Dialog, DialogContent, DialogTitle, Alert, AlertDescription } from '@djangocfg/ui-core';\n\nimport { ImageToolbar } from './ImageToolbar';\nimport { ImageInfo } from './ImageInfo';\nimport { useImageTransform, useImageLoading } from '../hooks';\nimport type { ImageViewerProps } from '../types';\n\n// =============================================================================\n// COMPONENT\n// =============================================================================\n\nexport function ImageViewer({ file, content, src: directSrc, inDialog = false }: ImageViewerProps) {\n const [scale, setScale] = useState(1);\n const [dialogOpen, setDialogOpen] = useState(false);\n const [loadError, setLoadError] = useState(false);\n const containerRef = useRef<HTMLDivElement>(null);\n const controlsRef = useRef<ReturnType<typeof useControls> | null>(null);\n\n // Loading state\n const {\n src,\n lqip,\n isFullyLoaded,\n useProgressiveLoading,\n error,\n hasContent,\n } = useImageLoading({ content, mimeType: file.mimeType, src: directSrc });\n\n // Reset load error when src changes\n useEffect(() => {\n setLoadError(false);\n }, [src]);\n\n // Transform state\n const { transform, rotate, flipH, flipV, transformStyle } = useImageTransform({\n resetKey: file.path,\n });\n\n // Zoom preset handler\n const handleZoomPreset = useCallback((value: number | 'fit') => {\n if (!controlsRef.current) return;\n if (value === 'fit') {\n controlsRef.current.resetTransform();\n } else {\n controlsRef.current.setTransform(0, 0, value);\n }\n }, []);\n\n // Expand to fullscreen\n const handleExpand = useCallback(() => {\n setDialogOpen(true);\n }, []);\n\n // Keyboard shortcuts\n useEffect(() => {\n const handleKeyDown = (e: KeyboardEvent) => {\n if (!containerRef.current?.contains(document.activeElement) &&\n document.activeElement !== containerRef.current) {\n return;\n }\n\n const controls = controlsRef.current;\n if (!controls) return;\n\n switch (e.key) {\n case '+':\n case '=':\n e.preventDefault();\n controls.zoomIn();\n break;\n case '-':\n e.preventDefault();\n controls.zoomOut();\n break;\n case '0':\n e.preventDefault();\n controls.resetTransform();\n break;\n case 'r':\n if (!e.metaKey && !e.ctrlKey) {\n e.preventDefault();\n rotate();\n }\n break;\n }\n };\n\n window.addEventListener('keydown', handleKeyDown);\n return () => window.removeEventListener('keydown', handleKeyDown);\n }, [rotate]);\n\n // Show error for oversized images or load errors\n if (error || loadError) {\n return (\n <div className=\"flex-1 flex flex-col items-center justify-center gap-3 bg-muted/30 p-4\">\n <AlertCircle className=\"w-12 h-12 text-destructive/70\" />\n <Alert variant=\"destructive\" className=\"max-w-md\">\n <AlertCircle className=\"h-4 w-4\" />\n <AlertDescription>{error || 'Failed to load image'}</AlertDescription>\n </Alert>\n </div>\n );\n }\n\n // No content\n if (!hasContent) {\n return (\n <div className=\"flex-1 flex flex-col items-center justify-center gap-2 bg-muted/30\">\n <ImageIcon className=\"w-12 h-12 text-muted-foreground/50\" />\n <p className=\"text-sm text-muted-foreground\">No image content</p>\n </div>\n );\n }\n\n return (\n <div\n ref={containerRef}\n tabIndex={0}\n className={cn(\n 'flex-1 h-full relative overflow-hidden outline-none',\n 'bg-[length:16px_16px]',\n '[background-color:hsl(var(--muted)/0.2)]',\n '[background-image:linear-gradient(45deg,hsl(var(--muted)/0.4)_25%,transparent_25%),linear-gradient(-45deg,hsl(var(--muted)/0.4)_25%,transparent_25%),linear-gradient(45deg,transparent_75%,hsl(var(--muted)/0.4)_75%),linear-gradient(-45deg,transparent_75%,hsl(var(--muted)/0.4)_75%)]',\n '[background-position:0_0,0_8px,8px_-8px,-8px_0px]'\n )}\n >\n {src && <ImageInfo src={src} />}\n\n {/* Progressive loading indicator */}\n {useProgressiveLoading && !isFullyLoaded && (\n <div className=\"absolute top-3 left-3 z-10 px-2 py-1 bg-background/80 backdrop-blur-sm border rounded text-[10px] text-muted-foreground font-mono flex items-center gap-1.5\">\n <div className=\"w-2 h-2 bg-blue-500 rounded-full animate-pulse\" />\n Loading...\n </div>\n )}\n\n <TransformWrapper\n initialScale={1}\n minScale={0.1}\n maxScale={8}\n centerOnInit\n centerZoomedOut\n onTransformed={(ref, state) => {\n setScale(state.scale);\n controlsRef.current = ref;\n }}\n onInit={(ref) => {\n controlsRef.current = ref;\n }}\n wheel={{ step: 0.1 }}\n doubleClick={{ mode: 'toggle', step: 2 }}\n panning={{ velocityDisabled: false }}\n >\n <ImageToolbar\n scale={scale}\n transform={transform}\n onRotate={rotate}\n onFlipH={flipH}\n onFlipV={flipV}\n onZoomPreset={handleZoomPreset}\n onExpand={!inDialog ? handleExpand : undefined}\n />\n\n <TransformComponent\n wrapperClass=\"!w-full !h-full cursor-grab active:cursor-grabbing\"\n contentClass=\"!w-full !h-full flex items-center justify-center\"\n >\n <div className=\"relative\">\n {/* LQIP Placeholder (blurred, shown while loading) */}\n {useProgressiveLoading && lqip && !isFullyLoaded && (\n <img\n src={lqip}\n alt=\"\"\n aria-hidden=\"true\"\n className=\"absolute inset-0 max-w-full max-h-full object-contain select-none\"\n style={{\n transform: transformStyle,\n filter: 'blur(20px)',\n transition: 'opacity 0.3s ease-out',\n opacity: isFullyLoaded ? 0 : 1,\n }}\n draggable={false}\n />\n )}\n\n {/* Full Image */}\n {src && (\n <img\n src={src}\n alt={file.name}\n className=\"max-w-full max-h-full object-contain select-none\"\n style={{\n transform: transformStyle,\n transition: useProgressiveLoading\n ? 'transform 0.15s ease-out, opacity 0.3s ease-out'\n : 'transform 0.15s ease-out',\n opacity: useProgressiveLoading && !isFullyLoaded ? 0 : 1,\n }}\n draggable={false}\n crossOrigin=\"anonymous\"\n onError={() => setLoadError(true)}\n />\n )}\n </div>\n </TransformComponent>\n </TransformWrapper>\n\n {/* Fullscreen dialog */}\n {!inDialog && (\n <Dialog open={dialogOpen} onOpenChange={setDialogOpen}>\n <DialogContent className=\"max-w-[95vw] max-h-[95vh] w-[95vw] h-[95vh] p-0 overflow-hidden [&>button]:hidden flex flex-col\">\n <DialogTitle className=\"sr-only\">{file.name}</DialogTitle>\n <div className=\"flex items-center justify-between px-4 py-2 border-b shrink-0\">\n <span className=\"text-sm font-medium truncate\">{file.name}</span>\n </div>\n <div className=\"flex-1 min-h-0\">\n <ImageViewer file={file} content={content} src={directSrc} inDialog />\n </div>\n </DialogContent>\n </Dialog>\n )}\n </div>\n );\n}\n","'use client';\n\nimport { useState, useMemo, useCallback } from 'react';\n\nexport interface UseCollapsibleContentOptions {\n /**\n * Maximum character length before collapsing\n * If both maxLength and maxLines are set, the stricter limit applies\n */\n maxLength?: number;\n /**\n * Maximum number of lines before collapsing\n * If both maxLength and maxLines are set, the stricter limit applies\n */\n maxLines?: number;\n /**\n * Start in expanded state (default: false - starts collapsed)\n */\n defaultExpanded?: boolean;\n}\n\nexport interface UseCollapsibleContentResult {\n /** Whether content is currently collapsed */\n isCollapsed: boolean;\n /** Toggle between collapsed/expanded state */\n toggleCollapsed: () => void;\n /** Set collapsed state directly */\n setCollapsed: (collapsed: boolean) => void;\n /** Content to display (truncated if collapsed, full if expanded) */\n displayContent: string;\n /** Whether the content exceeds limits and should be collapsible */\n shouldCollapse: boolean;\n /** Original content length */\n originalLength: number;\n /** Original line count */\n originalLineCount: number;\n}\n\n/**\n * Smart truncation that doesn't break words or markdown syntax\n */\nfunction smartTruncate(content: string, maxLength: number): string {\n if (content.length <= maxLength) {\n return content;\n }\n\n // Find a good break point (space, newline) near maxLength\n let breakPoint = maxLength;\n\n // Look backwards for a space or newline\n while (breakPoint > maxLength - 50 && breakPoint > 0) {\n const char = content[breakPoint];\n if (char === ' ' || char === '\\n' || char === '\\t') {\n break;\n }\n breakPoint--;\n }\n\n // If we couldn't find a good break point, just use maxLength\n if (breakPoint <= maxLength - 50) {\n breakPoint = maxLength;\n }\n\n let truncated = content.slice(0, breakPoint).trimEnd();\n\n // Fix unclosed markdown syntax\n truncated = fixUnclosedMarkdown(truncated);\n\n return truncated;\n}\n\n/**\n * Truncate by line count\n */\nfunction truncateByLines(content: string, maxLines: number): string {\n const lines = content.split('\\n');\n\n if (lines.length <= maxLines) {\n return content;\n }\n\n let truncated = lines.slice(0, maxLines).join('\\n').trimEnd();\n\n // Fix unclosed markdown syntax\n truncated = fixUnclosedMarkdown(truncated);\n\n return truncated;\n}\n\n/**\n * Fix unclosed markdown syntax to prevent rendering issues\n */\nfunction fixUnclosedMarkdown(content: string): string {\n let result = content;\n\n // Count occurrences of markdown markers\n const countOccurrences = (str: string, marker: string): number => {\n const escaped = marker.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n const matches = str.match(new RegExp(escaped, 'g'));\n return matches ? matches.length : 0;\n };\n\n // Fix unclosed bold (**) - must have even count\n const boldCount = countOccurrences(result, '**');\n if (boldCount % 2 !== 0) {\n result += '**';\n }\n\n // Fix unclosed italic (*) - but not **\n // Remove ** first for counting, then count single *\n const withoutBold = result.replace(/\\*\\*/g, '');\n const italicCount = countOccurrences(withoutBold, '*');\n if (italicCount % 2 !== 0) {\n result += '*';\n }\n\n // Fix unclosed inline code (`)\n const codeCount = countOccurrences(result, '`');\n // Ignore triple backticks for code blocks\n const tripleCount = countOccurrences(result, '```');\n const singleCodeCount = codeCount - (tripleCount * 3);\n if (singleCodeCount % 2 !== 0) {\n result += '`';\n }\n\n // Fix unclosed code blocks (```)\n if (tripleCount % 2 !== 0) {\n result += '\\n```';\n }\n\n // Fix unclosed strikethrough (~~)\n const strikeCount = countOccurrences(result, '~~');\n if (strikeCount % 2 !== 0) {\n result += '~~';\n }\n\n // Fix unclosed underline bold (__)\n const underlineBoldCount = countOccurrences(result, '__');\n if (underlineBoldCount % 2 !== 0) {\n result += '__';\n }\n\n // Fix unclosed underline italic (_) - but not __\n const withoutUnderlineBold = result.replace(/__/g, '');\n const underlineItalicCount = countOccurrences(withoutUnderlineBold, '_');\n if (underlineItalicCount % 2 !== 0) {\n result += '_';\n }\n\n return result;\n}\n\n/**\n * Hook for managing collapsible content with \"Read more...\" functionality\n *\n * @example\n * ```tsx\n * const { isCollapsed, toggleCollapsed, displayContent, shouldCollapse } = useCollapsibleContent(\n * longText,\n * { maxLength: 300, maxLines: 5 }\n * );\n *\n * return (\n * <div>\n * <Markdown content={displayContent} />\n * {shouldCollapse && (\n * <button onClick={toggleCollapsed}>\n * {isCollapsed ? 'Read more...' : 'Show less'}\n * </button>\n * )}\n * </div>\n * );\n * ```\n */\nexport function useCollapsibleContent(\n content: string,\n options: UseCollapsibleContentOptions = {}\n): UseCollapsibleContentResult {\n const { maxLength, maxLines, defaultExpanded = false } = options;\n\n const [isCollapsed, setIsCollapsed] = useState(!defaultExpanded);\n\n const originalLength = content.length;\n const originalLineCount = content.split('\\n').length;\n\n const { shouldCollapse, truncatedContent } = useMemo(() => {\n // If no limits set, don't collapse\n if (maxLength === undefined && maxLines === undefined) {\n return { shouldCollapse: false, truncatedContent: content };\n }\n\n let needsCollapse = false;\n let result = content;\n\n // Check line limit first (usually more restrictive for chat)\n if (maxLines !== undefined && originalLineCount > maxLines) {\n needsCollapse = true;\n result = truncateByLines(result, maxLines);\n }\n\n // Then check character limit\n if (maxLength !== undefined && result.length > maxLength) {\n needsCollapse = true;\n result = smartTruncate(result, maxLength);\n }\n\n return { shouldCollapse: needsCollapse, truncatedContent: result };\n }, [content, maxLength, maxLines, originalLineCount]);\n\n const displayContent = useMemo(() => {\n if (!shouldCollapse || !isCollapsed) {\n return content;\n }\n return truncatedContent;\n }, [content, truncatedContent, shouldCollapse, isCollapsed]);\n\n const toggleCollapsed = useCallback(() => {\n setIsCollapsed((prev) => !prev);\n }, []);\n\n const setCollapsed = useCallback((collapsed: boolean) => {\n setIsCollapsed(collapsed);\n }, []);\n\n return {\n isCollapsed,\n toggleCollapsed,\n setCollapsed,\n displayContent,\n shouldCollapse,\n originalLength,\n originalLineCount,\n };\n}\n\nexport default useCollapsibleContent;\n","'use client';\n\nimport React from 'react';\nimport ReactMarkdown from 'react-markdown';\nimport remarkGfm from 'remark-gfm';\n\nimport { CopyButton } from '@djangocfg/ui-core/components';\nimport { useResolvedTheme } from '@djangocfg/ui-core/hooks';\n\nimport Mermaid from '../../tools/Mermaid';\nimport PrettyCode from '../../tools/PrettyCode';\nimport { useCollapsibleContent } from './useCollapsibleContent';\n\nimport type { Components } from 'react-markdown';\n\n// Helper function to extract text content from React children\nconst extractTextFromChildren = (children: React.ReactNode): string => {\n if (typeof children === 'string') {\n return children;\n }\n\n if (typeof children === 'number') {\n return String(children);\n }\n\n if (React.isValidElement(children)) {\n const props = children.props as { children?: React.ReactNode };\n return extractTextFromChildren(props.children);\n }\n\n if (Array.isArray(children)) {\n return children.map(extractTextFromChildren).join('');\n }\n\n return '';\n};\n\nexport interface MarkdownMessageProps {\n /** Markdown content to render */\n content: string;\n /** Additional CSS classes */\n className?: string;\n /** Whether the message is from the user (affects styling) */\n isUser?: boolean;\n /** Use compact size (text-xs instead of text-sm) */\n isCompact?: boolean;\n /**\n * Enable collapsible \"Read more...\" functionality\n * When enabled, long content will be truncated with a toggle button\n * @default false\n */\n collapsible?: boolean;\n /**\n * Maximum character length before showing \"Read more...\"\n * Only applies when collapsible is true\n * If both maxLength and maxLines are set, the stricter limit applies\n */\n maxLength?: number;\n /**\n * Maximum number of lines before showing \"Read more...\"\n * Only applies when collapsible is true\n * If both maxLength and maxLines are set, the stricter limit applies\n */\n maxLines?: number;\n /**\n * Custom \"Read more\" button text\n * @default \"Read more...\"\n */\n readMoreLabel?: string;\n /**\n * Custom \"Show less\" button text\n * @default \"Show less\"\n */\n showLessLabel?: string;\n /**\n * Start expanded (only applies when collapsible is true)\n * @default false\n */\n defaultExpanded?: boolean;\n /**\n * Callback when collapsed state changes\n */\n onCollapseChange?: (isCollapsed: boolean) => void;\n}\n\n// Code block component with copy functionality\ninterface CodeBlockProps {\n code: string;\n language: string;\n isUser: boolean;\n isCompact?: boolean;\n}\n\nconst CodeBlock: React.FC<CodeBlockProps> = ({ code, language, isUser, isCompact = false }) => {\n const theme = useResolvedTheme();\n\n return (\n <div className=\"relative group my-3\">\n {/* Copy button */}\n <CopyButton\n value={code}\n variant=\"ghost\"\n className={`\n absolute top-2 right-2 z-10 opacity-0 group-hover:opacity-100 transition-opacity\n h-8 w-8\n ${isUser\n ? 'hover:bg-white/20 text-white'\n : 'hover:bg-muted-foreground/20 text-muted-foreground hover:text-foreground'\n }\n `}\n title=\"Copy code\"\n />\n\n {/* Code content */}\n <PrettyCode\n data={code}\n language={language}\n className={isCompact ? 'text-xs' : 'text-sm'}\n customBg={isUser ? \"bg-white/10\" : \"bg-muted dark:bg-muted\"}\n mode={theme}\n isCompact={isCompact}\n />\n </div>\n );\n};\n\n// Custom components for markdown in chat\n// Base size: text-sm (14px) for normal, text-xs (12px) for compact\nconst createMarkdownComponents = (isUser: boolean = false, isCompact: boolean = false): Components => {\n // Text size classes based on compact mode\n const textSize = isCompact ? 'text-xs' : 'text-sm';\n const headingBase = isCompact ? 'text-sm' : 'text-base';\n const headingSm = isCompact ? 'text-xs' : 'text-sm';\n\n return {\n // Headings - scaled for chat context\n h1: ({ children }) => (\n <h1 className={`${headingBase} font-bold mb-2 mt-3 first:mt-0`}>{children}</h1>\n ),\n h2: ({ children }) => (\n <h2 className={`${headingSm} font-bold mb-2 mt-3 first:mt-0`}>{children}</h2>\n ),\n h3: ({ children }) => (\n <h3 className={`${headingSm} font-semibold mb-1 mt-2 first:mt-0`}>{children}</h3>\n ),\n h4: ({ children }) => (\n <h4 className={`${headingSm} font-semibold mb-1 mt-2 first:mt-0`}>{children}</h4>\n ),\n h5: ({ children }) => (\n <h5 className={`${headingSm} font-medium mb-1 mt-2 first:mt-0`}>{children}</h5>\n ),\n h6: ({ children }) => (\n <h6 className={`${headingSm} font-medium mb-1 mt-2 first:mt-0`}>{children}</h6>\n ),\n\n // Paragraphs - compact spacing for chat\n p: ({ children }) => (\n <p className={`${textSize} mb-2 last:mb-0 leading-relaxed break-words`}>{children}</p>\n ),\n\n // Lists - compact\n ul: ({ children }) => (\n <ul className={`list-disc list-inside mb-2 space-y-1 ${textSize}`}>{children}</ul>\n ),\n ol: ({ children }) => (\n <ol className={`list-decimal list-inside mb-2 space-y-1 ${textSize}`}>{children}</ol>\n ),\n li: ({ children }) => (\n <li className=\"break-words\">{children}</li>\n ),\n\n // Links - appropriate for chat context\n a: ({ href, children }) => (\n <a\n href={href}\n className={`${textSize} text-primary underline hover:text-primary/80 transition-colors break-all`}\n target={href?.startsWith('http') ? '_blank' : undefined}\n rel={href?.startsWith('http') ? 'noopener noreferrer' : undefined}\n >\n {children}\n </a>\n ),\n\n // Code blocks - using CodeBlock component with copy functionality\n pre: ({ children }) => {\n // Extract code content and language\n let codeContent = '';\n let language = 'plaintext';\n\n if (React.isValidElement(children)) {\n const child = children;\n\n if (child.type === 'code' || (typeof child.type === 'function' && child.type.name === 'code')) {\n const codeProps = child.props as { className?: string; children?: React.ReactNode };\n const rawClassName = codeProps.className;\n language = rawClassName?.replace(/language-/, '').trim() || 'plaintext';\n codeContent = extractTextFromChildren(codeProps.children).trim();\n } else {\n codeContent = extractTextFromChildren(children).trim();\n }\n } else {\n codeContent = extractTextFromChildren(children).trim();\n }\n\n // If still no content, show placeholder\n if (!codeContent) {\n return (\n <div className=\"my-3 p-3 bg-muted rounded text-sm text-muted-foreground\">\n No content available\n </div>\n );\n }\n\n // Handle Mermaid diagrams separately\n if (language === 'mermaid') {\n return (\n <div className=\"my-3 max-w-full overflow-x-auto\">\n <Mermaid chart={codeContent} className=\"max-w-[600px] mx-auto\" isCompact={isCompact} />\n </div>\n );\n }\n\n // Try to use CodeBlock component, fallback to simple pre if it fails\n try {\n return <CodeBlock code={codeContent} language={language} isUser={isUser} isCompact={isCompact} />;\n } catch (error) {\n // Fallback to simple pre element with copy button\n console.warn('CodeBlock failed, using fallback:', error);\n return (\n <div className=\"relative group my-3\">\n <CopyButton\n value={codeContent}\n variant=\"ghost\"\n className={`\n absolute top-2 right-2 z-10 opacity-0 group-hover:opacity-100 transition-opacity\n h-8 w-8\n ${isUser\n ? 'hover:bg-white/20 text-white'\n : 'hover:bg-muted-foreground/20 text-muted-foreground hover:text-foreground'\n }\n `}\n title=\"Copy code\"\n />\n <pre className={`\n p-3 rounded text-xs font-mono overflow-x-auto\n ${isUser\n ? 'bg-white/10 text-white'\n : 'bg-muted text-foreground'\n }\n `}>\n <code>{codeContent}</code>\n </pre>\n </div>\n );\n }\n },\n\n // Inline code\n code: ({ children, className }) => {\n // If it's inside a pre tag, let pre handle it\n if (className?.includes('language-')) {\n return <code className={className}>{children}</code>;\n }\n\n // Extract text content safely\n const codeContent = extractTextFromChildren(children);\n\n // Inline code styling\n return (\n <code className=\"px-1.5 py-0.5 rounded text-xs font-mono bg-muted text-foreground break-all\">\n {codeContent}\n </code>\n );\n },\n\n // Blockquotes\n blockquote: ({ children }) => (\n <blockquote className={`${textSize} border-l-2 border-border pl-3 my-2 italic text-muted-foreground break-words`}>\n {children}\n </blockquote>\n ),\n\n // Tables - compact for chat\n table: ({ children }) => (\n <div className=\"overflow-x-auto my-3\">\n <table className={`min-w-full ${textSize} border-collapse`}>\n {children}\n </table>\n </div>\n ),\n thead: ({ children }) => (\n <thead className=\"bg-muted/50\">\n {children}\n </thead>\n ),\n tbody: ({ children }) => (\n <tbody>{children}</tbody>\n ),\n tr: ({ children }) => (\n <tr className=\"border-b border-border/50\">{children}</tr>\n ),\n th: ({ children }) => (\n <th className=\"px-2 py-1 text-left font-medium break-words\">{children}</th>\n ),\n td: ({ children }) => (\n <td className=\"px-2 py-1 break-words\">{children}</td>\n ),\n\n // Horizontal rule\n hr: () => (\n <hr className=\"my-3 border-0 h-px bg-border\" />\n ),\n\n // Strong and emphasis\n strong: ({ children }) => (\n <strong className=\"font-semibold\">{children}</strong>\n ),\n em: ({ children }) => (\n <em className=\"italic\">{children}</em>\n ),\n};};\n\n// Check if content contains markdown syntax or line breaks\nconst hasMarkdownSyntax = (text: string): boolean => {\n // If there are line breaks (after trim), treat as markdown for proper paragraph rendering\n if (text.trim().includes('\\n')) {\n return true;\n }\n\n // Common markdown patterns\n const markdownPatterns = [\n /^#{1,6}\\s/m, // Headers\n /\\*\\*[^*]+\\*\\*/, // Bold\n /\\*[^*]+\\*/, // Italic\n /__[^_]+__/, // Bold (underscore)\n /_[^_]+_/, // Italic (underscore)\n /\\[.+\\]\\(.+\\)/, // Links\n /!\\[.*\\]\\(.+\\)/, // Images\n /```[\\s\\S]*```/, // Code blocks\n /`[^`]+`/, // Inline code\n /^\\s*[-*+]\\s/m, // Unordered lists\n /^\\s*\\d+\\.\\s/m, // Ordered lists\n /^\\s*>/m, // Blockquotes\n /\\|.+\\|/, // Tables\n /^---+$/m, // Horizontal rules\n /~~[^~]+~~/, // Strikethrough\n ];\n\n return markdownPatterns.some(pattern => pattern.test(text));\n};\n\n/**\n * Read more / Show less toggle button\n */\ninterface CollapseToggleProps {\n isCollapsed: boolean;\n onClick: () => void;\n readMoreLabel: string;\n showLessLabel: string;\n isUser: boolean;\n isCompact: boolean;\n}\n\nconst CollapseToggle: React.FC<CollapseToggleProps> = ({\n isCollapsed,\n onClick,\n readMoreLabel,\n showLessLabel,\n isUser,\n isCompact,\n}) => {\n const textSize = isCompact ? 'text-xs' : 'text-sm';\n\n return (\n <button\n type=\"button\"\n onClick={onClick}\n className={`\n ${textSize} font-medium cursor-pointer\n transition-colors duration-200\n ${isUser\n ? 'text-white/80 hover:text-white'\n : 'text-primary hover:text-primary/80'\n }\n inline-flex items-center gap-1\n mt-1\n `}\n >\n {isCollapsed ? (\n <>\n {readMoreLabel}\n <svg\n className=\"w-3 h-3\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M19 9l-7 7-7-7\"\n />\n </svg>\n </>\n ) : (\n <>\n {showLessLabel}\n <svg\n className=\"w-3 h-3\"\n fill=\"none\"\n stroke=\"currentColor\"\n viewBox=\"0 0 24 24\"\n >\n <path\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth={2}\n d=\"M5 15l7-7 7 7\"\n />\n </svg>\n </>\n )}\n </button>\n );\n};\n\n/**\n * MarkdownMessage - Renders markdown content with syntax highlighting and GFM support\n *\n * Features:\n * - GitHub Flavored Markdown (GFM) support\n * - Syntax highlighted code blocks with copy button\n * - Mermaid diagram rendering\n * - Tables, lists, blockquotes\n * - User/assistant styling modes\n * - Plain text optimization (skips ReactMarkdown for simple text)\n * - Collapsible \"Read more...\" for long messages\n *\n * @example\n * ```tsx\n * <MarkdownMessage content=\"# Hello\\n\\nThis is **bold** text.\" />\n *\n * // User message styling\n * <MarkdownMessage content=\"Some content\" isUser />\n *\n * // Collapsible long content (for chat apps)\n * <MarkdownMessage\n * content={longText}\n * collapsible\n * maxLength={300}\n * maxLines={5}\n * />\n * ```\n */\nexport const MarkdownMessage: React.FC<MarkdownMessageProps> = ({\n content,\n className = \"\",\n isUser = false,\n isCompact = false,\n collapsible = false,\n maxLength,\n maxLines,\n readMoreLabel = \"Read more...\",\n showLessLabel = \"Show less\",\n defaultExpanded = false,\n onCollapseChange,\n}) => {\n // Trim content to remove leading/trailing whitespace and empty lines\n const trimmedContent = content.trim();\n\n // Collapsible content logic\n const collapsibleOptions = React.useMemo(() => {\n if (!collapsible) return {};\n return { maxLength, maxLines, defaultExpanded };\n }, [collapsible, maxLength, maxLines, defaultExpanded]);\n\n const {\n isCollapsed,\n toggleCollapsed,\n displayContent,\n shouldCollapse,\n } = useCollapsibleContent(\n trimmedContent,\n collapsible ? collapsibleOptions : {}\n );\n\n // Call onCollapseChange when state changes\n React.useEffect(() => {\n if (collapsible && shouldCollapse && onCollapseChange) {\n onCollapseChange(isCollapsed);\n }\n }, [isCollapsed, collapsible, shouldCollapse, onCollapseChange]);\n\n const components = React.useMemo(() => createMarkdownComponents(isUser, isCompact), [isUser, isCompact]);\n\n const textSizeClass = isCompact ? 'text-xs' : 'text-sm';\n const proseClass = isCompact ? 'prose-xs' : 'prose-sm';\n\n // For plain text without markdown, render directly without ReactMarkdown\n const isPlainText = !hasMarkdownSyntax(displayContent);\n\n // Render plain text\n if (isPlainText) {\n return (\n <span className={`${textSizeClass} leading-relaxed break-words ${className}`}>\n {displayContent}\n {collapsible && shouldCollapse && (\n <>\n {isCollapsed && '... '}\n <CollapseToggle\n isCollapsed={isCollapsed}\n onClick={toggleCollapsed}\n readMoreLabel={readMoreLabel}\n showLessLabel={showLessLabel}\n isUser={isUser}\n isCompact={isCompact}\n />\n </>\n )}\n </span>\n );\n }\n\n // Render markdown\n return (\n <div className={className}>\n <div\n className={`\n prose ${proseClass} max-w-none break-words overflow-hidden ${textSizeClass}\n ${isUser ? 'prose-invert' : 'dark:prose-invert'}\n `}\n style={{\n // Inherit colors from parent - fixes issues with external CSS variables\n '--tw-prose-body': 'inherit',\n '--tw-prose-headings': 'inherit',\n '--tw-prose-bold': 'inherit',\n '--tw-prose-links': 'inherit',\n color: 'inherit',\n } as React.CSSProperties}\n >\n <ReactMarkdown\n remarkPlugins={[remarkGfm]}\n components={components}\n >\n {displayContent}\n </ReactMarkdown>\n </div>\n {collapsible && shouldCollapse && (\n <CollapseToggle\n isCollapsed={isCollapsed}\n onClick={toggleCollapsed}\n readMoreLabel={readMoreLabel}\n showLessLabel={showLessLabel}\n isUser={isUser}\n isCompact={isCompact}\n />\n )}\n </div>\n );\n};\n\nexport default MarkdownMessage;\n"]}