@contractspec/bundle.library 3.8.10 → 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 +37 -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 -24310
- 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 -325
- package/dist/components/docs/specs/index.d.ts +3 -0
- package/dist/components/docs/specs/index.js +109 -1715
- 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 -28593
- 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 -24310
- 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 -325
- package/dist/node/components/docs/specs/index.js +109 -1715
- 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 -28593
- 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 +103 -31
- 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/index.ts +3 -0
- package/src/components/docs/studio/StudioOverviewPage.tsx +26 -0
- package/src/infrastructure/elysia/logger.ts +11 -3
|
@@ -1,11 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
import { gql } from "@apollo/client";
|
|
3
|
-
import { useQuery } from "@apollo/client/react";
|
|
4
|
-
import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
|
|
5
|
-
import { MessageCircle, Users } from "lucide-react";
|
|
6
|
-
import { useMemo } from "react";
|
|
7
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
8
|
-
var CONVERSATIONS_QUERY = gql`
|
|
1
|
+
import{gql as L}from"@apollo/client";import{useQuery as P}from"@apollo/client/react";import{useTemplateRuntime as W}from"@contractspec/lib.example-shared-ui";import{MessageCircle as X,Users as Z}from"lucide-react";import{useMemo as $}from"react";import{jsx as f,jsxs as k}from"react/jsx-runtime";var b=L`
|
|
9
2
|
query Conversations($projectId: ID!) {
|
|
10
3
|
conversations(projectId: $projectId) {
|
|
11
4
|
id
|
|
@@ -19,78 +12,4 @@ var CONVERSATIONS_QUERY = gql`
|
|
|
19
12
|
}
|
|
20
13
|
}
|
|
21
14
|
}
|
|
22
|
-
`;
|
|
23
|
-
function ConversationList({
|
|
24
|
-
selectedId,
|
|
25
|
-
onSelect
|
|
26
|
-
}) {
|
|
27
|
-
const { projectId } = useTemplateRuntime();
|
|
28
|
-
const { data, loading } = useQuery(CONVERSATIONS_QUERY, {
|
|
29
|
-
variables: { projectId },
|
|
30
|
-
fetchPolicy: "cache-and-network"
|
|
31
|
-
});
|
|
32
|
-
const conversations = useMemo(() => data?.conversations ?? [], [data]);
|
|
33
|
-
return /* @__PURE__ */ jsxs("aside", {
|
|
34
|
-
className: "h-full overflow-y-auto rounded-2xl border border-border bg-card",
|
|
35
|
-
children: [
|
|
36
|
-
/* @__PURE__ */ jsxs("header", {
|
|
37
|
-
className: "px -4 flex items-center justify-between border-border border-b px-4 py-3",
|
|
38
|
-
children: [
|
|
39
|
-
/* @__PURE__ */ jsxs("div", {
|
|
40
|
-
children: [
|
|
41
|
-
/* @__PURE__ */ jsx("p", {
|
|
42
|
-
className: "font-semibold text-sm",
|
|
43
|
-
children: "Conversations"
|
|
44
|
-
}),
|
|
45
|
-
/* @__PURE__ */ jsx("p", {
|
|
46
|
-
className: "text-muted-foreground text-xs",
|
|
47
|
-
children: loading ? "Loading…" : `${conversations.length} active`
|
|
48
|
-
})
|
|
49
|
-
]
|
|
50
|
-
}),
|
|
51
|
-
/* @__PURE__ */ jsx(Users, {
|
|
52
|
-
className: "h-4 w-4 text-muted-foreground"
|
|
53
|
-
})
|
|
54
|
-
]
|
|
55
|
-
}),
|
|
56
|
-
/* @__PURE__ */ jsxs("div", {
|
|
57
|
-
className: "divide-y divide-border/70",
|
|
58
|
-
children: [
|
|
59
|
-
conversations.map((conversation) => {
|
|
60
|
-
const isSelected = selectedId === conversation.id;
|
|
61
|
-
return /* @__PURE__ */ jsxs("button", {
|
|
62
|
-
type: "button",
|
|
63
|
-
className: `flex w-full flex-col items-start gap-1 px-4 py-3 text-left transition ${isSelected ? "bg-violet-500/10 text-foreground" : "hover:bg-muted/40"}`,
|
|
64
|
-
onClick: () => onSelect?.(conversation.id),
|
|
65
|
-
children: [
|
|
66
|
-
/* @__PURE__ */ jsxs("div", {
|
|
67
|
-
className: "flex items-center gap-2",
|
|
68
|
-
children: [
|
|
69
|
-
/* @__PURE__ */ jsx(MessageCircle, {
|
|
70
|
-
className: "h-4 w-4 text-muted-foreground"
|
|
71
|
-
}),
|
|
72
|
-
/* @__PURE__ */ jsx("span", {
|
|
73
|
-
className: "font-medium text-sm",
|
|
74
|
-
children: conversation.name || "Untitled conversation"
|
|
75
|
-
})
|
|
76
|
-
]
|
|
77
|
-
}),
|
|
78
|
-
/* @__PURE__ */ jsx("p", {
|
|
79
|
-
className: "text-muted-foreground text-xs",
|
|
80
|
-
children: conversation.participants.map((participant) => participant.displayName || participant.userId).join(" · ")
|
|
81
|
-
})
|
|
82
|
-
]
|
|
83
|
-
}, conversation.id);
|
|
84
|
-
}),
|
|
85
|
-
!loading && conversations.length === 0 ? /* @__PURE__ */ jsx("p", {
|
|
86
|
-
className: "p-4 text-center text-muted-foreground text-xs",
|
|
87
|
-
children: "No conversations yet."
|
|
88
|
-
}) : null
|
|
89
|
-
]
|
|
90
|
-
})
|
|
91
|
-
]
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
export {
|
|
95
|
-
ConversationList
|
|
96
|
-
};
|
|
15
|
+
`;function Y({selectedId:G,onSelect:H}){let{projectId:J}=W(),{data:B,loading:D}=P(b,{variables:{projectId:J},fetchPolicy:"cache-and-network"}),z=$(()=>B?.conversations??[],[B]);return k("aside",{className:"h-full overflow-y-auto rounded-2xl border border-border bg-card",children:[k("header",{className:"px -4 flex items-center justify-between border-border border-b px-4 py-3",children:[k("div",{children:[f("p",{className:"font-semibold text-sm",children:"Conversations"}),f("p",{className:"text-muted-foreground text-xs",children:D?"Loading…":`${z.length} active`})]}),f(Z,{className:"h-4 w-4 text-muted-foreground"})]}),k("div",{className:"divide-y divide-border/70",children:[z.map((w)=>{let K=G===w.id;return k("button",{type:"button",className:`flex w-full flex-col items-start gap-1 px-4 py-3 text-left transition ${K?"bg-violet-500/10 text-foreground":"hover:bg-muted/40"}`,onClick:()=>H?.(w.id),children:[k("div",{className:"flex items-center gap-2",children:[f(X,{className:"h-4 w-4 text-muted-foreground"}),f("span",{className:"font-medium text-sm",children:w.name||"Untitled conversation"})]}),f("p",{className:"text-muted-foreground text-xs",children:w.participants.map((F)=>F.displayName||F.userId).join(" · ")})]},w.id)}),!D&&z.length===0?f("p",{className:"p-4 text-center text-muted-foreground text-xs",children:"No conversations yet."}):null]})]})}export{Y as ConversationList};
|
|
@@ -1,11 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
import { gql } from "@apollo/client";
|
|
3
|
-
import { useMutation, useQuery } from "@apollo/client/react";
|
|
4
|
-
import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
|
|
5
|
-
import { useEffect, useRef } from "react";
|
|
6
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
7
|
-
"use client";
|
|
8
|
-
var MESSAGES_QUERY = gql`
|
|
1
|
+
import{gql as $}from"@apollo/client";import{useMutation as D,useQuery as U}from"@apollo/client/react";import{useTemplateRuntime as Y}from"@contractspec/lib.example-shared-ui";import{useEffect as X,useRef as h}from"react";import{jsx as B,jsxs as Z}from"react/jsx-runtime";var W=$`
|
|
9
2
|
query Messages($conversationId: ID!) {
|
|
10
3
|
messages(conversationId: $conversationId, limit: 50) {
|
|
11
4
|
id
|
|
@@ -16,153 +9,14 @@ var MESSAGES_QUERY = gql`
|
|
|
16
9
|
status
|
|
17
10
|
}
|
|
18
11
|
}
|
|
19
|
-
|
|
20
|
-
var SET_READ = gql`
|
|
12
|
+
`,q=$`
|
|
21
13
|
mutation SetMessagesRead($conversationId: ID!, $userId: String!) {
|
|
22
14
|
setMessagesRead(conversationId: $conversationId, userId: $userId)
|
|
23
15
|
}
|
|
24
|
-
`;
|
|
25
|
-
function MessageThread({
|
|
26
|
-
conversationId,
|
|
27
|
-
viewerId = "local-user"
|
|
28
|
-
}) {
|
|
29
|
-
const scrollRef = useRef(null);
|
|
30
|
-
const enabled = Boolean(conversationId);
|
|
31
|
-
const { data, loading } = useQuery(MESSAGES_QUERY, {
|
|
32
|
-
variables: { conversationId },
|
|
33
|
-
skip: !enabled,
|
|
34
|
-
fetchPolicy: "cache-and-network"
|
|
35
|
-
});
|
|
36
|
-
const [setRead] = useMutation(SET_READ);
|
|
37
|
-
const { projectId } = useTemplateRuntime();
|
|
38
|
-
const messages = data?.messages ?? [];
|
|
39
|
-
useEffect(() => {
|
|
40
|
-
if (!enabled || !conversationId)
|
|
41
|
-
return;
|
|
42
|
-
setRead({ variables: { conversationId, userId: viewerId } }).catch(() => {});
|
|
43
|
-
}, [conversationId, enabled, setRead, viewerId]);
|
|
44
|
-
useEffect(() => {
|
|
45
|
-
const container = scrollRef.current;
|
|
46
|
-
if (!container)
|
|
47
|
-
return;
|
|
48
|
-
container.scrollTop = container.scrollHeight;
|
|
49
|
-
}, [messages]);
|
|
50
|
-
if (!conversationId) {
|
|
51
|
-
return /* @__PURE__ */ jsx("div", {
|
|
52
|
-
className: "flex flex-1 items-center justify-center rounded-2xl border border-border border-dashed",
|
|
53
|
-
children: /* @__PURE__ */ jsx("p", {
|
|
54
|
-
className: "text-muted-foreground text-sm",
|
|
55
|
-
children: "Select a conversation"
|
|
56
|
-
})
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
return /* @__PURE__ */ jsx("div", {
|
|
60
|
-
className: "flex flex-1 flex-col rounded-2xl border border-border bg-card",
|
|
61
|
-
children: /* @__PURE__ */ jsx("div", {
|
|
62
|
-
ref: scrollRef,
|
|
63
|
-
className: "flex-1 space-y-3 overflow-y-auto p-4",
|
|
64
|
-
children: loading ? /* @__PURE__ */ jsx("p", {
|
|
65
|
-
className: "text-center text-muted-foreground text-sm",
|
|
66
|
-
children: "Loading…"
|
|
67
|
-
}) : messages.slice().reverse().map((message) => /* @__PURE__ */ jsxs("div", {
|
|
68
|
-
className: `flex flex-col ${message.senderId === viewerId ? "items-end" : "items-start"}`,
|
|
69
|
-
children: [
|
|
70
|
-
/* @__PURE__ */ jsx("div", {
|
|
71
|
-
className: `max-w-xs rounded-2xl px-3 py-2 text-sm ${message.senderId === viewerId ? "bg-violet-500 text-white" : "bg-muted text-foreground"}`,
|
|
72
|
-
children: /* @__PURE__ */ jsx("p", {
|
|
73
|
-
children: message.content
|
|
74
|
-
})
|
|
75
|
-
}),
|
|
76
|
-
/* @__PURE__ */ jsxs("span", {
|
|
77
|
-
className: "mt-1 text-muted-foreground text-xs",
|
|
78
|
-
children: [
|
|
79
|
-
message.senderName || message.senderId,
|
|
80
|
-
" ·",
|
|
81
|
-
" ",
|
|
82
|
-
new Date(message.createdAt).toLocaleTimeString([], {
|
|
83
|
-
hour: "2-digit",
|
|
84
|
-
minute: "2-digit"
|
|
85
|
-
})
|
|
86
|
-
]
|
|
87
|
-
})
|
|
88
|
-
]
|
|
89
|
-
}, message.id))
|
|
90
|
-
})
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
// src/components/templates/messaging/MessageComposer.tsx
|
|
95
|
-
import { gql as gql2 } from "@apollo/client";
|
|
96
|
-
import { useMutation as useMutation2 } from "@apollo/client/react";
|
|
97
|
-
import { useTemplateRuntime as useTemplateRuntime2 } from "@contractspec/lib.example-shared-ui";
|
|
98
|
-
import { Send } from "lucide-react";
|
|
99
|
-
import { useState } from "react";
|
|
100
|
-
import { jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime";
|
|
101
|
-
"use client";
|
|
102
|
-
var SEND_MESSAGE = gql2`
|
|
16
|
+
`;function R({conversationId:z,viewerId:F="local-user"}){let K=h(null),J=Boolean(z),{data:H,loading:L}=U(W,{variables:{conversationId:z},skip:!J,fetchPolicy:"cache-and-network"}),[O]=D(q),{projectId:P}=Y(),V=H?.messages??[];if(X(()=>{if(!J||!z)return;O({variables:{conversationId:z,userId:F}}).catch(()=>{})},[z,J,O,F]),X(()=>{let k=K.current;if(!k)return;k.scrollTop=k.scrollHeight},[V]),!z)return B("div",{className:"flex flex-1 items-center justify-center rounded-2xl border border-border border-dashed",children:B("p",{className:"text-muted-foreground text-sm",children:"Select a conversation"})});return B("div",{className:"flex flex-1 flex-col rounded-2xl border border-border bg-card",children:B("div",{ref:K,className:"flex-1 space-y-3 overflow-y-auto p-4",children:L?B("p",{className:"text-center text-muted-foreground text-sm",children:"Loading…"}):V.slice().reverse().map((k)=>Z("div",{className:`flex flex-col ${k.senderId===F?"items-end":"items-start"}`,children:[B("div",{className:`max-w-xs rounded-2xl px-3 py-2 text-sm ${k.senderId===F?"bg-violet-500 text-white":"bg-muted text-foreground"}`,children:B("p",{children:k.content})}),Z("span",{className:"mt-1 text-muted-foreground text-xs",children:[k.senderName||k.senderId," ·"," ",new Date(k.createdAt).toLocaleTimeString([],{hour:"2-digit",minute:"2-digit"})]})]},k.id))})})}import{gql as G}from"@apollo/client";import{useMutation as N}from"@apollo/client/react";import{useTemplateRuntime as Q}from"@contractspec/lib.example-shared-ui";import{Send as A}from"lucide-react";import{useState as T}from"react";import{jsx as y,jsxs as C}from"react/jsx-runtime";var _=G`
|
|
103
17
|
mutation SendMessage($input: SendMessageInput!) {
|
|
104
18
|
sendMessage(input: $input) {
|
|
105
19
|
id
|
|
106
20
|
}
|
|
107
21
|
}
|
|
108
|
-
`;
|
|
109
|
-
function MessageComposer({
|
|
110
|
-
conversationId,
|
|
111
|
-
viewerId = "local-user",
|
|
112
|
-
viewerName = "You"
|
|
113
|
-
}) {
|
|
114
|
-
const { projectId } = useTemplateRuntime2();
|
|
115
|
-
const [content, setContent] = useState("");
|
|
116
|
-
const [sendMessage, { loading }] = useMutation2(SEND_MESSAGE);
|
|
117
|
-
const handleSubmit = async (event) => {
|
|
118
|
-
event.preventDefault();
|
|
119
|
-
if (!conversationId || !content.trim())
|
|
120
|
-
return;
|
|
121
|
-
await sendMessage({
|
|
122
|
-
variables: {
|
|
123
|
-
input: {
|
|
124
|
-
projectId,
|
|
125
|
-
conversationId,
|
|
126
|
-
senderId: viewerId,
|
|
127
|
-
senderName: viewerName,
|
|
128
|
-
content: content.trim()
|
|
129
|
-
}
|
|
130
|
-
},
|
|
131
|
-
refetchQueries: [
|
|
132
|
-
{
|
|
133
|
-
query: MESSAGES_QUERY,
|
|
134
|
-
variables: { conversationId }
|
|
135
|
-
}
|
|
136
|
-
]
|
|
137
|
-
});
|
|
138
|
-
setContent("");
|
|
139
|
-
};
|
|
140
|
-
return /* @__PURE__ */ jsxs2("form", {
|
|
141
|
-
onSubmit: handleSubmit,
|
|
142
|
-
className: "mt-3 flex items-center gap-2 rounded-2xl border border-border bg-card px-4 py-3",
|
|
143
|
-
children: [
|
|
144
|
-
/* @__PURE__ */ jsx2("input", {
|
|
145
|
-
type: "text",
|
|
146
|
-
className: "flex-1 bg-transparent text-foreground text-sm outline-none",
|
|
147
|
-
placeholder: conversationId ? "Type a message…" : "Select a conversation to start",
|
|
148
|
-
disabled: !conversationId || loading,
|
|
149
|
-
value: content,
|
|
150
|
-
onChange: (event) => setContent(event.target.value)
|
|
151
|
-
}),
|
|
152
|
-
/* @__PURE__ */ jsxs2("button", {
|
|
153
|
-
type: "submit",
|
|
154
|
-
className: "btn-primary inline-flex items-center gap-1 text-sm",
|
|
155
|
-
disabled: !conversationId || loading || !content.trim(),
|
|
156
|
-
children: [
|
|
157
|
-
/* @__PURE__ */ jsx2(Send, {
|
|
158
|
-
className: "h-4 w-4"
|
|
159
|
-
}),
|
|
160
|
-
"Send"
|
|
161
|
-
]
|
|
162
|
-
})
|
|
163
|
-
]
|
|
164
|
-
});
|
|
165
|
-
}
|
|
166
|
-
export {
|
|
167
|
-
MessageComposer
|
|
168
|
-
};
|
|
22
|
+
`;function m({conversationId:z,viewerId:F="local-user",viewerName:K="You"}){let{projectId:J}=Q(),[H,L]=T(""),[O,{loading:P}]=N(_);return C("form",{onSubmit:async(k)=>{if(k.preventDefault(),!z||!H.trim())return;await O({variables:{input:{projectId:J,conversationId:z,senderId:F,senderName:K,content:H.trim()}},refetchQueries:[{query:W,variables:{conversationId:z}}]}),L("")},className:"mt-3 flex items-center gap-2 rounded-2xl border border-border bg-card px-4 py-3",children:[y("input",{type:"text",className:"flex-1 bg-transparent text-foreground text-sm outline-none",placeholder:z?"Type a message…":"Select a conversation to start",disabled:!z||P,value:H,onChange:(k)=>L(k.target.value)}),C("button",{type:"submit",className:"btn-primary inline-flex items-center gap-1 text-sm",disabled:!z||P||!H.trim(),children:[y(A,{className:"h-4 w-4"}),"Send"]})]})}export{m as MessageComposer};
|
|
@@ -1,11 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
import { gql } from "@apollo/client";
|
|
3
|
-
import { useMutation, useQuery } from "@apollo/client/react";
|
|
4
|
-
import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
|
|
5
|
-
import { useEffect, useRef } from "react";
|
|
6
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
7
|
-
"use client";
|
|
8
|
-
var MESSAGES_QUERY = gql`
|
|
1
|
+
import{gql as O}from"@apollo/client";import{useMutation as X,useQuery as Z}from"@apollo/client/react";import{useTemplateRuntime as $}from"@contractspec/lib.example-shared-ui";import{useEffect as L,useRef as h}from"react";import{jsx as z,jsxs as N}from"react/jsx-runtime";var y=O`
|
|
9
2
|
query Messages($conversationId: ID!) {
|
|
10
3
|
messages(conversationId: $conversationId, limit: 50) {
|
|
11
4
|
id
|
|
@@ -16,81 +9,8 @@ var MESSAGES_QUERY = gql`
|
|
|
16
9
|
status
|
|
17
10
|
}
|
|
18
11
|
}
|
|
19
|
-
|
|
20
|
-
var SET_READ = gql`
|
|
12
|
+
`,D=O`
|
|
21
13
|
mutation SetMessagesRead($conversationId: ID!, $userId: String!) {
|
|
22
14
|
setMessagesRead(conversationId: $conversationId, userId: $userId)
|
|
23
15
|
}
|
|
24
|
-
`;
|
|
25
|
-
function MessageThread({
|
|
26
|
-
conversationId,
|
|
27
|
-
viewerId = "local-user"
|
|
28
|
-
}) {
|
|
29
|
-
const scrollRef = useRef(null);
|
|
30
|
-
const enabled = Boolean(conversationId);
|
|
31
|
-
const { data, loading } = useQuery(MESSAGES_QUERY, {
|
|
32
|
-
variables: { conversationId },
|
|
33
|
-
skip: !enabled,
|
|
34
|
-
fetchPolicy: "cache-and-network"
|
|
35
|
-
});
|
|
36
|
-
const [setRead] = useMutation(SET_READ);
|
|
37
|
-
const { projectId } = useTemplateRuntime();
|
|
38
|
-
const messages = data?.messages ?? [];
|
|
39
|
-
useEffect(() => {
|
|
40
|
-
if (!enabled || !conversationId)
|
|
41
|
-
return;
|
|
42
|
-
setRead({ variables: { conversationId, userId: viewerId } }).catch(() => {});
|
|
43
|
-
}, [conversationId, enabled, setRead, viewerId]);
|
|
44
|
-
useEffect(() => {
|
|
45
|
-
const container = scrollRef.current;
|
|
46
|
-
if (!container)
|
|
47
|
-
return;
|
|
48
|
-
container.scrollTop = container.scrollHeight;
|
|
49
|
-
}, [messages]);
|
|
50
|
-
if (!conversationId) {
|
|
51
|
-
return /* @__PURE__ */ jsx("div", {
|
|
52
|
-
className: "flex flex-1 items-center justify-center rounded-2xl border border-border border-dashed",
|
|
53
|
-
children: /* @__PURE__ */ jsx("p", {
|
|
54
|
-
className: "text-muted-foreground text-sm",
|
|
55
|
-
children: "Select a conversation"
|
|
56
|
-
})
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
return /* @__PURE__ */ jsx("div", {
|
|
60
|
-
className: "flex flex-1 flex-col rounded-2xl border border-border bg-card",
|
|
61
|
-
children: /* @__PURE__ */ jsx("div", {
|
|
62
|
-
ref: scrollRef,
|
|
63
|
-
className: "flex-1 space-y-3 overflow-y-auto p-4",
|
|
64
|
-
children: loading ? /* @__PURE__ */ jsx("p", {
|
|
65
|
-
className: "text-center text-muted-foreground text-sm",
|
|
66
|
-
children: "Loading…"
|
|
67
|
-
}) : messages.slice().reverse().map((message) => /* @__PURE__ */ jsxs("div", {
|
|
68
|
-
className: `flex flex-col ${message.senderId === viewerId ? "items-end" : "items-start"}`,
|
|
69
|
-
children: [
|
|
70
|
-
/* @__PURE__ */ jsx("div", {
|
|
71
|
-
className: `max-w-xs rounded-2xl px-3 py-2 text-sm ${message.senderId === viewerId ? "bg-violet-500 text-white" : "bg-muted text-foreground"}`,
|
|
72
|
-
children: /* @__PURE__ */ jsx("p", {
|
|
73
|
-
children: message.content
|
|
74
|
-
})
|
|
75
|
-
}),
|
|
76
|
-
/* @__PURE__ */ jsxs("span", {
|
|
77
|
-
className: "mt-1 text-muted-foreground text-xs",
|
|
78
|
-
children: [
|
|
79
|
-
message.senderName || message.senderId,
|
|
80
|
-
" ·",
|
|
81
|
-
" ",
|
|
82
|
-
new Date(message.createdAt).toLocaleTimeString([], {
|
|
83
|
-
hour: "2-digit",
|
|
84
|
-
minute: "2-digit"
|
|
85
|
-
})
|
|
86
|
-
]
|
|
87
|
-
})
|
|
88
|
-
]
|
|
89
|
-
}, message.id))
|
|
90
|
-
})
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
export {
|
|
94
|
-
MessageThread,
|
|
95
|
-
MESSAGES_QUERY
|
|
96
|
-
};
|
|
16
|
+
`;function A({conversationId:B,viewerId:C="local-user"}){let H=h(null),F=Boolean(B),{data:P,loading:V}=Z(y,{variables:{conversationId:B},skip:!F,fetchPolicy:"cache-and-network"}),[J]=X(D),{projectId:W}=$(),K=P?.messages??[];if(L(()=>{if(!F||!B)return;J({variables:{conversationId:B,userId:C}}).catch(()=>{})},[B,F,J,C]),L(()=>{let k=H.current;if(!k)return;k.scrollTop=k.scrollHeight},[K]),!B)return z("div",{className:"flex flex-1 items-center justify-center rounded-2xl border border-border border-dashed",children:z("p",{className:"text-muted-foreground text-sm",children:"Select a conversation"})});return z("div",{className:"flex flex-1 flex-col rounded-2xl border border-border bg-card",children:z("div",{ref:H,className:"flex-1 space-y-3 overflow-y-auto p-4",children:V?z("p",{className:"text-center text-muted-foreground text-sm",children:"Loading…"}):K.slice().reverse().map((k)=>N("div",{className:`flex flex-col ${k.senderId===C?"items-end":"items-start"}`,children:[z("div",{className:`max-w-xs rounded-2xl px-3 py-2 text-sm ${k.senderId===C?"bg-violet-500 text-white":"bg-muted text-foreground"}`,children:z("p",{children:k.content})}),N("span",{className:"mt-1 text-muted-foreground text-xs",children:[k.senderName||k.senderId," ·"," ",new Date(k.createdAt).toLocaleTimeString([],{hour:"2-digit",minute:"2-digit"})]})]},k.id))})})}export{A as MessageThread,y as MESSAGES_QUERY};
|
|
@@ -1,11 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
import { gql } from "@apollo/client";
|
|
3
|
-
import { useQuery } from "@apollo/client/react";
|
|
4
|
-
import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
|
|
5
|
-
import { MessageCircle, Users } from "lucide-react";
|
|
6
|
-
import { useMemo } from "react";
|
|
7
|
-
import { jsx, jsxs } from "react/jsx-runtime";
|
|
8
|
-
var CONVERSATIONS_QUERY = gql`
|
|
1
|
+
import{gql as _}from"@apollo/client";import{useQuery as b}from"@apollo/client/react";import{useTemplateRuntime as f}from"@contractspec/lib.example-shared-ui";import{MessageCircle as h,Users as T}from"lucide-react";import{useMemo as C}from"react";import{jsx as X,jsxs as W}from"react/jsx-runtime";var w=_`
|
|
9
2
|
query Conversations($projectId: ID!) {
|
|
10
3
|
conversations(projectId: $projectId) {
|
|
11
4
|
id
|
|
@@ -19,87 +12,7 @@ var CONVERSATIONS_QUERY = gql`
|
|
|
19
12
|
}
|
|
20
13
|
}
|
|
21
14
|
}
|
|
22
|
-
`;
|
|
23
|
-
function ConversationList({
|
|
24
|
-
selectedId,
|
|
25
|
-
onSelect
|
|
26
|
-
}) {
|
|
27
|
-
const { projectId } = useTemplateRuntime();
|
|
28
|
-
const { data, loading } = useQuery(CONVERSATIONS_QUERY, {
|
|
29
|
-
variables: { projectId },
|
|
30
|
-
fetchPolicy: "cache-and-network"
|
|
31
|
-
});
|
|
32
|
-
const conversations = useMemo(() => data?.conversations ?? [], [data]);
|
|
33
|
-
return /* @__PURE__ */ jsxs("aside", {
|
|
34
|
-
className: "h-full overflow-y-auto rounded-2xl border border-border bg-card",
|
|
35
|
-
children: [
|
|
36
|
-
/* @__PURE__ */ jsxs("header", {
|
|
37
|
-
className: "px -4 flex items-center justify-between border-border border-b px-4 py-3",
|
|
38
|
-
children: [
|
|
39
|
-
/* @__PURE__ */ jsxs("div", {
|
|
40
|
-
children: [
|
|
41
|
-
/* @__PURE__ */ jsx("p", {
|
|
42
|
-
className: "font-semibold text-sm",
|
|
43
|
-
children: "Conversations"
|
|
44
|
-
}),
|
|
45
|
-
/* @__PURE__ */ jsx("p", {
|
|
46
|
-
className: "text-muted-foreground text-xs",
|
|
47
|
-
children: loading ? "Loading…" : `${conversations.length} active`
|
|
48
|
-
})
|
|
49
|
-
]
|
|
50
|
-
}),
|
|
51
|
-
/* @__PURE__ */ jsx(Users, {
|
|
52
|
-
className: "h-4 w-4 text-muted-foreground"
|
|
53
|
-
})
|
|
54
|
-
]
|
|
55
|
-
}),
|
|
56
|
-
/* @__PURE__ */ jsxs("div", {
|
|
57
|
-
className: "divide-y divide-border/70",
|
|
58
|
-
children: [
|
|
59
|
-
conversations.map((conversation) => {
|
|
60
|
-
const isSelected = selectedId === conversation.id;
|
|
61
|
-
return /* @__PURE__ */ jsxs("button", {
|
|
62
|
-
type: "button",
|
|
63
|
-
className: `flex w-full flex-col items-start gap-1 px-4 py-3 text-left transition ${isSelected ? "bg-violet-500/10 text-foreground" : "hover:bg-muted/40"}`,
|
|
64
|
-
onClick: () => onSelect?.(conversation.id),
|
|
65
|
-
children: [
|
|
66
|
-
/* @__PURE__ */ jsxs("div", {
|
|
67
|
-
className: "flex items-center gap-2",
|
|
68
|
-
children: [
|
|
69
|
-
/* @__PURE__ */ jsx(MessageCircle, {
|
|
70
|
-
className: "h-4 w-4 text-muted-foreground"
|
|
71
|
-
}),
|
|
72
|
-
/* @__PURE__ */ jsx("span", {
|
|
73
|
-
className: "font-medium text-sm",
|
|
74
|
-
children: conversation.name || "Untitled conversation"
|
|
75
|
-
})
|
|
76
|
-
]
|
|
77
|
-
}),
|
|
78
|
-
/* @__PURE__ */ jsx("p", {
|
|
79
|
-
className: "text-muted-foreground text-xs",
|
|
80
|
-
children: conversation.participants.map((participant) => participant.displayName || participant.userId).join(" · ")
|
|
81
|
-
})
|
|
82
|
-
]
|
|
83
|
-
}, conversation.id);
|
|
84
|
-
}),
|
|
85
|
-
!loading && conversations.length === 0 ? /* @__PURE__ */ jsx("p", {
|
|
86
|
-
className: "p-4 text-center text-muted-foreground text-xs",
|
|
87
|
-
children: "No conversations yet."
|
|
88
|
-
}) : null
|
|
89
|
-
]
|
|
90
|
-
})
|
|
91
|
-
]
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
// src/components/templates/messaging/MessageThread.tsx
|
|
96
|
-
import { gql as gql2 } from "@apollo/client";
|
|
97
|
-
import { useMutation, useQuery as useQuery2 } from "@apollo/client/react";
|
|
98
|
-
import { useTemplateRuntime as useTemplateRuntime2 } from "@contractspec/lib.example-shared-ui";
|
|
99
|
-
import { useEffect, useRef } from "react";
|
|
100
|
-
import { jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime";
|
|
101
|
-
"use client";
|
|
102
|
-
var MESSAGES_QUERY = gql2`
|
|
15
|
+
`;function G({selectedId:z,onSelect:F}){let{projectId:$}=f(),{data:K,loading:J}=b(w,{variables:{projectId:$},fetchPolicy:"cache-and-network"}),P=C(()=>K?.conversations??[],[K]);return W("aside",{className:"h-full overflow-y-auto rounded-2xl border border-border bg-card",children:[W("header",{className:"px -4 flex items-center justify-between border-border border-b px-4 py-3",children:[W("div",{children:[X("p",{className:"font-semibold text-sm",children:"Conversations"}),X("p",{className:"text-muted-foreground text-xs",children:J?"Loading…":`${P.length} active`})]}),X(T,{className:"h-4 w-4 text-muted-foreground"})]}),W("div",{className:"divide-y divide-border/70",children:[P.map((H)=>{let k=z===H.id;return W("button",{type:"button",className:`flex w-full flex-col items-start gap-1 px-4 py-3 text-left transition ${k?"bg-violet-500/10 text-foreground":"hover:bg-muted/40"}`,onClick:()=>F?.(H.id),children:[W("div",{className:"flex items-center gap-2",children:[X(h,{className:"h-4 w-4 text-muted-foreground"}),X("span",{className:"font-medium text-sm",children:H.name||"Untitled conversation"})]}),X("p",{className:"text-muted-foreground text-xs",children:H.participants.map((V)=>V.displayName||V.userId).join(" · ")})]},H.id)}),!J&&P.length===0?X("p",{className:"p-4 text-center text-muted-foreground text-xs",children:"No conversations yet."}):null]})]})}import{gql as U}from"@apollo/client";import{useMutation as R,useQuery as E}from"@apollo/client/react";import{useTemplateRuntime as M}from"@contractspec/lib.example-shared-ui";import{useEffect as Y,useRef as S}from"react";import{jsx as Z,jsxs as q}from"react/jsx-runtime";var y=U`
|
|
103
16
|
query Messages($conversationId: ID!) {
|
|
104
17
|
messages(conversationId: $conversationId, limit: 50) {
|
|
105
18
|
id
|
|
@@ -110,187 +23,14 @@ var MESSAGES_QUERY = gql2`
|
|
|
110
23
|
status
|
|
111
24
|
}
|
|
112
25
|
}
|
|
113
|
-
|
|
114
|
-
var SET_READ = gql2`
|
|
26
|
+
`,p=U`
|
|
115
27
|
mutation SetMessagesRead($conversationId: ID!, $userId: String!) {
|
|
116
28
|
setMessagesRead(conversationId: $conversationId, userId: $userId)
|
|
117
29
|
}
|
|
118
|
-
`;
|
|
119
|
-
function MessageThread({
|
|
120
|
-
conversationId,
|
|
121
|
-
viewerId = "local-user"
|
|
122
|
-
}) {
|
|
123
|
-
const scrollRef = useRef(null);
|
|
124
|
-
const enabled = Boolean(conversationId);
|
|
125
|
-
const { data, loading } = useQuery2(MESSAGES_QUERY, {
|
|
126
|
-
variables: { conversationId },
|
|
127
|
-
skip: !enabled,
|
|
128
|
-
fetchPolicy: "cache-and-network"
|
|
129
|
-
});
|
|
130
|
-
const [setRead] = useMutation(SET_READ);
|
|
131
|
-
const { projectId } = useTemplateRuntime2();
|
|
132
|
-
const messages = data?.messages ?? [];
|
|
133
|
-
useEffect(() => {
|
|
134
|
-
if (!enabled || !conversationId)
|
|
135
|
-
return;
|
|
136
|
-
setRead({ variables: { conversationId, userId: viewerId } }).catch(() => {});
|
|
137
|
-
}, [conversationId, enabled, setRead, viewerId]);
|
|
138
|
-
useEffect(() => {
|
|
139
|
-
const container = scrollRef.current;
|
|
140
|
-
if (!container)
|
|
141
|
-
return;
|
|
142
|
-
container.scrollTop = container.scrollHeight;
|
|
143
|
-
}, [messages]);
|
|
144
|
-
if (!conversationId) {
|
|
145
|
-
return /* @__PURE__ */ jsx2("div", {
|
|
146
|
-
className: "flex flex-1 items-center justify-center rounded-2xl border border-border border-dashed",
|
|
147
|
-
children: /* @__PURE__ */ jsx2("p", {
|
|
148
|
-
className: "text-muted-foreground text-sm",
|
|
149
|
-
children: "Select a conversation"
|
|
150
|
-
})
|
|
151
|
-
});
|
|
152
|
-
}
|
|
153
|
-
return /* @__PURE__ */ jsx2("div", {
|
|
154
|
-
className: "flex flex-1 flex-col rounded-2xl border border-border bg-card",
|
|
155
|
-
children: /* @__PURE__ */ jsx2("div", {
|
|
156
|
-
ref: scrollRef,
|
|
157
|
-
className: "flex-1 space-y-3 overflow-y-auto p-4",
|
|
158
|
-
children: loading ? /* @__PURE__ */ jsx2("p", {
|
|
159
|
-
className: "text-center text-muted-foreground text-sm",
|
|
160
|
-
children: "Loading…"
|
|
161
|
-
}) : messages.slice().reverse().map((message) => /* @__PURE__ */ jsxs2("div", {
|
|
162
|
-
className: `flex flex-col ${message.senderId === viewerId ? "items-end" : "items-start"}`,
|
|
163
|
-
children: [
|
|
164
|
-
/* @__PURE__ */ jsx2("div", {
|
|
165
|
-
className: `max-w-xs rounded-2xl px-3 py-2 text-sm ${message.senderId === viewerId ? "bg-violet-500 text-white" : "bg-muted text-foreground"}`,
|
|
166
|
-
children: /* @__PURE__ */ jsx2("p", {
|
|
167
|
-
children: message.content
|
|
168
|
-
})
|
|
169
|
-
}),
|
|
170
|
-
/* @__PURE__ */ jsxs2("span", {
|
|
171
|
-
className: "mt-1 text-muted-foreground text-xs",
|
|
172
|
-
children: [
|
|
173
|
-
message.senderName || message.senderId,
|
|
174
|
-
" ·",
|
|
175
|
-
" ",
|
|
176
|
-
new Date(message.createdAt).toLocaleTimeString([], {
|
|
177
|
-
hour: "2-digit",
|
|
178
|
-
minute: "2-digit"
|
|
179
|
-
})
|
|
180
|
-
]
|
|
181
|
-
})
|
|
182
|
-
]
|
|
183
|
-
}, message.id))
|
|
184
|
-
})
|
|
185
|
-
});
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
// src/components/templates/messaging/MessageComposer.tsx
|
|
189
|
-
import { gql as gql3 } from "@apollo/client";
|
|
190
|
-
import { useMutation as useMutation2 } from "@apollo/client/react";
|
|
191
|
-
import { useTemplateRuntime as useTemplateRuntime3 } from "@contractspec/lib.example-shared-ui";
|
|
192
|
-
import { Send } from "lucide-react";
|
|
193
|
-
import { useState } from "react";
|
|
194
|
-
import { jsx as jsx3, jsxs as jsxs3 } from "react/jsx-runtime";
|
|
195
|
-
"use client";
|
|
196
|
-
var SEND_MESSAGE = gql3`
|
|
30
|
+
`;function D({conversationId:z,viewerId:F="local-user"}){let $=S(null),K=Boolean(z),{data:J,loading:P}=E(y,{variables:{conversationId:z},skip:!K,fetchPolicy:"cache-and-network"}),[H]=R(p),{projectId:k}=M(),V=J?.messages??[];if(Y(()=>{if(!K||!z)return;H({variables:{conversationId:z,userId:F}}).catch(()=>{})},[z,K,H,F]),Y(()=>{let B=$.current;if(!B)return;B.scrollTop=B.scrollHeight},[V]),!z)return Z("div",{className:"flex flex-1 items-center justify-center rounded-2xl border border-border border-dashed",children:Z("p",{className:"text-muted-foreground text-sm",children:"Select a conversation"})});return Z("div",{className:"flex flex-1 flex-col rounded-2xl border border-border bg-card",children:Z("div",{ref:$,className:"flex-1 space-y-3 overflow-y-auto p-4",children:P?Z("p",{className:"text-center text-muted-foreground text-sm",children:"Loading…"}):V.slice().reverse().map((B)=>q("div",{className:`flex flex-col ${B.senderId===F?"items-end":"items-start"}`,children:[Z("div",{className:`max-w-xs rounded-2xl px-3 py-2 text-sm ${B.senderId===F?"bg-violet-500 text-white":"bg-muted text-foreground"}`,children:Z("p",{children:B.content})}),q("span",{className:"mt-1 text-muted-foreground text-xs",children:[B.senderName||B.senderId," ·"," ",new Date(B.createdAt).toLocaleTimeString([],{hour:"2-digit",minute:"2-digit"})]})]},B.id))})})}import{gql as u}from"@apollo/client";import{useMutation as l}from"@apollo/client/react";import{useTemplateRuntime as g}from"@contractspec/lib.example-shared-ui";import{Send as j}from"lucide-react";import{useState as m}from"react";import{jsx as A,jsxs as N}from"react/jsx-runtime";var x=u`
|
|
197
31
|
mutation SendMessage($input: SendMessageInput!) {
|
|
198
32
|
sendMessage(input: $input) {
|
|
199
33
|
id
|
|
200
34
|
}
|
|
201
35
|
}
|
|
202
|
-
`;
|
|
203
|
-
function MessageComposer({
|
|
204
|
-
conversationId,
|
|
205
|
-
viewerId = "local-user",
|
|
206
|
-
viewerName = "You"
|
|
207
|
-
}) {
|
|
208
|
-
const { projectId } = useTemplateRuntime3();
|
|
209
|
-
const [content, setContent] = useState("");
|
|
210
|
-
const [sendMessage, { loading }] = useMutation2(SEND_MESSAGE);
|
|
211
|
-
const handleSubmit = async (event) => {
|
|
212
|
-
event.preventDefault();
|
|
213
|
-
if (!conversationId || !content.trim())
|
|
214
|
-
return;
|
|
215
|
-
await sendMessage({
|
|
216
|
-
variables: {
|
|
217
|
-
input: {
|
|
218
|
-
projectId,
|
|
219
|
-
conversationId,
|
|
220
|
-
senderId: viewerId,
|
|
221
|
-
senderName: viewerName,
|
|
222
|
-
content: content.trim()
|
|
223
|
-
}
|
|
224
|
-
},
|
|
225
|
-
refetchQueries: [
|
|
226
|
-
{
|
|
227
|
-
query: MESSAGES_QUERY,
|
|
228
|
-
variables: { conversationId }
|
|
229
|
-
}
|
|
230
|
-
]
|
|
231
|
-
});
|
|
232
|
-
setContent("");
|
|
233
|
-
};
|
|
234
|
-
return /* @__PURE__ */ jsxs3("form", {
|
|
235
|
-
onSubmit: handleSubmit,
|
|
236
|
-
className: "mt-3 flex items-center gap-2 rounded-2xl border border-border bg-card px-4 py-3",
|
|
237
|
-
children: [
|
|
238
|
-
/* @__PURE__ */ jsx3("input", {
|
|
239
|
-
type: "text",
|
|
240
|
-
className: "flex-1 bg-transparent text-foreground text-sm outline-none",
|
|
241
|
-
placeholder: conversationId ? "Type a message…" : "Select a conversation to start",
|
|
242
|
-
disabled: !conversationId || loading,
|
|
243
|
-
value: content,
|
|
244
|
-
onChange: (event) => setContent(event.target.value)
|
|
245
|
-
}),
|
|
246
|
-
/* @__PURE__ */ jsxs3("button", {
|
|
247
|
-
type: "submit",
|
|
248
|
-
className: "btn-primary inline-flex items-center gap-1 text-sm",
|
|
249
|
-
disabled: !conversationId || loading || !content.trim(),
|
|
250
|
-
children: [
|
|
251
|
-
/* @__PURE__ */ jsx3(Send, {
|
|
252
|
-
className: "h-4 w-4"
|
|
253
|
-
}),
|
|
254
|
-
"Send"
|
|
255
|
-
]
|
|
256
|
-
})
|
|
257
|
-
]
|
|
258
|
-
});
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
// src/components/templates/messaging/MessagingWorkspace.tsx
|
|
262
|
-
import { registerTemplateComponents } from "@contractspec/lib.example-shared-ui";
|
|
263
|
-
import { useState as useState2 } from "react";
|
|
264
|
-
import { jsx as jsx4, jsxs as jsxs4 } from "react/jsx-runtime";
|
|
265
|
-
"use client";
|
|
266
|
-
function MessagingWorkspace() {
|
|
267
|
-
const [conversationId, setConversationId] = useState2();
|
|
268
|
-
return /* @__PURE__ */ jsxs4("div", {
|
|
269
|
-
className: "grid gap-4 md:grid-cols-[280px,1fr]",
|
|
270
|
-
children: [
|
|
271
|
-
/* @__PURE__ */ jsx4(ConversationList, {
|
|
272
|
-
selectedId: conversationId,
|
|
273
|
-
onSelect: setConversationId
|
|
274
|
-
}),
|
|
275
|
-
/* @__PURE__ */ jsxs4("div", {
|
|
276
|
-
className: "flex flex-col gap-3",
|
|
277
|
-
children: [
|
|
278
|
-
/* @__PURE__ */ jsx4(MessageThread, {
|
|
279
|
-
conversationId
|
|
280
|
-
}),
|
|
281
|
-
/* @__PURE__ */ jsx4(MessageComposer, {
|
|
282
|
-
conversationId
|
|
283
|
-
})
|
|
284
|
-
]
|
|
285
|
-
})
|
|
286
|
-
]
|
|
287
|
-
});
|
|
288
|
-
}
|
|
289
|
-
registerTemplateComponents("messaging-app", {
|
|
290
|
-
list: MessagingWorkspace,
|
|
291
|
-
detail: MessageThread,
|
|
292
|
-
form: MessageComposer
|
|
293
|
-
});
|
|
294
|
-
export {
|
|
295
|
-
MessagingWorkspace
|
|
296
|
-
};
|
|
36
|
+
`;function L({conversationId:z,viewerId:F="local-user",viewerName:$="You"}){let{projectId:K}=g(),[J,P]=m(""),[H,{loading:k}]=l(x);return N("form",{onSubmit:async(B)=>{if(B.preventDefault(),!z||!J.trim())return;await H({variables:{input:{projectId:K,conversationId:z,senderId:F,senderName:$,content:J.trim()}},refetchQueries:[{query:y,variables:{conversationId:z}}]}),P("")},className:"mt-3 flex items-center gap-2 rounded-2xl border border-border bg-card px-4 py-3",children:[A("input",{type:"text",className:"flex-1 bg-transparent text-foreground text-sm outline-none",placeholder:z?"Type a message…":"Select a conversation to start",disabled:!z||k,value:J,onChange:(B)=>P(B.target.value)}),N("button",{type:"submit",className:"btn-primary inline-flex items-center gap-1 text-sm",disabled:!z||k||!J.trim(),children:[A(j,{className:"h-4 w-4"}),"Send"]})]})}import{registerTemplateComponents as I}from"@contractspec/lib.example-shared-ui";import{useState as v}from"react";import{jsx as O,jsxs as Q}from"react/jsx-runtime";function d(){let[z,F]=v();return Q("div",{className:"grid gap-4 md:grid-cols-[280px,1fr]",children:[O(G,{selectedId:z,onSelect:F}),Q("div",{className:"flex flex-col gap-3",children:[O(D,{conversationId:z}),O(L,{conversationId:z})]})]})}I("messaging-app",{list:d,detail:D,form:L});export{d as MessagingWorkspace};
|