@happyvertical/smrt-content 0.30.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/AGENTS.md +194 -0
- package/CLAUDE.md +1 -0
- package/LICENSE +7 -0
- package/README.md +634 -0
- package/dist/__smrt-register__.d.ts +2 -0
- package/dist/__smrt-register__.d.ts.map +1 -0
- package/dist/asset-associable.d.ts +115 -0
- package/dist/asset-associable.d.ts.map +1 -0
- package/dist/body-format.d.ts +29 -0
- package/dist/body-format.d.ts.map +1 -0
- package/dist/body-format.js +604 -0
- package/dist/body-format.js.map +1 -0
- package/dist/content-asset.d.ts +17 -0
- package/dist/content-asset.d.ts.map +1 -0
- package/dist/content-assets.d.ts +10 -0
- package/dist/content-assets.d.ts.map +1 -0
- package/dist/content-chat-handlers.d.ts +115 -0
- package/dist/content-chat-handlers.d.ts.map +1 -0
- package/dist/content-chat-prompts.d.ts +3 -0
- package/dist/content-chat-prompts.d.ts.map +1 -0
- package/dist/content-chat-session.d.ts +26 -0
- package/dist/content-chat-session.d.ts.map +1 -0
- package/dist/content-contribution-attachment.d.ts +42 -0
- package/dist/content-contribution-attachment.d.ts.map +1 -0
- package/dist/content-contribution-attachments.d.ts +8 -0
- package/dist/content-contribution-attachments.d.ts.map +1 -0
- package/dist/content-contribution-config.d.ts +84 -0
- package/dist/content-contribution-config.d.ts.map +1 -0
- package/dist/content-contribution-revision.d.ts +38 -0
- package/dist/content-contribution-revision.d.ts.map +1 -0
- package/dist/content-contribution-revisions.d.ts +8 -0
- package/dist/content-contribution-revisions.d.ts.map +1 -0
- package/dist/content-contribution-type.d.ts +51 -0
- package/dist/content-contribution-type.d.ts.map +1 -0
- package/dist/content-contribution-types.d.ts +7 -0
- package/dist/content-contribution-types.d.ts.map +1 -0
- package/dist/content-contribution.d.ts +161 -0
- package/dist/content-contribution.d.ts.map +1 -0
- package/dist/content-contributions.d.ts +53 -0
- package/dist/content-contributions.d.ts.map +1 -0
- package/dist/content-contributor.d.ts +30 -0
- package/dist/content-contributor.d.ts.map +1 -0
- package/dist/content-contributors.d.ts +13 -0
- package/dist/content-contributors.d.ts.map +1 -0
- package/dist/content-correction.d.ts +39 -0
- package/dist/content-correction.d.ts.map +1 -0
- package/dist/content-corrections.d.ts +9 -0
- package/dist/content-corrections.d.ts.map +1 -0
- package/dist/content-editor-assistant.d.ts +68 -0
- package/dist/content-editor-assistant.d.ts.map +1 -0
- package/dist/content-editor-assistant.js +97 -0
- package/dist/content-editor-assistant.js.map +1 -0
- package/dist/content-feed-parser.d.ts +19 -0
- package/dist/content-feed-parser.d.ts.map +1 -0
- package/dist/content-feed-source.d.ts +52 -0
- package/dist/content-feed-source.d.ts.map +1 -0
- package/dist/content-feed-sources.d.ts +11 -0
- package/dist/content-feed-sources.d.ts.map +1 -0
- package/dist/content-feed-sync.d.ts +23 -0
- package/dist/content-feed-sync.d.ts.map +1 -0
- package/dist/content-governance-assignment.d.ts +42 -0
- package/dist/content-governance-assignment.d.ts.map +1 -0
- package/dist/content-governance-assignments.d.ts +11 -0
- package/dist/content-governance-assignments.d.ts.map +1 -0
- package/dist/content-governance-policies.d.ts +7 -0
- package/dist/content-governance-policies.d.ts.map +1 -0
- package/dist/content-governance-policy.d.ts +29 -0
- package/dist/content-governance-policy.d.ts.map +1 -0
- package/dist/content-governance-profile.d.ts +31 -0
- package/dist/content-governance-profile.d.ts.map +1 -0
- package/dist/content-governance-profiles.d.ts +7 -0
- package/dist/content-governance-profiles.d.ts.map +1 -0
- package/dist/content-governance.d.ts +188 -0
- package/dist/content-governance.d.ts.map +1 -0
- package/dist/content-prompts.d.ts +10 -0
- package/dist/content-prompts.d.ts.map +1 -0
- package/dist/content-reference.d.ts +17 -0
- package/dist/content-reference.d.ts.map +1 -0
- package/dist/content-references.d.ts +55 -0
- package/dist/content-references.d.ts.map +1 -0
- package/dist/content-review.d.ts +34 -0
- package/dist/content-review.d.ts.map +1 -0
- package/dist/content-reviews.d.ts +21 -0
- package/dist/content-reviews.d.ts.map +1 -0
- package/dist/content-transparency.d.ts +72 -0
- package/dist/content-transparency.d.ts.map +1 -0
- package/dist/content-types.d.ts +51 -0
- package/dist/content-types.d.ts.map +1 -0
- package/dist/content-version.d.ts +38 -0
- package/dist/content-version.d.ts.map +1 -0
- package/dist/content-versions.d.ts +16 -0
- package/dist/content-versions.d.ts.map +1 -0
- package/dist/content.d.ts +736 -0
- package/dist/content.d.ts.map +1 -0
- package/dist/contents.d.ts +292 -0
- package/dist/contents.d.ts.map +1 -0
- package/dist/database-utils.d.ts +3 -0
- package/dist/database-utils.d.ts.map +1 -0
- package/dist/index.d.ts +78 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11602 -0
- package/dist/index.js.map +1 -0
- package/dist/manifest.json +12308 -0
- package/dist/mock-smrt-client.d.ts +493 -0
- package/dist/mock-smrt-client.d.ts.map +1 -0
- package/dist/mock-smrt-client.js +390 -0
- package/dist/mock-smrt-client.js.map +1 -0
- package/dist/playground.d.ts +2 -0
- package/dist/playground.d.ts.map +1 -0
- package/dist/playground.js +454 -0
- package/dist/playground.js.map +1 -0
- package/dist/publish-readiness.d.ts +30 -0
- package/dist/publish-readiness.d.ts.map +1 -0
- package/dist/publish-readiness.js +74 -0
- package/dist/publish-readiness.js.map +1 -0
- package/dist/safe-remote-url.d.ts +52 -0
- package/dist/safe-remote-url.d.ts.map +1 -0
- package/dist/serialization.d.ts +78 -0
- package/dist/serialization.d.ts.map +1 -0
- package/dist/smrt-knowledge.json +6130 -0
- package/dist/svelte/api.d.ts +3 -0
- package/dist/svelte/api.d.ts.map +1 -0
- package/dist/svelte/api.js +10 -0
- package/dist/svelte/components/ArticleCard.svelte +159 -0
- package/dist/svelte/components/ArticleCard.svelte.d.ts +17 -0
- package/dist/svelte/components/ArticleCard.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ArticleList.svelte +75 -0
- package/dist/svelte/components/ArticleList.svelte.d.ts +21 -0
- package/dist/svelte/components/ArticleList.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentAgentChat.svelte +652 -0
- package/dist/svelte/components/ContentAgentChat.svelte.d.ts +17 -0
- package/dist/svelte/components/ContentAgentChat.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentBodyEditor.svelte +1446 -0
- package/dist/svelte/components/ContentBodyEditor.svelte.d.ts +25 -0
- package/dist/svelte/components/ContentBodyEditor.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentBodyRenderer.svelte +152 -0
- package/dist/svelte/components/ContentBodyRenderer.svelte.d.ts +10 -0
- package/dist/svelte/components/ContentBodyRenderer.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentClaimAuditTool.svelte +441 -0
- package/dist/svelte/components/ContentClaimAuditTool.svelte.d.ts +12 -0
- package/dist/svelte/components/ContentClaimAuditTool.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentContributionForm.svelte +226 -0
- package/dist/svelte/components/ContentContributionForm.svelte.d.ts +23 -0
- package/dist/svelte/components/ContentContributionForm.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentContributionInbox.svelte +322 -0
- package/dist/svelte/components/ContentContributionInbox.svelte.d.ts +22 -0
- package/dist/svelte/components/ContentContributionInbox.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentContributionPortal.svelte +182 -0
- package/dist/svelte/components/ContentContributionPortal.svelte.d.ts +12 -0
- package/dist/svelte/components/ContentContributionPortal.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentContributionTypeManager.svelte +281 -0
- package/dist/svelte/components/ContentContributionTypeManager.svelte.d.ts +10 -0
- package/dist/svelte/components/ContentContributionTypeManager.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentContributorManager.svelte +140 -0
- package/dist/svelte/components/ContentContributorManager.svelte.d.ts +10 -0
- package/dist/svelte/components/ContentContributorManager.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentCorrectionsTool.svelte +361 -0
- package/dist/svelte/components/ContentCorrectionsTool.svelte.d.ts +11 -0
- package/dist/svelte/components/ContentCorrectionsTool.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentEditor.svelte +2166 -0
- package/dist/svelte/components/ContentEditor.svelte.d.ts +26 -0
- package/dist/svelte/components/ContentEditor.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentGovernanceAssignmentEditor.svelte +199 -0
- package/dist/svelte/components/ContentGovernanceAssignmentEditor.svelte.d.ts +11 -0
- package/dist/svelte/components/ContentGovernanceAssignmentEditor.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentGovernanceManager.svelte +340 -0
- package/dist/svelte/components/ContentGovernanceManager.svelte.d.ts +11 -0
- package/dist/svelte/components/ContentGovernanceManager.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentGovernancePanel.svelte +2244 -0
- package/dist/svelte/components/ContentGovernancePanel.svelte.d.ts +26 -0
- package/dist/svelte/components/ContentGovernancePanel.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentGovernancePolicyEditor.svelte +110 -0
- package/dist/svelte/components/ContentGovernancePolicyEditor.svelte.d.ts +10 -0
- package/dist/svelte/components/ContentGovernancePolicyEditor.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentGovernanceProfileEditor.svelte +185 -0
- package/dist/svelte/components/ContentGovernanceProfileEditor.svelte.d.ts +11 -0
- package/dist/svelte/components/ContentGovernanceProfileEditor.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentGovernanceTool.svelte +56 -0
- package/dist/svelte/components/ContentGovernanceTool.svelte.d.ts +13 -0
- package/dist/svelte/components/ContentGovernanceTool.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentImageBrowser.svelte +243 -0
- package/dist/svelte/components/ContentImageBrowser.svelte.d.ts +18 -0
- package/dist/svelte/components/ContentImageBrowser.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentImageChooser.svelte +134 -0
- package/dist/svelte/components/ContentImageChooser.svelte.d.ts +11 -0
- package/dist/svelte/components/ContentImageChooser.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentList.svelte +906 -0
- package/dist/svelte/components/ContentList.svelte.d.ts +16 -0
- package/dist/svelte/components/ContentList.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentMetadataFields.svelte +107 -0
- package/dist/svelte/components/ContentMetadataFields.svelte.d.ts +8 -0
- package/dist/svelte/components/ContentMetadataFields.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentReferencesPanel.svelte +221 -0
- package/dist/svelte/components/ContentReferencesPanel.svelte.d.ts +20 -0
- package/dist/svelte/components/ContentReferencesPanel.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentReviewStatusTray.svelte +151 -0
- package/dist/svelte/components/ContentReviewStatusTray.svelte.d.ts +20 -0
- package/dist/svelte/components/ContentReviewStatusTray.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentStatusFields.svelte +85 -0
- package/dist/svelte/components/ContentStatusFields.svelte.d.ts +8 -0
- package/dist/svelte/components/ContentStatusFields.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentTitleField.svelte +54 -0
- package/dist/svelte/components/ContentTitleField.svelte.d.ts +10 -0
- package/dist/svelte/components/ContentTitleField.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentTransparencyReport.svelte +322 -0
- package/dist/svelte/components/ContentTransparencyReport.svelte.d.ts +10 -0
- package/dist/svelte/components/ContentTransparencyReport.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentTransparencyTool.svelte +314 -0
- package/dist/svelte/components/ContentTransparencyTool.svelte.d.ts +10 -0
- package/dist/svelte/components/ContentTransparencyTool.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ContentVersionsTool.svelte +291 -0
- package/dist/svelte/components/ContentVersionsTool.svelte.d.ts +10 -0
- package/dist/svelte/components/ContentVersionsTool.svelte.d.ts.map +1 -0
- package/dist/svelte/components/GovernedContentEditor.svelte +409 -0
- package/dist/svelte/components/GovernedContentEditor.svelte.d.ts +35 -0
- package/dist/svelte/components/GovernedContentEditor.svelte.d.ts.map +1 -0
- package/dist/svelte/components/ImageThumbnail.cache.d.ts +14 -0
- package/dist/svelte/components/ImageThumbnail.cache.d.ts.map +1 -0
- package/dist/svelte/components/ImageThumbnail.cache.js +36 -0
- package/dist/svelte/components/ImageThumbnail.svelte +159 -0
- package/dist/svelte/components/ImageThumbnail.svelte.d.ts +8 -0
- package/dist/svelte/components/ImageThumbnail.svelte.d.ts.map +1 -0
- package/dist/svelte/components/Markdown.svelte +125 -0
- package/dist/svelte/components/Markdown.svelte.d.ts +11 -0
- package/dist/svelte/components/Markdown.svelte.d.ts.map +1 -0
- package/dist/svelte/content-editor-form.d.ts +63 -0
- package/dist/svelte/content-editor-form.d.ts.map +1 -0
- package/dist/svelte/content-editor-form.js +94 -0
- package/dist/svelte/content-editor-media.d.ts +12 -0
- package/dist/svelte/content-editor-media.d.ts.map +1 -0
- package/dist/svelte/content-editor-media.js +84 -0
- package/dist/svelte/content-editor-state.svelte.d.ts +35 -0
- package/dist/svelte/content-editor-state.svelte.d.ts.map +1 -0
- package/dist/svelte/content-editor-state.svelte.js +141 -0
- package/dist/svelte/governance-manager-client.d.ts +22 -0
- package/dist/svelte/governance-manager-client.d.ts.map +1 -0
- package/dist/svelte/governance-manager-client.js +1 -0
- package/dist/svelte/i18n.contribution.d.ts +57 -0
- package/dist/svelte/i18n.contribution.d.ts.map +1 -0
- package/dist/svelte/i18n.contribution.js +64 -0
- package/dist/svelte/i18n.editor.d.ts +71 -0
- package/dist/svelte/i18n.editor.d.ts.map +1 -0
- package/dist/svelte/i18n.editor.js +87 -0
- package/dist/svelte/i18n.governance.d.ts +66 -0
- package/dist/svelte/i18n.governance.d.ts.map +1 -0
- package/dist/svelte/i18n.governance.js +66 -0
- package/dist/svelte/i18n.routes.d.ts +66 -0
- package/dist/svelte/i18n.routes.d.ts.map +1 -0
- package/dist/svelte/i18n.routes.js +75 -0
- package/dist/svelte/i18n.tools.d.ts +81 -0
- package/dist/svelte/i18n.tools.d.ts.map +1 -0
- package/dist/svelte/i18n.tools.js +90 -0
- package/dist/svelte/index.d.ts +101 -0
- package/dist/svelte/index.d.ts.map +1 -0
- package/dist/svelte/index.js +63 -0
- package/dist/svelte/playground.d.ts +281 -0
- package/dist/svelte/playground.d.ts.map +1 -0
- package/dist/svelte/playground.js +438 -0
- package/dist/svelte/routes/ContentContributionsRoute.svelte +809 -0
- package/dist/svelte/routes/ContentContributionsRoute.svelte.d.ts +10 -0
- package/dist/svelte/routes/ContentContributionsRoute.svelte.d.ts.map +1 -0
- package/dist/svelte/routes/ContentFactsRoute.svelte +612 -0
- package/dist/svelte/routes/ContentFactsRoute.svelte.d.ts +11 -0
- package/dist/svelte/routes/ContentFactsRoute.svelte.d.ts.map +1 -0
- package/dist/svelte/routes/ContentGovernanceRoute.svelte +218 -0
- package/dist/svelte/routes/ContentGovernanceRoute.svelte.d.ts +10 -0
- package/dist/svelte/routes/ContentGovernanceRoute.svelte.d.ts.map +1 -0
- package/dist/svelte/routes/ContentWorkspaceRoute.svelte +431 -0
- package/dist/svelte/routes/ContentWorkspaceRoute.svelte.d.ts +12 -0
- package/dist/svelte/routes/ContentWorkspaceRoute.svelte.d.ts.map +1 -0
- package/dist/svelte/routes/PublishedArticleRoute.svelte +194 -0
- package/dist/svelte/routes/PublishedArticleRoute.svelte.d.ts +10 -0
- package/dist/svelte/routes/PublishedArticleRoute.svelte.d.ts.map +1 -0
- package/dist/svelte/routes/index.d.ts +8 -0
- package/dist/svelte/routes/index.d.ts.map +1 -0
- package/dist/svelte/routes/index.js +6 -0
- package/dist/svelte/routes/shared.d.ts +90 -0
- package/dist/svelte/routes/shared.d.ts.map +1 -0
- package/dist/svelte/routes/shared.js +104 -0
- package/dist/svelte/types.d.ts +69 -0
- package/dist/svelte/types.d.ts.map +1 -0
- package/dist/svelte/types.js +6 -0
- package/dist/thumbnail-generator.d.ts +174 -0
- package/dist/thumbnail-generator.d.ts.map +1 -0
- package/dist/ui.d.ts +10 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +42 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils.d.ts +18 -0
- package/dist/utils.d.ts.map +1 -0
- package/package.json +119 -0
|
@@ -0,0 +1,438 @@
|
|
|
1
|
+
import { CONTENT_MODULE_META } from '../ui.js';
|
|
2
|
+
const DEFAULT_CONTENT_PLAYGROUND_API_BASE_URL = '/api/v1';
|
|
3
|
+
function resolveContentPlaygroundApiBaseUrl() {
|
|
4
|
+
const configuredViaGlobal = globalThis
|
|
5
|
+
.__SMRT_CONTENT_PLAYGROUND_API_BASE_URL__;
|
|
6
|
+
if (configuredViaGlobal) {
|
|
7
|
+
return configuredViaGlobal;
|
|
8
|
+
}
|
|
9
|
+
const browserLocation = globalThis.location;
|
|
10
|
+
if (browserLocation) {
|
|
11
|
+
const configuredViaQuery = new URLSearchParams(browserLocation.search).get('smrtContentApiBaseUrl');
|
|
12
|
+
if (configuredViaQuery) {
|
|
13
|
+
return configuredViaQuery;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return DEFAULT_CONTENT_PLAYGROUND_API_BASE_URL;
|
|
17
|
+
}
|
|
18
|
+
const sampleArticles = [
|
|
19
|
+
{
|
|
20
|
+
id: 'article-aurora-kitchen',
|
|
21
|
+
slug: 'aurora-kitchen-notes',
|
|
22
|
+
title: 'Aurora Kitchen Notes',
|
|
23
|
+
description: 'A reference article card preview showing how editorial metadata lands in the package playground.',
|
|
24
|
+
publish_date: '2026-03-14T12:00:00.000Z',
|
|
25
|
+
author: 'Editorial Systems',
|
|
26
|
+
tags: ['release', 'editorial', 'qa'],
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
id: 'article-governance-habits',
|
|
30
|
+
slug: 'governance-habits',
|
|
31
|
+
title: 'Governance Habits That Scale',
|
|
32
|
+
description: 'Teams can move fast when quality gates are visible, lightweight, and shared with contributors.',
|
|
33
|
+
publish_date: '2026-03-19T09:30:00.000Z',
|
|
34
|
+
author: 'Content Ops',
|
|
35
|
+
tags: ['governance', 'quality', 'workflows'],
|
|
36
|
+
},
|
|
37
|
+
];
|
|
38
|
+
const sampleContributions = [
|
|
39
|
+
{
|
|
40
|
+
id: 'contribution-1',
|
|
41
|
+
title: 'Spring buyer guide',
|
|
42
|
+
contributionTypeKey: 'article',
|
|
43
|
+
status: 'needs_changes',
|
|
44
|
+
revisionCount: 2,
|
|
45
|
+
editorNotes: 'Please tighten the sourcing notes in the opening section.',
|
|
46
|
+
contributorName: 'Taylor Rowan',
|
|
47
|
+
contributorEmail: 'taylor@example.com',
|
|
48
|
+
intakeDecision: 'needs_changes',
|
|
49
|
+
body: 'The spring buyer guide draft is attached, with sourcing notes for the opening section and the product comparison appendix.',
|
|
50
|
+
updatedAt: '2026-03-20T15:18:00.000Z',
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
id: 'contribution-2',
|
|
54
|
+
title: 'Field report: Pacific logistics',
|
|
55
|
+
contributionTypeKey: 'report',
|
|
56
|
+
status: 'submitted',
|
|
57
|
+
revisionCount: 1,
|
|
58
|
+
contributorName: 'Jordan Lee',
|
|
59
|
+
contributorEmail: 'jordan@example.com',
|
|
60
|
+
intakeDecision: 'submitted',
|
|
61
|
+
body: 'Field notes from the Pacific corridor include updated shipping windows, route constraints, and operator interviews.',
|
|
62
|
+
updatedAt: '2026-03-18T10:40:00.000Z',
|
|
63
|
+
},
|
|
64
|
+
];
|
|
65
|
+
const sampleGovernanceDefinitions = {
|
|
66
|
+
effective: {
|
|
67
|
+
policies: [
|
|
68
|
+
{
|
|
69
|
+
id: 'policy-facts',
|
|
70
|
+
key: 'facts',
|
|
71
|
+
label: 'Facts review',
|
|
72
|
+
kind: 'facts',
|
|
73
|
+
instructions: 'Compare claims against linked facts before publication.',
|
|
74
|
+
enabled: true,
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
id: 'policy-style',
|
|
78
|
+
key: 'style',
|
|
79
|
+
label: 'Style review',
|
|
80
|
+
kind: 'custom',
|
|
81
|
+
instructions: 'Apply newsroom tone, structure, and clarity guidelines.',
|
|
82
|
+
enabled: true,
|
|
83
|
+
},
|
|
84
|
+
],
|
|
85
|
+
profiles: [
|
|
86
|
+
{
|
|
87
|
+
id: 'profile-publication',
|
|
88
|
+
key: 'publication',
|
|
89
|
+
label: 'Publication',
|
|
90
|
+
description: 'Required before governed content can be published.',
|
|
91
|
+
enabled: true,
|
|
92
|
+
requirements: [
|
|
93
|
+
{
|
|
94
|
+
policyKey: 'facts',
|
|
95
|
+
label: 'Facts review',
|
|
96
|
+
blocking: true,
|
|
97
|
+
acceptedStatuses: ['passed'],
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
policyKey: 'style',
|
|
101
|
+
label: 'Style review',
|
|
102
|
+
blocking: false,
|
|
103
|
+
acceptedStatuses: ['passed', 'warning'],
|
|
104
|
+
},
|
|
105
|
+
],
|
|
106
|
+
},
|
|
107
|
+
],
|
|
108
|
+
assignments: [
|
|
109
|
+
{
|
|
110
|
+
id: 'assignment-article',
|
|
111
|
+
key: 'article',
|
|
112
|
+
label: 'Articles',
|
|
113
|
+
contentType: 'article',
|
|
114
|
+
contentVariant: null,
|
|
115
|
+
enabled: true,
|
|
116
|
+
factLinkingEnabled: true,
|
|
117
|
+
transparencyEnabled: true,
|
|
118
|
+
publicationProfileKey: 'publication',
|
|
119
|
+
correctionProfileKey: null,
|
|
120
|
+
enforcePublishReadiness: true,
|
|
121
|
+
defaultFactRelationship: 'supports',
|
|
122
|
+
},
|
|
123
|
+
],
|
|
124
|
+
},
|
|
125
|
+
persisted: {
|
|
126
|
+
policies: [
|
|
127
|
+
{
|
|
128
|
+
id: 'policy-style',
|
|
129
|
+
key: 'style',
|
|
130
|
+
label: 'Style review',
|
|
131
|
+
kind: 'custom',
|
|
132
|
+
instructions: 'Apply newsroom tone, structure, and clarity guidelines.',
|
|
133
|
+
enabled: true,
|
|
134
|
+
},
|
|
135
|
+
],
|
|
136
|
+
profiles: [
|
|
137
|
+
{
|
|
138
|
+
id: 'profile-publication',
|
|
139
|
+
key: 'publication',
|
|
140
|
+
label: 'Publication',
|
|
141
|
+
description: 'Required before governed content can be published.',
|
|
142
|
+
enabled: true,
|
|
143
|
+
requirements: [
|
|
144
|
+
{
|
|
145
|
+
policyKey: 'facts',
|
|
146
|
+
label: 'Facts review',
|
|
147
|
+
blocking: true,
|
|
148
|
+
acceptedStatuses: ['passed'],
|
|
149
|
+
},
|
|
150
|
+
{
|
|
151
|
+
policyKey: 'style',
|
|
152
|
+
label: 'Style review',
|
|
153
|
+
blocking: false,
|
|
154
|
+
acceptedStatuses: ['passed', 'warning'],
|
|
155
|
+
},
|
|
156
|
+
],
|
|
157
|
+
},
|
|
158
|
+
],
|
|
159
|
+
assignments: [
|
|
160
|
+
{
|
|
161
|
+
id: 'assignment-article',
|
|
162
|
+
key: 'article',
|
|
163
|
+
label: 'Articles',
|
|
164
|
+
contentType: 'article',
|
|
165
|
+
contentVariant: null,
|
|
166
|
+
enabled: true,
|
|
167
|
+
factLinkingEnabled: true,
|
|
168
|
+
transparencyEnabled: true,
|
|
169
|
+
publicationProfileKey: 'publication',
|
|
170
|
+
correctionProfileKey: null,
|
|
171
|
+
enforcePublishReadiness: true,
|
|
172
|
+
defaultFactRelationship: 'supports',
|
|
173
|
+
},
|
|
174
|
+
],
|
|
175
|
+
},
|
|
176
|
+
};
|
|
177
|
+
const sampleEditorContent = {
|
|
178
|
+
id: 'content-playground-editor',
|
|
179
|
+
slug: 'playground-editor-reference',
|
|
180
|
+
title: 'Reference editorial draft',
|
|
181
|
+
description: 'A working editor preview with copy, references, and assets already populated.',
|
|
182
|
+
body: `# Editorial Draft
|
|
183
|
+
|
|
184
|
+
This preview is meant to feel like a real authoring surface.
|
|
185
|
+
|
|
186
|
+
- tighten the lede
|
|
187
|
+
- verify product claims
|
|
188
|
+
- attach supporting references`,
|
|
189
|
+
author: 'Editorial Systems',
|
|
190
|
+
type: 'article',
|
|
191
|
+
status: 'draft',
|
|
192
|
+
state: 'active',
|
|
193
|
+
source: 'manual',
|
|
194
|
+
tags: ['editorial', 'playground'],
|
|
195
|
+
referenceIds: ['fact-aurora', 'source-governance'],
|
|
196
|
+
assetIds: [],
|
|
197
|
+
assets: [],
|
|
198
|
+
};
|
|
199
|
+
const noop = () => { };
|
|
200
|
+
function cloneValue(value) {
|
|
201
|
+
return JSON.parse(JSON.stringify(value));
|
|
202
|
+
}
|
|
203
|
+
function buildPlaygroundResponse(data) {
|
|
204
|
+
return {
|
|
205
|
+
data,
|
|
206
|
+
success: true,
|
|
207
|
+
};
|
|
208
|
+
}
|
|
209
|
+
function upsertByIdOrKey(items, value, prefix) {
|
|
210
|
+
const id = value.id || `${prefix}-${value.key || items.length + 1}`;
|
|
211
|
+
const nextValue = {
|
|
212
|
+
...value,
|
|
213
|
+
id,
|
|
214
|
+
};
|
|
215
|
+
const index = items.findIndex((item) => item.id === id || (!!value.key && item.key === value.key));
|
|
216
|
+
if (index === -1) {
|
|
217
|
+
return [...items, nextValue];
|
|
218
|
+
}
|
|
219
|
+
const nextItems = [...items];
|
|
220
|
+
nextItems[index] = {
|
|
221
|
+
...nextItems[index],
|
|
222
|
+
...nextValue,
|
|
223
|
+
};
|
|
224
|
+
return nextItems;
|
|
225
|
+
}
|
|
226
|
+
function createGovernancePlaygroundClient(seed = sampleGovernanceDefinitions) {
|
|
227
|
+
let policies = cloneValue(seed.effective.policies);
|
|
228
|
+
let profiles = cloneValue(seed.effective.profiles);
|
|
229
|
+
let assignments = cloneValue(seed.effective.assignments);
|
|
230
|
+
const getDefinitions = () => ({
|
|
231
|
+
effective: {
|
|
232
|
+
policies: cloneValue(policies),
|
|
233
|
+
profiles: cloneValue(profiles),
|
|
234
|
+
assignments: cloneValue(assignments),
|
|
235
|
+
},
|
|
236
|
+
persisted: {
|
|
237
|
+
policies: cloneValue(policies),
|
|
238
|
+
profiles: cloneValue(profiles),
|
|
239
|
+
assignments: cloneValue(assignments),
|
|
240
|
+
},
|
|
241
|
+
});
|
|
242
|
+
return {
|
|
243
|
+
contents: {
|
|
244
|
+
getGovernanceDefinitions: async () => buildPlaygroundResponse(getDefinitions()),
|
|
245
|
+
},
|
|
246
|
+
contentGovernancePolicies: {
|
|
247
|
+
create: async (policy) => {
|
|
248
|
+
policies = upsertByIdOrKey(policies, policy, 'policy');
|
|
249
|
+
return buildPlaygroundResponse(policies[policies.length - 1]);
|
|
250
|
+
},
|
|
251
|
+
update: async (id, policy) => {
|
|
252
|
+
policies = upsertByIdOrKey(policies, { ...policy, id }, 'policy');
|
|
253
|
+
return buildPlaygroundResponse(policies.find((item) => item.id === id));
|
|
254
|
+
},
|
|
255
|
+
delete: async (id) => {
|
|
256
|
+
policies = policies.filter((item) => item.id !== id);
|
|
257
|
+
return buildPlaygroundResponse(undefined);
|
|
258
|
+
},
|
|
259
|
+
},
|
|
260
|
+
contentGovernanceProfiles: {
|
|
261
|
+
create: async (profile) => {
|
|
262
|
+
profiles = upsertByIdOrKey(profiles, profile, 'profile');
|
|
263
|
+
return buildPlaygroundResponse(profiles[profiles.length - 1]);
|
|
264
|
+
},
|
|
265
|
+
update: async (id, profile) => {
|
|
266
|
+
profiles = upsertByIdOrKey(profiles, { ...profile, id }, 'profile');
|
|
267
|
+
return buildPlaygroundResponse(profiles.find((item) => item.id === id));
|
|
268
|
+
},
|
|
269
|
+
delete: async (id) => {
|
|
270
|
+
profiles = profiles.filter((item) => item.id !== id);
|
|
271
|
+
return buildPlaygroundResponse(undefined);
|
|
272
|
+
},
|
|
273
|
+
},
|
|
274
|
+
contentGovernanceAssignments: {
|
|
275
|
+
create: async (assignment) => {
|
|
276
|
+
assignments = upsertByIdOrKey(assignments, assignment, 'assignment');
|
|
277
|
+
return buildPlaygroundResponse(assignments[assignments.length - 1]);
|
|
278
|
+
},
|
|
279
|
+
update: async (id, assignment) => {
|
|
280
|
+
assignments = upsertByIdOrKey(assignments, { ...assignment, id }, 'assignment');
|
|
281
|
+
return buildPlaygroundResponse(assignments.find((item) => item.id === id));
|
|
282
|
+
},
|
|
283
|
+
delete: async (id) => {
|
|
284
|
+
assignments = assignments.filter((item) => item.id !== id);
|
|
285
|
+
return buildPlaygroundResponse(undefined);
|
|
286
|
+
},
|
|
287
|
+
},
|
|
288
|
+
};
|
|
289
|
+
}
|
|
290
|
+
const markdownExample = `# Content Playground
|
|
291
|
+
|
|
292
|
+
This preview module lives in \`src/svelte/playground.ts\`.
|
|
293
|
+
|
|
294
|
+
- Package-owned previews stay close to the real components
|
|
295
|
+
- The shared host simply discovers and renders them
|
|
296
|
+
- Live entries can still point at the package's generated API routes`;
|
|
297
|
+
// Keep the published playground module importable from Node so `smrt
|
|
298
|
+
// playground list` can inspect entry metadata without needing a Svelte loader.
|
|
299
|
+
const loadArticleCard = () => import('./components/ArticleCard.svelte');
|
|
300
|
+
const loadArticleList = () => import('./components/ArticleList.svelte');
|
|
301
|
+
const loadContentEditor = () => import('./components/ContentEditor.svelte');
|
|
302
|
+
const loadContentContributionInbox = () => import('./components/ContentContributionInbox.svelte');
|
|
303
|
+
const loadContentContributionPortal = () => import('./components/ContentContributionPortal.svelte');
|
|
304
|
+
const loadContentGovernanceManager = () => import('./components/ContentGovernanceManager.svelte');
|
|
305
|
+
const loadMarkdown = () => import('./components/Markdown.svelte');
|
|
306
|
+
const governancePlaygroundClient = createGovernancePlaygroundClient();
|
|
307
|
+
export default {
|
|
308
|
+
packageName: '@happyvertical/smrt-content',
|
|
309
|
+
displayName: 'Content',
|
|
310
|
+
description: CONTENT_MODULE_META.description,
|
|
311
|
+
moduleMeta: CONTENT_MODULE_META,
|
|
312
|
+
entries: [
|
|
313
|
+
{
|
|
314
|
+
id: 'article-card',
|
|
315
|
+
slotId: 'article-card',
|
|
316
|
+
title: 'Article Card',
|
|
317
|
+
description: 'Editorial teaser card with tags and metadata.',
|
|
318
|
+
loadComponent: loadArticleCard,
|
|
319
|
+
order: 1,
|
|
320
|
+
props: {
|
|
321
|
+
article: sampleArticles[0],
|
|
322
|
+
showTags: true,
|
|
323
|
+
},
|
|
324
|
+
modes: {
|
|
325
|
+
mock: {
|
|
326
|
+
label: 'Mock',
|
|
327
|
+
},
|
|
328
|
+
},
|
|
329
|
+
},
|
|
330
|
+
{
|
|
331
|
+
id: 'article-list',
|
|
332
|
+
slotId: 'article-list',
|
|
333
|
+
title: 'Article List',
|
|
334
|
+
description: 'Reference list/grid layout for published content.',
|
|
335
|
+
loadComponent: loadArticleList,
|
|
336
|
+
order: 2,
|
|
337
|
+
props: {
|
|
338
|
+
articles: sampleArticles,
|
|
339
|
+
showTags: true,
|
|
340
|
+
},
|
|
341
|
+
modes: {
|
|
342
|
+
mock: {
|
|
343
|
+
label: 'Mock',
|
|
344
|
+
},
|
|
345
|
+
},
|
|
346
|
+
},
|
|
347
|
+
{
|
|
348
|
+
id: 'markdown',
|
|
349
|
+
slotId: 'markdown',
|
|
350
|
+
title: 'Markdown Renderer',
|
|
351
|
+
description: 'Safe markdown rendering with a small editorial snippet.',
|
|
352
|
+
loadComponent: loadMarkdown,
|
|
353
|
+
order: 3,
|
|
354
|
+
props: {
|
|
355
|
+
content: markdownExample,
|
|
356
|
+
},
|
|
357
|
+
modes: {
|
|
358
|
+
mock: {
|
|
359
|
+
label: 'Mock',
|
|
360
|
+
},
|
|
361
|
+
},
|
|
362
|
+
},
|
|
363
|
+
{
|
|
364
|
+
id: 'content-editor',
|
|
365
|
+
title: 'Content Editor',
|
|
366
|
+
description: 'Authoring surface for body copy, references, and media.',
|
|
367
|
+
loadComponent: loadContentEditor,
|
|
368
|
+
order: 4,
|
|
369
|
+
props: {
|
|
370
|
+
apiBaseUrl: resolveContentPlaygroundApiBaseUrl(),
|
|
371
|
+
content: sampleEditorContent,
|
|
372
|
+
contentId: sampleEditorContent.id,
|
|
373
|
+
agentChatEnabled: false,
|
|
374
|
+
agentChatNotice: 'The shared playground keeps the editor preview local. Run the content package app when you want the live agent chat routes too.',
|
|
375
|
+
onSave: noop,
|
|
376
|
+
onCancel: noop,
|
|
377
|
+
},
|
|
378
|
+
modes: {
|
|
379
|
+
mock: {
|
|
380
|
+
label: 'Mock',
|
|
381
|
+
},
|
|
382
|
+
},
|
|
383
|
+
},
|
|
384
|
+
{
|
|
385
|
+
id: 'contribution-portal',
|
|
386
|
+
title: 'Contribution Portal',
|
|
387
|
+
description: 'Contributor-facing inbox and submission status view.',
|
|
388
|
+
loadComponent: loadContentContributionPortal,
|
|
389
|
+
order: 5,
|
|
390
|
+
props: {
|
|
391
|
+
contributions: sampleContributions,
|
|
392
|
+
},
|
|
393
|
+
modes: {
|
|
394
|
+
mock: {
|
|
395
|
+
label: 'Mock',
|
|
396
|
+
},
|
|
397
|
+
},
|
|
398
|
+
},
|
|
399
|
+
{
|
|
400
|
+
id: 'contribution-inbox',
|
|
401
|
+
title: 'Contribution Inbox',
|
|
402
|
+
description: 'Editorial review queue for approving, rejecting, or requesting changes.',
|
|
403
|
+
loadComponent: loadContentContributionInbox,
|
|
404
|
+
order: 6,
|
|
405
|
+
props: {
|
|
406
|
+
contributions: sampleContributions,
|
|
407
|
+
},
|
|
408
|
+
modes: {
|
|
409
|
+
mock: {
|
|
410
|
+
label: 'Mock',
|
|
411
|
+
},
|
|
412
|
+
},
|
|
413
|
+
},
|
|
414
|
+
{
|
|
415
|
+
id: 'governance-manager',
|
|
416
|
+
title: 'Governance Manager',
|
|
417
|
+
description: 'Administrative view with in-memory mock data and optional live package routes.',
|
|
418
|
+
loadComponent: loadContentGovernanceManager,
|
|
419
|
+
order: 7,
|
|
420
|
+
modes: {
|
|
421
|
+
mock: {
|
|
422
|
+
label: 'Mock',
|
|
423
|
+
description: 'Uses an in-memory governance client so the shared playground works without a package-local dev server.',
|
|
424
|
+
props: {
|
|
425
|
+
client: governancePlaygroundClient,
|
|
426
|
+
},
|
|
427
|
+
},
|
|
428
|
+
live: {
|
|
429
|
+
label: 'Live',
|
|
430
|
+
description: 'Requires the content package dev server and generated routes. Override the base URL with ?smrtContentApiBaseUrl=... or window.__SMRT_CONTENT_PLAYGROUND_API_BASE_URL__ when needed.',
|
|
431
|
+
props: {
|
|
432
|
+
apiBaseUrl: resolveContentPlaygroundApiBaseUrl(),
|
|
433
|
+
},
|
|
434
|
+
},
|
|
435
|
+
},
|
|
436
|
+
},
|
|
437
|
+
],
|
|
438
|
+
};
|