@supernal/interface 1.0.0
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.
- package/LICENSE +22 -0
- package/README.md +165 -0
- package/dist/cjs/names/API.js +104 -0
- package/dist/cjs/names/API.js.map +1 -0
- package/dist/cjs/names/Components.js +104 -0
- package/dist/cjs/names/Components.js.map +1 -0
- package/dist/cjs/names/Containers.js +99 -0
- package/dist/cjs/names/Containers.js.map +1 -0
- package/dist/cjs/names/Functions.js +114 -0
- package/dist/cjs/names/Functions.js.map +1 -0
- package/dist/cjs/names/index.js +118 -0
- package/dist/cjs/names/index.js.map +1 -0
- package/dist/cjs/src/adapters/ChatUIProvider.js +176 -0
- package/dist/cjs/src/adapters/ChatUIProvider.js.map +1 -0
- package/dist/cjs/src/adapters/bridge.js +225 -0
- package/dist/cjs/src/adapters/bridge.js.map +1 -0
- package/dist/cjs/src/adapters/copilotkit/CopilotKitAdapter.js +289 -0
- package/dist/cjs/src/adapters/copilotkit/CopilotKitAdapter.js.map +1 -0
- package/dist/cjs/src/adapters/copilotkit/index.js +10 -0
- package/dist/cjs/src/adapters/copilotkit/index.js.map +1 -0
- package/dist/cjs/src/adapters/index.js +63 -0
- package/dist/cjs/src/adapters/index.js.map +1 -0
- package/dist/cjs/src/adapters/native/NativeAdapter.js +268 -0
- package/dist/cjs/src/adapters/native/NativeAdapter.js.map +1 -0
- package/dist/cjs/src/adapters/native/index.js +10 -0
- package/dist/cjs/src/adapters/native/index.js.map +1 -0
- package/dist/cjs/src/adapters/types/index.js +9 -0
- package/dist/cjs/src/adapters/types/index.js.map +1 -0
- package/dist/cjs/src/ai/ToolExecutor.js +211 -0
- package/dist/cjs/src/ai/ToolExecutor.js.map +1 -0
- package/dist/cjs/src/ai/ToolMatcher.js +202 -0
- package/dist/cjs/src/ai/ToolMatcher.js.map +1 -0
- package/dist/cjs/src/ai/index.js +29 -0
- package/dist/cjs/src/ai/index.js.map +1 -0
- package/dist/cjs/src/architecture/createContainer.js +106 -0
- package/dist/cjs/src/architecture/createContainer.js.map +1 -0
- package/dist/cjs/src/architecture/initialize.js +125 -0
- package/dist/cjs/src/architecture/initialize.js.map +1 -0
- package/dist/cjs/src/architecture/registry.js +111 -0
- package/dist/cjs/src/architecture/registry.js.map +1 -0
- package/dist/cjs/src/background/architecture/ArchitectureInitializer.js +174 -0
- package/dist/cjs/src/background/architecture/ArchitectureInitializer.js.map +1 -0
- package/dist/cjs/src/background/architecture/Containers.js +46 -0
- package/dist/cjs/src/background/architecture/Containers.js.map +1 -0
- package/dist/cjs/src/background/architecture/DataContractTypes.js +28 -0
- package/dist/cjs/src/background/architecture/DataContractTypes.js.map +1 -0
- package/dist/cjs/src/background/architecture/index.js +24 -0
- package/dist/cjs/src/background/architecture/index.js.map +1 -0
- package/dist/cjs/src/background/navigation/NavigationGraph.js +71 -0
- package/dist/cjs/src/background/navigation/NavigationGraph.js.map +1 -0
- package/dist/cjs/src/background/navigation/RuntimeTreeBuilder.js +66 -0
- package/dist/cjs/src/background/navigation/RuntimeTreeBuilder.js.map +1 -0
- package/dist/cjs/src/background/navigation/useComponentTracking.js +20 -0
- package/dist/cjs/src/background/navigation/useComponentTracking.js.map +1 -0
- package/dist/cjs/src/background/registry/ComponentRegistry.js +340 -0
- package/dist/cjs/src/background/registry/ComponentRegistry.js.map +1 -0
- package/dist/cjs/src/background/registry/ToolRegistry.js +668 -0
- package/dist/cjs/src/background/registry/ToolRegistry.js.map +1 -0
- package/dist/cjs/src/browser.js +70 -0
- package/dist/cjs/src/browser.js.map +1 -0
- package/dist/cjs/src/components/ComponentScanner.js +362 -0
- package/dist/cjs/src/components/ComponentScanner.js.map +1 -0
- package/dist/cjs/src/components/index.js +24 -0
- package/dist/cjs/src/components/index.js.map +1 -0
- package/dist/cjs/src/data/TestDataManager.js +187 -0
- package/dist/cjs/src/data/TestDataManager.js.map +1 -0
- package/dist/cjs/src/data/index.js +23 -0
- package/dist/cjs/src/data/index.js.map +1 -0
- package/dist/cjs/src/decorators/Component.js +108 -0
- package/dist/cjs/src/decorators/Component.js.map +1 -0
- package/dist/cjs/src/decorators/ContainerHelpers.js +45 -0
- package/dist/cjs/src/decorators/ContainerHelpers.js.map +1 -0
- package/dist/cjs/src/decorators/SpecializedTools.js +386 -0
- package/dist/cjs/src/decorators/SpecializedTools.js.map +1 -0
- package/dist/cjs/src/decorators/Tool.js +700 -0
- package/dist/cjs/src/decorators/Tool.js.map +1 -0
- package/dist/cjs/src/decorators/ToolHelpers.js +261 -0
- package/dist/cjs/src/decorators/ToolHelpers.js.map +1 -0
- package/dist/cjs/src/decorators/ToolPreset.js +270 -0
- package/dist/cjs/src/decorators/ToolPreset.js.map +1 -0
- package/dist/cjs/src/decorators/ToolProvider.js +86 -0
- package/dist/cjs/src/decorators/ToolProvider.js.map +1 -0
- package/dist/cjs/src/decorators/index.js +44 -0
- package/dist/cjs/src/decorators/index.js.map +1 -0
- package/dist/cjs/src/execution/DOMExecutor.js +233 -0
- package/dist/cjs/src/execution/DOMExecutor.js.map +1 -0
- package/dist/cjs/src/execution/PlaywrightExecutor.js +196 -0
- package/dist/cjs/src/execution/PlaywrightExecutor.js.map +1 -0
- package/dist/cjs/src/exposure/ExposureCollector.js +358 -0
- package/dist/cjs/src/exposure/ExposureCollector.js.map +1 -0
- package/dist/cjs/src/exposure/index.js +26 -0
- package/dist/cjs/src/exposure/index.js.map +1 -0
- package/dist/cjs/src/index.js +187 -0
- package/dist/cjs/src/index.js.map +1 -0
- package/dist/cjs/src/interfaces/StatefulComponent.js +50 -0
- package/dist/cjs/src/interfaces/StatefulComponent.js.map +1 -0
- package/dist/cjs/src/name-contracts/ContractScanner.js +15 -0
- package/dist/cjs/src/name-contracts/ContractScanner.js.map +1 -0
- package/dist/cjs/src/name-contracts/RouteContractScanner.js +225 -0
- package/dist/cjs/src/name-contracts/RouteContractScanner.js.map +1 -0
- package/dist/cjs/src/name-contracts/index.js +15 -0
- package/dist/cjs/src/name-contracts/index.js.map +1 -0
- package/dist/cjs/src/names/createNames.js +86 -0
- package/dist/cjs/src/names/createNames.js.map +1 -0
- package/dist/cjs/src/react/hooks/useChatWithContext.js +221 -0
- package/dist/cjs/src/react/hooks/useChatWithContext.js.map +1 -0
- package/dist/cjs/src/react/index.js +28 -0
- package/dist/cjs/src/react/index.js.map +1 -0
- package/dist/cjs/src/react/useNavigationHandler.js +88 -0
- package/dist/cjs/src/react/useNavigationHandler.js.map +1 -0
- package/dist/cjs/src/react/usePersistedState.js +72 -0
- package/dist/cjs/src/react/usePersistedState.js.map +1 -0
- package/dist/cjs/src/react/useToolBinding.js +110 -0
- package/dist/cjs/src/react/useToolBinding.js.map +1 -0
- package/dist/cjs/src/routes/RouteContractGenerator.js +119 -0
- package/dist/cjs/src/routes/RouteContractGenerator.js.map +1 -0
- package/dist/cjs/src/routes/RouteContractsConfig.js +39 -0
- package/dist/cjs/src/routes/RouteContractsConfig.js.map +1 -0
- package/dist/cjs/src/routes/index.js +20 -0
- package/dist/cjs/src/routes/index.js.map +1 -0
- package/dist/cjs/src/routes/scanners/NameExtractor.js +193 -0
- package/dist/cjs/src/routes/scanners/NameExtractor.js.map +1 -0
- package/dist/cjs/src/routes/scanners/NextjsDynamicScanner.js +102 -0
- package/dist/cjs/src/routes/scanners/NextjsDynamicScanner.js.map +1 -0
- package/dist/cjs/src/routes/scanners/RouteScanner.js +13 -0
- package/dist/cjs/src/routes/scanners/RouteScanner.js.map +1 -0
- package/dist/cjs/src/storage/LocalStorageAdapter.js +87 -0
- package/dist/cjs/src/storage/LocalStorageAdapter.js.map +1 -0
- package/dist/cjs/src/storage/StateManager.js +299 -0
- package/dist/cjs/src/storage/StateManager.js.map +1 -0
- package/dist/cjs/src/storage/StorageAdapter.js +164 -0
- package/dist/cjs/src/storage/StorageAdapter.js.map +1 -0
- package/dist/cjs/src/storage/index.js +37 -0
- package/dist/cjs/src/storage/index.js.map +1 -0
- package/dist/cjs/src/testing/BrowserStateInjection.js +130 -0
- package/dist/cjs/src/testing/BrowserStateInjection.js.map +1 -0
- package/dist/cjs/src/testing/ComponentStateHelpers.js +200 -0
- package/dist/cjs/src/testing/ComponentStateHelpers.js.map +1 -0
- package/dist/cjs/src/testing/GherkinParser.js +252 -0
- package/dist/cjs/src/testing/GherkinParser.js.map +1 -0
- package/dist/cjs/src/testing/PlaywrightStateHelpers.js +254 -0
- package/dist/cjs/src/testing/PlaywrightStateHelpers.js.map +1 -0
- package/dist/cjs/src/testing/TestRunner.js +158 -0
- package/dist/cjs/src/testing/TestRunner.js.map +1 -0
- package/dist/cjs/src/testing/index.js +46 -0
- package/dist/cjs/src/testing/index.js.map +1 -0
- package/dist/cjs/src/testing/selectors.js +84 -0
- package/dist/cjs/src/testing/selectors.js.map +1 -0
- package/dist/cjs/src/tools/SystemTools.js +262 -0
- package/dist/cjs/src/tools/SystemTools.js.map +1 -0
- package/dist/cjs/src/types/ClassifiedTool.js +50 -0
- package/dist/cjs/src/types/ClassifiedTool.js.map +1 -0
- package/dist/cjs/src/types/ComponentState.js +30 -0
- package/dist/cjs/src/types/ComponentState.js.map +1 -0
- package/dist/cjs/src/types/DiscoverableToolProvider.js +9 -0
- package/dist/cjs/src/types/DiscoverableToolProvider.js.map +1 -0
- package/dist/cjs/src/types/ExposureState.js +25 -0
- package/dist/cjs/src/types/ExposureState.js.map +1 -0
- package/dist/cjs/src/types/NavigationGraph.js +8 -0
- package/dist/cjs/src/types/NavigationGraph.js.map +1 -0
- package/dist/cjs/src/types/OperationType.js +49 -0
- package/dist/cjs/src/types/OperationType.js.map +1 -0
- package/dist/cjs/src/types/StateManagers.js +39 -0
- package/dist/cjs/src/types/StateManagers.js.map +1 -0
- package/dist/cjs/src/types/Tool.js +41 -0
- package/dist/cjs/src/types/Tool.js.map +1 -0
- package/dist/cjs/src/types/ToolPermissions.js +54 -0
- package/dist/cjs/src/types/ToolPermissions.js.map +1 -0
- package/dist/cjs/src/types/ToolResult.js +25 -0
- package/dist/cjs/src/types/ToolResult.js.map +1 -0
- package/dist/cjs/src/types/index.js +59 -0
- package/dist/cjs/src/types/index.js.map +1 -0
- package/dist/cjs/src/ui/react/chat/ChatBubble.js +221 -0
- package/dist/cjs/src/ui/react/chat/ChatBubble.js.map +1 -0
- package/dist/esm/names/API.d.ts +77 -0
- package/dist/esm/names/API.d.ts.map +1 -0
- package/dist/esm/names/API.js +99 -0
- package/dist/esm/names/API.js.map +1 -0
- package/dist/esm/names/Components.d.ts +77 -0
- package/dist/esm/names/Components.d.ts.map +1 -0
- package/dist/esm/names/Components.js +99 -0
- package/dist/esm/names/Components.js.map +1 -0
- package/dist/esm/names/Containers.d.ts +84 -0
- package/dist/esm/names/Containers.d.ts.map +1 -0
- package/dist/esm/names/Containers.js +94 -0
- package/dist/esm/names/Containers.js.map +1 -0
- package/dist/esm/names/Functions.d.ts +87 -0
- package/dist/esm/names/Functions.d.ts.map +1 -0
- package/dist/esm/names/Functions.js +109 -0
- package/dist/esm/names/Functions.js.map +1 -0
- package/dist/esm/names/index.d.ts +187 -0
- package/dist/esm/names/index.d.ts.map +1 -0
- package/dist/esm/names/index.js +99 -0
- package/dist/esm/names/index.js.map +1 -0
- package/dist/esm/src/adapters/ChatUIProvider.d.ts +76 -0
- package/dist/esm/src/adapters/ChatUIProvider.d.ts.map +1 -0
- package/dist/esm/src/adapters/ChatUIProvider.js +136 -0
- package/dist/esm/src/adapters/ChatUIProvider.js.map +1 -0
- package/dist/esm/src/adapters/bridge.d.ts +145 -0
- package/dist/esm/src/adapters/bridge.d.ts.map +1 -0
- package/dist/esm/src/adapters/bridge.js +218 -0
- package/dist/esm/src/adapters/bridge.js.map +1 -0
- package/dist/esm/src/adapters/copilotkit/CopilotKitAdapter.d.ts +49 -0
- package/dist/esm/src/adapters/copilotkit/CopilotKitAdapter.d.ts.map +1 -0
- package/dist/esm/src/adapters/copilotkit/CopilotKitAdapter.js +251 -0
- package/dist/esm/src/adapters/copilotkit/CopilotKitAdapter.js.map +1 -0
- package/dist/esm/src/adapters/copilotkit/index.d.ts +6 -0
- package/dist/esm/src/adapters/copilotkit/index.d.ts.map +1 -0
- package/dist/esm/src/adapters/copilotkit/index.js +5 -0
- package/dist/esm/src/adapters/copilotkit/index.js.map +1 -0
- package/dist/esm/src/adapters/index.d.ts +31 -0
- package/dist/esm/src/adapters/index.d.ts.map +1 -0
- package/dist/esm/src/adapters/index.js +32 -0
- package/dist/esm/src/adapters/index.js.map +1 -0
- package/dist/esm/src/adapters/native/NativeAdapter.d.ts +47 -0
- package/dist/esm/src/adapters/native/NativeAdapter.d.ts.map +1 -0
- package/dist/esm/src/adapters/native/NativeAdapter.js +230 -0
- package/dist/esm/src/adapters/native/NativeAdapter.js.map +1 -0
- package/dist/esm/src/adapters/native/index.d.ts +6 -0
- package/dist/esm/src/adapters/native/index.d.ts.map +1 -0
- package/dist/esm/src/adapters/native/index.js +5 -0
- package/dist/esm/src/adapters/native/index.js.map +1 -0
- package/dist/esm/src/adapters/types/index.d.ts +155 -0
- package/dist/esm/src/adapters/types/index.d.ts.map +1 -0
- package/dist/esm/src/adapters/types/index.js +8 -0
- package/dist/esm/src/adapters/types/index.js.map +1 -0
- package/dist/esm/src/ai/ToolExecutor.d.ts +49 -0
- package/dist/esm/src/ai/ToolExecutor.d.ts.map +1 -0
- package/dist/esm/src/ai/ToolExecutor.js +174 -0
- package/dist/esm/src/ai/ToolExecutor.js.map +1 -0
- package/dist/esm/src/ai/ToolMatcher.d.ts +61 -0
- package/dist/esm/src/ai/ToolMatcher.d.ts.map +1 -0
- package/dist/esm/src/ai/ToolMatcher.js +198 -0
- package/dist/esm/src/ai/ToolMatcher.js.map +1 -0
- package/dist/esm/src/ai/index.d.ts +9 -0
- package/dist/esm/src/ai/index.d.ts.map +1 -0
- package/dist/esm/src/ai/index.js +13 -0
- package/dist/esm/src/ai/index.js.map +1 -0
- package/dist/esm/src/architecture/createContainer.d.ts +60 -0
- package/dist/esm/src/architecture/createContainer.d.ts.map +1 -0
- package/dist/esm/src/architecture/createContainer.js +102 -0
- package/dist/esm/src/architecture/createContainer.js.map +1 -0
- package/dist/esm/src/architecture/initialize.d.ts +81 -0
- package/dist/esm/src/architecture/initialize.d.ts.map +1 -0
- package/dist/esm/src/architecture/initialize.js +121 -0
- package/dist/esm/src/architecture/initialize.js.map +1 -0
- package/dist/esm/src/architecture/registry.d.ts +61 -0
- package/dist/esm/src/architecture/registry.d.ts.map +1 -0
- package/dist/esm/src/architecture/registry.js +107 -0
- package/dist/esm/src/architecture/registry.js.map +1 -0
- package/dist/esm/src/background/architecture/ArchitectureInitializer.d.ts +95 -0
- package/dist/esm/src/background/architecture/ArchitectureInitializer.d.ts.map +1 -0
- package/dist/esm/src/background/architecture/ArchitectureInitializer.js +170 -0
- package/dist/esm/src/background/architecture/ArchitectureInitializer.js.map +1 -0
- package/dist/esm/src/background/architecture/Containers.d.ts +52 -0
- package/dist/esm/src/background/architecture/Containers.d.ts.map +1 -0
- package/dist/esm/src/background/architecture/Containers.js +40 -0
- package/dist/esm/src/background/architecture/Containers.js.map +1 -0
- package/dist/esm/src/background/architecture/DataContractTypes.d.ts +33 -0
- package/dist/esm/src/background/architecture/DataContractTypes.d.ts.map +1 -0
- package/dist/esm/src/background/architecture/DataContractTypes.js +22 -0
- package/dist/esm/src/background/architecture/DataContractTypes.js.map +1 -0
- package/dist/esm/src/background/architecture/index.d.ts +12 -0
- package/dist/esm/src/background/architecture/index.d.ts.map +1 -0
- package/dist/esm/src/background/architecture/index.js +13 -0
- package/dist/esm/src/background/architecture/index.js.map +1 -0
- package/dist/esm/src/background/navigation/NavigationGraph.d.ts +48 -0
- package/dist/esm/src/background/navigation/NavigationGraph.d.ts.map +1 -0
- package/dist/esm/src/background/navigation/NavigationGraph.js +67 -0
- package/dist/esm/src/background/navigation/NavigationGraph.js.map +1 -0
- package/dist/esm/src/background/navigation/RuntimeTreeBuilder.d.ts +30 -0
- package/dist/esm/src/background/navigation/RuntimeTreeBuilder.d.ts.map +1 -0
- package/dist/esm/src/background/navigation/RuntimeTreeBuilder.js +60 -0
- package/dist/esm/src/background/navigation/RuntimeTreeBuilder.js.map +1 -0
- package/dist/esm/src/background/navigation/useComponentTracking.d.ts +10 -0
- package/dist/esm/src/background/navigation/useComponentTracking.d.ts.map +1 -0
- package/dist/esm/src/background/navigation/useComponentTracking.js +17 -0
- package/dist/esm/src/background/navigation/useComponentTracking.js.map +1 -0
- package/dist/esm/src/background/registry/ComponentRegistry.d.ts +192 -0
- package/dist/esm/src/background/registry/ComponentRegistry.d.ts.map +1 -0
- package/dist/esm/src/background/registry/ComponentRegistry.js +336 -0
- package/dist/esm/src/background/registry/ComponentRegistry.js.map +1 -0
- package/dist/esm/src/background/registry/ToolRegistry.d.ts +232 -0
- package/dist/esm/src/background/registry/ToolRegistry.d.ts.map +1 -0
- package/dist/esm/src/background/registry/ToolRegistry.js +664 -0
- package/dist/esm/src/background/registry/ToolRegistry.js.map +1 -0
- package/dist/esm/src/browser.d.ts +21 -0
- package/dist/esm/src/browser.d.ts.map +1 -0
- package/dist/esm/src/browser.js +31 -0
- package/dist/esm/src/browser.js.map +1 -0
- package/dist/esm/src/components/ComponentScanner.d.ts +99 -0
- package/dist/esm/src/components/ComponentScanner.d.ts.map +1 -0
- package/dist/esm/src/components/ComponentScanner.js +325 -0
- package/dist/esm/src/components/ComponentScanner.js.map +1 -0
- package/dist/esm/src/components/index.d.ts +9 -0
- package/dist/esm/src/components/index.d.ts.map +1 -0
- package/dist/esm/src/components/index.js +8 -0
- package/dist/esm/src/components/index.js.map +1 -0
- package/dist/esm/src/data/TestDataManager.d.ts +125 -0
- package/dist/esm/src/data/TestDataManager.d.ts.map +1 -0
- package/dist/esm/src/data/TestDataManager.js +183 -0
- package/dist/esm/src/data/TestDataManager.js.map +1 -0
- package/dist/esm/src/data/index.d.ts +7 -0
- package/dist/esm/src/data/index.d.ts.map +1 -0
- package/dist/esm/src/data/index.js +7 -0
- package/dist/esm/src/data/index.js.map +1 -0
- package/dist/esm/src/decorators/Component.d.ts +59 -0
- package/dist/esm/src/decorators/Component.d.ts.map +1 -0
- package/dist/esm/src/decorators/Component.js +103 -0
- package/dist/esm/src/decorators/Component.js.map +1 -0
- package/dist/esm/src/decorators/ContainerHelpers.d.ts +26 -0
- package/dist/esm/src/decorators/ContainerHelpers.d.ts.map +1 -0
- package/dist/esm/src/decorators/ContainerHelpers.js +42 -0
- package/dist/esm/src/decorators/ContainerHelpers.js.map +1 -0
- package/dist/esm/src/decorators/SpecializedTools.d.ts +218 -0
- package/dist/esm/src/decorators/SpecializedTools.d.ts.map +1 -0
- package/dist/esm/src/decorators/SpecializedTools.js +383 -0
- package/dist/esm/src/decorators/SpecializedTools.js.map +1 -0
- package/dist/esm/src/decorators/Tool.d.ts +210 -0
- package/dist/esm/src/decorators/Tool.d.ts.map +1 -0
- package/dist/esm/src/decorators/Tool.js +694 -0
- package/dist/esm/src/decorators/Tool.js.map +1 -0
- package/dist/esm/src/decorators/ToolHelpers.d.ts +74 -0
- package/dist/esm/src/decorators/ToolHelpers.d.ts.map +1 -0
- package/dist/esm/src/decorators/ToolHelpers.js +219 -0
- package/dist/esm/src/decorators/ToolHelpers.js.map +1 -0
- package/dist/esm/src/decorators/ToolPreset.d.ts +138 -0
- package/dist/esm/src/decorators/ToolPreset.d.ts.map +1 -0
- package/dist/esm/src/decorators/ToolPreset.js +259 -0
- package/dist/esm/src/decorators/ToolPreset.js.map +1 -0
- package/dist/esm/src/decorators/ToolProvider.d.ts +65 -0
- package/dist/esm/src/decorators/ToolProvider.d.ts.map +1 -0
- package/dist/esm/src/decorators/ToolProvider.js +81 -0
- package/dist/esm/src/decorators/ToolProvider.js.map +1 -0
- package/dist/esm/src/decorators/index.d.ts +13 -0
- package/dist/esm/src/decorators/index.d.ts.map +1 -0
- package/dist/esm/src/decorators/index.js +14 -0
- package/dist/esm/src/decorators/index.js.map +1 -0
- package/dist/esm/src/execution/DOMExecutor.d.ts +43 -0
- package/dist/esm/src/execution/DOMExecutor.d.ts.map +1 -0
- package/dist/esm/src/execution/DOMExecutor.js +229 -0
- package/dist/esm/src/execution/DOMExecutor.js.map +1 -0
- package/dist/esm/src/execution/PlaywrightExecutor.d.ts +38 -0
- package/dist/esm/src/execution/PlaywrightExecutor.d.ts.map +1 -0
- package/dist/esm/src/execution/PlaywrightExecutor.js +192 -0
- package/dist/esm/src/execution/PlaywrightExecutor.js.map +1 -0
- package/dist/esm/src/exposure/ExposureCollector.d.ts +88 -0
- package/dist/esm/src/exposure/ExposureCollector.d.ts.map +1 -0
- package/dist/esm/src/exposure/ExposureCollector.js +354 -0
- package/dist/esm/src/exposure/ExposureCollector.js.map +1 -0
- package/dist/esm/src/exposure/index.d.ts +8 -0
- package/dist/esm/src/exposure/index.d.ts.map +1 -0
- package/dist/esm/src/exposure/index.js +10 -0
- package/dist/esm/src/exposure/index.js.map +1 -0
- package/dist/esm/src/index.d.ts +49 -0
- package/dist/esm/src/index.d.ts.map +1 -0
- package/dist/esm/src/index.js +79 -0
- package/dist/esm/src/index.js.map +1 -0
- package/dist/esm/src/interfaces/StatefulComponent.d.ts +72 -0
- package/dist/esm/src/interfaces/StatefulComponent.d.ts.map +1 -0
- package/dist/esm/src/interfaces/StatefulComponent.js +47 -0
- package/dist/esm/src/interfaces/StatefulComponent.js.map +1 -0
- package/dist/esm/src/name-contracts/ContractScanner.d.ts +61 -0
- package/dist/esm/src/name-contracts/ContractScanner.d.ts.map +1 -0
- package/dist/esm/src/name-contracts/ContractScanner.js +11 -0
- package/dist/esm/src/name-contracts/ContractScanner.js.map +1 -0
- package/dist/esm/src/name-contracts/RouteContractScanner.d.ts +30 -0
- package/dist/esm/src/name-contracts/RouteContractScanner.d.ts.map +1 -0
- package/dist/esm/src/name-contracts/RouteContractScanner.js +188 -0
- package/dist/esm/src/name-contracts/RouteContractScanner.js.map +1 -0
- package/dist/esm/src/name-contracts/index.d.ts +10 -0
- package/dist/esm/src/name-contracts/index.d.ts.map +1 -0
- package/dist/esm/src/name-contracts/index.js +10 -0
- package/dist/esm/src/name-contracts/index.js.map +1 -0
- package/dist/esm/src/names/createNames.d.ts +49 -0
- package/dist/esm/src/names/createNames.d.ts.map +1 -0
- package/dist/esm/src/names/createNames.js +81 -0
- package/dist/esm/src/names/createNames.js.map +1 -0
- package/dist/esm/src/react/hooks/useChatWithContext.d.ts +68 -0
- package/dist/esm/src/react/hooks/useChatWithContext.d.ts.map +1 -0
- package/dist/esm/src/react/hooks/useChatWithContext.js +218 -0
- package/dist/esm/src/react/hooks/useChatWithContext.js.map +1 -0
- package/dist/esm/src/react/index.d.ts +12 -0
- package/dist/esm/src/react/index.d.ts.map +1 -0
- package/dist/esm/src/react/index.js +21 -0
- package/dist/esm/src/react/index.js.map +1 -0
- package/dist/esm/src/react/useNavigationHandler.d.ts +42 -0
- package/dist/esm/src/react/useNavigationHandler.d.ts.map +1 -0
- package/dist/esm/src/react/useNavigationHandler.js +85 -0
- package/dist/esm/src/react/useNavigationHandler.js.map +1 -0
- package/dist/esm/src/react/usePersistedState.d.ts +13 -0
- package/dist/esm/src/react/usePersistedState.d.ts.map +1 -0
- package/dist/esm/src/react/usePersistedState.js +69 -0
- package/dist/esm/src/react/usePersistedState.js.map +1 -0
- package/dist/esm/src/react/useToolBinding.d.ts +8 -0
- package/dist/esm/src/react/useToolBinding.d.ts.map +1 -0
- package/dist/esm/src/react/useToolBinding.js +107 -0
- package/dist/esm/src/react/useToolBinding.js.map +1 -0
- package/dist/esm/src/routes/RouteContractGenerator.d.ts +37 -0
- package/dist/esm/src/routes/RouteContractGenerator.d.ts.map +1 -0
- package/dist/esm/src/routes/RouteContractGenerator.js +115 -0
- package/dist/esm/src/routes/RouteContractGenerator.js.map +1 -0
- package/dist/esm/src/routes/RouteContractsConfig.d.ts +93 -0
- package/dist/esm/src/routes/RouteContractsConfig.d.ts.map +1 -0
- package/dist/esm/src/routes/RouteContractsConfig.js +36 -0
- package/dist/esm/src/routes/RouteContractsConfig.js.map +1 -0
- package/dist/esm/src/routes/index.d.ts +13 -0
- package/dist/esm/src/routes/index.d.ts.map +1 -0
- package/dist/esm/src/routes/index.js +13 -0
- package/dist/esm/src/routes/index.js.map +1 -0
- package/dist/esm/src/routes/scanners/NameExtractor.d.ts +36 -0
- package/dist/esm/src/routes/scanners/NameExtractor.d.ts.map +1 -0
- package/dist/esm/src/routes/scanners/NameExtractor.js +156 -0
- package/dist/esm/src/routes/scanners/NameExtractor.js.map +1 -0
- package/dist/esm/src/routes/scanners/NextjsDynamicScanner.d.ts +35 -0
- package/dist/esm/src/routes/scanners/NextjsDynamicScanner.d.ts.map +1 -0
- package/dist/esm/src/routes/scanners/NextjsDynamicScanner.js +98 -0
- package/dist/esm/src/routes/scanners/NextjsDynamicScanner.js.map +1 -0
- package/dist/esm/src/routes/scanners/RouteScanner.d.ts +64 -0
- package/dist/esm/src/routes/scanners/RouteScanner.d.ts.map +1 -0
- package/dist/esm/src/routes/scanners/RouteScanner.js +9 -0
- package/dist/esm/src/routes/scanners/RouteScanner.js.map +1 -0
- package/dist/esm/src/storage/LocalStorageAdapter.d.ts +29 -0
- package/dist/esm/src/storage/LocalStorageAdapter.d.ts.map +1 -0
- package/dist/esm/src/storage/LocalStorageAdapter.js +83 -0
- package/dist/esm/src/storage/LocalStorageAdapter.js.map +1 -0
- package/dist/esm/src/storage/StateManager.d.ts +175 -0
- package/dist/esm/src/storage/StateManager.d.ts.map +1 -0
- package/dist/esm/src/storage/StateManager.js +295 -0
- package/dist/esm/src/storage/StateManager.js.map +1 -0
- package/dist/esm/src/storage/StorageAdapter.d.ts +94 -0
- package/dist/esm/src/storage/StorageAdapter.d.ts.map +1 -0
- package/dist/esm/src/storage/StorageAdapter.js +158 -0
- package/dist/esm/src/storage/StorageAdapter.js.map +1 -0
- package/dist/esm/src/storage/index.d.ts +12 -0
- package/dist/esm/src/storage/index.d.ts.map +1 -0
- package/dist/esm/src/storage/index.js +17 -0
- package/dist/esm/src/storage/index.js.map +1 -0
- package/dist/esm/src/testing/BrowserStateInjection.d.ts +74 -0
- package/dist/esm/src/testing/BrowserStateInjection.d.ts.map +1 -0
- package/dist/esm/src/testing/BrowserStateInjection.js +126 -0
- package/dist/esm/src/testing/BrowserStateInjection.js.map +1 -0
- package/dist/esm/src/testing/ComponentStateHelpers.d.ts +121 -0
- package/dist/esm/src/testing/ComponentStateHelpers.d.ts.map +1 -0
- package/dist/esm/src/testing/ComponentStateHelpers.js +190 -0
- package/dist/esm/src/testing/ComponentStateHelpers.js.map +1 -0
- package/dist/esm/src/testing/GherkinParser.d.ts +87 -0
- package/dist/esm/src/testing/GherkinParser.d.ts.map +1 -0
- package/dist/esm/src/testing/GherkinParser.js +248 -0
- package/dist/esm/src/testing/GherkinParser.js.map +1 -0
- package/dist/esm/src/testing/PlaywrightStateHelpers.d.ts +163 -0
- package/dist/esm/src/testing/PlaywrightStateHelpers.d.ts.map +1 -0
- package/dist/esm/src/testing/PlaywrightStateHelpers.js +242 -0
- package/dist/esm/src/testing/PlaywrightStateHelpers.js.map +1 -0
- package/dist/esm/src/testing/TestRunner.d.ts +50 -0
- package/dist/esm/src/testing/TestRunner.d.ts.map +1 -0
- package/dist/esm/src/testing/TestRunner.js +121 -0
- package/dist/esm/src/testing/TestRunner.js.map +1 -0
- package/dist/esm/src/testing/index.d.ts +12 -0
- package/dist/esm/src/testing/index.d.ts.map +1 -0
- package/dist/esm/src/testing/index.js +25 -0
- package/dist/esm/src/testing/index.js.map +1 -0
- package/dist/esm/src/testing/selectors.d.ts +65 -0
- package/dist/esm/src/testing/selectors.d.ts.map +1 -0
- package/dist/esm/src/testing/selectors.js +76 -0
- package/dist/esm/src/testing/selectors.js.map +1 -0
- package/dist/esm/src/tools/SystemTools.d.ts +139 -0
- package/dist/esm/src/tools/SystemTools.d.ts.map +1 -0
- package/dist/esm/src/tools/SystemTools.js +258 -0
- package/dist/esm/src/tools/SystemTools.js.map +1 -0
- package/dist/esm/src/types/ClassifiedTool.d.ts +61 -0
- package/dist/esm/src/types/ClassifiedTool.d.ts.map +1 -0
- package/dist/esm/src/types/ClassifiedTool.js +47 -0
- package/dist/esm/src/types/ClassifiedTool.js.map +1 -0
- package/dist/esm/src/types/ComponentState.d.ts +207 -0
- package/dist/esm/src/types/ComponentState.d.ts.map +1 -0
- package/dist/esm/src/types/ComponentState.js +25 -0
- package/dist/esm/src/types/ComponentState.js.map +1 -0
- package/dist/esm/src/types/DiscoverableToolProvider.d.ts +59 -0
- package/dist/esm/src/types/DiscoverableToolProvider.d.ts.map +1 -0
- package/dist/esm/src/types/DiscoverableToolProvider.js +8 -0
- package/dist/esm/src/types/DiscoverableToolProvider.js.map +1 -0
- package/dist/esm/src/types/ExposureState.d.ts +75 -0
- package/dist/esm/src/types/ExposureState.d.ts.map +1 -0
- package/dist/esm/src/types/ExposureState.js +22 -0
- package/dist/esm/src/types/ExposureState.js.map +1 -0
- package/dist/esm/src/types/NavigationGraph.d.ts +98 -0
- package/dist/esm/src/types/NavigationGraph.d.ts.map +1 -0
- package/dist/esm/src/types/NavigationGraph.js +7 -0
- package/dist/esm/src/types/NavigationGraph.js.map +1 -0
- package/dist/esm/src/types/OperationType.d.ts +45 -0
- package/dist/esm/src/types/OperationType.d.ts.map +1 -0
- package/dist/esm/src/types/OperationType.js +46 -0
- package/dist/esm/src/types/OperationType.js.map +1 -0
- package/dist/esm/src/types/StateManagers.d.ts +35 -0
- package/dist/esm/src/types/StateManagers.d.ts.map +1 -0
- package/dist/esm/src/types/StateManagers.js +36 -0
- package/dist/esm/src/types/StateManagers.js.map +1 -0
- package/dist/esm/src/types/Tool.d.ts +162 -0
- package/dist/esm/src/types/Tool.d.ts.map +1 -0
- package/dist/esm/src/types/Tool.js +38 -0
- package/dist/esm/src/types/Tool.js.map +1 -0
- package/dist/esm/src/types/ToolPermissions.d.ts +73 -0
- package/dist/esm/src/types/ToolPermissions.d.ts.map +1 -0
- package/dist/esm/src/types/ToolPermissions.js +51 -0
- package/dist/esm/src/types/ToolPermissions.js.map +1 -0
- package/dist/esm/src/types/ToolResult.d.ts +129 -0
- package/dist/esm/src/types/ToolResult.d.ts.map +1 -0
- package/dist/esm/src/types/ToolResult.js +22 -0
- package/dist/esm/src/types/ToolResult.js.map +1 -0
- package/dist/esm/src/types/index.d.ts +47 -0
- package/dist/esm/src/types/index.d.ts.map +1 -0
- package/dist/esm/src/types/index.js +42 -0
- package/dist/esm/src/types/index.js.map +1 -0
- package/dist/esm/src/ui/react/chat/ChatBubble.d.ts +23 -0
- package/dist/esm/src/ui/react/chat/ChatBubble.d.ts.map +1 -0
- package/dist/esm/src/ui/react/chat/ChatBubble.js +184 -0
- package/dist/esm/src/ui/react/chat/ChatBubble.js.map +1 -0
- package/package.json +118 -0
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* useNavigationHandler - React Hook for Automatic Navigation Setup
|
|
4
|
+
*
|
|
5
|
+
* Single-line hook that sets up navigation for any page.
|
|
6
|
+
* Uses NavigationGraph to automatically resolve routes from container definitions.
|
|
7
|
+
*
|
|
8
|
+
* This eliminates the need for manual route maps in every page component.
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
exports.useNavigationHandler = useNavigationHandler;
|
|
12
|
+
const react_1 = require("react");
|
|
13
|
+
const NavigationGraph_1 = require("../background/navigation/NavigationGraph");
|
|
14
|
+
/**
|
|
15
|
+
* Set up automatic navigation handler for the current page
|
|
16
|
+
*
|
|
17
|
+
* This hook:
|
|
18
|
+
* 1. Gets routes from NavigationGraph (populated by container definitions)
|
|
19
|
+
* 2. Creates a handler that resolves page names → routes
|
|
20
|
+
* 3. Registers the handler with NavigationGraph
|
|
21
|
+
* 4. Supports dynamic routes (e.g., "blog/post-slug")
|
|
22
|
+
*
|
|
23
|
+
* @param router - Next.js router or any router with a `push` method
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* ```typescript
|
|
27
|
+
* import { useRouter } from 'next/router';
|
|
28
|
+
* import { useNavigationHandler } from '@supernal-interface/core/react';
|
|
29
|
+
*
|
|
30
|
+
* export default function MyPage() {
|
|
31
|
+
* const router = useRouter();
|
|
32
|
+
* useNavigationHandler(router); // ← ONE LINE!
|
|
33
|
+
*
|
|
34
|
+
* return <div>...</div>;
|
|
35
|
+
* }
|
|
36
|
+
* ```
|
|
37
|
+
*
|
|
38
|
+
* @example
|
|
39
|
+
* ```typescript
|
|
40
|
+
* // Without a router (uses window.location as fallback)
|
|
41
|
+
* useNavigationHandler();
|
|
42
|
+
* ```
|
|
43
|
+
*/
|
|
44
|
+
function useNavigationHandler(router) {
|
|
45
|
+
(0, react_1.useEffect)(() => {
|
|
46
|
+
const graph = NavigationGraph_1.NavigationGraph.getInstance();
|
|
47
|
+
const handler = (pageNameOrRoute) => {
|
|
48
|
+
const pageName = typeof pageNameOrRoute === 'string' ? pageNameOrRoute : pageNameOrRoute?.name || pageNameOrRoute?.path;
|
|
49
|
+
if (!pageName)
|
|
50
|
+
return;
|
|
51
|
+
console.log(`🗺️ [Navigation] Request: ${pageName}`);
|
|
52
|
+
// Use NavigationGraph to resolve route
|
|
53
|
+
let route = graph.getRouteByName(pageName);
|
|
54
|
+
if (!route) {
|
|
55
|
+
console.warn(`⚠️ [Navigation] No exact route found for: ${pageName}`);
|
|
56
|
+
// Try treating as a path (e.g., "blog/type-safe" → "/blog/type-safe")
|
|
57
|
+
if (pageName.includes('/')) {
|
|
58
|
+
const routePath = pageName.startsWith('/') ? pageName : `/${pageName}`;
|
|
59
|
+
console.log(`🗺️ [Navigation] Attempting dynamic path: ${routePath}`);
|
|
60
|
+
// Navigate using provided router or fallback to window.location
|
|
61
|
+
if (router?.push) {
|
|
62
|
+
router.push(routePath);
|
|
63
|
+
}
|
|
64
|
+
else if (typeof window !== 'undefined') {
|
|
65
|
+
window.location.href = routePath;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
// Extract path from RouteInfo
|
|
71
|
+
const routePath = route.path || route.name || pageName;
|
|
72
|
+
console.log(`🗺️ [Navigation] Resolved: ${pageName} → ${routePath}`);
|
|
73
|
+
// Navigate using provided router or fallback to window.location
|
|
74
|
+
if (router?.push) {
|
|
75
|
+
router.push(routePath);
|
|
76
|
+
}
|
|
77
|
+
else if (typeof window !== 'undefined') {
|
|
78
|
+
window.location.href = routePath;
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
graph.setNavigationHandler(handler);
|
|
82
|
+
return () => {
|
|
83
|
+
// Clean up handler on unmount
|
|
84
|
+
graph.setNavigationHandler(() => { });
|
|
85
|
+
};
|
|
86
|
+
}, [router]);
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=useNavigationHandler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useNavigationHandler.js","sourceRoot":"","sources":["../../../../src/react/useNavigationHandler.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG;;AAmCH,oDAoDC;AArFD,iCAAkC;AAClC,8EAA2E;AAE3E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,SAAgB,oBAAoB,CAClC,MAAyC;IAEzC,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,MAAM,KAAK,GAAG,iCAAe,CAAC,WAAW,EAAE,CAAC;QAE5C,MAAM,OAAO,GAAG,CAAC,eAA6B,EAAE,EAAE;YAChD,MAAM,QAAQ,GAAG,OAAO,eAAe,KAAK,QAAQ,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,EAAE,IAAI,IAAI,eAAe,EAAE,IAAI,CAAC;YACxH,IAAI,CAAC,QAAQ;gBAAE,OAAO;YAEtB,OAAO,CAAC,GAAG,CAAC,8BAA8B,QAAQ,EAAE,CAAC,CAAC;YAEtD,uCAAuC;YACvC,IAAI,KAAK,GAAG,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YAE3C,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,OAAO,CAAC,IAAI,CAAC,8CAA8C,QAAQ,EAAE,CAAC,CAAC;gBAEvE,sEAAsE;gBACtE,IAAI,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;oBAC3B,MAAM,SAAS,GAAG,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,QAAQ,EAAE,CAAC;oBACvE,OAAO,CAAC,GAAG,CAAC,8CAA8C,SAAS,EAAE,CAAC,CAAC;oBAEvE,gEAAgE;oBAChE,IAAI,MAAM,EAAE,IAAI,EAAE,CAAC;wBACjB,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;oBACzB,CAAC;yBAAM,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;wBACzC,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,SAAS,CAAC;oBACnC,CAAC;gBACH,CAAC;gBACD,OAAO;YACT,CAAC;YAED,8BAA8B;YAC9B,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,IAAI,QAAQ,CAAC;YACvD,OAAO,CAAC,GAAG,CAAC,+BAA+B,QAAQ,MAAM,SAAS,EAAE,CAAC,CAAC;YAEtE,gEAAgE;YAChE,IAAI,MAAM,EAAE,IAAI,EAAE,CAAC;gBACjB,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACzB,CAAC;iBAAM,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;gBACzC,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,SAAS,CAAC;YACnC,CAAC;QACH,CAAC,CAAC;QAEF,KAAK,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;QAEpC,OAAO,GAAG,EAAE;YACV,8BAA8B;YAC9B,KAAK,CAAC,oBAAoB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;QACvC,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;AACf,CAAC"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* usePersistedState - SSR-safe state persistence hook
|
|
4
|
+
*
|
|
5
|
+
* Like useState, but persists using StateManager and handles hydration properly.
|
|
6
|
+
* Uses the storage adapter pattern for pluggable persistence.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```tsx
|
|
10
|
+
* const [count, setCount] = usePersistedState('my-count', 0);
|
|
11
|
+
* ```
|
|
12
|
+
*/
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.usePersistedState = usePersistedState;
|
|
15
|
+
const react_1 = require("react");
|
|
16
|
+
const StateManager_1 = require("../storage/StateManager");
|
|
17
|
+
const LocalStorageAdapter_1 = require("../storage/LocalStorageAdapter");
|
|
18
|
+
const StateManagers_1 = require("../types/StateManagers");
|
|
19
|
+
// Get or create a singleton StateManager for browser usage
|
|
20
|
+
let browserStateManager = null;
|
|
21
|
+
function getBrowserStateManager() {
|
|
22
|
+
if (!browserStateManager && typeof window !== 'undefined') {
|
|
23
|
+
browserStateManager = StateManager_1.StateManager.getInstance(StateManagers_1.StateManagers.SupernalCoreV1, new LocalStorageAdapter_1.LocalStorageAdapter());
|
|
24
|
+
}
|
|
25
|
+
return browserStateManager;
|
|
26
|
+
}
|
|
27
|
+
function usePersistedState(key, defaultValue) {
|
|
28
|
+
// Always start with default value (matches SSR)
|
|
29
|
+
const [state, setState] = (0, react_1.useState)(defaultValue);
|
|
30
|
+
const [isHydrated, setIsHydrated] = (0, react_1.useState)(false);
|
|
31
|
+
// Hydrate from storage after mount (client-only)
|
|
32
|
+
(0, react_1.useEffect)(() => {
|
|
33
|
+
if (typeof window === 'undefined')
|
|
34
|
+
return;
|
|
35
|
+
const stateManager = getBrowserStateManager();
|
|
36
|
+
(async () => {
|
|
37
|
+
try {
|
|
38
|
+
await stateManager.initialize();
|
|
39
|
+
const stored = await stateManager.get(key);
|
|
40
|
+
if (stored && 'value' in stored) {
|
|
41
|
+
setState(stored.value);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
catch (e) {
|
|
45
|
+
// eslint-disable-next-line no-console
|
|
46
|
+
console.warn(`[usePersistedState] Failed to load "${key}":`, e);
|
|
47
|
+
}
|
|
48
|
+
setIsHydrated(true);
|
|
49
|
+
})();
|
|
50
|
+
}, [key]);
|
|
51
|
+
// Persist to storage on changes (but only after hydration)
|
|
52
|
+
(0, react_1.useEffect)(() => {
|
|
53
|
+
if (!isHydrated || typeof window === 'undefined')
|
|
54
|
+
return;
|
|
55
|
+
const stateManager = getBrowserStateManager();
|
|
56
|
+
(async () => {
|
|
57
|
+
try {
|
|
58
|
+
await stateManager.set(key, {
|
|
59
|
+
kind: 'ui-component',
|
|
60
|
+
componentId: key,
|
|
61
|
+
value: state
|
|
62
|
+
}); // Type assertion needed as we're adding custom 'value' field
|
|
63
|
+
}
|
|
64
|
+
catch (e) {
|
|
65
|
+
// eslint-disable-next-line no-console
|
|
66
|
+
console.warn(`[usePersistedState] Failed to save "${key}":`, e);
|
|
67
|
+
}
|
|
68
|
+
})();
|
|
69
|
+
}, [key, state, isHydrated]);
|
|
70
|
+
return [state, setState];
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=usePersistedState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usePersistedState.js","sourceRoot":"","sources":["../../../../src/react/usePersistedState.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;AAqBH,8CAmDC;AAtED,iCAA4C;AAC5C,0DAAuD;AACvD,wEAAqE;AACrE,0DAAuD;AAGvD,2DAA2D;AAC3D,IAAI,mBAAmB,GAAwB,IAAI,CAAC;AAEpD,SAAS,sBAAsB;IAC7B,IAAI,CAAC,mBAAmB,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;QAC1D,mBAAmB,GAAG,2BAAY,CAAC,WAAW,CAC5C,6BAAa,CAAC,cAAc,EAC5B,IAAI,yCAAmB,EAAE,CAC1B,CAAC;IACJ,CAAC;IACD,OAAO,mBAAoB,CAAC;AAC9B,CAAC;AAED,SAAgB,iBAAiB,CAC/B,GAAW,EACX,YAAe;IAEf,gDAAgD;IAChD,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAI,YAAY,CAAC,CAAC;IACpD,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAC;IAEpD,iDAAiD;IACjD,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,OAAO,MAAM,KAAK,WAAW;YAAE,OAAO;QAE1C,MAAM,YAAY,GAAG,sBAAsB,EAAE,CAAC;QAE9C,CAAC,KAAK,IAAI,EAAE;YACV,IAAI,CAAC;gBACH,MAAM,YAAY,CAAC,UAAU,EAAE,CAAC;gBAChC,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,GAAG,CAAgC,GAAG,CAAC,CAAC;gBAC1E,IAAI,MAAM,IAAI,OAAO,IAAI,MAAM,EAAE,CAAC;oBAChC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBACzB,CAAC;YACH,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,sCAAsC;gBACtC,OAAO,CAAC,IAAI,CAAC,uCAAuC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC;YAED,aAAa,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC,CAAC,EAAE,CAAC;IACP,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAEV,2DAA2D;IAC3D,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,CAAC,UAAU,IAAI,OAAO,MAAM,KAAK,WAAW;YAAE,OAAO;QAEzD,MAAM,YAAY,GAAG,sBAAsB,EAAE,CAAC;QAE9C,CAAC,KAAK,IAAI,EAAE;YACV,IAAI,CAAC;gBACH,MAAM,YAAY,CAAC,GAAG,CAAgC,GAAG,EAAE;oBACzD,IAAI,EAAE,cAAc;oBACpB,WAAW,EAAE,GAAG;oBAChB,KAAK,EAAE,KAAK;iBACN,CAAC,CAAC,CAAE,6DAA6D;YAC3E,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,sCAAsC;gBACtC,OAAO,CAAC,IAAI,CAAC,uCAAuC,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC;YAClE,CAAC;QACH,CAAC,CAAC,EAAE,CAAC;IACP,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC;IAE7B,OAAO,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;AAC3B,CAAC"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* useToolBinding Hook
|
|
4
|
+
* Auto-wires DOM elements to @Tool decorators based on data-testid
|
|
5
|
+
*
|
|
6
|
+
* Simplified version - tools receive raw events and handle their own logic
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.useToolBinding = useToolBinding;
|
|
10
|
+
const react_1 = require("react");
|
|
11
|
+
const ToolRegistry_1 = require("../background/registry/ToolRegistry");
|
|
12
|
+
function useToolBinding(containerRef, containerTestId, instanceId) {
|
|
13
|
+
(0, react_1.useEffect)(() => {
|
|
14
|
+
if (!containerRef.current)
|
|
15
|
+
return;
|
|
16
|
+
const storageKey = instanceId ? `${containerTestId}:${instanceId}` : containerTestId;
|
|
17
|
+
// 1. Register instance for duplicate detection
|
|
18
|
+
try {
|
|
19
|
+
ToolRegistry_1.ToolRegistry.registerInstance(storageKey, containerRef.current);
|
|
20
|
+
}
|
|
21
|
+
catch (error) {
|
|
22
|
+
console.error(`[useToolBinding] Instance already exists: ${storageKey}`, error);
|
|
23
|
+
return; // Don't wire up duplicate instances
|
|
24
|
+
}
|
|
25
|
+
// 2. Find all elements with data-testid within container (and the container itself)
|
|
26
|
+
const elements = [];
|
|
27
|
+
// Check if container itself has data-testid
|
|
28
|
+
if (containerRef.current.hasAttribute('data-testid')) {
|
|
29
|
+
elements.push(containerRef.current);
|
|
30
|
+
}
|
|
31
|
+
// Find children with data-testid
|
|
32
|
+
const childElements = containerRef.current.querySelectorAll('[data-testid]');
|
|
33
|
+
elements.push(...Array.from(childElements));
|
|
34
|
+
const handlers = [];
|
|
35
|
+
elements.forEach((element) => {
|
|
36
|
+
const testId = element.getAttribute('data-testid');
|
|
37
|
+
if (!testId)
|
|
38
|
+
return;
|
|
39
|
+
// 3. Find matching tool from registry
|
|
40
|
+
const tool = ToolRegistry_1.ToolRegistry.findToolByElementId(testId);
|
|
41
|
+
if (!tool || !tool.method) {
|
|
42
|
+
console.warn(`[useToolBinding] Tool not found or has no method for elementId: ${testId}`);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
// Note: instance may not be set yet (lazy initialization)
|
|
46
|
+
// We'll check for it when the event fires
|
|
47
|
+
// 4. Create handler that extracts values from events and calls tool
|
|
48
|
+
const handler = async (event) => {
|
|
49
|
+
if (!tool.method || !tool.instance) {
|
|
50
|
+
console.warn(`[useToolBinding] Tool ${tool.name} missing method or instance`);
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
// Extract value from event based on element type
|
|
54
|
+
let value;
|
|
55
|
+
const target = event.target;
|
|
56
|
+
if (target instanceof HTMLInputElement) {
|
|
57
|
+
if (target.type === 'checkbox') {
|
|
58
|
+
value = target.checked;
|
|
59
|
+
}
|
|
60
|
+
else if (target.type === 'radio') {
|
|
61
|
+
value = target.value;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
value = target.value;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
else if (target instanceof HTMLSelectElement) {
|
|
68
|
+
value = target.value;
|
|
69
|
+
}
|
|
70
|
+
else if (target instanceof HTMLTextAreaElement) {
|
|
71
|
+
value = target.value;
|
|
72
|
+
}
|
|
73
|
+
// For buttons and other elements, no value needed (void call)
|
|
74
|
+
const options = {
|
|
75
|
+
// Storage will be added in next step
|
|
76
|
+
// For now, tools get extracted value
|
|
77
|
+
};
|
|
78
|
+
try {
|
|
79
|
+
// Call the actual decorated method with extracted value
|
|
80
|
+
const result = value !== undefined
|
|
81
|
+
? await tool.method.call(tool.instance, value, options)
|
|
82
|
+
: await tool.method.call(tool.instance, options);
|
|
83
|
+
console.log(`[useToolBinding] Tool ${tool.name} executed successfully`, result);
|
|
84
|
+
}
|
|
85
|
+
catch (error) {
|
|
86
|
+
console.error(`[useToolBinding] Tool execution failed: ${tool.name}`, error);
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
// 5. Wire up with appropriate event type
|
|
90
|
+
// Use tool's actionType if specified, otherwise infer from element
|
|
91
|
+
let eventType = tool.actionType || 'click';
|
|
92
|
+
if (!tool.actionType) {
|
|
93
|
+
if (element instanceof HTMLInputElement || element instanceof HTMLSelectElement || element instanceof HTMLTextAreaElement) {
|
|
94
|
+
eventType = 'change';
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
console.log(`[useToolBinding] Wiring ${testId} with event: ${eventType}`);
|
|
98
|
+
element.addEventListener(eventType, handler);
|
|
99
|
+
handlers.push({ element, event: eventType, handler });
|
|
100
|
+
});
|
|
101
|
+
// 6. Cleanup
|
|
102
|
+
return () => {
|
|
103
|
+
handlers.forEach(({ element, event, handler }) => {
|
|
104
|
+
element.removeEventListener(event, handler);
|
|
105
|
+
});
|
|
106
|
+
ToolRegistry_1.ToolRegistry.unregisterInstance(storageKey);
|
|
107
|
+
};
|
|
108
|
+
}, [containerRef, containerTestId, instanceId]);
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=useToolBinding.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useToolBinding.js","sourceRoot":"","sources":["../../../../src/react/useToolBinding.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Generated from: 2025-12-28-simple-name-extraction.md
|
|
3
|
+
// Generated on: 2025-12-28
|
|
4
|
+
// DO NOT EDIT - Regenerate from documentation if changes needed
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.RouteContractGenerator = void 0;
|
|
7
|
+
/**
|
|
8
|
+
* Generates type-safe route contracts with structured output.
|
|
9
|
+
* Groups routes by category (Views, API, etc.) and HTTP methods.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```typescript
|
|
13
|
+
* import { RouteContractGenerator } from '@supernal/interface-core/routes';
|
|
14
|
+
*
|
|
15
|
+
* const generator = new RouteContractGenerator();
|
|
16
|
+
* const scanResult = await scanner.scan();
|
|
17
|
+
*
|
|
18
|
+
* // Generate contracts
|
|
19
|
+
* const content = generator.generate(scanResult);
|
|
20
|
+
*
|
|
21
|
+
* // Generated output:
|
|
22
|
+
* // export const Routes = {
|
|
23
|
+
* // Views: {
|
|
24
|
+
* // Overview: '/:repo/:branch/overview'
|
|
25
|
+
* // },
|
|
26
|
+
* // API: {
|
|
27
|
+
* // Users: {
|
|
28
|
+
* // GET: '/api/users',
|
|
29
|
+
* // POST: '/api/users'
|
|
30
|
+
* // }
|
|
31
|
+
* // }
|
|
32
|
+
* // } as const;
|
|
33
|
+
* ```
|
|
34
|
+
*/
|
|
35
|
+
class RouteContractGenerator {
|
|
36
|
+
generate(scanResult) {
|
|
37
|
+
// Group routes by category
|
|
38
|
+
const grouped = this.groupRoutes(scanResult.routes);
|
|
39
|
+
return `
|
|
40
|
+
// Generated from route scanning
|
|
41
|
+
// DO NOT EDIT - Regenerate with: sc routes generate
|
|
42
|
+
|
|
43
|
+
${this.generateViews(grouped.view)}
|
|
44
|
+
${this.generateAPI(grouped.api)}
|
|
45
|
+
|
|
46
|
+
// Helper to build route with params
|
|
47
|
+
// Supports both string patterns and route objects with metadata
|
|
48
|
+
export function buildRoute(
|
|
49
|
+
route: string | { pattern: string; [key: string]: any },
|
|
50
|
+
params: Record<string, string>
|
|
51
|
+
): string {
|
|
52
|
+
const pattern = typeof route === 'string' ? route : route.pattern;
|
|
53
|
+
let result = pattern;
|
|
54
|
+
for (const [key, value] of Object.entries(params)) {
|
|
55
|
+
result = result.replace(\`:$\{key}\`, value);
|
|
56
|
+
}
|
|
57
|
+
return result;
|
|
58
|
+
}
|
|
59
|
+
`.trim();
|
|
60
|
+
}
|
|
61
|
+
groupRoutes(routes) {
|
|
62
|
+
const grouped = {};
|
|
63
|
+
routes.forEach(route => {
|
|
64
|
+
const category = route.metadata?.category || 'other';
|
|
65
|
+
if (!grouped[category])
|
|
66
|
+
grouped[category] = [];
|
|
67
|
+
grouped[category].push(route);
|
|
68
|
+
});
|
|
69
|
+
return grouped;
|
|
70
|
+
}
|
|
71
|
+
generateViews(views = []) {
|
|
72
|
+
if (views.length === 0)
|
|
73
|
+
return '';
|
|
74
|
+
const entries = views.map(view => {
|
|
75
|
+
const name = this.toPascalCase(view.id.replace('view-', ''));
|
|
76
|
+
return ` ${name}: '${view.pattern}',`;
|
|
77
|
+
}).join('\n');
|
|
78
|
+
return `
|
|
79
|
+
export const Routes = {
|
|
80
|
+
Views: {
|
|
81
|
+
${entries}
|
|
82
|
+
},
|
|
83
|
+
`;
|
|
84
|
+
}
|
|
85
|
+
generateAPI(apis = []) {
|
|
86
|
+
if (apis.length === 0)
|
|
87
|
+
return '';
|
|
88
|
+
const entries = apis.map(api => {
|
|
89
|
+
const name = this.toPascalCase(api.id.replace('api-', ''));
|
|
90
|
+
const methods = api.metadata?.methods;
|
|
91
|
+
const params = api.params;
|
|
92
|
+
// Generate route object with metadata
|
|
93
|
+
if (methods || params.length > 0) {
|
|
94
|
+
const parts = [
|
|
95
|
+
`pattern: '${api.pattern}'`,
|
|
96
|
+
methods && methods.length > 0 ? `methods: [${methods.map(m => `'${m}'`).join(', ')}] as const` : null,
|
|
97
|
+
params.length > 0 ? `params: [${params.map(p => `'${p}'`).join(', ')}] as const` : null,
|
|
98
|
+
].filter(Boolean);
|
|
99
|
+
return ` ${name}: {\n ${parts.join(',\n ')}\n },`;
|
|
100
|
+
}
|
|
101
|
+
// Fallback: simple string (for backward compatibility)
|
|
102
|
+
return ` ${name}: '${api.pattern}',`;
|
|
103
|
+
}).join('\n');
|
|
104
|
+
return `
|
|
105
|
+
API: {
|
|
106
|
+
${entries}
|
|
107
|
+
},
|
|
108
|
+
} as const;
|
|
109
|
+
`;
|
|
110
|
+
}
|
|
111
|
+
toPascalCase(str) {
|
|
112
|
+
return str
|
|
113
|
+
.split(/[-_]/)
|
|
114
|
+
.map(part => part.charAt(0).toUpperCase() + part.slice(1))
|
|
115
|
+
.join('');
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
exports.RouteContractGenerator = RouteContractGenerator;
|
|
119
|
+
//# sourceMappingURL=RouteContractGenerator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RouteContractGenerator.js","sourceRoot":"","sources":["../../../../src/routes/RouteContractGenerator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Generated from: 2025-12-27-implementation.md
|
|
3
|
+
// Generated on: 2025-12-28
|
|
4
|
+
// DO NOT EDIT - Regenerate from documentation if changes needed
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.exampleNextjsConfig = void 0;
|
|
7
|
+
/**
|
|
8
|
+
* Example config for Next.js 14 app with dynamic routing
|
|
9
|
+
*/
|
|
10
|
+
exports.exampleNextjsConfig = {
|
|
11
|
+
routingSystem: 'nextjs-dynamic',
|
|
12
|
+
scanPaths: {
|
|
13
|
+
routes: ['src/app'],
|
|
14
|
+
configs: ['src/lib/routing'],
|
|
15
|
+
components: ['src/components/views'],
|
|
16
|
+
},
|
|
17
|
+
output: {
|
|
18
|
+
contractsPath: 'src/lib/routing/Routes.ts',
|
|
19
|
+
testUtilsPath: 'tests/utils/routes.ts',
|
|
20
|
+
moduleFormat: 'esm',
|
|
21
|
+
},
|
|
22
|
+
generation: {
|
|
23
|
+
includeJsDocs: true,
|
|
24
|
+
includeValidation: true,
|
|
25
|
+
defaults: {
|
|
26
|
+
repo: 'default-repo',
|
|
27
|
+
branch: 'main',
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
migration: {
|
|
31
|
+
detectPatterns: [
|
|
32
|
+
'page\\.goto\\([\'"`](.+?)[\'"`]\\)',
|
|
33
|
+
'navigate\\([\'"`](.+?)[\'"`]\\)',
|
|
34
|
+
],
|
|
35
|
+
filePatterns: ['**/*.spec.ts', '**/*.test.ts'],
|
|
36
|
+
dryRun: false,
|
|
37
|
+
},
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=RouteContractsConfig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RouteContractsConfig.js","sourceRoot":"","sources":["../../../../src/routes/RouteContractsConfig.ts"],"names":[],"mappings":";AAAA,+CAA+C;AAC/C,2BAA2B;AAC3B,gEAAgE;;;AA8GhE;;GAEG;AACU,QAAA,mBAAmB,GAAyB;IACvD,aAAa,EAAE,gBAAgB;IAC/B,SAAS,EAAE;QACT,MAAM,EAAE,CAAC,SAAS,CAAC;QACnB,OAAO,EAAE,CAAC,iBAAiB,CAAC;QAC5B,UAAU,EAAE,CAAC,sBAAsB,CAAC;KACrC;IACD,MAAM,EAAE;QACN,aAAa,EAAE,2BAA2B;QAC1C,aAAa,EAAE,uBAAuB;QACtC,YAAY,EAAE,KAAK;KACpB;IACD,UAAU,EAAE;QACV,aAAa,EAAE,IAAI;QACnB,iBAAiB,EAAE,IAAI;QACvB,QAAQ,EAAE;YACR,IAAI,EAAE,cAAc;YACpB,MAAM,EAAE,MAAM;SACf;KACF;IACD,SAAS,EAAE;QACT,cAAc,EAAE;YACd,oCAAoC;YACpC,iCAAiC;SAClC;QACD,YAAY,EAAE,CAAC,cAAc,EAAE,cAAc,CAAC;QAC9C,MAAM,EAAE,KAAK;KACd;CACF,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Route Scanning System
|
|
4
|
+
*
|
|
5
|
+
* Scans Next.js routes (App Router + Pages Router) and generates
|
|
6
|
+
* type-safe route contracts with HTTP method extraction.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.RouteContractGenerator = exports.NameExtractor = exports.NextjsDynamicScanner = exports.RouteScanner = void 0;
|
|
10
|
+
// Scanners
|
|
11
|
+
var RouteScanner_1 = require("./scanners/RouteScanner");
|
|
12
|
+
Object.defineProperty(exports, "RouteScanner", { enumerable: true, get: function () { return RouteScanner_1.RouteScanner; } });
|
|
13
|
+
var NextjsDynamicScanner_1 = require("./scanners/NextjsDynamicScanner");
|
|
14
|
+
Object.defineProperty(exports, "NextjsDynamicScanner", { enumerable: true, get: function () { return NextjsDynamicScanner_1.NextjsDynamicScanner; } });
|
|
15
|
+
var NameExtractor_1 = require("./scanners/NameExtractor");
|
|
16
|
+
Object.defineProperty(exports, "NameExtractor", { enumerable: true, get: function () { return NameExtractor_1.NameExtractor; } });
|
|
17
|
+
// Generation
|
|
18
|
+
var RouteContractGenerator_1 = require("./RouteContractGenerator");
|
|
19
|
+
Object.defineProperty(exports, "RouteContractGenerator", { enumerable: true, get: function () { return RouteContractGenerator_1.RouteContractGenerator; } });
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/routes/index.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AAEH,WAAW;AACX,wDAAuD;AAA9C,4GAAA,YAAY,OAAA;AAGrB,wEAAuE;AAA9D,4HAAA,oBAAoB,OAAA;AAC7B,0DAAyD;AAAhD,8GAAA,aAAa,OAAA;AAEtB,aAAa;AACb,mEAAkE;AAAzD,gIAAA,sBAAsB,OAAA"}
|