@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.
Files changed (291) hide show
  1. package/AGENTS.md +194 -0
  2. package/CLAUDE.md +1 -0
  3. package/LICENSE +7 -0
  4. package/README.md +634 -0
  5. package/dist/__smrt-register__.d.ts +2 -0
  6. package/dist/__smrt-register__.d.ts.map +1 -0
  7. package/dist/asset-associable.d.ts +115 -0
  8. package/dist/asset-associable.d.ts.map +1 -0
  9. package/dist/body-format.d.ts +29 -0
  10. package/dist/body-format.d.ts.map +1 -0
  11. package/dist/body-format.js +604 -0
  12. package/dist/body-format.js.map +1 -0
  13. package/dist/content-asset.d.ts +17 -0
  14. package/dist/content-asset.d.ts.map +1 -0
  15. package/dist/content-assets.d.ts +10 -0
  16. package/dist/content-assets.d.ts.map +1 -0
  17. package/dist/content-chat-handlers.d.ts +115 -0
  18. package/dist/content-chat-handlers.d.ts.map +1 -0
  19. package/dist/content-chat-prompts.d.ts +3 -0
  20. package/dist/content-chat-prompts.d.ts.map +1 -0
  21. package/dist/content-chat-session.d.ts +26 -0
  22. package/dist/content-chat-session.d.ts.map +1 -0
  23. package/dist/content-contribution-attachment.d.ts +42 -0
  24. package/dist/content-contribution-attachment.d.ts.map +1 -0
  25. package/dist/content-contribution-attachments.d.ts +8 -0
  26. package/dist/content-contribution-attachments.d.ts.map +1 -0
  27. package/dist/content-contribution-config.d.ts +84 -0
  28. package/dist/content-contribution-config.d.ts.map +1 -0
  29. package/dist/content-contribution-revision.d.ts +38 -0
  30. package/dist/content-contribution-revision.d.ts.map +1 -0
  31. package/dist/content-contribution-revisions.d.ts +8 -0
  32. package/dist/content-contribution-revisions.d.ts.map +1 -0
  33. package/dist/content-contribution-type.d.ts +51 -0
  34. package/dist/content-contribution-type.d.ts.map +1 -0
  35. package/dist/content-contribution-types.d.ts +7 -0
  36. package/dist/content-contribution-types.d.ts.map +1 -0
  37. package/dist/content-contribution.d.ts +161 -0
  38. package/dist/content-contribution.d.ts.map +1 -0
  39. package/dist/content-contributions.d.ts +53 -0
  40. package/dist/content-contributions.d.ts.map +1 -0
  41. package/dist/content-contributor.d.ts +30 -0
  42. package/dist/content-contributor.d.ts.map +1 -0
  43. package/dist/content-contributors.d.ts +13 -0
  44. package/dist/content-contributors.d.ts.map +1 -0
  45. package/dist/content-correction.d.ts +39 -0
  46. package/dist/content-correction.d.ts.map +1 -0
  47. package/dist/content-corrections.d.ts +9 -0
  48. package/dist/content-corrections.d.ts.map +1 -0
  49. package/dist/content-editor-assistant.d.ts +68 -0
  50. package/dist/content-editor-assistant.d.ts.map +1 -0
  51. package/dist/content-editor-assistant.js +97 -0
  52. package/dist/content-editor-assistant.js.map +1 -0
  53. package/dist/content-feed-parser.d.ts +19 -0
  54. package/dist/content-feed-parser.d.ts.map +1 -0
  55. package/dist/content-feed-source.d.ts +52 -0
  56. package/dist/content-feed-source.d.ts.map +1 -0
  57. package/dist/content-feed-sources.d.ts +11 -0
  58. package/dist/content-feed-sources.d.ts.map +1 -0
  59. package/dist/content-feed-sync.d.ts +23 -0
  60. package/dist/content-feed-sync.d.ts.map +1 -0
  61. package/dist/content-governance-assignment.d.ts +42 -0
  62. package/dist/content-governance-assignment.d.ts.map +1 -0
  63. package/dist/content-governance-assignments.d.ts +11 -0
  64. package/dist/content-governance-assignments.d.ts.map +1 -0
  65. package/dist/content-governance-policies.d.ts +7 -0
  66. package/dist/content-governance-policies.d.ts.map +1 -0
  67. package/dist/content-governance-policy.d.ts +29 -0
  68. package/dist/content-governance-policy.d.ts.map +1 -0
  69. package/dist/content-governance-profile.d.ts +31 -0
  70. package/dist/content-governance-profile.d.ts.map +1 -0
  71. package/dist/content-governance-profiles.d.ts +7 -0
  72. package/dist/content-governance-profiles.d.ts.map +1 -0
  73. package/dist/content-governance.d.ts +188 -0
  74. package/dist/content-governance.d.ts.map +1 -0
  75. package/dist/content-prompts.d.ts +10 -0
  76. package/dist/content-prompts.d.ts.map +1 -0
  77. package/dist/content-reference.d.ts +17 -0
  78. package/dist/content-reference.d.ts.map +1 -0
  79. package/dist/content-references.d.ts +55 -0
  80. package/dist/content-references.d.ts.map +1 -0
  81. package/dist/content-review.d.ts +34 -0
  82. package/dist/content-review.d.ts.map +1 -0
  83. package/dist/content-reviews.d.ts +21 -0
  84. package/dist/content-reviews.d.ts.map +1 -0
  85. package/dist/content-transparency.d.ts +72 -0
  86. package/dist/content-transparency.d.ts.map +1 -0
  87. package/dist/content-types.d.ts +51 -0
  88. package/dist/content-types.d.ts.map +1 -0
  89. package/dist/content-version.d.ts +38 -0
  90. package/dist/content-version.d.ts.map +1 -0
  91. package/dist/content-versions.d.ts +16 -0
  92. package/dist/content-versions.d.ts.map +1 -0
  93. package/dist/content.d.ts +736 -0
  94. package/dist/content.d.ts.map +1 -0
  95. package/dist/contents.d.ts +292 -0
  96. package/dist/contents.d.ts.map +1 -0
  97. package/dist/database-utils.d.ts +3 -0
  98. package/dist/database-utils.d.ts.map +1 -0
  99. package/dist/index.d.ts +78 -0
  100. package/dist/index.d.ts.map +1 -0
  101. package/dist/index.js +11602 -0
  102. package/dist/index.js.map +1 -0
  103. package/dist/manifest.json +12308 -0
  104. package/dist/mock-smrt-client.d.ts +493 -0
  105. package/dist/mock-smrt-client.d.ts.map +1 -0
  106. package/dist/mock-smrt-client.js +390 -0
  107. package/dist/mock-smrt-client.js.map +1 -0
  108. package/dist/playground.d.ts +2 -0
  109. package/dist/playground.d.ts.map +1 -0
  110. package/dist/playground.js +454 -0
  111. package/dist/playground.js.map +1 -0
  112. package/dist/publish-readiness.d.ts +30 -0
  113. package/dist/publish-readiness.d.ts.map +1 -0
  114. package/dist/publish-readiness.js +74 -0
  115. package/dist/publish-readiness.js.map +1 -0
  116. package/dist/safe-remote-url.d.ts +52 -0
  117. package/dist/safe-remote-url.d.ts.map +1 -0
  118. package/dist/serialization.d.ts +78 -0
  119. package/dist/serialization.d.ts.map +1 -0
  120. package/dist/smrt-knowledge.json +6130 -0
  121. package/dist/svelte/api.d.ts +3 -0
  122. package/dist/svelte/api.d.ts.map +1 -0
  123. package/dist/svelte/api.js +10 -0
  124. package/dist/svelte/components/ArticleCard.svelte +159 -0
  125. package/dist/svelte/components/ArticleCard.svelte.d.ts +17 -0
  126. package/dist/svelte/components/ArticleCard.svelte.d.ts.map +1 -0
  127. package/dist/svelte/components/ArticleList.svelte +75 -0
  128. package/dist/svelte/components/ArticleList.svelte.d.ts +21 -0
  129. package/dist/svelte/components/ArticleList.svelte.d.ts.map +1 -0
  130. package/dist/svelte/components/ContentAgentChat.svelte +652 -0
  131. package/dist/svelte/components/ContentAgentChat.svelte.d.ts +17 -0
  132. package/dist/svelte/components/ContentAgentChat.svelte.d.ts.map +1 -0
  133. package/dist/svelte/components/ContentBodyEditor.svelte +1446 -0
  134. package/dist/svelte/components/ContentBodyEditor.svelte.d.ts +25 -0
  135. package/dist/svelte/components/ContentBodyEditor.svelte.d.ts.map +1 -0
  136. package/dist/svelte/components/ContentBodyRenderer.svelte +152 -0
  137. package/dist/svelte/components/ContentBodyRenderer.svelte.d.ts +10 -0
  138. package/dist/svelte/components/ContentBodyRenderer.svelte.d.ts.map +1 -0
  139. package/dist/svelte/components/ContentClaimAuditTool.svelte +441 -0
  140. package/dist/svelte/components/ContentClaimAuditTool.svelte.d.ts +12 -0
  141. package/dist/svelte/components/ContentClaimAuditTool.svelte.d.ts.map +1 -0
  142. package/dist/svelte/components/ContentContributionForm.svelte +226 -0
  143. package/dist/svelte/components/ContentContributionForm.svelte.d.ts +23 -0
  144. package/dist/svelte/components/ContentContributionForm.svelte.d.ts.map +1 -0
  145. package/dist/svelte/components/ContentContributionInbox.svelte +322 -0
  146. package/dist/svelte/components/ContentContributionInbox.svelte.d.ts +22 -0
  147. package/dist/svelte/components/ContentContributionInbox.svelte.d.ts.map +1 -0
  148. package/dist/svelte/components/ContentContributionPortal.svelte +182 -0
  149. package/dist/svelte/components/ContentContributionPortal.svelte.d.ts +12 -0
  150. package/dist/svelte/components/ContentContributionPortal.svelte.d.ts.map +1 -0
  151. package/dist/svelte/components/ContentContributionTypeManager.svelte +281 -0
  152. package/dist/svelte/components/ContentContributionTypeManager.svelte.d.ts +10 -0
  153. package/dist/svelte/components/ContentContributionTypeManager.svelte.d.ts.map +1 -0
  154. package/dist/svelte/components/ContentContributorManager.svelte +140 -0
  155. package/dist/svelte/components/ContentContributorManager.svelte.d.ts +10 -0
  156. package/dist/svelte/components/ContentContributorManager.svelte.d.ts.map +1 -0
  157. package/dist/svelte/components/ContentCorrectionsTool.svelte +361 -0
  158. package/dist/svelte/components/ContentCorrectionsTool.svelte.d.ts +11 -0
  159. package/dist/svelte/components/ContentCorrectionsTool.svelte.d.ts.map +1 -0
  160. package/dist/svelte/components/ContentEditor.svelte +2166 -0
  161. package/dist/svelte/components/ContentEditor.svelte.d.ts +26 -0
  162. package/dist/svelte/components/ContentEditor.svelte.d.ts.map +1 -0
  163. package/dist/svelte/components/ContentGovernanceAssignmentEditor.svelte +199 -0
  164. package/dist/svelte/components/ContentGovernanceAssignmentEditor.svelte.d.ts +11 -0
  165. package/dist/svelte/components/ContentGovernanceAssignmentEditor.svelte.d.ts.map +1 -0
  166. package/dist/svelte/components/ContentGovernanceManager.svelte +340 -0
  167. package/dist/svelte/components/ContentGovernanceManager.svelte.d.ts +11 -0
  168. package/dist/svelte/components/ContentGovernanceManager.svelte.d.ts.map +1 -0
  169. package/dist/svelte/components/ContentGovernancePanel.svelte +2244 -0
  170. package/dist/svelte/components/ContentGovernancePanel.svelte.d.ts +26 -0
  171. package/dist/svelte/components/ContentGovernancePanel.svelte.d.ts.map +1 -0
  172. package/dist/svelte/components/ContentGovernancePolicyEditor.svelte +110 -0
  173. package/dist/svelte/components/ContentGovernancePolicyEditor.svelte.d.ts +10 -0
  174. package/dist/svelte/components/ContentGovernancePolicyEditor.svelte.d.ts.map +1 -0
  175. package/dist/svelte/components/ContentGovernanceProfileEditor.svelte +185 -0
  176. package/dist/svelte/components/ContentGovernanceProfileEditor.svelte.d.ts +11 -0
  177. package/dist/svelte/components/ContentGovernanceProfileEditor.svelte.d.ts.map +1 -0
  178. package/dist/svelte/components/ContentGovernanceTool.svelte +56 -0
  179. package/dist/svelte/components/ContentGovernanceTool.svelte.d.ts +13 -0
  180. package/dist/svelte/components/ContentGovernanceTool.svelte.d.ts.map +1 -0
  181. package/dist/svelte/components/ContentImageBrowser.svelte +243 -0
  182. package/dist/svelte/components/ContentImageBrowser.svelte.d.ts +18 -0
  183. package/dist/svelte/components/ContentImageBrowser.svelte.d.ts.map +1 -0
  184. package/dist/svelte/components/ContentImageChooser.svelte +134 -0
  185. package/dist/svelte/components/ContentImageChooser.svelte.d.ts +11 -0
  186. package/dist/svelte/components/ContentImageChooser.svelte.d.ts.map +1 -0
  187. package/dist/svelte/components/ContentList.svelte +906 -0
  188. package/dist/svelte/components/ContentList.svelte.d.ts +16 -0
  189. package/dist/svelte/components/ContentList.svelte.d.ts.map +1 -0
  190. package/dist/svelte/components/ContentMetadataFields.svelte +107 -0
  191. package/dist/svelte/components/ContentMetadataFields.svelte.d.ts +8 -0
  192. package/dist/svelte/components/ContentMetadataFields.svelte.d.ts.map +1 -0
  193. package/dist/svelte/components/ContentReferencesPanel.svelte +221 -0
  194. package/dist/svelte/components/ContentReferencesPanel.svelte.d.ts +20 -0
  195. package/dist/svelte/components/ContentReferencesPanel.svelte.d.ts.map +1 -0
  196. package/dist/svelte/components/ContentReviewStatusTray.svelte +151 -0
  197. package/dist/svelte/components/ContentReviewStatusTray.svelte.d.ts +20 -0
  198. package/dist/svelte/components/ContentReviewStatusTray.svelte.d.ts.map +1 -0
  199. package/dist/svelte/components/ContentStatusFields.svelte +85 -0
  200. package/dist/svelte/components/ContentStatusFields.svelte.d.ts +8 -0
  201. package/dist/svelte/components/ContentStatusFields.svelte.d.ts.map +1 -0
  202. package/dist/svelte/components/ContentTitleField.svelte +54 -0
  203. package/dist/svelte/components/ContentTitleField.svelte.d.ts +10 -0
  204. package/dist/svelte/components/ContentTitleField.svelte.d.ts.map +1 -0
  205. package/dist/svelte/components/ContentTransparencyReport.svelte +322 -0
  206. package/dist/svelte/components/ContentTransparencyReport.svelte.d.ts +10 -0
  207. package/dist/svelte/components/ContentTransparencyReport.svelte.d.ts.map +1 -0
  208. package/dist/svelte/components/ContentTransparencyTool.svelte +314 -0
  209. package/dist/svelte/components/ContentTransparencyTool.svelte.d.ts +10 -0
  210. package/dist/svelte/components/ContentTransparencyTool.svelte.d.ts.map +1 -0
  211. package/dist/svelte/components/ContentVersionsTool.svelte +291 -0
  212. package/dist/svelte/components/ContentVersionsTool.svelte.d.ts +10 -0
  213. package/dist/svelte/components/ContentVersionsTool.svelte.d.ts.map +1 -0
  214. package/dist/svelte/components/GovernedContentEditor.svelte +409 -0
  215. package/dist/svelte/components/GovernedContentEditor.svelte.d.ts +35 -0
  216. package/dist/svelte/components/GovernedContentEditor.svelte.d.ts.map +1 -0
  217. package/dist/svelte/components/ImageThumbnail.cache.d.ts +14 -0
  218. package/dist/svelte/components/ImageThumbnail.cache.d.ts.map +1 -0
  219. package/dist/svelte/components/ImageThumbnail.cache.js +36 -0
  220. package/dist/svelte/components/ImageThumbnail.svelte +159 -0
  221. package/dist/svelte/components/ImageThumbnail.svelte.d.ts +8 -0
  222. package/dist/svelte/components/ImageThumbnail.svelte.d.ts.map +1 -0
  223. package/dist/svelte/components/Markdown.svelte +125 -0
  224. package/dist/svelte/components/Markdown.svelte.d.ts +11 -0
  225. package/dist/svelte/components/Markdown.svelte.d.ts.map +1 -0
  226. package/dist/svelte/content-editor-form.d.ts +63 -0
  227. package/dist/svelte/content-editor-form.d.ts.map +1 -0
  228. package/dist/svelte/content-editor-form.js +94 -0
  229. package/dist/svelte/content-editor-media.d.ts +12 -0
  230. package/dist/svelte/content-editor-media.d.ts.map +1 -0
  231. package/dist/svelte/content-editor-media.js +84 -0
  232. package/dist/svelte/content-editor-state.svelte.d.ts +35 -0
  233. package/dist/svelte/content-editor-state.svelte.d.ts.map +1 -0
  234. package/dist/svelte/content-editor-state.svelte.js +141 -0
  235. package/dist/svelte/governance-manager-client.d.ts +22 -0
  236. package/dist/svelte/governance-manager-client.d.ts.map +1 -0
  237. package/dist/svelte/governance-manager-client.js +1 -0
  238. package/dist/svelte/i18n.contribution.d.ts +57 -0
  239. package/dist/svelte/i18n.contribution.d.ts.map +1 -0
  240. package/dist/svelte/i18n.contribution.js +64 -0
  241. package/dist/svelte/i18n.editor.d.ts +71 -0
  242. package/dist/svelte/i18n.editor.d.ts.map +1 -0
  243. package/dist/svelte/i18n.editor.js +87 -0
  244. package/dist/svelte/i18n.governance.d.ts +66 -0
  245. package/dist/svelte/i18n.governance.d.ts.map +1 -0
  246. package/dist/svelte/i18n.governance.js +66 -0
  247. package/dist/svelte/i18n.routes.d.ts +66 -0
  248. package/dist/svelte/i18n.routes.d.ts.map +1 -0
  249. package/dist/svelte/i18n.routes.js +75 -0
  250. package/dist/svelte/i18n.tools.d.ts +81 -0
  251. package/dist/svelte/i18n.tools.d.ts.map +1 -0
  252. package/dist/svelte/i18n.tools.js +90 -0
  253. package/dist/svelte/index.d.ts +101 -0
  254. package/dist/svelte/index.d.ts.map +1 -0
  255. package/dist/svelte/index.js +63 -0
  256. package/dist/svelte/playground.d.ts +281 -0
  257. package/dist/svelte/playground.d.ts.map +1 -0
  258. package/dist/svelte/playground.js +438 -0
  259. package/dist/svelte/routes/ContentContributionsRoute.svelte +809 -0
  260. package/dist/svelte/routes/ContentContributionsRoute.svelte.d.ts +10 -0
  261. package/dist/svelte/routes/ContentContributionsRoute.svelte.d.ts.map +1 -0
  262. package/dist/svelte/routes/ContentFactsRoute.svelte +612 -0
  263. package/dist/svelte/routes/ContentFactsRoute.svelte.d.ts +11 -0
  264. package/dist/svelte/routes/ContentFactsRoute.svelte.d.ts.map +1 -0
  265. package/dist/svelte/routes/ContentGovernanceRoute.svelte +218 -0
  266. package/dist/svelte/routes/ContentGovernanceRoute.svelte.d.ts +10 -0
  267. package/dist/svelte/routes/ContentGovernanceRoute.svelte.d.ts.map +1 -0
  268. package/dist/svelte/routes/ContentWorkspaceRoute.svelte +431 -0
  269. package/dist/svelte/routes/ContentWorkspaceRoute.svelte.d.ts +12 -0
  270. package/dist/svelte/routes/ContentWorkspaceRoute.svelte.d.ts.map +1 -0
  271. package/dist/svelte/routes/PublishedArticleRoute.svelte +194 -0
  272. package/dist/svelte/routes/PublishedArticleRoute.svelte.d.ts +10 -0
  273. package/dist/svelte/routes/PublishedArticleRoute.svelte.d.ts.map +1 -0
  274. package/dist/svelte/routes/index.d.ts +8 -0
  275. package/dist/svelte/routes/index.d.ts.map +1 -0
  276. package/dist/svelte/routes/index.js +6 -0
  277. package/dist/svelte/routes/shared.d.ts +90 -0
  278. package/dist/svelte/routes/shared.d.ts.map +1 -0
  279. package/dist/svelte/routes/shared.js +104 -0
  280. package/dist/svelte/types.d.ts +69 -0
  281. package/dist/svelte/types.d.ts.map +1 -0
  282. package/dist/svelte/types.js +6 -0
  283. package/dist/thumbnail-generator.d.ts +174 -0
  284. package/dist/thumbnail-generator.d.ts.map +1 -0
  285. package/dist/ui.d.ts +10 -0
  286. package/dist/ui.d.ts.map +1 -0
  287. package/dist/ui.js +42 -0
  288. package/dist/ui.js.map +1 -0
  289. package/dist/utils.d.ts +18 -0
  290. package/dist/utils.d.ts.map +1 -0
  291. package/package.json +119 -0
@@ -0,0 +1,10 @@
1
+ import { type ContentRouteNavigationItem } from './shared.js';
2
+ interface ContentContributionsRouteProps {
3
+ navigation?: ContentRouteNavigationItem[];
4
+ apiBaseUrl?: string;
5
+ embedded?: boolean;
6
+ }
7
+ declare const ContentContributionsRoute: import("svelte").Component<ContentContributionsRouteProps, {}, "">;
8
+ type ContentContributionsRoute = ReturnType<typeof ContentContributionsRoute>;
9
+ export default ContentContributionsRoute;
10
+ //# sourceMappingURL=ContentContributionsRoute.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ContentContributionsRoute.svelte.d.ts","sourceRoot":"","sources":["../../../src/svelte/routes/ContentContributionsRoute.svelte.ts"],"names":[],"mappings":"AAmBA,OAAO,EAGL,KAAK,0BAA0B,EAChC,MAAM,aAAa,CAAC;AAGrB,UAAU,8BAA8B;IACtC,UAAU,CAAC,EAAE,0BAA0B,EAAE,CAAC;IAC1C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAkcD,QAAA,MAAM,yBAAyB,oEAAwC,CAAC;AACxE,KAAK,yBAAyB,GAAG,UAAU,CAAC,OAAO,yBAAyB,CAAC,CAAC;AAC9E,eAAe,yBAAyB,CAAC"}
@@ -0,0 +1,612 @@
1
+ <script lang="ts">
2
+ import { useI18n } from '@happyvertical/smrt-ui/i18n';
3
+ import { onMount } from 'svelte';
4
+ import { createClient, type FactData } from '../../mock-smrt-client.js';
5
+ import { M } from '../i18n.routes.js';
6
+ import {
7
+ CONTENT_DEFAULT_ROUTE_NAVIGATION,
8
+ CONTENT_ROUTE_IDS,
9
+ type ContentRouteNavigationItem,
10
+ } from './shared.js';
11
+
12
+ interface ContentFactsRouteProps {
13
+ navigation?: ContentRouteNavigationItem[];
14
+ apiBaseUrl?: string;
15
+ createHref?: string | null;
16
+ embedded?: boolean;
17
+ }
18
+
19
+ let {
20
+ navigation = CONTENT_DEFAULT_ROUTE_NAVIGATION,
21
+ apiBaseUrl = '/api/v1',
22
+ createHref = null,
23
+ embedded = false,
24
+ }: ContentFactsRouteProps = $props();
25
+
26
+ const client = $derived(createClient(apiBaseUrl));
27
+ const { t } = useI18n();
28
+
29
+ let query = $state('');
30
+ let latestOnly = $state(true);
31
+ let includeSuperseded = $state(false);
32
+ let facts = $state<FactData[]>([]);
33
+ let loading = $state(true);
34
+ let refreshing = $state(false);
35
+ let error = $state<string | null>(null);
36
+
37
+ function formatConfidence(value: number | null | undefined) {
38
+ if (typeof value !== 'number' || Number.isNaN(value)) return '—';
39
+ return `${Math.round(value * 100)}%`;
40
+ }
41
+
42
+ function formatDate(value: string | undefined) {
43
+ if (!value) return '—';
44
+ return new Date(value).toLocaleString('en-US', {
45
+ year: 'numeric',
46
+ month: 'short',
47
+ day: 'numeric',
48
+ hour: 'numeric',
49
+ minute: '2-digit',
50
+ });
51
+ }
52
+
53
+ function metadataEntries(fact: FactData) {
54
+ return Object.entries(fact.metadata ?? {}).slice(0, 4);
55
+ }
56
+
57
+ async function loadFacts() {
58
+ error = null;
59
+ refreshing = true;
60
+
61
+ try {
62
+ const response = await client.contents.browseFacts(query, {
63
+ limit: 100,
64
+ latestOnly,
65
+ includeSuperseded,
66
+ });
67
+ facts = response.data;
68
+ } catch (err: any) {
69
+ error = err.message || 'Failed to load facts.';
70
+ } finally {
71
+ loading = false;
72
+ refreshing = false;
73
+ }
74
+ }
75
+
76
+ function handleSubmit(event: SubmitEvent) {
77
+ event.preventDefault();
78
+ void loadFacts();
79
+ }
80
+
81
+ onMount(() => {
82
+ void loadFacts();
83
+ });
84
+ </script>
85
+
86
+ <div class:page={true} class:page--embedded={embedded}>
87
+ <header class="page-header">
88
+ <div class="container">
89
+ <div class="page-header__copy">
90
+ <div class="eyebrow">{t(M['content.facts.eyebrow'])}</div>
91
+ <h1>{t(M['content.facts.heading'])}</h1>
92
+ <p>
93
+ {t(M['content.facts.intro'])}
94
+ </p>
95
+ </div>
96
+
97
+ <div class="page-header__actions">
98
+ <nav class="page-nav" aria-label={t(M['content.facts.nav_aria'])}>
99
+ {#each navigation as item (item.routeId)}
100
+ <a
101
+ href={item.href}
102
+ aria-current={item.routeId === CONTENT_ROUTE_IDS.facts
103
+ ? 'page'
104
+ : undefined}
105
+ >
106
+ {item.label}
107
+ </a>
108
+ {/each}
109
+ </nav>
110
+
111
+ {#if createHref}
112
+ <a class="page-cta" href={createHref}>{t(M['content.facts.create_cta'])}</a>
113
+ {/if}
114
+ </div>
115
+ </div>
116
+ </header>
117
+
118
+ <main class="container page-main">
119
+ <section class="filters-panel">
120
+ <form class="filters" onsubmit={handleSubmit}>
121
+ <label class="search-field">
122
+ <span>Search</span>
123
+ <input
124
+ type="search"
125
+ bind:value={query}
126
+ placeholder={t(M['content.facts.search_placeholder'])}
127
+ />
128
+ </label>
129
+
130
+ <label class="toggle">
131
+ <input
132
+ type="checkbox"
133
+ bind:checked={latestOnly}
134
+ onchange={() => void loadFacts()}
135
+ />
136
+ <span>{t(M['content.facts.latest_only'])}</span>
137
+ </label>
138
+
139
+ <label class="toggle">
140
+ <input
141
+ type="checkbox"
142
+ bind:checked={includeSuperseded}
143
+ onchange={() => void loadFacts()}
144
+ />
145
+ <span>{t(M['content.facts.include_superseded'])}</span>
146
+ </label>
147
+
148
+ <button class="refresh-button" type="submit" disabled={refreshing}>
149
+ {refreshing ? 'Refreshing…' : 'Refresh'}
150
+ </button>
151
+ </form>
152
+ </section>
153
+
154
+ {#if error}
155
+ <section class="panel panel--error">
156
+ <strong>Error</strong>
157
+ <p>{error}</p>
158
+ </section>
159
+ {:else if loading}
160
+ <section class="panel empty-state">
161
+ <p>{t(M['content.facts.loading'])}</p>
162
+ </section>
163
+ {:else if facts.length === 0}
164
+ <section class="panel empty-state">
165
+ <h2>{t(M['content.facts.empty_title'])}</h2>
166
+ <p>
167
+ {t(M['content.facts.empty_body'])}
168
+ </p>
169
+ </section>
170
+ {:else}
171
+ <section class="panel results-panel">
172
+ <div class="results-meta">
173
+ <div>
174
+ <strong>{facts.length}</strong>
175
+ <span>{facts.length === 1 ? 'fact loaded' : 'facts loaded'}</span>
176
+ </div>
177
+ <div class="results-hints">
178
+ <span>{latestOnly ? 'Latest versions' : 'All versions'}</span>
179
+ <span>{includeSuperseded ? 'Superseded included' : 'Superseded hidden'}</span>
180
+ </div>
181
+ </div>
182
+
183
+ <div class="facts-list">
184
+ {#each facts as fact (fact.id ?? `${fact.textRefined}-${fact.createdAt}`)}
185
+ <article class="fact-row">
186
+ <div class="fact-row__header">
187
+ <div class="fact-row__badges">
188
+ {#if fact.status}
189
+ <span class="badge">{fact.status}</span>
190
+ {/if}
191
+ {#if fact.domain}
192
+ <span class="badge badge--neutral">{fact.domain}</span>
193
+ {/if}
194
+ </div>
195
+
196
+ <div class="fact-row__stats">
197
+ <span>Confidence {formatConfidence(fact.confidence)}</span>
198
+ <span>Sources {fact.sourceCount ?? 0}</span>
199
+ <span>{formatDate(fact.updatedAt || fact.createdAt)}</span>
200
+ </div>
201
+ </div>
202
+
203
+ <h2>{fact.textRefined || fact.textRaw || 'Untitled fact'}</h2>
204
+
205
+ {#if fact.textRaw && fact.textRefined && fact.textRaw !== fact.textRefined}
206
+ <details>
207
+ <summary>{t(M['content.facts.raw_input'])}</summary>
208
+ <p>{fact.textRaw}</p>
209
+ </details>
210
+ {/if}
211
+
212
+ {#if metadataEntries(fact).length > 0}
213
+ <dl class="metadata-list">
214
+ {#each metadataEntries(fact) as [key, value]}
215
+ <div>
216
+ <dt>{key}</dt>
217
+ <dd>{typeof value === 'string' ? value : JSON.stringify(value)}</dd>
218
+ </div>
219
+ {/each}
220
+ </dl>
221
+ {/if}
222
+ </article>
223
+ {/each}
224
+ </div>
225
+ </section>
226
+ {/if}
227
+ </main>
228
+ </div>
229
+
230
+ <style>
231
+ :global(body:has(.page:not(.page--embedded))) {
232
+ margin: 0;
233
+ font-family:
234
+ var(--smrt-font-family, 'Inter', -apple-system, BlinkMacSystemFont,
235
+ 'Segoe UI', Roboto, sans-serif);
236
+ background:
237
+ radial-gradient(
238
+ circle at top,
239
+ color-mix(in srgb, var(--smrt-color-primary) 10%, transparent),
240
+ transparent 36%
241
+ ),
242
+ var(--smrt-color-background);
243
+ color: var(--smrt-color-on-background);
244
+ min-height: 100vh;
245
+ }
246
+
247
+ .page {
248
+ min-height: 100vh;
249
+ padding: 2rem 1.25rem 3rem;
250
+ }
251
+
252
+ .page--embedded {
253
+ min-height: auto;
254
+ padding: 0;
255
+ }
256
+
257
+ .container {
258
+ max-width: 1280px;
259
+ margin: 0 auto;
260
+ }
261
+
262
+ .page-header {
263
+ margin-bottom: 1.5rem;
264
+ }
265
+
266
+ .page-header .container {
267
+ display: flex;
268
+ justify-content: space-between;
269
+ gap: 1rem;
270
+ align-items: flex-start;
271
+ flex-wrap: wrap;
272
+ }
273
+
274
+ .page-header__copy {
275
+ max-width: 50rem;
276
+ }
277
+
278
+ .page-header__actions {
279
+ display: grid;
280
+ gap: 0.85rem;
281
+ justify-items: end;
282
+ }
283
+
284
+ .eyebrow {
285
+ color: var(--smrt-color-on-surface-variant);
286
+ text-transform: uppercase;
287
+ letter-spacing: var(--smrt-typography-label-medium-tracking, 0.08em);
288
+ font-size: var(--smrt-typography-label-medium-size, 0.78rem);
289
+ font-weight: var(--smrt-typography-weight-bold, 700);
290
+ }
291
+
292
+ .page-header h1 {
293
+ margin: 0.35rem 0 0.65rem;
294
+ font-size: clamp(2rem, 5vw, 3rem);
295
+ line-height: 1.05;
296
+ }
297
+
298
+ .page-header p {
299
+ margin: 0;
300
+ color: var(--smrt-color-on-surface-variant);
301
+ font-size: var(--smrt-typography-body-large-size, 1rem);
302
+ max-width: 44rem;
303
+ }
304
+
305
+ .page-nav {
306
+ display: flex;
307
+ gap: 0.75rem;
308
+ flex-wrap: wrap;
309
+ align-items: center;
310
+ justify-content: flex-end;
311
+ }
312
+
313
+ .page-nav a,
314
+ .page-cta {
315
+ display: inline-flex;
316
+ align-items: center;
317
+ justify-content: center;
318
+ min-height: 2.5rem;
319
+ padding: 0 1rem;
320
+ border-radius: var(--smrt-radius-full, 9999px);
321
+ border: 1px solid var(--smrt-color-outline-variant);
322
+ background: color-mix(
323
+ in srgb,
324
+ var(--smrt-color-surface) 92%,
325
+ transparent
326
+ );
327
+ color: var(--smrt-color-on-surface);
328
+ text-decoration: none;
329
+ font-weight: var(--smrt-typography-weight-semibold, 600);
330
+ }
331
+
332
+ .page-nav a[aria-current='page'] {
333
+ color: var(--smrt-color-primary);
334
+ border-color: color-mix(
335
+ in srgb,
336
+ var(--smrt-color-primary) 28%,
337
+ transparent
338
+ );
339
+ background: color-mix(
340
+ in srgb,
341
+ var(--smrt-color-primary) 10%,
342
+ var(--smrt-color-surface)
343
+ );
344
+ }
345
+
346
+ .page-cta {
347
+ background: var(--smrt-color-primary);
348
+ color: var(--smrt-color-on-primary);
349
+ border-color: transparent;
350
+ }
351
+
352
+ .page-main {
353
+ display: grid;
354
+ gap: 1rem;
355
+ }
356
+
357
+ .filters-panel,
358
+ .panel {
359
+ border: 1px solid var(--smrt-color-outline-variant);
360
+ background: color-mix(
361
+ in srgb,
362
+ var(--smrt-color-surface) 96%,
363
+ transparent
364
+ );
365
+ border-radius: 1rem;
366
+ box-shadow: var(--smrt-elevation-1, 0 8px 24px rgba(15, 23, 42, 0.05));
367
+ }
368
+
369
+ .filters-panel {
370
+ padding: 1rem;
371
+ }
372
+
373
+ .panel {
374
+ padding: 1.25rem;
375
+ }
376
+
377
+ .panel--error {
378
+ border-color: color-mix(in srgb, var(--smrt-color-error) 30%, transparent);
379
+ }
380
+
381
+ .filters {
382
+ display: grid;
383
+ grid-template-columns: minmax(0, 1.8fr) repeat(2, auto) auto;
384
+ gap: 0.75rem;
385
+ align-items: end;
386
+ }
387
+
388
+ .search-field {
389
+ display: grid;
390
+ gap: 0.4rem;
391
+ }
392
+
393
+ .search-field span {
394
+ font-size: var(--smrt-typography-label-large-size, 0.82rem);
395
+ font-weight: var(--smrt-typography-weight-bold, 700);
396
+ color: var(--smrt-color-on-surface-variant);
397
+ }
398
+
399
+ .search-field input {
400
+ min-height: 2.85rem;
401
+ border-radius: 0.85rem;
402
+ border: 1px solid var(--smrt-color-outline-variant);
403
+ background: var(--smrt-color-surface);
404
+ color: var(--smrt-color-on-surface);
405
+ padding: 0 0.95rem;
406
+ }
407
+
408
+ .toggle {
409
+ min-height: 2.85rem;
410
+ display: inline-flex;
411
+ align-items: center;
412
+ gap: 0.55rem;
413
+ padding: 0 0.9rem;
414
+ border-radius: 0.85rem;
415
+ background: var(--smrt-color-surface-container-low);
416
+ color: var(--smrt-color-on-surface);
417
+ }
418
+
419
+ .refresh-button {
420
+ min-height: 2.85rem;
421
+ border-radius: 0.85rem;
422
+ border: none;
423
+ background: var(--smrt-color-primary);
424
+ color: var(--smrt-color-on-primary);
425
+ padding: 0 1rem;
426
+ font-weight: var(--smrt-typography-weight-bold, 700);
427
+ cursor: pointer;
428
+ }
429
+
430
+ .results-panel {
431
+ display: grid;
432
+ gap: 1rem;
433
+ }
434
+
435
+ .results-meta {
436
+ display: flex;
437
+ justify-content: space-between;
438
+ gap: 1rem;
439
+ align-items: center;
440
+ flex-wrap: wrap;
441
+ padding-bottom: 0.25rem;
442
+ border-bottom: 1px solid var(--smrt-color-outline-variant);
443
+ }
444
+
445
+ .results-meta strong {
446
+ font-size: var(--smrt-typography-title-large-size, 1.2rem);
447
+ margin-right: 0.5rem;
448
+ }
449
+
450
+ .results-meta span {
451
+ color: var(--smrt-color-on-surface-variant);
452
+ }
453
+
454
+ .results-hints {
455
+ display: flex;
456
+ gap: 0.5rem;
457
+ flex-wrap: wrap;
458
+ }
459
+
460
+ .results-hints span {
461
+ display: inline-flex;
462
+ align-items: center;
463
+ min-height: 1.9rem;
464
+ padding: 0 0.7rem;
465
+ border-radius: var(--smrt-radius-full, 9999px);
466
+ background: var(--smrt-color-surface-container-low);
467
+ font-size: var(--smrt-typography-label-large-size, 0.82rem);
468
+ }
469
+
470
+ .facts-list {
471
+ display: grid;
472
+ }
473
+
474
+ .fact-row {
475
+ display: grid;
476
+ gap: 0.9rem;
477
+ padding: 1rem 0;
478
+ border-bottom: 1px solid var(--smrt-color-outline-variant);
479
+ }
480
+
481
+ .fact-row:first-child {
482
+ padding-top: 0;
483
+ }
484
+
485
+ .fact-row:last-child {
486
+ border-bottom: none;
487
+ padding-bottom: 0;
488
+ }
489
+
490
+ .fact-row__header {
491
+ display: flex;
492
+ justify-content: space-between;
493
+ gap: 0.75rem;
494
+ align-items: flex-start;
495
+ flex-wrap: wrap;
496
+ }
497
+
498
+ .fact-row__badges,
499
+ .fact-row__stats {
500
+ display: flex;
501
+ gap: 0.5rem;
502
+ flex-wrap: wrap;
503
+ align-items: center;
504
+ }
505
+
506
+ .fact-row h2 {
507
+ margin: 0;
508
+ font-size: var(--smrt-typography-title-medium-size, 1.08rem);
509
+ line-height: var(--smrt-typography-title-medium-line-height, 1.45);
510
+ color: var(--smrt-color-on-surface);
511
+ }
512
+
513
+ .fact-row__stats span {
514
+ color: var(--smrt-color-on-surface-variant);
515
+ font-size: var(--smrt-typography-body-medium-size, 0.84rem);
516
+ }
517
+
518
+ .badge {
519
+ display: inline-flex;
520
+ align-items: center;
521
+ min-height: 1.65rem;
522
+ padding: 0 0.6rem;
523
+ border-radius: var(--smrt-radius-full, 9999px);
524
+ background: color-mix(
525
+ in srgb,
526
+ var(--smrt-color-primary) 12%,
527
+ transparent
528
+ );
529
+ color: var(--smrt-color-primary);
530
+ font-size: var(--smrt-typography-label-medium-size, 0.75rem);
531
+ font-weight: var(--smrt-typography-weight-bold, 700);
532
+ text-transform: capitalize;
533
+ }
534
+
535
+ .badge--neutral {
536
+ background: var(--smrt-color-surface-container-low);
537
+ color: var(--smrt-color-on-surface-variant);
538
+ }
539
+
540
+ details {
541
+ border-top: 1px solid var(--smrt-color-outline-variant);
542
+ padding-top: 0.8rem;
543
+ }
544
+
545
+ details summary {
546
+ cursor: pointer;
547
+ font-weight: var(--smrt-typography-weight-bold, 700);
548
+ color: var(--smrt-color-on-surface);
549
+ }
550
+
551
+ details p {
552
+ margin: 0.75rem 0 0;
553
+ color: var(--smrt-color-on-surface-variant);
554
+ white-space: pre-wrap;
555
+ }
556
+
557
+ .metadata-list {
558
+ display: flex;
559
+ gap: 0.65rem;
560
+ flex-wrap: wrap;
561
+ margin: 0;
562
+ }
563
+
564
+ .metadata-list div {
565
+ min-width: 10rem;
566
+ max-width: 18rem;
567
+ display: grid;
568
+ gap: 0.15rem;
569
+ }
570
+
571
+ .metadata-list dt {
572
+ font-size: var(--smrt-typography-label-medium-size, 0.72rem);
573
+ font-weight: var(--smrt-typography-weight-bold, 700);
574
+ color: var(--smrt-color-on-surface-variant);
575
+ text-transform: uppercase;
576
+ letter-spacing: var(--smrt-typography-label-medium-tracking, 0.05em);
577
+ }
578
+
579
+ .metadata-list dd {
580
+ margin: 0;
581
+ color: var(--smrt-color-on-surface);
582
+ word-break: break-word;
583
+ }
584
+
585
+ .empty-state {
586
+ text-align: center;
587
+ }
588
+
589
+ .empty-state h2,
590
+ .empty-state p {
591
+ margin: 0;
592
+ }
593
+
594
+ .empty-state p {
595
+ color: var(--smrt-color-on-surface-variant);
596
+ }
597
+
598
+ @media (max-width: 840px) {
599
+ .page-header__actions {
600
+ width: 100%;
601
+ justify-items: stretch;
602
+ }
603
+
604
+ .page-nav {
605
+ justify-content: flex-start;
606
+ }
607
+
608
+ .filters {
609
+ grid-template-columns: 1fr;
610
+ }
611
+ }
612
+ </style>
@@ -0,0 +1,11 @@
1
+ import { type ContentRouteNavigationItem } from './shared.js';
2
+ interface ContentFactsRouteProps {
3
+ navigation?: ContentRouteNavigationItem[];
4
+ apiBaseUrl?: string;
5
+ createHref?: string | null;
6
+ embedded?: boolean;
7
+ }
8
+ declare const ContentFactsRoute: import("svelte").Component<ContentFactsRouteProps, {}, "">;
9
+ type ContentFactsRoute = ReturnType<typeof ContentFactsRoute>;
10
+ export default ContentFactsRoute;
11
+ //# sourceMappingURL=ContentFactsRoute.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ContentFactsRoute.svelte.d.ts","sourceRoot":"","sources":["../../../src/svelte/routes/ContentFactsRoute.svelte.ts"],"names":[],"mappings":"AAOA,OAAO,EAGL,KAAK,0BAA0B,EAChC,MAAM,aAAa,CAAC;AAGrB,UAAU,sBAAsB;IAC9B,UAAU,CAAC,EAAE,0BAA0B,EAAE,CAAC;IAC1C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC3B,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAiND,QAAA,MAAM,iBAAiB,4DAAwC,CAAC;AAChE,KAAK,iBAAiB,GAAG,UAAU,CAAC,OAAO,iBAAiB,CAAC,CAAC;AAC9D,eAAe,iBAAiB,CAAC"}