@contractspec/bundle.library 3.8.9 → 3.8.11
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/.turbo/turbo-build.log +606 -594
- package/CHANGELOG.md +68 -0
- package/dist/application/context-storage/index.js +1 -28
- package/dist/application/index.js +13 -2133
- package/dist/application/mcp/cliMcp.js +4 -452
- package/dist/application/mcp/common.js +1 -193
- package/dist/application/mcp/contractsMcp.js +2 -549
- package/dist/application/mcp/contractsMcpResources.js +2 -123
- package/dist/application/mcp/contractsMcpTools.js +1 -199
- package/dist/application/mcp/docsMcp.catalog.js +3 -381
- package/dist/application/mcp/docsMcp.data.js +1 -147
- package/dist/application/mcp/docsMcp.js +6 -1039
- package/dist/application/mcp/docsMcp.prompts.js +6 -521
- package/dist/application/mcp/docsMcp.reference.js +3 -235
- package/dist/application/mcp/docsMcp.resources.js +3 -519
- package/dist/application/mcp/docsMcp.tools.js +3 -518
- package/dist/application/mcp/index.js +13 -2106
- package/dist/application/mcp/internalMcp.js +2 -410
- package/dist/application/mcp/normalizeMcpRequest.js +1 -21
- package/dist/application/mcp/providerRankingMcp.js +1 -530
- package/dist/bundles/LibraryBundle.js +1 -138
- package/dist/bundles/index.js +1 -138
- package/dist/components/docs/DocsIndexPage.js +2 -912
- package/dist/components/docs/advanced/AdvancedMCPPage.js +4 -271
- package/dist/components/docs/advanced/AdvancedOverlayEditorPage.js +1 -107
- package/dist/components/docs/advanced/AdvancedRenderersPage.js +2 -118
- package/dist/components/docs/advanced/AdvancedSpecExperimentsPage.js +4 -92
- package/dist/components/docs/advanced/AdvancedTelemetryPage.js +2 -373
- package/dist/components/docs/advanced/AdvancedWorkflowMonitoringPage.js +2 -99
- package/dist/components/docs/advanced/index.js +10 -1055
- package/dist/components/docs/architecture/ArchitectureAppConfigPage.js +6 -243
- package/dist/components/docs/architecture/ArchitectureControlPlanePage.js +3 -160
- package/dist/components/docs/architecture/ArchitectureIntegrationBindingPage.js +7 -259
- package/dist/components/docs/architecture/ArchitectureKnowledgeBindingPage.js +6 -374
- package/dist/components/docs/architecture/ArchitectureMultiTenancyPage.js +2 -166
- package/dist/components/docs/architecture/ArchitectureOverviewPage.js +1 -143
- package/dist/components/docs/architecture/index.js +20 -1340
- package/dist/components/docs/comparison/ComparisonAutomationPlatformsPage.js +1 -245
- package/dist/components/docs/comparison/ComparisonEnterprisePlatformsPage.js +1 -230
- package/dist/components/docs/comparison/ComparisonInternalToolBuildersPage.js +1 -245
- package/dist/components/docs/comparison/ComparisonOverviewPage.js +1 -202
- package/dist/components/docs/comparison/ComparisonWindmillPage.js +1 -254
- package/dist/components/docs/comparison/ComparisonWorkflowEnginesPage.js +1 -339
- package/dist/components/docs/comparison/index.js +1 -1510
- package/dist/components/docs/docsManifest.js +1 -611
- package/dist/components/docs/docsManifest.test.d.ts +1 -0
- package/dist/components/docs/ecosystem/IntegrationsPage.js +2 -103
- package/dist/components/docs/ecosystem/PluginsPage.js +13 -179
- package/dist/components/docs/ecosystem/RegistryPage.js +7 -100
- package/dist/components/docs/ecosystem/TemplatesPage.js +3 -141
- package/dist/components/docs/ecosystem/ecosystem.docblocks.js +2 -48
- package/dist/components/docs/ecosystem/index.js +23 -569
- package/dist/components/docs/examples/DocsExamplesPage.js +4 -124
- package/dist/components/docs/examples/ExampleShowcasePage.js +4 -244
- package/dist/components/docs/examples/exampleShowcaseData.js +4 -39
- package/dist/components/docs/examples/index.js +4 -330
- package/dist/components/docs/generated/docs-index.generated.js +1 -5
- package/dist/components/docs/generated/index.js +1 -74
- package/dist/components/docs/generated/loader.js +1 -74
- package/dist/components/docs/getting-started/CLIPage.js +4 -271
- package/dist/components/docs/getting-started/CompatibilityPage.js +1 -173
- package/dist/components/docs/getting-started/DataViewTutorialPage.js +4 -134
- package/dist/components/docs/getting-started/DeveloperToolsPage.js +1 -194
- package/dist/components/docs/getting-started/HelloWorldPage.js +5 -183
- package/dist/components/docs/getting-started/InstallationPage.js +3 -154
- package/dist/components/docs/getting-started/StartHerePage.js +2 -129
- package/dist/components/docs/getting-started/TroubleshootingPage.js +2 -168
- package/dist/components/docs/getting-started/VSCodeExtensionPage.js +1 -432
- package/dist/components/docs/getting-started/getting-started.docblocks.js +4 -41
- package/dist/components/docs/getting-started/index.js +18 -1869
- package/dist/components/docs/guides/GuideCIDiffGatingPage.js +2 -196
- package/dist/components/docs/guides/GuideConnectInRepoPage.d.ts +1 -0
- package/dist/components/docs/guides/GuideConnectInRepoPage.js +44 -0
- package/dist/components/docs/guides/GuideContractTypesPage.js +6 -541
- package/dist/components/docs/guides/GuideDocsPipelinePage.js +3 -207
- package/dist/components/docs/guides/GuideFirstModuleBundlePage.d.ts +1 -0
- package/dist/components/docs/guides/GuideFirstModuleBundlePage.js +76 -0
- package/dist/components/docs/guides/GuideGenerateDocsClientsSchemasPage.js +2 -209
- package/dist/components/docs/guides/GuideHostBuilderWorkbenchPage.d.ts +1 -0
- package/dist/components/docs/guides/GuideHostBuilderWorkbenchPage.js +70 -0
- package/dist/components/docs/guides/GuideImportExistingCodebasesPage.js +8 -754
- package/dist/components/docs/guides/GuideNextjsOneEndpointPage.js +6 -268
- package/dist/components/docs/guides/GuideSpecValidationTypingPage.js +4 -196
- package/dist/components/docs/guides/GuidesIndexPage.js +2 -169
- package/dist/components/docs/guides/guides.docblocks.js +11 -75
- package/dist/components/docs/guides/index.d.ts +3 -0
- package/dist/components/docs/guides/index.js +213 -2428
- package/dist/components/docs/index.js +542 -24297
- package/dist/components/docs/integrations/IntegrationsCircuitBreakersPage.js +2 -42
- package/dist/components/docs/integrations/IntegrationsElevenLabsPage.js +3 -105
- package/dist/components/docs/integrations/IntegrationsGithubPage.js +3 -142
- package/dist/components/docs/integrations/IntegrationsGmailPage.js +3 -109
- package/dist/components/docs/integrations/IntegrationsGoogleCalendarPage.js +3 -79
- package/dist/components/docs/integrations/IntegrationsHealthRoutingPage.js +3 -146
- package/dist/components/docs/integrations/IntegrationsMistralPage.js +5 -150
- package/dist/components/docs/integrations/IntegrationsOpenAIPage.js +5 -140
- package/dist/components/docs/integrations/IntegrationsOverviewPage.js +1 -160
- package/dist/components/docs/integrations/IntegrationsPostmarkPage.js +4 -218
- package/dist/components/docs/integrations/IntegrationsPowensPage.js +4 -300
- package/dist/components/docs/integrations/IntegrationsQdrantPage.js +5 -111
- package/dist/components/docs/integrations/IntegrationsResendPage.js +3 -102
- package/dist/components/docs/integrations/IntegrationsS3Page.js +4 -124
- package/dist/components/docs/integrations/IntegrationsSlackPage.js +3 -144
- package/dist/components/docs/integrations/IntegrationsSpecModelPage.js +7 -290
- package/dist/components/docs/integrations/IntegrationsStripePage.js +6 -327
- package/dist/components/docs/integrations/IntegrationsTwilioPage.js +3 -128
- package/dist/components/docs/integrations/IntegrationsWhatsappMetaPage.js +2 -146
- package/dist/components/docs/integrations/IntegrationsWhatsappTwilioPage.js +2 -156
- package/dist/components/docs/integrations/index.js +52 -3100
- package/dist/components/docs/intent/ContractFirstApiPage.js +2 -126
- package/dist/components/docs/intent/DeterministicCodegenPage.js +2 -148
- package/dist/components/docs/intent/GenerateClientFromSchemaPage.js +7 -207
- package/dist/components/docs/intent/OpenapiAlternativePage.js +3 -201
- package/dist/components/docs/intent/SchemaValidationTypescriptPage.js +4 -144
- package/dist/components/docs/intent/SpecDrivenDevelopmentPage.js +2 -126
- package/dist/components/docs/intent/index.js +15 -1135
- package/dist/components/docs/intent/intent-pages.docblocks.js +1 -201
- package/dist/components/docs/knowledge/KnowledgeCategoriesPage.js +6 -750
- package/dist/components/docs/knowledge/KnowledgeExamplesPage.js +4 -175
- package/dist/components/docs/knowledge/KnowledgeOverviewPage.js +1 -116
- package/dist/components/docs/knowledge/KnowledgeSourcesPage.js +8 -391
- package/dist/components/docs/knowledge/KnowledgeSpacesPage.js +6 -302
- package/dist/components/docs/knowledge/index.js +21 -1730
- package/dist/components/docs/libraries/LibrariesAccessibilityPage.js +3 -198
- package/dist/components/docs/libraries/LibrariesAiAgentPage.js +3 -141
- package/dist/components/docs/libraries/LibrariesAnalyticsPage.js +4 -80
- package/dist/components/docs/libraries/LibrariesContentGenPage.js +2 -100
- package/dist/components/docs/libraries/LibrariesContractsPage.js +2 -284
- package/dist/components/docs/libraries/LibrariesCostTrackingPage.js +3 -112
- package/dist/components/docs/libraries/LibrariesDataBackendPage.js +2 -166
- package/dist/components/docs/libraries/LibrariesDataViewsPage.js +3 -186
- package/dist/components/docs/libraries/LibrariesDesignSystemPage.js +4 -279
- package/dist/components/docs/libraries/LibrariesEvolutionPage.js +4 -127
- package/dist/components/docs/libraries/LibrariesGraphQLPage.js +2 -173
- package/dist/components/docs/libraries/LibrariesGrowthPage.js +3 -88
- package/dist/components/docs/libraries/LibrariesMultiTenancyPage.js +3 -108
- package/dist/components/docs/libraries/LibrariesObservabilityPage.js +5 -130
- package/dist/components/docs/libraries/LibrariesOverlayEnginePage.js +4 -110
- package/dist/components/docs/libraries/LibrariesOverviewPage.js +1 -170
- package/dist/components/docs/libraries/LibrariesPersonalizationPage.js +4 -114
- package/dist/components/docs/libraries/LibrariesProgressiveDeliveryPage.js +3 -132
- package/dist/components/docs/libraries/LibrariesResiliencePage.js +4 -120
- package/dist/components/docs/libraries/LibrariesRuntimePage.js +2 -200
- package/dist/components/docs/libraries/LibrariesSLOPage.js +3 -116
- package/dist/components/docs/libraries/LibrariesSchemaPage.js +3 -273
- package/dist/components/docs/libraries/LibrariesSupportBotPage.js +3 -134
- package/dist/components/docs/libraries/LibrariesTestingPage.js +3 -133
- package/dist/components/docs/libraries/LibrariesUIKitPage.js +2 -230
- package/dist/components/docs/libraries/LibrariesWorkflowComposerPage.js +3 -88
- package/dist/components/docs/libraries/LibrariesWorkflowsPage.js +2 -181
- package/dist/components/docs/libraries/index.js +54 -4147
- package/dist/components/docs/manifesto/ManifestoPage.js +1 -86
- package/dist/components/docs/ops/AutoEvolutionOpsPage.js +2 -132
- package/dist/components/docs/ops/DistributedTracingOpsPage.js +2 -71
- package/dist/components/docs/ops/index.js +3 -202
- package/dist/components/docs/ops/ops-lifecycle.docblocks.js +3 -38
- package/dist/components/docs/ops/ops-runbooks-a.docblocks.js +3 -94
- package/dist/components/docs/ops/ops-runbooks-b.docblocks.js +3 -76
- package/dist/components/docs/ops/ops-slo-tenant.docblocks.js +3 -76
- package/dist/components/docs/ops/ops-top.docs.js +2 -17
- package/dist/components/docs/ops/ops.docs.js +10 -302
- package/dist/components/docs/product/product.docblocks.js +5 -72
- package/dist/components/docs/reference/DocsMarkdownContent.js +2 -196
- package/dist/components/docs/reference/DocsReferenceContent.js +3 -256
- package/dist/components/docs/reference/DocsReferenceIndexClient.js +2 -127
- package/dist/components/docs/reference/DocsReferenceIndexPage.js +2 -206
- package/dist/components/docs/reference/DocsReferencePage.js +3 -265
- package/dist/components/docs/reference/docsMarkdownParser.js +2 -92
- package/dist/components/docs/reference/index.js +4 -470
- package/dist/components/docs/safety/SafetyAuditingPage.js +2 -350
- package/dist/components/docs/safety/SafetyMigrationsPage.js +2 -359
- package/dist/components/docs/safety/SafetyOverviewPage.js +1 -101
- package/dist/components/docs/safety/SafetyPDPPage.js +2 -301
- package/dist/components/docs/safety/SafetySecurityTrustPage.js +1 -206
- package/dist/components/docs/safety/SafetySigningPage.js +3 -90
- package/dist/components/docs/safety/SafetyTenantIsolationPage.js +2 -79
- package/dist/components/docs/safety/index.js +7 -1480
- package/dist/components/docs/shared/StudioPrompt.js +1 -31
- package/dist/components/docs/specs/SpecsBuilderControlPlanePage.d.ts +1 -0
- package/dist/components/docs/specs/SpecsBuilderControlPlanePage.js +34 -0
- package/dist/components/docs/specs/SpecsCapabilitiesPage.js +2 -158
- package/dist/components/docs/specs/SpecsConnectPage.d.ts +1 -0
- package/dist/components/docs/specs/SpecsConnectPage.js +8 -0
- package/dist/components/docs/specs/SpecsDataViewsPage.js +2 -260
- package/dist/components/docs/specs/SpecsModuleBundlesPage.d.ts +1 -0
- package/dist/components/docs/specs/SpecsModuleBundlesPage.js +67 -0
- package/dist/components/docs/specs/SpecsOverlaysPage.js +2 -372
- package/dist/components/docs/specs/SpecsOverviewPage.js +1 -186
- package/dist/components/docs/specs/SpecsPolicyPage.js +3 -420
- package/dist/components/docs/specs/SpecsWorkflowsPage.js +2 -312
- package/dist/components/docs/specs/index.d.ts +3 -0
- package/dist/components/docs/specs/index.js +109 -1702
- package/dist/components/docs/studio/StudioBYOKPage.js +1 -26
- package/dist/components/docs/studio/StudioDeploymentsPage.js +1 -26
- package/dist/components/docs/studio/StudioGettingStartedPage.js +1 -26
- package/dist/components/docs/studio/StudioIntegrationsPage.js +1 -26
- package/dist/components/docs/studio/StudioOverviewPage.js +1 -157
- package/dist/components/docs/studio/StudioVisualBuilderPage.js +1 -26
- package/dist/components/docs/studio/index.js +1 -282
- package/dist/components/docs/tech/contracts/tech-docs.docblocks.js +2 -19
- package/dist/components/integrations/index.js +2 -600
- package/dist/components/integrations/molecules/IntegrationCard.js +1 -100
- package/dist/components/integrations/organisms/IntegrationMarketplace.js +1 -214
- package/dist/components/integrations/organisms/IntegrationSettings.js +2 -284
- package/dist/components/integrations/organisms/KnowledgeSourceList.js +1 -103
- package/dist/components/legal/PrivacyTemplate.js +1 -1025
- package/dist/components/legal/TermsTemplate.js +1 -941
- package/dist/components/legal/index.js +1 -1963
- package/dist/components/shared/FeatureGateNotice.js +1 -38
- package/dist/components/shared/index.js +1 -38
- package/dist/components/shell/WorkspaceHeader.js +1 -100
- package/dist/components/shell/WorkspaceProjectShellLayout.js +1 -222
- package/dist/components/shell/WorkspaceShellRenderer.js +1 -228
- package/dist/components/shell/WorkspaceSidebar.js +1 -68
- package/dist/components/shell/index.js +1 -287
- package/dist/components/templates/engine/index.js +1 -39
- package/dist/components/templates/index.js +11 -965
- package/dist/components/templates/messaging/ConversationList.js +2 -83
- package/dist/components/templates/messaging/MessageComposer.js +4 -150
- package/dist/components/templates/messaging/MessageThread.js +3 -83
- package/dist/components/templates/messaging/MessagingWorkspace.js +5 -265
- package/dist/components/templates/messaging/index.js +5 -269
- package/dist/components/templates/recipes/LanguageSwitcher.js +1 -16
- package/dist/components/templates/recipes/RecipeCard.js +1 -80
- package/dist/components/templates/recipes/RecipeDetail.js +1 -74
- package/dist/components/templates/recipes/RecipeList.js +3 -245
- package/dist/components/templates/recipes/index.js +3 -248
- package/dist/components/templates/todos/FilterBar.js +1 -107
- package/dist/components/templates/todos/TaskForm.js +2 -158
- package/dist/components/templates/todos/TaskItem.js +1 -77
- package/dist/components/templates/todos/TaskList.js +5 -449
- package/dist/components/templates/todos/index.js +5 -452
- package/dist/config/contractspec-blueprint.js +1 -123
- package/dist/config/contractspec-branding.js +1 -44
- package/dist/config/contractspec-routes.js +1 -24
- package/dist/config/index.js +1 -126
- package/dist/features/contracts-registry.js +1 -178
- package/dist/features/docs/docs.contracts.js +1 -17
- package/dist/features/docs/index.js +1 -17
- package/dist/features/docs.feature.js +1 -33
- package/dist/features/index.js +1 -315
- package/dist/features/mcp.feature.js +1 -30
- package/dist/features/presentations.feature.js +1 -33
- package/dist/features/registry.js +1 -116
- package/dist/index.js +556 -28580
- package/dist/infrastructure/elysia/index.js +1 -35
- package/dist/infrastructure/elysia/logger.js +1 -35
- package/dist/infrastructure/index.js +1 -35
- package/dist/libs/email/client.js +1 -114
- package/dist/libs/email/contact.js +12 -165
- package/dist/libs/email/newsletter.js +6 -167
- package/dist/libs/email/types.js +0 -2
- package/dist/libs/email/utils.js +2 -8
- package/dist/libs/email/waitlist-application.js +28 -209
- package/dist/libs/email/waitlist.js +6 -167
- package/dist/libs/email.js +46 -363
- package/dist/libs/posthog/client.js +1 -63
- package/dist/libs/posthog/native.js +1 -23
- package/dist/libs/posthog/server.js +1 -13
- package/dist/libs/pricing-examples.js +1 -18
- package/dist/node/application/context-storage/index.js +1 -28
- package/dist/node/application/index.js +13 -2133
- package/dist/node/application/mcp/cliMcp.js +4 -452
- package/dist/node/application/mcp/common.js +1 -193
- package/dist/node/application/mcp/contractsMcp.js +2 -549
- package/dist/node/application/mcp/contractsMcpResources.js +2 -123
- package/dist/node/application/mcp/contractsMcpTools.js +1 -199
- package/dist/node/application/mcp/docsMcp.catalog.js +3 -381
- package/dist/node/application/mcp/docsMcp.data.js +1 -147
- package/dist/node/application/mcp/docsMcp.js +6 -1039
- package/dist/node/application/mcp/docsMcp.prompts.js +6 -521
- package/dist/node/application/mcp/docsMcp.reference.js +3 -235
- package/dist/node/application/mcp/docsMcp.resources.js +3 -519
- package/dist/node/application/mcp/docsMcp.tools.js +3 -518
- package/dist/node/application/mcp/index.js +13 -2106
- package/dist/node/application/mcp/internalMcp.js +2 -410
- package/dist/node/application/mcp/normalizeMcpRequest.js +1 -21
- package/dist/node/application/mcp/providerRankingMcp.js +1 -530
- package/dist/node/bundles/LibraryBundle.js +1 -138
- package/dist/node/bundles/index.js +1 -138
- package/dist/node/components/docs/DocsIndexPage.js +2 -912
- package/dist/node/components/docs/advanced/AdvancedMCPPage.js +4 -271
- package/dist/node/components/docs/advanced/AdvancedOverlayEditorPage.js +1 -107
- package/dist/node/components/docs/advanced/AdvancedRenderersPage.js +2 -118
- package/dist/node/components/docs/advanced/AdvancedSpecExperimentsPage.js +4 -92
- package/dist/node/components/docs/advanced/AdvancedTelemetryPage.js +2 -373
- package/dist/node/components/docs/advanced/AdvancedWorkflowMonitoringPage.js +2 -99
- package/dist/node/components/docs/advanced/index.js +10 -1055
- package/dist/node/components/docs/architecture/ArchitectureAppConfigPage.js +6 -243
- package/dist/node/components/docs/architecture/ArchitectureControlPlanePage.js +3 -160
- package/dist/node/components/docs/architecture/ArchitectureIntegrationBindingPage.js +7 -259
- package/dist/node/components/docs/architecture/ArchitectureKnowledgeBindingPage.js +6 -374
- package/dist/node/components/docs/architecture/ArchitectureMultiTenancyPage.js +2 -166
- package/dist/node/components/docs/architecture/ArchitectureOverviewPage.js +1 -143
- package/dist/node/components/docs/architecture/index.js +20 -1340
- package/dist/node/components/docs/comparison/ComparisonAutomationPlatformsPage.js +1 -245
- package/dist/node/components/docs/comparison/ComparisonEnterprisePlatformsPage.js +1 -230
- package/dist/node/components/docs/comparison/ComparisonInternalToolBuildersPage.js +1 -245
- package/dist/node/components/docs/comparison/ComparisonOverviewPage.js +1 -202
- package/dist/node/components/docs/comparison/ComparisonWindmillPage.js +1 -254
- package/dist/node/components/docs/comparison/ComparisonWorkflowEnginesPage.js +1 -339
- package/dist/node/components/docs/comparison/index.js +1 -1510
- package/dist/node/components/docs/docsManifest.js +1 -611
- package/dist/node/components/docs/ecosystem/IntegrationsPage.js +2 -103
- package/dist/node/components/docs/ecosystem/PluginsPage.js +13 -179
- package/dist/node/components/docs/ecosystem/RegistryPage.js +7 -100
- package/dist/node/components/docs/ecosystem/TemplatesPage.js +3 -141
- package/dist/node/components/docs/ecosystem/ecosystem.docblocks.js +2 -48
- package/dist/node/components/docs/ecosystem/index.js +23 -569
- package/dist/node/components/docs/examples/DocsExamplesPage.js +4 -124
- package/dist/node/components/docs/examples/ExampleShowcasePage.js +4 -244
- package/dist/node/components/docs/examples/exampleShowcaseData.js +4 -39
- package/dist/node/components/docs/examples/index.js +4 -330
- package/dist/node/components/docs/generated/docs-index.generated.js +1 -5
- package/dist/node/components/docs/generated/index.js +1 -74
- package/dist/node/components/docs/generated/loader.js +1 -74
- package/dist/node/components/docs/getting-started/CLIPage.js +4 -271
- package/dist/node/components/docs/getting-started/CompatibilityPage.js +1 -173
- package/dist/node/components/docs/getting-started/DataViewTutorialPage.js +4 -134
- package/dist/node/components/docs/getting-started/DeveloperToolsPage.js +1 -194
- package/dist/node/components/docs/getting-started/HelloWorldPage.js +5 -183
- package/dist/node/components/docs/getting-started/InstallationPage.js +3 -154
- package/dist/node/components/docs/getting-started/StartHerePage.js +2 -129
- package/dist/node/components/docs/getting-started/TroubleshootingPage.js +2 -168
- package/dist/node/components/docs/getting-started/VSCodeExtensionPage.js +1 -432
- package/dist/node/components/docs/getting-started/getting-started.docblocks.js +4 -41
- package/dist/node/components/docs/getting-started/index.js +18 -1869
- package/dist/node/components/docs/guides/GuideCIDiffGatingPage.js +2 -196
- package/dist/node/components/docs/guides/GuideConnectInRepoPage.js +43 -0
- package/dist/node/components/docs/guides/GuideContractTypesPage.js +6 -541
- package/dist/node/components/docs/guides/GuideDocsPipelinePage.js +3 -207
- package/dist/node/components/docs/guides/GuideFirstModuleBundlePage.js +75 -0
- package/dist/node/components/docs/guides/GuideGenerateDocsClientsSchemasPage.js +2 -209
- package/dist/node/components/docs/guides/GuideHostBuilderWorkbenchPage.js +69 -0
- package/dist/node/components/docs/guides/GuideImportExistingCodebasesPage.js +8 -754
- package/dist/node/components/docs/guides/GuideNextjsOneEndpointPage.js +6 -268
- package/dist/node/components/docs/guides/GuideSpecValidationTypingPage.js +4 -196
- package/dist/node/components/docs/guides/GuidesIndexPage.js +2 -169
- package/dist/node/components/docs/guides/guides.docblocks.js +11 -75
- package/dist/node/components/docs/guides/index.js +213 -2428
- package/dist/node/components/docs/index.js +542 -24297
- package/dist/node/components/docs/integrations/IntegrationsCircuitBreakersPage.js +2 -42
- package/dist/node/components/docs/integrations/IntegrationsElevenLabsPage.js +3 -105
- package/dist/node/components/docs/integrations/IntegrationsGithubPage.js +3 -142
- package/dist/node/components/docs/integrations/IntegrationsGmailPage.js +3 -109
- package/dist/node/components/docs/integrations/IntegrationsGoogleCalendarPage.js +3 -79
- package/dist/node/components/docs/integrations/IntegrationsHealthRoutingPage.js +3 -146
- package/dist/node/components/docs/integrations/IntegrationsMistralPage.js +5 -150
- package/dist/node/components/docs/integrations/IntegrationsOpenAIPage.js +5 -140
- package/dist/node/components/docs/integrations/IntegrationsOverviewPage.js +1 -160
- package/dist/node/components/docs/integrations/IntegrationsPostmarkPage.js +4 -218
- package/dist/node/components/docs/integrations/IntegrationsPowensPage.js +4 -300
- package/dist/node/components/docs/integrations/IntegrationsQdrantPage.js +5 -111
- package/dist/node/components/docs/integrations/IntegrationsResendPage.js +3 -102
- package/dist/node/components/docs/integrations/IntegrationsS3Page.js +4 -124
- package/dist/node/components/docs/integrations/IntegrationsSlackPage.js +3 -144
- package/dist/node/components/docs/integrations/IntegrationsSpecModelPage.js +7 -290
- package/dist/node/components/docs/integrations/IntegrationsStripePage.js +6 -327
- package/dist/node/components/docs/integrations/IntegrationsTwilioPage.js +3 -128
- package/dist/node/components/docs/integrations/IntegrationsWhatsappMetaPage.js +2 -146
- package/dist/node/components/docs/integrations/IntegrationsWhatsappTwilioPage.js +2 -156
- package/dist/node/components/docs/integrations/index.js +52 -3100
- package/dist/node/components/docs/intent/ContractFirstApiPage.js +2 -126
- package/dist/node/components/docs/intent/DeterministicCodegenPage.js +2 -148
- package/dist/node/components/docs/intent/GenerateClientFromSchemaPage.js +7 -207
- package/dist/node/components/docs/intent/OpenapiAlternativePage.js +3 -201
- package/dist/node/components/docs/intent/SchemaValidationTypescriptPage.js +4 -144
- package/dist/node/components/docs/intent/SpecDrivenDevelopmentPage.js +2 -126
- package/dist/node/components/docs/intent/index.js +15 -1135
- package/dist/node/components/docs/intent/intent-pages.docblocks.js +1 -201
- package/dist/node/components/docs/knowledge/KnowledgeCategoriesPage.js +6 -750
- package/dist/node/components/docs/knowledge/KnowledgeExamplesPage.js +4 -175
- package/dist/node/components/docs/knowledge/KnowledgeOverviewPage.js +1 -116
- package/dist/node/components/docs/knowledge/KnowledgeSourcesPage.js +8 -391
- package/dist/node/components/docs/knowledge/KnowledgeSpacesPage.js +6 -302
- package/dist/node/components/docs/knowledge/index.js +21 -1730
- package/dist/node/components/docs/libraries/LibrariesAccessibilityPage.js +3 -198
- package/dist/node/components/docs/libraries/LibrariesAiAgentPage.js +3 -141
- package/dist/node/components/docs/libraries/LibrariesAnalyticsPage.js +4 -80
- package/dist/node/components/docs/libraries/LibrariesContentGenPage.js +2 -100
- package/dist/node/components/docs/libraries/LibrariesContractsPage.js +2 -284
- package/dist/node/components/docs/libraries/LibrariesCostTrackingPage.js +3 -112
- package/dist/node/components/docs/libraries/LibrariesDataBackendPage.js +2 -166
- package/dist/node/components/docs/libraries/LibrariesDataViewsPage.js +3 -186
- package/dist/node/components/docs/libraries/LibrariesDesignSystemPage.js +4 -279
- package/dist/node/components/docs/libraries/LibrariesEvolutionPage.js +4 -127
- package/dist/node/components/docs/libraries/LibrariesGraphQLPage.js +2 -173
- package/dist/node/components/docs/libraries/LibrariesGrowthPage.js +3 -88
- package/dist/node/components/docs/libraries/LibrariesMultiTenancyPage.js +3 -108
- package/dist/node/components/docs/libraries/LibrariesObservabilityPage.js +5 -130
- package/dist/node/components/docs/libraries/LibrariesOverlayEnginePage.js +4 -110
- package/dist/node/components/docs/libraries/LibrariesOverviewPage.js +1 -170
- package/dist/node/components/docs/libraries/LibrariesPersonalizationPage.js +4 -114
- package/dist/node/components/docs/libraries/LibrariesProgressiveDeliveryPage.js +3 -132
- package/dist/node/components/docs/libraries/LibrariesResiliencePage.js +4 -120
- package/dist/node/components/docs/libraries/LibrariesRuntimePage.js +2 -200
- package/dist/node/components/docs/libraries/LibrariesSLOPage.js +3 -116
- package/dist/node/components/docs/libraries/LibrariesSchemaPage.js +3 -273
- package/dist/node/components/docs/libraries/LibrariesSupportBotPage.js +3 -134
- package/dist/node/components/docs/libraries/LibrariesTestingPage.js +3 -133
- package/dist/node/components/docs/libraries/LibrariesUIKitPage.js +2 -230
- package/dist/node/components/docs/libraries/LibrariesWorkflowComposerPage.js +3 -88
- package/dist/node/components/docs/libraries/LibrariesWorkflowsPage.js +2 -181
- package/dist/node/components/docs/libraries/index.js +54 -4147
- package/dist/node/components/docs/manifesto/ManifestoPage.js +1 -86
- package/dist/node/components/docs/ops/AutoEvolutionOpsPage.js +2 -132
- package/dist/node/components/docs/ops/DistributedTracingOpsPage.js +2 -71
- package/dist/node/components/docs/ops/index.js +3 -202
- package/dist/node/components/docs/ops/ops-lifecycle.docblocks.js +3 -38
- package/dist/node/components/docs/ops/ops-runbooks-a.docblocks.js +3 -94
- package/dist/node/components/docs/ops/ops-runbooks-b.docblocks.js +3 -76
- package/dist/node/components/docs/ops/ops-slo-tenant.docblocks.js +3 -76
- package/dist/node/components/docs/ops/ops-top.docs.js +2 -17
- package/dist/node/components/docs/ops/ops.docs.js +10 -302
- package/dist/node/components/docs/product/product.docblocks.js +5 -72
- package/dist/node/components/docs/reference/DocsMarkdownContent.js +2 -196
- package/dist/node/components/docs/reference/DocsReferenceContent.js +3 -256
- package/dist/node/components/docs/reference/DocsReferenceIndexClient.js +2 -127
- package/dist/node/components/docs/reference/DocsReferenceIndexPage.js +2 -206
- package/dist/node/components/docs/reference/DocsReferencePage.js +3 -265
- package/dist/node/components/docs/reference/docsMarkdownParser.js +2 -92
- package/dist/node/components/docs/reference/index.js +4 -470
- package/dist/node/components/docs/safety/SafetyAuditingPage.js +2 -350
- package/dist/node/components/docs/safety/SafetyMigrationsPage.js +2 -359
- package/dist/node/components/docs/safety/SafetyOverviewPage.js +1 -101
- package/dist/node/components/docs/safety/SafetyPDPPage.js +2 -301
- package/dist/node/components/docs/safety/SafetySecurityTrustPage.js +1 -206
- package/dist/node/components/docs/safety/SafetySigningPage.js +3 -90
- package/dist/node/components/docs/safety/SafetyTenantIsolationPage.js +2 -79
- package/dist/node/components/docs/safety/index.js +7 -1480
- package/dist/node/components/docs/shared/StudioPrompt.js +1 -31
- package/dist/node/components/docs/specs/SpecsBuilderControlPlanePage.js +33 -0
- package/dist/node/components/docs/specs/SpecsCapabilitiesPage.js +2 -158
- package/dist/node/components/docs/specs/SpecsConnectPage.js +7 -0
- package/dist/node/components/docs/specs/SpecsDataViewsPage.js +2 -260
- package/dist/node/components/docs/specs/SpecsModuleBundlesPage.js +66 -0
- package/dist/node/components/docs/specs/SpecsOverlaysPage.js +2 -372
- package/dist/node/components/docs/specs/SpecsOverviewPage.js +1 -186
- package/dist/node/components/docs/specs/SpecsPolicyPage.js +3 -420
- package/dist/node/components/docs/specs/SpecsWorkflowsPage.js +2 -312
- package/dist/node/components/docs/specs/index.js +109 -1702
- package/dist/node/components/docs/studio/StudioBYOKPage.js +1 -26
- package/dist/node/components/docs/studio/StudioDeploymentsPage.js +1 -26
- package/dist/node/components/docs/studio/StudioGettingStartedPage.js +1 -26
- package/dist/node/components/docs/studio/StudioIntegrationsPage.js +1 -26
- package/dist/node/components/docs/studio/StudioOverviewPage.js +1 -157
- package/dist/node/components/docs/studio/StudioVisualBuilderPage.js +1 -26
- package/dist/node/components/docs/studio/index.js +1 -282
- package/dist/node/components/docs/tech/contracts/tech-docs.docblocks.js +2 -19
- package/dist/node/components/integrations/index.js +2 -600
- package/dist/node/components/integrations/molecules/IntegrationCard.js +1 -100
- package/dist/node/components/integrations/organisms/IntegrationMarketplace.js +1 -214
- package/dist/node/components/integrations/organisms/IntegrationSettings.js +2 -284
- package/dist/node/components/integrations/organisms/KnowledgeSourceList.js +1 -103
- package/dist/node/components/legal/PrivacyTemplate.js +1 -1025
- package/dist/node/components/legal/TermsTemplate.js +1 -941
- package/dist/node/components/legal/index.js +1 -1963
- package/dist/node/components/shared/FeatureGateNotice.js +1 -38
- package/dist/node/components/shared/index.js +1 -38
- package/dist/node/components/shell/WorkspaceHeader.js +1 -100
- package/dist/node/components/shell/WorkspaceProjectShellLayout.js +1 -222
- package/dist/node/components/shell/WorkspaceShellRenderer.js +1 -228
- package/dist/node/components/shell/WorkspaceSidebar.js +1 -68
- package/dist/node/components/shell/index.js +1 -287
- package/dist/node/components/templates/engine/index.js +1 -39
- package/dist/node/components/templates/index.js +11 -965
- package/dist/node/components/templates/messaging/ConversationList.js +2 -83
- package/dist/node/components/templates/messaging/MessageComposer.js +4 -150
- package/dist/node/components/templates/messaging/MessageThread.js +3 -83
- package/dist/node/components/templates/messaging/MessagingWorkspace.js +5 -265
- package/dist/node/components/templates/messaging/index.js +5 -269
- package/dist/node/components/templates/recipes/LanguageSwitcher.js +1 -16
- package/dist/node/components/templates/recipes/RecipeCard.js +1 -80
- package/dist/node/components/templates/recipes/RecipeDetail.js +1 -74
- package/dist/node/components/templates/recipes/RecipeList.js +3 -245
- package/dist/node/components/templates/recipes/index.js +3 -248
- package/dist/node/components/templates/todos/FilterBar.js +1 -107
- package/dist/node/components/templates/todos/TaskForm.js +2 -158
- package/dist/node/components/templates/todos/TaskItem.js +1 -77
- package/dist/node/components/templates/todos/TaskList.js +5 -449
- package/dist/node/components/templates/todos/index.js +5 -452
- package/dist/node/config/contractspec-blueprint.js +1 -123
- package/dist/node/config/contractspec-branding.js +1 -44
- package/dist/node/config/contractspec-routes.js +1 -24
- package/dist/node/config/index.js +1 -126
- package/dist/node/features/contracts-registry.js +1 -178
- package/dist/node/features/docs/docs.contracts.js +1 -17
- package/dist/node/features/docs/index.js +1 -17
- package/dist/node/features/docs.feature.js +1 -33
- package/dist/node/features/index.js +1 -315
- package/dist/node/features/mcp.feature.js +1 -30
- package/dist/node/features/presentations.feature.js +1 -33
- package/dist/node/features/registry.js +1 -116
- package/dist/node/index.js +556 -28580
- package/dist/node/infrastructure/elysia/index.js +1 -35
- package/dist/node/infrastructure/elysia/logger.js +1 -35
- package/dist/node/infrastructure/index.js +1 -35
- package/dist/node/libs/email/client.js +1 -114
- package/dist/node/libs/email/contact.js +12 -165
- package/dist/node/libs/email/newsletter.js +6 -167
- package/dist/node/libs/email/types.js +0 -2
- package/dist/node/libs/email/utils.js +2 -8
- package/dist/node/libs/email/waitlist-application.js +28 -209
- package/dist/node/libs/email/waitlist.js +6 -167
- package/dist/node/libs/email.js +46 -363
- package/dist/node/libs/posthog/client.js +1 -63
- package/dist/node/libs/posthog/native.js +1 -23
- package/dist/node/libs/posthog/server.js +1 -13
- package/dist/node/libs/pricing-examples.js +1 -18
- package/dist/node/presentation/features/atoms/FeatureIcon/FeatureIcon.js +1 -97
- package/dist/node/presentation/features/atoms/FeatureIcon/index.js +1 -97
- package/dist/node/presentation/features/atoms/index.js +1 -97
- package/dist/node/presentation/features/hooks/index.js +1 -397
- package/dist/node/presentation/features/hooks/useContractsRegistry.js +1 -289
- package/dist/node/presentation/features/hooks/useFeatureFilters.js +1 -75
- package/dist/node/presentation/features/hooks/useFeatureRegistry.js +1 -147
- package/dist/node/presentation/features/hooks/useRelatedDocs.js +1 -28
- package/dist/node/presentation/features/index.js +1 -3063
- package/dist/node/presentation/features/molecules/FeatureCard/FeatureCard.js +1 -366
- package/dist/node/presentation/features/molecules/FeatureCard/index.js +1 -366
- package/dist/node/presentation/features/molecules/FeatureCategoryHeader/FeatureCategoryHeader.js +1 -50
- package/dist/node/presentation/features/molecules/FeatureCategoryHeader/index.js +1 -50
- package/dist/node/presentation/features/molecules/FeatureFilters/FeatureFilters.js +1 -92
- package/dist/node/presentation/features/molecules/FeatureFilters/index.js +1 -92
- package/dist/node/presentation/features/molecules/FeatureHoverPreview/FeatureHoverPreview.js +1 -176
- package/dist/node/presentation/features/molecules/FeatureHoverPreview/index.js +1 -176
- package/dist/node/presentation/features/molecules/index.js +1 -505
- package/dist/node/presentation/features/organisms/FeatureDataViewsList.js +1 -304
- package/dist/node/presentation/features/organisms/FeatureDetail/FeatureDetail.js +1 -154
- package/dist/node/presentation/features/organisms/FeatureDetail/index.js +1 -154
- package/dist/node/presentation/features/organisms/FeatureDiscovery/FeatureDiscovery.js +1 -909
- package/dist/node/presentation/features/organisms/FeatureDiscovery/index.js +1 -909
- package/dist/node/presentation/features/organisms/FeatureEventsList.js +1 -302
- package/dist/node/presentation/features/organisms/FeatureFormsList.js +1 -302
- package/dist/node/presentation/features/organisms/FeatureOperationsList.js +1 -180
- package/dist/node/presentation/features/organisms/FeaturePresentationsList.js +1 -304
- package/dist/node/presentation/features/organisms/index.js +1 -1359
- package/dist/node/presentation/features/templates/FeatureDataViewDetailTemplate/FeatureDataViewDetailTemplate.js +1 -332
- package/dist/node/presentation/features/templates/FeatureDataViewDetailTemplate/index.js +1 -332
- package/dist/node/presentation/features/templates/FeatureDataViewsTemplate/FeatureDataViewsTemplate.js +1 -342
- package/dist/node/presentation/features/templates/FeatureDataViewsTemplate/index.js +1 -342
- package/dist/node/presentation/features/templates/FeatureEventDetailTemplate/FeatureEventDetailTemplate.js +1 -303
- package/dist/node/presentation/features/templates/FeatureEventDetailTemplate/index.js +1 -303
- package/dist/node/presentation/features/templates/FeatureEventsTemplate/FeatureEventsTemplate.js +1 -340
- package/dist/node/presentation/features/templates/FeatureEventsTemplate/index.js +1 -340
- package/dist/node/presentation/features/templates/FeatureFormDetailTemplate/FeatureFormDetailTemplate.js +1 -329
- package/dist/node/presentation/features/templates/FeatureFormDetailTemplate/index.js +1 -329
- package/dist/node/presentation/features/templates/FeatureFormsTemplate/FeatureFormsTemplate.js +1 -340
- package/dist/node/presentation/features/templates/FeatureFormsTemplate/index.js +1 -340
- package/dist/node/presentation/features/templates/FeatureOperationDetailTemplate/FeatureOperationDetailTemplate.js +1 -302
- package/dist/node/presentation/features/templates/FeatureOperationDetailTemplate/index.js +1 -302
- package/dist/node/presentation/features/templates/FeatureOperationsTemplate/FeatureOperationsTemplate.js +1 -218
- package/dist/node/presentation/features/templates/FeatureOperationsTemplate/index.js +1 -218
- package/dist/node/presentation/features/templates/FeatureOverviewTemplate/FeatureOverviewTemplate.js +1 -187
- package/dist/node/presentation/features/templates/FeatureOverviewTemplate/index.js +1 -187
- package/dist/node/presentation/features/templates/FeaturePresentationDetailTemplate/FeaturePresentationDetailTemplate.js +1 -306
- package/dist/node/presentation/features/templates/FeaturePresentationDetailTemplate/index.js +1 -306
- package/dist/node/presentation/features/templates/FeaturePresentationsTemplate/FeaturePresentationsTemplate.js +1 -342
- package/dist/node/presentation/features/templates/FeaturePresentationsTemplate/index.js +1 -342
- package/dist/presentation/features/atoms/FeatureIcon/FeatureIcon.js +1 -97
- package/dist/presentation/features/atoms/FeatureIcon/index.js +1 -97
- package/dist/presentation/features/atoms/index.js +1 -97
- package/dist/presentation/features/hooks/index.js +1 -397
- package/dist/presentation/features/hooks/useContractsRegistry.js +1 -289
- package/dist/presentation/features/hooks/useFeatureFilters.js +1 -75
- package/dist/presentation/features/hooks/useFeatureRegistry.js +1 -147
- package/dist/presentation/features/hooks/useRelatedDocs.js +1 -28
- package/dist/presentation/features/index.js +1 -3063
- package/dist/presentation/features/molecules/FeatureCard/FeatureCard.js +1 -366
- package/dist/presentation/features/molecules/FeatureCard/index.js +1 -366
- package/dist/presentation/features/molecules/FeatureCategoryHeader/FeatureCategoryHeader.js +1 -50
- package/dist/presentation/features/molecules/FeatureCategoryHeader/index.js +1 -50
- package/dist/presentation/features/molecules/FeatureFilters/FeatureFilters.js +1 -92
- package/dist/presentation/features/molecules/FeatureFilters/index.js +1 -92
- package/dist/presentation/features/molecules/FeatureHoverPreview/FeatureHoverPreview.js +1 -176
- package/dist/presentation/features/molecules/FeatureHoverPreview/index.js +1 -176
- package/dist/presentation/features/molecules/index.js +1 -505
- package/dist/presentation/features/organisms/FeatureDataViewsList.js +1 -304
- package/dist/presentation/features/organisms/FeatureDetail/FeatureDetail.js +1 -154
- package/dist/presentation/features/organisms/FeatureDetail/index.js +1 -154
- package/dist/presentation/features/organisms/FeatureDiscovery/FeatureDiscovery.js +1 -909
- package/dist/presentation/features/organisms/FeatureDiscovery/index.js +1 -909
- package/dist/presentation/features/organisms/FeatureEventsList.js +1 -302
- package/dist/presentation/features/organisms/FeatureFormsList.js +1 -302
- package/dist/presentation/features/organisms/FeatureOperationsList.js +1 -180
- package/dist/presentation/features/organisms/FeaturePresentationsList.js +1 -304
- package/dist/presentation/features/organisms/index.js +1 -1359
- package/dist/presentation/features/templates/FeatureDataViewDetailTemplate/FeatureDataViewDetailTemplate.js +1 -332
- package/dist/presentation/features/templates/FeatureDataViewDetailTemplate/index.js +1 -332
- package/dist/presentation/features/templates/FeatureDataViewsTemplate/FeatureDataViewsTemplate.js +1 -342
- package/dist/presentation/features/templates/FeatureDataViewsTemplate/index.js +1 -342
- package/dist/presentation/features/templates/FeatureEventDetailTemplate/FeatureEventDetailTemplate.js +1 -303
- package/dist/presentation/features/templates/FeatureEventDetailTemplate/index.js +1 -303
- package/dist/presentation/features/templates/FeatureEventsTemplate/FeatureEventsTemplate.js +1 -340
- package/dist/presentation/features/templates/FeatureEventsTemplate/index.js +1 -340
- package/dist/presentation/features/templates/FeatureFormDetailTemplate/FeatureFormDetailTemplate.js +1 -329
- package/dist/presentation/features/templates/FeatureFormDetailTemplate/index.js +1 -329
- package/dist/presentation/features/templates/FeatureFormsTemplate/FeatureFormsTemplate.js +1 -340
- package/dist/presentation/features/templates/FeatureFormsTemplate/index.js +1 -340
- package/dist/presentation/features/templates/FeatureOperationDetailTemplate/FeatureOperationDetailTemplate.js +1 -302
- package/dist/presentation/features/templates/FeatureOperationDetailTemplate/index.js +1 -302
- package/dist/presentation/features/templates/FeatureOperationsTemplate/FeatureOperationsTemplate.js +1 -218
- package/dist/presentation/features/templates/FeatureOperationsTemplate/index.js +1 -218
- package/dist/presentation/features/templates/FeatureOverviewTemplate/FeatureOverviewTemplate.js +1 -187
- package/dist/presentation/features/templates/FeatureOverviewTemplate/index.js +1 -187
- package/dist/presentation/features/templates/FeaturePresentationDetailTemplate/FeaturePresentationDetailTemplate.js +1 -306
- package/dist/presentation/features/templates/FeaturePresentationDetailTemplate/index.js +1 -306
- package/dist/presentation/features/templates/FeaturePresentationsTemplate/FeaturePresentationsTemplate.js +1 -342
- package/dist/presentation/features/templates/FeaturePresentationsTemplate/index.js +1 -342
- package/package.json +109 -37
- package/src/components/docs/DocsIndexPage.tsx +55 -0
- package/src/components/docs/architecture/ArchitectureControlPlanePage.tsx +19 -0
- package/src/components/docs/architecture/ArchitectureOverviewPage.tsx +34 -0
- package/src/components/docs/docsManifest.test.ts +70 -0
- package/src/components/docs/docsManifest.ts +71 -1
- package/src/components/docs/ecosystem/PluginsPage.tsx +24 -10
- package/src/components/docs/ecosystem/RegistryPage.tsx +11 -6
- package/src/components/docs/generated/docs-index._common.json +206 -273
- package/src/components/docs/generated/docs-index.control-plane.json +18 -0
- package/src/components/docs/generated/docs-index.defineExample.json +10 -0
- package/src/components/docs/generated/docs-index.manifest.json +22 -12
- package/src/components/docs/generated/docs-index.platform-acp.json +64 -0
- package/src/components/docs/generated/docs-index.platform-agent.json +89 -1
- package/src/components/docs/generated/docs-index.platform-context.json +48 -0
- package/src/components/docs/generated/docs-index.platform-control-plane.json +72 -0
- package/src/components/docs/generated/docs-index.platform-database.json +40 -0
- package/src/components/docs/generated/docs-index.platform-docs.json +64 -0
- package/src/components/docs/generated/docs-index.platform-provider-ranking.json +89 -1
- package/src/components/docs/generated/docs-index.pocket-family-office.json +8 -0
- package/src/components/docs/generated/docs-index.unknown.json +8 -0
- package/src/components/docs/guides/GuideConnectInRepoPage.tsx +184 -0
- package/src/components/docs/guides/GuideFirstModuleBundlePage.tsx +182 -0
- package/src/components/docs/guides/GuideHostBuilderWorkbenchPage.tsx +230 -0
- package/src/components/docs/guides/GuidesIndexPage.tsx +21 -0
- package/src/components/docs/guides/index.ts +3 -0
- package/src/components/docs/specs/SpecsBuilderControlPlanePage.tsx +210 -0
- package/src/components/docs/specs/SpecsConnectPage.tsx +162 -0
- package/src/components/docs/specs/SpecsModuleBundlesPage.tsx +223 -0
- package/src/components/docs/specs/SpecsOverlaysPage.tsx +20 -0
- package/src/components/docs/specs/SpecsOverviewPage.tsx +44 -0
- package/src/components/docs/specs/SpecsWorkflowsPage.tsx +9 -1
- package/src/components/docs/specs/index.ts +3 -0
- package/src/components/docs/studio/StudioOverviewPage.tsx +26 -0
- package/src/infrastructure/elysia/logger.ts +11 -3
|
@@ -1,207 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
var DOCS_INDEX_MANIFEST = "docs-index.manifest.json";
|
|
1
|
+
var P="docs-index.manifest.json";import{readFile as g}from"node:fs/promises";import{dirname as w,join as d}from"node:path";import{fileURLToPath as C}from"node:url";var u=w(C(import.meta.url)),f=null,a=null,m=new Map;function R(n){if(!n)return"_common";if(n.includes("/")){let[o]=n.split("/");return o||"_common"}return"_common"}async function I(){if(!f)f=g(d(u,P),"utf8").then((n)=>JSON.parse(n));return f}function N(n){let o=n.contentRoot??".";return d(u,o)}async function h(n){let o=m.get(n);if(o)return o;let s=g(d(u,n),"utf8").then((i)=>JSON.parse(i));return m.set(n,s),s}async function k(){if(!a)a=(async()=>{let n=await I();return(await Promise.all(n.chunks.map((s)=>h(s.file)))).flat()})();return a}async function b(){return I()}async function Q(n){let o=await I(),s=R(n),i=o.chunks.find((c)=>c.key===s);if(!i)return null;let r=(await h(i.file)).find((c)=>c.id===n);if(!r||!r.contentPath)return null;let t=d(N(o),r.contentPath);try{let c=await g(t,"utf8");return{entry:r,content:c}}catch{return null}}import{DocsIndexDataView as O,DocsSearchForm as A}from"@contractspec/lib.contracts-spec/docs";import{DataViewList as G,formRenderer as T,StatusChip as D}from"@contractspec/lib.design-system";import{HStack as J,VStack as l}from"@contractspec/lib.ui-kit-web/ui/stack";import{H1 as X,Muted as E}from"@contractspec/lib.ui-kit-web/ui/typography";import{useMemo as M,useState as v}from"react";import{jsx as e,jsxs as p}from"react/jsx-runtime";function B(n){if(!n)return;return n.replace(/<!--.*?-->/g,"").replace(/[ \t]+/g," ").replace(/\n{3,}/g,`
|
|
3
2
|
|
|
4
|
-
|
|
5
|
-
import { readFile } from "node:fs/promises";
|
|
6
|
-
import { dirname, join } from "node:path";
|
|
7
|
-
import { fileURLToPath } from "node:url";
|
|
8
|
-
var baseDir = dirname(fileURLToPath(import.meta.url));
|
|
9
|
-
var manifestPromise = null;
|
|
10
|
-
var docsPromise = null;
|
|
11
|
-
var chunkCache = new Map;
|
|
12
|
-
function chunkKeyForId(id) {
|
|
13
|
-
if (!id)
|
|
14
|
-
return "_common";
|
|
15
|
-
if (id.includes("/")) {
|
|
16
|
-
const [prefix] = id.split("/");
|
|
17
|
-
return prefix || "_common";
|
|
18
|
-
}
|
|
19
|
-
return "_common";
|
|
20
|
-
}
|
|
21
|
-
async function loadManifest() {
|
|
22
|
-
if (!manifestPromise) {
|
|
23
|
-
manifestPromise = readFile(join(baseDir, DOCS_INDEX_MANIFEST), "utf8").then((content) => JSON.parse(content));
|
|
24
|
-
}
|
|
25
|
-
return manifestPromise;
|
|
26
|
-
}
|
|
27
|
-
function resolveContentRoot(manifest) {
|
|
28
|
-
const root = manifest.contentRoot ?? ".";
|
|
29
|
-
return join(baseDir, root);
|
|
30
|
-
}
|
|
31
|
-
async function loadChunk(fileName) {
|
|
32
|
-
const cached = chunkCache.get(fileName);
|
|
33
|
-
if (cached)
|
|
34
|
-
return cached;
|
|
35
|
-
const load = readFile(join(baseDir, fileName), "utf8").then((content) => JSON.parse(content));
|
|
36
|
-
chunkCache.set(fileName, load);
|
|
37
|
-
return load;
|
|
38
|
-
}
|
|
39
|
-
async function listGeneratedDocs() {
|
|
40
|
-
if (!docsPromise) {
|
|
41
|
-
docsPromise = (async () => {
|
|
42
|
-
const manifest = await loadManifest();
|
|
43
|
-
const chunks = await Promise.all(manifest.chunks.map((chunk) => loadChunk(chunk.file)));
|
|
44
|
-
return chunks.flat();
|
|
45
|
-
})();
|
|
46
|
-
}
|
|
47
|
-
return docsPromise;
|
|
48
|
-
}
|
|
49
|
-
async function getDocsIndexManifest() {
|
|
50
|
-
return loadManifest();
|
|
51
|
-
}
|
|
52
|
-
async function getGeneratedDocById(id) {
|
|
53
|
-
const manifest = await loadManifest();
|
|
54
|
-
const key = chunkKeyForId(id);
|
|
55
|
-
const chunk = manifest.chunks.find((item) => item.key === key);
|
|
56
|
-
if (!chunk)
|
|
57
|
-
return null;
|
|
58
|
-
const entries = await loadChunk(chunk.file);
|
|
59
|
-
const entry = entries.find((doc) => doc.id === id);
|
|
60
|
-
if (!entry || !entry.contentPath)
|
|
61
|
-
return null;
|
|
62
|
-
const contentPath = join(resolveContentRoot(manifest), entry.contentPath);
|
|
63
|
-
try {
|
|
64
|
-
const content = await readFile(contentPath, "utf8");
|
|
65
|
-
return { entry, content };
|
|
66
|
-
} catch {
|
|
67
|
-
return null;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
// src/components/docs/reference/DocsReferenceIndexClient.tsx
|
|
72
|
-
import {
|
|
73
|
-
DocsIndexDataView,
|
|
74
|
-
DocsSearchForm
|
|
75
|
-
} from "@contractspec/lib.contracts-spec/docs";
|
|
76
|
-
import {
|
|
77
|
-
DataViewList,
|
|
78
|
-
formRenderer,
|
|
79
|
-
StatusChip
|
|
80
|
-
} from "@contractspec/lib.design-system";
|
|
81
|
-
import { HStack, VStack } from "@contractspec/lib.ui-kit-web/ui/stack";
|
|
82
|
-
import { H1, Muted } from "@contractspec/lib.ui-kit-web/ui/typography";
|
|
83
|
-
import { useMemo, useState } from "react";
|
|
84
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
85
|
-
"use client";
|
|
86
|
-
function cleanSummary(summary) {
|
|
87
|
-
if (!summary)
|
|
88
|
-
return;
|
|
89
|
-
return summary.replace(/<!--.*?-->/g, "").replace(/[ \t]+/g, " ").replace(/\n{3,}/g, `
|
|
90
|
-
|
|
91
|
-
`).trim();
|
|
92
|
-
}
|
|
93
|
-
function normalizeEntry(entry) {
|
|
94
|
-
const summary = cleanSummary(entry.summary);
|
|
95
|
-
const kind = entry.kind ?? (entry.source === "generated" ? "reference" : undefined);
|
|
96
|
-
const visibility = entry.visibility ?? (entry.source === "generated" ? "public" : undefined);
|
|
97
|
-
return {
|
|
98
|
-
...entry,
|
|
99
|
-
summary,
|
|
100
|
-
kind,
|
|
101
|
-
visibility
|
|
102
|
-
};
|
|
103
|
-
}
|
|
104
|
-
function matchesQuery(entry, query) {
|
|
105
|
-
if (!query)
|
|
106
|
-
return true;
|
|
107
|
-
const haystack = [entry.title, entry.summary, entry.id, ...entry.tags ?? []].filter(Boolean).join(" ").toLowerCase();
|
|
108
|
-
return haystack.includes(query.toLowerCase());
|
|
109
|
-
}
|
|
110
|
-
function DocsReferenceIndexClient({
|
|
111
|
-
entries
|
|
112
|
-
}) {
|
|
113
|
-
const [filters, setFilters] = useState({});
|
|
114
|
-
const normalizedEntries = useMemo(() => entries.map(normalizeEntry), [entries]);
|
|
115
|
-
const filteredEntries = useMemo(() => {
|
|
116
|
-
const query = filters.query?.trim() ?? "";
|
|
117
|
-
return normalizedEntries.filter((entry) => {
|
|
118
|
-
if (filters.kind && entry.kind !== filters.kind)
|
|
119
|
-
return false;
|
|
120
|
-
if (filters.visibility && entry.visibility !== filters.visibility)
|
|
121
|
-
return false;
|
|
122
|
-
return matchesQuery(entry, query);
|
|
123
|
-
});
|
|
124
|
-
}, [filters, normalizedEntries]);
|
|
125
|
-
const searchForm = formRenderer.render(DocsSearchForm, {
|
|
126
|
-
defaultValues: {
|
|
127
|
-
query: filters.query ?? "",
|
|
128
|
-
visibility: filters.visibility ?? "",
|
|
129
|
-
kind: filters.kind ?? ""
|
|
130
|
-
},
|
|
131
|
-
overrides: {
|
|
132
|
-
onSubmitOverride: (values) => {
|
|
133
|
-
const submitted = values;
|
|
134
|
-
setFilters({
|
|
135
|
-
query: submitted.query ?? "",
|
|
136
|
-
visibility: submitted.visibility ?? "",
|
|
137
|
-
kind: submitted.kind ?? ""
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
});
|
|
142
|
-
return /* @__PURE__ */ jsxs(VStack, {
|
|
143
|
-
gap: "xl",
|
|
144
|
-
children: [
|
|
145
|
-
/* @__PURE__ */ jsxs(VStack, {
|
|
146
|
-
gap: "sm",
|
|
147
|
-
children: [
|
|
148
|
-
/* @__PURE__ */ jsx(H1, {
|
|
149
|
-
children: "Reference"
|
|
150
|
-
}),
|
|
151
|
-
/* @__PURE__ */ jsx(Muted, {
|
|
152
|
-
children: "Generated reference material for public contract surfaces, versions, owners, and example-backed implementations. Use this when you need the repo truth, not just the narrative docs layer."
|
|
153
|
-
})
|
|
154
|
-
]
|
|
155
|
-
}),
|
|
156
|
-
/* @__PURE__ */ jsx(VStack, {
|
|
157
|
-
gap: "sm",
|
|
158
|
-
className: "max-w-2xl",
|
|
159
|
-
children: searchForm
|
|
160
|
-
}),
|
|
161
|
-
/* @__PURE__ */ jsx(DataViewList, {
|
|
162
|
-
spec: DocsIndexDataView,
|
|
163
|
-
items: filteredEntries,
|
|
164
|
-
emptyState: /* @__PURE__ */ jsx(Muted, {
|
|
165
|
-
children: "No reference docs match your filters."
|
|
166
|
-
}),
|
|
167
|
-
onSelect: (entry) => {
|
|
168
|
-
if (entry.route) {
|
|
169
|
-
window.location.assign(entry.route);
|
|
170
|
-
}
|
|
171
|
-
},
|
|
172
|
-
renderActions: (entry) => {
|
|
173
|
-
return /* @__PURE__ */ jsxs(HStack, {
|
|
174
|
-
gap: "xs",
|
|
175
|
-
justify: "end",
|
|
176
|
-
children: [
|
|
177
|
-
entry.kind ? /* @__PURE__ */ jsx(StatusChip, {
|
|
178
|
-
size: "sm",
|
|
179
|
-
label: entry.kind
|
|
180
|
-
}) : null,
|
|
181
|
-
entry.visibility ? /* @__PURE__ */ jsx(StatusChip, {
|
|
182
|
-
size: "sm",
|
|
183
|
-
label: entry.visibility
|
|
184
|
-
}) : null,
|
|
185
|
-
entry.version ? /* @__PURE__ */ jsx(StatusChip, {
|
|
186
|
-
size: "sm",
|
|
187
|
-
label: `v${entry.version}`
|
|
188
|
-
}) : null
|
|
189
|
-
]
|
|
190
|
-
});
|
|
191
|
-
}
|
|
192
|
-
})
|
|
193
|
-
]
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
// src/components/docs/reference/DocsReferenceIndexPage.tsx
|
|
198
|
-
import { jsx as jsx2 } from "react/jsx-runtime";
|
|
199
|
-
async function DocsReferenceIndexPage() {
|
|
200
|
-
const entries = await listGeneratedDocs();
|
|
201
|
-
return /* @__PURE__ */ jsx2(DocsReferenceIndexClient, {
|
|
202
|
-
entries
|
|
203
|
-
});
|
|
204
|
-
}
|
|
205
|
-
export {
|
|
206
|
-
DocsReferenceIndexPage
|
|
207
|
-
};
|
|
3
|
+
`).trim()}function F(n){let o=B(n.summary),s=n.kind??(n.source==="generated"?"reference":void 0),i=n.visibility??(n.source==="generated"?"public":void 0);return{...n,summary:o,kind:s,visibility:i}}function K(n,o){if(!o)return!0;return[n.title,n.summary,n.id,...n.tags??[]].filter(Boolean).join(" ").toLowerCase().includes(o.toLowerCase())}function _({entries:n}){let[o,s]=v({}),i=M(()=>n.map(F),[n]),x=M(()=>{let t=o.query?.trim()??"";return i.filter((c)=>{if(o.kind&&c.kind!==o.kind)return!1;if(o.visibility&&c.visibility!==o.visibility)return!1;return K(c,t)})},[o,i]),r=T.render(A,{defaultValues:{query:o.query??"",visibility:o.visibility??"",kind:o.kind??""},overrides:{onSubmitOverride:(t)=>{let c=t;s({query:c.query??"",visibility:c.visibility??"",kind:c.kind??""})}}});return p(l,{gap:"xl",children:[p(l,{gap:"sm",children:[e(X,{children:"Reference"}),e(E,{children:"Generated reference material for public contract surfaces, versions, owners, and example-backed implementations. Use this when you need the repo truth, not just the narrative docs layer."})]}),e(l,{gap:"sm",className:"max-w-2xl",children:r}),e(G,{spec:O,items:x,emptyState:e(E,{children:"No reference docs match your filters."}),onSelect:(t)=>{if(t.route)window.location.assign(t.route)},renderActions:(t)=>{return p(J,{gap:"xs",justify:"end",children:[t.kind?e(D,{size:"sm",label:t.kind}):null,t.visibility?e(D,{size:"sm",label:t.visibility}):null,t.version?e(D,{size:"sm",label:`v${t.version}`}):null]})}})]})}import{jsx as U}from"react/jsx-runtime";async function cn(){let n=await k();return U(_,{entries:n})}export{cn as DocsReferenceIndexPage};
|
|
@@ -1,266 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
function stripMetadata(content) {
|
|
4
|
-
const withoutTitle = content.replace(/^#\s+.*\n+/m, "");
|
|
5
|
-
return withoutTitle.replace(METADATA_SECTION, "");
|
|
6
|
-
}
|
|
7
|
-
function isBlockStart(line) {
|
|
8
|
-
return /^#{1,4}\s+/.test(line) || /^```/.test(line) || /^\s*[-*]\s+/.test(line) || /^\s*\d+\.\s+/.test(line) || /^>\s+/.test(line);
|
|
9
|
-
}
|
|
10
|
-
function parseDocsMarkdown(content) {
|
|
11
|
-
const lines = stripMetadata(content).split(/\r?\n/);
|
|
12
|
-
const blocks = [];
|
|
13
|
-
let i = 0;
|
|
14
|
-
while (i < lines.length) {
|
|
15
|
-
const line = lines[i] ?? "";
|
|
16
|
-
if (line.startsWith("<!-- @generated")) {
|
|
17
|
-
i += 1;
|
|
18
|
-
continue;
|
|
19
|
-
}
|
|
20
|
-
const trimmed = line.trim();
|
|
21
|
-
if (!trimmed) {
|
|
22
|
-
i += 1;
|
|
23
|
-
continue;
|
|
24
|
-
}
|
|
25
|
-
if (trimmed.startsWith("```")) {
|
|
26
|
-
const language = trimmed.slice(3).trim();
|
|
27
|
-
const codeLines = [];
|
|
28
|
-
i += 1;
|
|
29
|
-
while (i < lines.length && !(lines[i] ?? "").trim().startsWith("```")) {
|
|
30
|
-
codeLines.push(lines[i] ?? "");
|
|
31
|
-
i += 1;
|
|
32
|
-
}
|
|
33
|
-
i += 1;
|
|
34
|
-
blocks.push({
|
|
35
|
-
type: "code",
|
|
36
|
-
language: language || "text",
|
|
37
|
-
code: codeLines.join(`
|
|
38
|
-
`)
|
|
39
|
-
});
|
|
40
|
-
continue;
|
|
41
|
-
}
|
|
42
|
-
if (/^#{1,4}\s+/.test(trimmed)) {
|
|
43
|
-
const level = trimmed.match(/^#{1,4}/)?.[0].length ?? 2;
|
|
44
|
-
blocks.push({
|
|
45
|
-
type: "heading",
|
|
46
|
-
level,
|
|
47
|
-
text: trimmed.replace(/^#{1,4}\s+/, "")
|
|
48
|
-
});
|
|
49
|
-
i += 1;
|
|
50
|
-
continue;
|
|
51
|
-
}
|
|
52
|
-
if (/^>\s+/.test(trimmed)) {
|
|
53
|
-
const quoteLines = [];
|
|
54
|
-
while (i < lines.length && /^>\s+/.test((lines[i] ?? "").trim())) {
|
|
55
|
-
quoteLines.push((lines[i] ?? "").trim().replace(/^>\s+/, ""));
|
|
56
|
-
i += 1;
|
|
57
|
-
}
|
|
58
|
-
blocks.push({ type: "quote", text: quoteLines.join(" ") });
|
|
59
|
-
continue;
|
|
60
|
-
}
|
|
61
|
-
if (/^[-*]\s+/.test(trimmed) || /^\d+\.\s+/.test(trimmed)) {
|
|
62
|
-
const ordered = /^\d+\.\s+/.test(trimmed);
|
|
63
|
-
const items = [];
|
|
64
|
-
while (i < lines.length && isBlockStart((lines[i] ?? "").trim())) {
|
|
65
|
-
const itemLine = (lines[i] ?? "").trim();
|
|
66
|
-
if (ordered && /^\d+\.\s+/.test(itemLine)) {
|
|
67
|
-
items.push(itemLine.replace(/^\d+\.\s+/, ""));
|
|
68
|
-
} else if (!ordered && /^[-*]\s+/.test(itemLine)) {
|
|
69
|
-
items.push(itemLine.replace(/^[-*]\s+/, ""));
|
|
70
|
-
} else {
|
|
71
|
-
break;
|
|
72
|
-
}
|
|
73
|
-
i += 1;
|
|
74
|
-
}
|
|
75
|
-
blocks.push({ type: "list", ordered, items });
|
|
76
|
-
continue;
|
|
77
|
-
}
|
|
78
|
-
const paragraphLines = [];
|
|
79
|
-
while (i < lines.length && !isBlockStart((lines[i] ?? "").trim())) {
|
|
80
|
-
const paragraphLine = (lines[i] ?? "").trim();
|
|
81
|
-
if (!paragraphLine)
|
|
82
|
-
break;
|
|
83
|
-
paragraphLines.push(paragraphLine);
|
|
84
|
-
i += 1;
|
|
85
|
-
}
|
|
86
|
-
blocks.push({ type: "paragraph", text: paragraphLines.join(" ") });
|
|
87
|
-
}
|
|
88
|
-
return blocks;
|
|
89
|
-
}
|
|
1
|
+
var F=/^##\s+Metadata[\s\S]*?(?=^##\s|^#\s|Z)/m;function J(p){return p.replace(/^#\s+.*\n+/m,"").replace(F,"")}function D(p){return/^#{1,4}\s+/.test(p)||/^```/.test(p)||/^\s*[-*]\s+/.test(p)||/^\s*\d+\.\s+/.test(p)||/^>\s+/.test(p)}function E(p){let s=J(p).split(/\r?\n/),h=[],i=0;while(i<s.length){let u=s[i]??"";if(u.startsWith("<!-- @generated")){i+=1;continue}let t=u.trim();if(!t){i+=1;continue}if(t.startsWith("```")){let g=t.slice(3).trim(),f=[];i+=1;while(i<s.length&&!(s[i]??"").trim().startsWith("```"))f.push(s[i]??""),i+=1;i+=1,h.push({type:"code",language:g||"text",code:f.join(`
|
|
2
|
+
`)});continue}if(/^#{1,4}\s+/.test(t)){let g=t.match(/^#{1,4}/)?.[0].length??2;h.push({type:"heading",level:g,text:t.replace(/^#{1,4}\s+/,"")}),i+=1;continue}if(/^>\s+/.test(t)){let g=[];while(i<s.length&&/^>\s+/.test((s[i]??"").trim()))g.push((s[i]??"").trim().replace(/^>\s+/,"")),i+=1;h.push({type:"quote",text:g.join(" ")});continue}if(/^[-*]\s+/.test(t)||/^\d+\.\s+/.test(t)){let g=/^\d+\.\s+/.test(t),f=[];while(i<s.length&&D((s[i]??"").trim())){let o=(s[i]??"").trim();if(g&&/^\d+\.\s+/.test(o))f.push(o.replace(/^\d+\.\s+/,""));else if(!g&&/^[-*]\s+/.test(o))f.push(o.replace(/^[-*]\s+/,""));else break;i+=1}h.push({type:"list",ordered:g,items:f});continue}let q=[];while(i<s.length&&!D((s[i]??"").trim())){let g=(s[i]??"").trim();if(!g)break;q.push(g),i+=1}h.push({type:"paragraph",text:q.join(" ")})}return h}import{CodeBlock as K}from"@contractspec/lib.design-system";import{HStack as N,VStack as B}from"@contractspec/lib.ui-kit-web/ui/stack";import{BlockQuote as O,H2 as X,H3 as Y,H4 as _,Muted as P,P as d}from"@contractspec/lib.ui-kit-web/ui/typography";import{jsx as r,jsxs as U}from"react/jsx-runtime";var $=new Set(["typescript","tsx","javascript","jsx","bash","shell","json","yaml","graphql","sql","python","go","rust","css","scss","html","markdown","text"]);function Q(p){if(!p)return"text";let s=p.toLowerCase();return $.has(s)?s:"text"}function R(p,s){if(p<=2)return r(X,{children:s});if(p===3)return r(Y,{children:s});return r(_,{children:s})}function e({content:p}){let s=E(p);if(!s.length)return r(P,{children:"No reference content available."});return r(B,{gap:"md",children:s.map((h,i)=>{switch(h.type){case"heading":return r(B,{children:R(h.level,h.text)},i);case"paragraph":return r(d,{children:h.text},i);case"quote":return r(O,{children:h.text},i);case"code":return r(K,{language:Q(h.language),code:h.code},i);case"list":return r(B,{gap:"xs",children:h.items.map((u,t)=>U(N,{gap:"sm",align:"start",children:[r(P,{children:h.ordered?`${t+1}.`:"•"}),r(d,{className:"leading-relaxed",children:u})]},t))},i);default:return null}})})}import{ContractReferenceDataView as L}from"@contractspec/lib.contracts-spec/docs";import{DataViewRenderer as z}from"@contractspec/lib.design-system";import{VStack as G}from"@contractspec/lib.ui-kit-web/ui/stack";import{jsx as A,jsxs as n}from"react/jsx-runtime";function T(p,s){return p.match(new RegExp(`- \\*\\*${s}\\*\\*: (.+)`,"i"))?.[1]?.trim()}function I(p){if(!p)return;return p.replace(/<!--.*?-->/g,"").replace(/[ \t]+/g," ").replace(/\n{3,}/g,`
|
|
90
3
|
|
|
91
|
-
|
|
92
|
-
import { CodeBlock } from "@contractspec/lib.design-system";
|
|
93
|
-
import { HStack, VStack } from "@contractspec/lib.ui-kit-web/ui/stack";
|
|
94
|
-
import {
|
|
95
|
-
BlockQuote,
|
|
96
|
-
H2,
|
|
97
|
-
H3,
|
|
98
|
-
H4,
|
|
99
|
-
Muted,
|
|
100
|
-
P
|
|
101
|
-
} from "@contractspec/lib.ui-kit-web/ui/typography";
|
|
102
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
103
|
-
"use client";
|
|
104
|
-
var CODE_LANGUAGES = new Set([
|
|
105
|
-
"typescript",
|
|
106
|
-
"tsx",
|
|
107
|
-
"javascript",
|
|
108
|
-
"jsx",
|
|
109
|
-
"bash",
|
|
110
|
-
"shell",
|
|
111
|
-
"json",
|
|
112
|
-
"yaml",
|
|
113
|
-
"graphql",
|
|
114
|
-
"sql",
|
|
115
|
-
"python",
|
|
116
|
-
"go",
|
|
117
|
-
"rust",
|
|
118
|
-
"css",
|
|
119
|
-
"scss",
|
|
120
|
-
"html",
|
|
121
|
-
"markdown",
|
|
122
|
-
"text"
|
|
123
|
-
]);
|
|
124
|
-
function toCodeLanguage(language) {
|
|
125
|
-
if (!language)
|
|
126
|
-
return "text";
|
|
127
|
-
const normalized = language.toLowerCase();
|
|
128
|
-
return CODE_LANGUAGES.has(normalized) ? normalized : "text";
|
|
129
|
-
}
|
|
130
|
-
function renderHeading(level, text) {
|
|
131
|
-
if (level <= 2)
|
|
132
|
-
return /* @__PURE__ */ jsx(H2, {
|
|
133
|
-
children: text
|
|
134
|
-
});
|
|
135
|
-
if (level === 3)
|
|
136
|
-
return /* @__PURE__ */ jsx(H3, {
|
|
137
|
-
children: text
|
|
138
|
-
});
|
|
139
|
-
return /* @__PURE__ */ jsx(H4, {
|
|
140
|
-
children: text
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
function DocsMarkdownContent({ content }) {
|
|
144
|
-
const blocks = parseDocsMarkdown(content);
|
|
145
|
-
if (!blocks.length) {
|
|
146
|
-
return /* @__PURE__ */ jsx(Muted, {
|
|
147
|
-
children: "No reference content available."
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
return /* @__PURE__ */ jsx(VStack, {
|
|
151
|
-
gap: "md",
|
|
152
|
-
children: blocks.map((block, index) => {
|
|
153
|
-
switch (block.type) {
|
|
154
|
-
case "heading":
|
|
155
|
-
return /* @__PURE__ */ jsx(VStack, {
|
|
156
|
-
children: renderHeading(block.level, block.text)
|
|
157
|
-
}, index);
|
|
158
|
-
case "paragraph":
|
|
159
|
-
return /* @__PURE__ */ jsx(P, {
|
|
160
|
-
children: block.text
|
|
161
|
-
}, index);
|
|
162
|
-
case "quote":
|
|
163
|
-
return /* @__PURE__ */ jsx(BlockQuote, {
|
|
164
|
-
children: block.text
|
|
165
|
-
}, index);
|
|
166
|
-
case "code":
|
|
167
|
-
return /* @__PURE__ */ jsx(CodeBlock, {
|
|
168
|
-
language: toCodeLanguage(block.language),
|
|
169
|
-
code: block.code
|
|
170
|
-
}, index);
|
|
171
|
-
case "list":
|
|
172
|
-
return /* @__PURE__ */ jsx(VStack, {
|
|
173
|
-
gap: "xs",
|
|
174
|
-
children: block.items.map((item, itemIndex) => /* @__PURE__ */ jsxs(HStack, {
|
|
175
|
-
gap: "sm",
|
|
176
|
-
align: "start",
|
|
177
|
-
children: [
|
|
178
|
-
/* @__PURE__ */ jsx(Muted, {
|
|
179
|
-
children: block.ordered ? `${itemIndex + 1}.` : "•"
|
|
180
|
-
}),
|
|
181
|
-
/* @__PURE__ */ jsx(P, {
|
|
182
|
-
className: "leading-relaxed",
|
|
183
|
-
children: item
|
|
184
|
-
})
|
|
185
|
-
]
|
|
186
|
-
}, itemIndex))
|
|
187
|
-
}, index);
|
|
188
|
-
default:
|
|
189
|
-
return null;
|
|
190
|
-
}
|
|
191
|
-
})
|
|
192
|
-
});
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
// src/components/docs/reference/DocsReferenceContent.tsx
|
|
196
|
-
import { ContractReferenceDataView } from "@contractspec/lib.contracts-spec/docs";
|
|
197
|
-
import { DataViewRenderer } from "@contractspec/lib.design-system";
|
|
198
|
-
import { VStack as VStack2 } from "@contractspec/lib.ui-kit-web/ui/stack";
|
|
199
|
-
import { jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime";
|
|
200
|
-
"use client";
|
|
201
|
-
function extractMeta(content, label) {
|
|
202
|
-
const match = content.match(new RegExp(`- \\*\\*${label}\\*\\*: (.+)`, "i"));
|
|
203
|
-
return match?.[1]?.trim();
|
|
204
|
-
}
|
|
205
|
-
function cleanSummary(summary) {
|
|
206
|
-
if (!summary)
|
|
207
|
-
return;
|
|
208
|
-
return summary.replace(/<!--.*?-->/g, "").replace(/[ \t]+/g, " ").replace(/\n{3,}/g, `
|
|
209
|
-
|
|
210
|
-
`).trim();
|
|
211
|
-
}
|
|
212
|
-
function DocsReferenceContent({
|
|
213
|
-
entry,
|
|
214
|
-
content
|
|
215
|
-
}) {
|
|
216
|
-
const summary = cleanSummary(entry.summary);
|
|
217
|
-
const type = extractMeta(content, "Type");
|
|
218
|
-
const version = extractMeta(content, "Version") ?? entry.version;
|
|
219
|
-
const tags = extractMeta(content, "Tags")?.split(",").map((tag) => tag.trim()).filter(Boolean);
|
|
220
|
-
const owners = extractMeta(content, "Owners")?.split(",").map((owner) => owner.trim()).filter(Boolean);
|
|
221
|
-
const stability = extractMeta(content, "Stability") ?? entry.visibility;
|
|
222
|
-
const referenceItem = {
|
|
223
|
-
reference: {
|
|
224
|
-
key: entry.title ?? entry.id,
|
|
225
|
-
version,
|
|
226
|
-
type,
|
|
227
|
-
title: entry.title ?? entry.id,
|
|
228
|
-
description: summary,
|
|
229
|
-
tags: tags ?? entry.tags,
|
|
230
|
-
owners: owners ?? entry.owners,
|
|
231
|
-
stability
|
|
232
|
-
}
|
|
233
|
-
};
|
|
234
|
-
const detailSpec = {
|
|
235
|
-
...ContractReferenceDataView,
|
|
236
|
-
meta: {
|
|
237
|
-
...ContractReferenceDataView.meta,
|
|
238
|
-
title: entry.title ?? ContractReferenceDataView.meta.title,
|
|
239
|
-
description: summary ?? ContractReferenceDataView.meta.description
|
|
240
|
-
}
|
|
241
|
-
};
|
|
242
|
-
return /* @__PURE__ */ jsxs2(VStack2, {
|
|
243
|
-
gap: "xl",
|
|
244
|
-
children: [
|
|
245
|
-
/* @__PURE__ */ jsx2(DataViewRenderer, {
|
|
246
|
-
spec: detailSpec,
|
|
247
|
-
item: referenceItem
|
|
248
|
-
}),
|
|
249
|
-
/* @__PURE__ */ jsx2(DocsMarkdownContent, {
|
|
250
|
-
content
|
|
251
|
-
})
|
|
252
|
-
]
|
|
253
|
-
});
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
// src/components/docs/reference/DocsReferencePage.tsx
|
|
257
|
-
import { jsx as jsx3 } from "react/jsx-runtime";
|
|
258
|
-
function DocsReferencePage({ entry, content }) {
|
|
259
|
-
return /* @__PURE__ */ jsx3(DocsReferenceContent, {
|
|
260
|
-
entry,
|
|
261
|
-
content
|
|
262
|
-
});
|
|
263
|
-
}
|
|
264
|
-
export {
|
|
265
|
-
DocsReferencePage
|
|
266
|
-
};
|
|
4
|
+
`).trim()}function Z({entry:p,content:s}){let h=I(p.summary),i=T(s,"Type"),u=T(s,"Version")??p.version,t=T(s,"Tags")?.split(",").map((W)=>W.trim()).filter(Boolean),q=T(s,"Owners")?.split(",").map((W)=>W.trim()).filter(Boolean),g=T(s,"Stability")??p.visibility,f={reference:{key:p.title??p.id,version:u,type:i,title:p.title??p.id,description:h,tags:t??p.tags,owners:q??p.owners,stability:g}},o={...L,meta:{...L.meta,title:p.title??L.meta.title,description:h??L.meta.description}};return n(G,{gap:"xl",children:[A(z,{spec:o,item:f}),A(e,{content:s})]})}import{jsx as v}from"react/jsx-runtime";function x({entry:p,content:s}){return v(Z,{entry:p,content:s})}export{x as DocsReferencePage};
|
|
@@ -1,92 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
function stripMetadata(content) {
|
|
4
|
-
const withoutTitle = content.replace(/^#\s+.*\n+/m, "");
|
|
5
|
-
return withoutTitle.replace(METADATA_SECTION, "");
|
|
6
|
-
}
|
|
7
|
-
function isBlockStart(line) {
|
|
8
|
-
return /^#{1,4}\s+/.test(line) || /^```/.test(line) || /^\s*[-*]\s+/.test(line) || /^\s*\d+\.\s+/.test(line) || /^>\s+/.test(line);
|
|
9
|
-
}
|
|
10
|
-
function parseDocsMarkdown(content) {
|
|
11
|
-
const lines = stripMetadata(content).split(/\r?\n/);
|
|
12
|
-
const blocks = [];
|
|
13
|
-
let i = 0;
|
|
14
|
-
while (i < lines.length) {
|
|
15
|
-
const line = lines[i] ?? "";
|
|
16
|
-
if (line.startsWith("<!-- @generated")) {
|
|
17
|
-
i += 1;
|
|
18
|
-
continue;
|
|
19
|
-
}
|
|
20
|
-
const trimmed = line.trim();
|
|
21
|
-
if (!trimmed) {
|
|
22
|
-
i += 1;
|
|
23
|
-
continue;
|
|
24
|
-
}
|
|
25
|
-
if (trimmed.startsWith("```")) {
|
|
26
|
-
const language = trimmed.slice(3).trim();
|
|
27
|
-
const codeLines = [];
|
|
28
|
-
i += 1;
|
|
29
|
-
while (i < lines.length && !(lines[i] ?? "").trim().startsWith("```")) {
|
|
30
|
-
codeLines.push(lines[i] ?? "");
|
|
31
|
-
i += 1;
|
|
32
|
-
}
|
|
33
|
-
i += 1;
|
|
34
|
-
blocks.push({
|
|
35
|
-
type: "code",
|
|
36
|
-
language: language || "text",
|
|
37
|
-
code: codeLines.join(`
|
|
38
|
-
`)
|
|
39
|
-
});
|
|
40
|
-
continue;
|
|
41
|
-
}
|
|
42
|
-
if (/^#{1,4}\s+/.test(trimmed)) {
|
|
43
|
-
const level = trimmed.match(/^#{1,4}/)?.[0].length ?? 2;
|
|
44
|
-
blocks.push({
|
|
45
|
-
type: "heading",
|
|
46
|
-
level,
|
|
47
|
-
text: trimmed.replace(/^#{1,4}\s+/, "")
|
|
48
|
-
});
|
|
49
|
-
i += 1;
|
|
50
|
-
continue;
|
|
51
|
-
}
|
|
52
|
-
if (/^>\s+/.test(trimmed)) {
|
|
53
|
-
const quoteLines = [];
|
|
54
|
-
while (i < lines.length && /^>\s+/.test((lines[i] ?? "").trim())) {
|
|
55
|
-
quoteLines.push((lines[i] ?? "").trim().replace(/^>\s+/, ""));
|
|
56
|
-
i += 1;
|
|
57
|
-
}
|
|
58
|
-
blocks.push({ type: "quote", text: quoteLines.join(" ") });
|
|
59
|
-
continue;
|
|
60
|
-
}
|
|
61
|
-
if (/^[-*]\s+/.test(trimmed) || /^\d+\.\s+/.test(trimmed)) {
|
|
62
|
-
const ordered = /^\d+\.\s+/.test(trimmed);
|
|
63
|
-
const items = [];
|
|
64
|
-
while (i < lines.length && isBlockStart((lines[i] ?? "").trim())) {
|
|
65
|
-
const itemLine = (lines[i] ?? "").trim();
|
|
66
|
-
if (ordered && /^\d+\.\s+/.test(itemLine)) {
|
|
67
|
-
items.push(itemLine.replace(/^\d+\.\s+/, ""));
|
|
68
|
-
} else if (!ordered && /^[-*]\s+/.test(itemLine)) {
|
|
69
|
-
items.push(itemLine.replace(/^[-*]\s+/, ""));
|
|
70
|
-
} else {
|
|
71
|
-
break;
|
|
72
|
-
}
|
|
73
|
-
i += 1;
|
|
74
|
-
}
|
|
75
|
-
blocks.push({ type: "list", ordered, items });
|
|
76
|
-
continue;
|
|
77
|
-
}
|
|
78
|
-
const paragraphLines = [];
|
|
79
|
-
while (i < lines.length && !isBlockStart((lines[i] ?? "").trim())) {
|
|
80
|
-
const paragraphLine = (lines[i] ?? "").trim();
|
|
81
|
-
if (!paragraphLine)
|
|
82
|
-
break;
|
|
83
|
-
paragraphLines.push(paragraphLine);
|
|
84
|
-
i += 1;
|
|
85
|
-
}
|
|
86
|
-
blocks.push({ type: "paragraph", text: paragraphLines.join(" ") });
|
|
87
|
-
}
|
|
88
|
-
return blocks;
|
|
89
|
-
}
|
|
90
|
-
export {
|
|
91
|
-
parseDocsMarkdown
|
|
92
|
-
};
|
|
1
|
+
var h=/^##\s+Metadata[\s\S]*?(?=^##\s|^#\s|Z)/m;function g(i){return i.replace(/^#\s+.*\n+/m,"").replace(h,"")}function l(i){return/^#{1,4}\s+/.test(i)||/^```/.test(i)||/^\s*[-*]\s+/.test(i)||/^\s*\d+\.\s+/.test(i)||/^>\s+/.test(i)}function u(i){let e=g(i).split(/\r?\n/),r=[],t=0;while(t<e.length){let c=e[t]??"";if(c.startsWith("<!-- @generated")){t+=1;continue}let n=c.trim();if(!n){t+=1;continue}if(n.startsWith("```")){let s=n.slice(3).trim(),o=[];t+=1;while(t<e.length&&!(e[t]??"").trim().startsWith("```"))o.push(e[t]??""),t+=1;t+=1,r.push({type:"code",language:s||"text",code:o.join(`
|
|
2
|
+
`)});continue}if(/^#{1,4}\s+/.test(n)){let s=n.match(/^#{1,4}/)?.[0].length??2;r.push({type:"heading",level:s,text:n.replace(/^#{1,4}\s+/,"")}),t+=1;continue}if(/^>\s+/.test(n)){let s=[];while(t<e.length&&/^>\s+/.test((e[t]??"").trim()))s.push((e[t]??"").trim().replace(/^>\s+/,"")),t+=1;r.push({type:"quote",text:s.join(" ")});continue}if(/^[-*]\s+/.test(n)||/^\d+\.\s+/.test(n)){let s=/^\d+\.\s+/.test(n),o=[];while(t<e.length&&l((e[t]??"").trim())){let a=(e[t]??"").trim();if(s&&/^\d+\.\s+/.test(a))o.push(a.replace(/^\d+\.\s+/,""));else if(!s&&/^[-*]\s+/.test(a))o.push(a.replace(/^[-*]\s+/,""));else break;t+=1}r.push({type:"list",ordered:s,items:o});continue}let p=[];while(t<e.length&&!l((e[t]??"").trim())){let s=(e[t]??"").trim();if(!s)break;p.push(s),t+=1}r.push({type:"paragraph",text:p.join(" ")})}return r}export{u as parseDocsMarkdown};
|