@lssm/example.content-generation 0.0.0-canary-20251217063201 → 0.0.0-canary-20251217073102

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 (51) hide show
  1. package/.turbo/turbo-build$colon$bundle.log +56 -51
  2. package/CHANGELOG.md +5 -4
  3. package/dist/docs/content-generation.docblock.js +27 -14
  4. package/dist/docs/index.js +1 -1
  5. package/dist/example.js +38 -1
  6. package/dist/generate.js +52 -1
  7. package/dist/index.js +5 -1
  8. package/dist/libs/content-gen/dist/generators/blog.js +68 -1
  9. package/dist/libs/content-gen/dist/generators/email.js +96 -9
  10. package/dist/libs/content-gen/dist/generators/landing-page.js +76 -2
  11. package/dist/libs/content-gen/dist/generators/social.js +73 -1
  12. package/dist/libs/content-gen/dist/seo/optimizer.js +48 -1
  13. package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +16 -76
  14. package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +16 -350
  15. package/dist/libs/contracts/dist/docs/index.js +29 -1
  16. package/dist/libs/contracts/dist/docs/presentations.js +71 -1
  17. package/dist/libs/contracts/dist/docs/registry.js +44 -1
  18. package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +16 -383
  19. package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +16 -68
  20. package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +16 -140
  21. package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +16 -86
  22. package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +16 -1
  23. package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +24 -2
  24. package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +21 -2
  25. package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +16 -213
  26. package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +73 -5
  27. package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +37 -1
  28. package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +16 -1
  29. package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +20 -262
  30. package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +48 -1
  31. package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +24 -2
  32. package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +23 -2
  33. package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +25 -16
  34. package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +67 -1
  35. package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +22 -2
  36. package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +40 -36
  37. package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +47 -1
  38. package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +23 -2
  39. package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +36 -3
  40. package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +20 -1
  41. package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +36 -3
  42. package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +20 -1
  43. package/dist/libs/logger/dist/context.node.js +78 -1
  44. package/dist/libs/logger/dist/elysia-plugin.js +3 -1
  45. package/dist/libs/logger/dist/formatters.js +163 -9
  46. package/dist/libs/logger/dist/index.js +7 -1
  47. package/dist/libs/logger/dist/logger.node.js +189 -1
  48. package/dist/libs/logger/dist/timer.js +126 -1
  49. package/dist/libs/logger/dist/tracer.node.js +115 -1
  50. package/dist/libs/logger/dist/types.js +13 -1
  51. package/package.json +7 -6
@@ -7,63 +7,68 @@
7
7
  ℹ tsconfig: tsconfig.json
8
8
  ℹ Build start
9
9
  ℹ Cleaning 72 files
10
- ℹ dist/generate.js  1.54 kB │ gzip: 0.79 kB
11
- ℹ dist/docs/content-generation.docblock.js  1.19 kB │ gzip: 0.63 kB
12
- ℹ dist/example.js  0.57 kB │ gzip: 0.33 kB
13
- ℹ dist/index.js  0.17 kB │ gzip: 0.12 kB
10
+ ℹ dist/generate.js  2.07 kB │ gzip: 0.93 kB
11
+ ℹ dist/docs/content-generation.docblock.js  1.37 kB │ gzip: 0.69 kB
12
+ ℹ dist/example.js  0.78 kB │ gzip: 0.41 kB
13
+ ℹ dist/index.js  0.20 kB │ gzip: 0.13 kB
14
14
  ℹ dist/docs/index.js  0.04 kB │ gzip: 0.06 kB
15
- ℹ dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js 16.51 kB │ gzip: 7.15 kB
16
- ℹ dist/libs/contracts/dist/docs/tech/schema/README.docblock.js 10.97 kB │ gzip: 4.28 kB
17
- ℹ dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js  9.65 kB │ gzip: 3.77 kB
18
- ℹ dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js  9.10 kB │ gzip: 3.41 kB
19
- ℹ dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js  8.74 kB │ gzip: 2.67 kB
20
- ℹ dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js  5.91 kB │ gzip: 2.61 kB
21
- ℹ dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js  5.62 kB │ gzip: 2.58 kB
22
- ℹ dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js  5.42 kB │ gzip: 2.25 kB
23
- ℹ dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js  4.35 kB │ gzip: 2.05 kB
24
- ℹ dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js  3.89 kB │ gzip: 1.69 kB
25
- ℹ dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js  3.58 kB │ gzip: 1.38 kB
26
- ℹ dist/libs/contracts/dist/docs/PUBLISHING.docblock.js  3.42 kB │ gzip: 1.58 kB
27
- ℹ dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js  3.34 kB │ gzip: 1.45 kB
28
- ℹ dist/libs/logger/dist/formatters.js  3.31 kB │ gzip: 1.34 kB
29
- ℹ dist/libs/logger/dist/logger.node.js  3.24 kB │ gzip: 1.28 kB
30
- ℹ dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js  3.07 kB │ gzip: 1.38 kB
31
- ℹ dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js  3.03 kB │ gzip: 1.32 kB
32
- ℹ dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js  2.98 kB │ gzip: 1.52 kB
33
- ℹ dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js  2.81 kB │ gzip: 1.41 kB
34
- ℹ dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js  2.73 kB │ gzip: 1.30 kB
35
- ℹ dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js  2.49 kB │ gzip: 1.11 kB
36
- ℹ dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js  2.13 kB │ gzip: 1.03 kB
37
- ℹ dist/libs/content-gen/dist/generators/email.js  1.92 kB │ gzip: 0.94 kB
38
- ℹ dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js  1.89 kB │ gzip: 0.93 kB
39
- ℹ dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js  1.78 kB │ gzip: 0.87 kB
40
- ℹ dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js  1.70 kB │ gzip: 0.89 kB
41
- ℹ dist/libs/content-gen/dist/generators/landing-page.js  1.61 kB │ gzip: 0.92 kB
42
- ℹ dist/libs/logger/dist/tracer.node.js  1.59 kB │ gzip: 0.68 kB
43
- ℹ dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js  1.57 kB │ gzip: 0.77 kB
44
- ℹ dist/libs/content-gen/dist/generators/blog.js  1.52 kB │ gzip: 0.79 kB
45
- ℹ dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js  1.47 kB │ gzip: 0.73 kB
46
- ℹ dist/libs/contracts/dist/docs/index.js  1.42 kB │ gzip: 0.47 kB
47
- ℹ dist/libs/content-gen/dist/generators/social.js  1.35 kB │ gzip: 0.76 kB
48
- ℹ dist/libs/logger/dist/timer.js  1.25 kB │ gzip: 0.50 kB
49
- ℹ dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js  1.23 kB │ gzip: 0.68 kB
50
- ℹ dist/libs/contracts/dist/docs/presentations.js  1.14 kB │ gzip: 0.56 kB
51
- ℹ dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js  0.89 kB │ gzip: 0.55 kB
52
- ℹ dist/libs/content-gen/dist/seo/optimizer.js  0.87 kB │ gzip: 0.51 kB
53
- ℹ dist/libs/logger/dist/context.node.js  0.67 kB │ gzip: 0.32 kB
54
- ℹ dist/libs/contracts/dist/docs/registry.js  0.63 kB │ gzip: 0.39 kB
55
- ℹ dist/libs/logger/dist/index.js  0.23 kB │ gzip: 0.13 kB
56
- ℹ dist/libs/logger/dist/types.js  0.16 kB │ gzip: 0.14 kB
15
+ ℹ dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js 16.91 kB │ gzip: 7.23 kB
16
+ ℹ dist/libs/contracts/dist/docs/tech/schema/README.docblock.js 11.21 kB │ gzip: 4.33 kB
17
+ ℹ dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js  9.96 kB │ gzip: 3.83 kB
18
+ ℹ dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js  9.53 kB │ gzip: 3.50 kB
19
+ ℹ dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js  9.22 kB │ gzip: 2.77 kB
20
+ ℹ dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js  6.16 kB │ gzip: 2.65 kB
21
+ ℹ dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js  5.85 kB │ gzip: 2.66 kB
22
+ ℹ dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js  5.66 kB │ gzip: 2.34 kB
23
+ ℹ dist/libs/logger/dist/formatters.js  5.42 kB │ gzip: 1.71 kB
24
+ ℹ dist/libs/logger/dist/logger.node.js  5.40 kB │ gzip: 1.66 kB
25
+ ℹ dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js  4.62 kB │ gzip: 2.13 kB
26
+ ℹ dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js  4.16 kB │ gzip: 1.78 kB
27
+ ℹ dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js  3.85 kB │ gzip: 1.47 kB
28
+ ℹ dist/libs/contracts/dist/docs/PUBLISHING.docblock.js  3.62 kB │ gzip: 1.65 kB
29
+ ℹ dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js  3.60 kB │ gzip: 1.53 kB
30
+ ℹ dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js  3.33 kB │ gzip: 1.47 kB
31
+ ℹ dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js  3.30 kB │ gzip: 1.42 kB
32
+ ℹ dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js  3.25 kB │ gzip: 1.59 kB
33
+ ℹ dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js  3.13 kB │ gzip: 1.47 kB
34
+ ℹ dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js  2.97 kB │ gzip: 1.38 kB
35
+ ℹ dist/libs/logger/dist/tracer.node.js  2.86 kB │ gzip: 1.01 kB
36
+ ℹ dist/libs/content-gen/dist/generators/email.js  2.85 kB │ gzip: 1.17 kB
37
+ ℹ dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js  2.75 kB │ gzip: 1.22 kB
38
+ ℹ dist/libs/logger/dist/timer.js  2.43 kB │ gzip: 0.85 kB
39
+ ℹ dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js  2.40 kB │ gzip: 1.13 kB
40
+ ℹ dist/libs/content-gen/dist/generators/landing-page.js  2.24 kB │ gzip: 1.10 kB
41
+ ℹ dist/libs/contracts/dist/docs/presentations.js  2.18 kB │ gzip: 0.77 kB
42
+ ℹ dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js  2.13 kB │ gzip: 1.02 kB
43
+ ℹ dist/libs/content-gen/dist/generators/blog.js  2.10 kB │ gzip: 0.96 kB
44
+ ℹ dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js  2.04 kB │ gzip: 0.97 kB
45
+ ℹ dist/libs/content-gen/dist/generators/social.js  1.98 kB │ gzip: 0.95 kB
46
+ ℹ dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js  1.96 kB │ gzip: 0.97 kB
47
+ ℹ dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js  1.85 kB │ gzip: 0.87 kB
48
+ ℹ dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js  1.73 kB │ gzip: 0.82 kB
49
+ ℹ dist/libs/logger/dist/context.node.js  1.63 kB │ gzip: 0.62 kB
50
+ ℹ dist/libs/contracts/dist/docs/index.js  1.58 kB │ gzip: 0.51 kB
51
+ ℹ dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js  1.46 kB │ gzip: 0.77 kB
52
+ ℹ dist/libs/content-gen/dist/seo/optimizer.js  1.37 kB │ gzip: 0.66 kB
53
+ ℹ dist/libs/contracts/dist/docs/registry.js  1.25 kB │ gzip: 0.56 kB
54
+ ℹ dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js  1.14 kB │ gzip: 0.65 kB
55
+ ℹ dist/libs/logger/dist/types.js  0.44 kB │ gzip: 0.23 kB
56
+ ℹ dist/libs/logger/dist/index.js  0.31 kB │ gzip: 0.16 kB
57
57
  ℹ dist/libs/logger/dist/elysia-plugin.js  0.07 kB │ gzip: 0.07 kB
58
58
  ℹ dist/example.d.ts  1.02 kB │ gzip: 0.41 kB
59
59
  ℹ dist/index.d.ts  0.14 kB │ gzip: 0.10 kB
60
60
  ℹ dist/generate.d.ts  0.14 kB │ gzip: 0.12 kB
61
61
  ℹ dist/docs/content-generation.docblock.d.ts  0.01 kB │ gzip: 0.03 kB
62
62
  ℹ dist/docs/index.d.ts  0.01 kB │ gzip: 0.03 kB
63
- ℹ 53 files, total: 146.09 kB
63
+ ℹ 53 files, total: 167.68 kB
64
64
  [UNRESOLVED_IMPORT] Warning: Could not resolve 'node:async_hooks' in ../../libs/logger/dist/context.node.mjs
65
- - Module not found, treating it as an external dependency in ../../libs/logger/dist/context.node.mjs at 34..52
66
-  │
67
-  │ Help: The "main" field here was ignored. Main fields must be configured explicitly when using the "neutral" platform.
65
+ ╭─[ ../../libs/logger/dist/context.node.mjs:1:35 ]
66
+ │
67
+ 1 │ import { AsyncLocalStorage } from "node:async_hooks";
68
+  │ ─────────┬────────
69
+  │ ╰────────── Module not found, treating it as an external dependency
70
+  │
71
+  │ Help: The "main" field here was ignored. Main fields must be configured explicitly when using the "neutral" platform.
72
+ ───╯
68
73
 
69
- ✔ Build complete in 6167ms
74
+ ✔ Build complete in 1340ms
package/CHANGELOG.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # @lssm/example.content-generation
2
2
 
3
- ## 0.0.0-canary-20251217063201
3
+ ## 0.0.0-canary-20251217073102
4
4
 
5
5
  ### Minor Changes
6
6
 
@@ -9,6 +9,7 @@
9
9
  ### Patch Changes
10
10
 
11
11
  - Updated dependencies [66a5dfd]
12
- - @lssm/lib.content-gen@0.0.0-canary-20251217063201
13
- - @lssm/lib.contracts@0.0.0-canary-20251217063201
14
- - @lssm/lib.logger@0.0.0-canary-20251217063201
12
+ - @lssm/lib.content-gen@0.0.0-canary-20251217073102
13
+ - @lssm/lib.contracts@0.0.0-canary-20251217073102
14
+ - @lssm/lib.logger@0.0.0-canary-20251217073102
15
+ - @lssm/lib.schema@0.0.0-canary-20251217073102
@@ -1,16 +1,29 @@
1
- import{a as e}from"../libs/contracts/dist/docs/registry.js";import"../libs/contracts/dist/docs/index.js";e([{id:`docs.examples.content-generation`,title:`Content Generation (example)`,summary:`Generate a consistent set of marketing assets from a typed ContentBrief (blog, landing hero, email, social, SEO).`,kind:`reference`,visibility:`public`,route:`/docs/examples/content-generation`,tags:[`content`,`marketing`,`example`],body:`## What this example shows
2
- - A spec-first-ish interface for content brief inputs (typed, validated).
3
- - Deterministic orchestration of generators (same input → same structure).
1
+ import { registerDocBlocks } from "../libs/contracts/dist/docs/registry.js";
2
+ import "../libs/contracts/dist/docs/index.js";
4
3
 
5
- ## Outputs
6
- - Blog intro
7
- - Landing hero
8
- - Email subject/body
9
- - Social post bodies
10
- - SEO metadata`},{id:`docs.examples.content-generation.usage`,title:`Content Generation — Usage`,summary:`How to run the example and extend the brief.`,kind:`usage`,visibility:`public`,route:`/docs/examples/content-generation/usage`,tags:[`content`,`usage`],body:`## Usage
11
- - Call \`runContentGenerationExample()\`.
12
- - Modify the \`ContentBrief\` fields to drive different outputs.
4
+ //#region src/docs/content-generation.docblock.ts
5
+ registerDocBlocks([{
6
+ id: "docs.examples.content-generation",
7
+ title: "Content Generation (example)",
8
+ summary: "Generate a consistent set of marketing assets from a typed ContentBrief (blog, landing hero, email, social, SEO).",
9
+ kind: "reference",
10
+ visibility: "public",
11
+ route: "/docs/examples/content-generation",
12
+ tags: [
13
+ "content",
14
+ "marketing",
15
+ "example"
16
+ ],
17
+ body: `## What this example shows\n- A spec-first-ish interface for content brief inputs (typed, validated).\n- Deterministic orchestration of generators (same input → same structure).\n\n## Outputs\n- Blog intro\n- Landing hero\n- Email subject/body\n- Social post bodies\n- SEO metadata`
18
+ }, {
19
+ id: "docs.examples.content-generation.usage",
20
+ title: "Content Generation — Usage",
21
+ summary: "How to run the example and extend the brief.",
22
+ kind: "usage",
23
+ visibility: "public",
24
+ route: "/docs/examples/content-generation/usage",
25
+ tags: ["content", "usage"],
26
+ body: `## Usage\n- Call \`runContentGenerationExample()\`.\n- Modify the \`ContentBrief\` fields to drive different outputs.\n\n## Guardrails\n- Avoid PII in briefs.\n- Keep output logging structured; no raw \`console.log\` in library code.`
27
+ }]);
13
28
 
14
- ## Guardrails
15
- - Avoid PII in briefs.
16
- - Keep output logging structured; no raw \`console.log\` in library code.`}]);
29
+ //#endregion
@@ -1 +1 @@
1
- import"./content-generation.docblock.js";
1
+ import "./content-generation.docblock.js";
package/dist/example.js CHANGED
@@ -1 +1,38 @@
1
- var e={id:`content-generation`,title:`Content Generation`,summary:`Generate blog/landing/email/social/SEO assets from a typed ContentBrief using @lssm/lib.content-gen.`,tags:[`content`,`marketing`,`generation`,`ai`],kind:`script`,visibility:`public`,docs:{rootDocId:`docs.examples.content-generation`,usageDocId:`docs.examples.content-generation.usage`},entrypoints:{packageName:`@lssm/example.content-generation`,docs:`./docs`},surfaces:{templates:!0,sandbox:{enabled:!0,modes:[`markdown`]},studio:{enabled:!0,installable:!0},mcp:{enabled:!0}}};export{e as default};
1
+ //#region src/example.ts
2
+ const example = {
3
+ id: "content-generation",
4
+ title: "Content Generation",
5
+ summary: "Generate blog/landing/email/social/SEO assets from a typed ContentBrief using @lssm/lib.content-gen.",
6
+ tags: [
7
+ "content",
8
+ "marketing",
9
+ "generation",
10
+ "ai"
11
+ ],
12
+ kind: "script",
13
+ visibility: "public",
14
+ docs: {
15
+ rootDocId: "docs.examples.content-generation",
16
+ usageDocId: "docs.examples.content-generation.usage"
17
+ },
18
+ entrypoints: {
19
+ packageName: "@lssm/example.content-generation",
20
+ docs: "./docs"
21
+ },
22
+ surfaces: {
23
+ templates: true,
24
+ sandbox: {
25
+ enabled: true,
26
+ modes: ["markdown"]
27
+ },
28
+ studio: {
29
+ enabled: true,
30
+ installable: true
31
+ },
32
+ mcp: { enabled: true }
33
+ }
34
+ };
35
+ var example_default = example;
36
+
37
+ //#endregion
38
+ export { example_default as default };
package/dist/generate.js CHANGED
@@ -1 +1,52 @@
1
- import{e}from"./libs/content-gen/dist/generators/blog.js";import{e as t}from"./libs/content-gen/dist/generators/landing-page.js";import{e as n}from"./libs/content-gen/dist/generators/email.js";import{e as r}from"./libs/content-gen/dist/generators/social.js";import{e as i}from"./libs/content-gen/dist/seo/optimizer.js";import{e as a}from"./libs/logger/dist/types.js";import{o}from"./libs/logger/dist/logger.node.js";import"./libs/logger/dist/index.js";const s=new o({level:process.env.NODE_ENV===`production`?a.INFO:a.DEBUG,environment:process.env.NODE_ENV||`development`,enableColors:process.env.NODE_ENV!==`production`});async function c(){let a={title:`AI-Native Operations Copilot`,summary:`Automates support resolutions, growth playbooks, and DevOps rituals.`,problems:[`Support queues pile up after hours`,`Growth teams lack fresh experiments`],solutions:[`Stateful AI agents grounded in your knowledge spaces`,`CI-safe approval workflows for human review`,`Analytics + experimentation stack built into ContractSpec`],metrics:[`80% auto-resolution rate`,`10+ experiments shipped weekly`],audience:{role:`COO`,industry:`Fintech`,maturity:`scaleup`},callToAction:`Book a 15‑minute pilot run`},o=await new e().generate(a),c=await new t().generate(a),l=await new n().generate({brief:a,variant:`announcement`}),u=await new r().generate(a),d=new i().optimize(a);s.info(`Generated content assets`,{blogIntro:o.intro,landingHero:c.hero,emailSubject:l.subject,socialPosts:u.map(e=>e.body),seo:d})}export{c as runContentGenerationExample};
1
+ import { BlogGenerator } from "./libs/content-gen/dist/generators/blog.js";
2
+ import { LandingPageGenerator } from "./libs/content-gen/dist/generators/landing-page.js";
3
+ import { EmailCampaignGenerator } from "./libs/content-gen/dist/generators/email.js";
4
+ import { SocialPostGenerator } from "./libs/content-gen/dist/generators/social.js";
5
+ import { SeoOptimizer } from "./libs/content-gen/dist/seo/optimizer.js";
6
+ import { LogLevel } from "./libs/logger/dist/types.js";
7
+ import { Logger } from "./libs/logger/dist/logger.node.js";
8
+ import "./libs/logger/dist/index.js";
9
+
10
+ //#region src/generate.ts
11
+ const logger = new Logger({
12
+ level: process.env.NODE_ENV === "production" ? LogLevel.INFO : LogLevel.DEBUG,
13
+ environment: process.env.NODE_ENV || "development",
14
+ enableColors: process.env.NODE_ENV !== "production"
15
+ });
16
+ async function runContentGenerationExample() {
17
+ const brief = {
18
+ title: "AI-Native Operations Copilot",
19
+ summary: "Automates support resolutions, growth playbooks, and DevOps rituals.",
20
+ problems: ["Support queues pile up after hours", "Growth teams lack fresh experiments"],
21
+ solutions: [
22
+ "Stateful AI agents grounded in your knowledge spaces",
23
+ "CI-safe approval workflows for human review",
24
+ "Analytics + experimentation stack built into ContractSpec"
25
+ ],
26
+ metrics: ["80% auto-resolution rate", "10+ experiments shipped weekly"],
27
+ audience: {
28
+ role: "COO",
29
+ industry: "Fintech",
30
+ maturity: "scaleup"
31
+ },
32
+ callToAction: "Book a 15‑minute pilot run"
33
+ };
34
+ const blog = await new BlogGenerator().generate(brief);
35
+ const landing = await new LandingPageGenerator().generate(brief);
36
+ const email = await new EmailCampaignGenerator().generate({
37
+ brief,
38
+ variant: "announcement"
39
+ });
40
+ const social = await new SocialPostGenerator().generate(brief);
41
+ const seo = new SeoOptimizer().optimize(brief);
42
+ logger.info("Generated content assets", {
43
+ blogIntro: blog.intro,
44
+ landingHero: landing.hero,
45
+ emailSubject: email.subject,
46
+ socialPosts: social.map((post) => post.body),
47
+ seo
48
+ });
49
+ }
50
+
51
+ //#endregion
52
+ export { runContentGenerationExample };
package/dist/index.js CHANGED
@@ -1 +1,5 @@
1
- import e from"./example.js";import{runContentGenerationExample as t}from"./generate.js";import"./docs/index.js";export{e as example,t as runContentGenerationExample};
1
+ import example_default from "./example.js";
2
+ import { runContentGenerationExample } from "./generate.js";
3
+ import "./docs/index.js";
4
+
5
+ export { example_default as example, runContentGenerationExample };
@@ -1 +1,68 @@
1
- var e=class{llm;model;temperature;constructor(e){this.llm=e?.llm,this.model=e?.model,this.temperature=e?.temperature??.4}async generate(e){return this.llm?this.generateWithLlm(e):this.generateDeterministic(e)}async generateWithLlm(e){let t=(await this.llm.chat([{role:`system`,content:[{type:`text`,text:`You are a product marketing writer. Produce JSON with title, subtitle, intro, sections[].heading/body/bullets, outro.`}]},{role:`user`,content:[{type:`text`,text:JSON.stringify({brief:e})}]}],{responseFormat:`json`,model:this.model,temperature:this.temperature})).message.content.find(e=>`text`in e);return t&&`text`in t?JSON.parse(t.text):this.generateDeterministic(e)}generateDeterministic(e){let t=`Operators like ${e.audience.role} teams face ${e.problems.slice(0,2).join(` and `)}. ${e.title} changes that by ${e.summary}.`,n=[{heading:`Why now`,body:this.renderWhyNow(e)},{heading:`What you get`,body:`A focused stack built for policy-safe automation.`,bullets:e.solutions},{heading:`Proof it works`,body:`Teams using the blueprint report measurable wins.`,bullets:e.metrics??[`Launch workflows in minutes`,`Cut review time by 60%`]}];return{title:e.title,subtitle:e.summary,intro:t,sections:n,outro:e.callToAction??`Ready to see it live? Spin up a sandbox in under 5 minutes.`}}renderWhyNow(e){return`${`${e.audience.role}${e.audience.industry?` in ${e.audience.industry}`:``}`} teams are stuck with ${e.problems.slice(0,2).join(`; `)}. ${e.title} delivers guardrails without slowing shipping.`}};export{e};
1
+ //#region ../../libs/content-gen/dist/generators/blog.js
2
+ var BlogGenerator = class {
3
+ llm;
4
+ model;
5
+ temperature;
6
+ constructor(options) {
7
+ this.llm = options?.llm;
8
+ this.model = options?.model;
9
+ this.temperature = options?.temperature ?? .4;
10
+ }
11
+ async generate(brief) {
12
+ if (this.llm) return this.generateWithLlm(brief);
13
+ return this.generateDeterministic(brief);
14
+ }
15
+ async generateWithLlm(brief) {
16
+ const jsonPart = (await this.llm.chat([{
17
+ role: "system",
18
+ content: [{
19
+ type: "text",
20
+ text: "You are a product marketing writer. Produce JSON with title, subtitle, intro, sections[].heading/body/bullets, outro."
21
+ }]
22
+ }, {
23
+ role: "user",
24
+ content: [{
25
+ type: "text",
26
+ text: JSON.stringify({ brief })
27
+ }]
28
+ }], {
29
+ responseFormat: "json",
30
+ model: this.model,
31
+ temperature: this.temperature
32
+ })).message.content.find((part) => "text" in part);
33
+ if (jsonPart && "text" in jsonPart) return JSON.parse(jsonPart.text);
34
+ return this.generateDeterministic(brief);
35
+ }
36
+ generateDeterministic(brief) {
37
+ const intro = `Operators like ${brief.audience.role} teams face ${brief.problems.slice(0, 2).join(" and ")}. ${brief.title} changes that by ${brief.summary}.`;
38
+ const sections = [
39
+ {
40
+ heading: "Why now",
41
+ body: this.renderWhyNow(brief)
42
+ },
43
+ {
44
+ heading: "What you get",
45
+ body: "A focused stack built for policy-safe automation.",
46
+ bullets: brief.solutions
47
+ },
48
+ {
49
+ heading: "Proof it works",
50
+ body: "Teams using the blueprint report measurable wins.",
51
+ bullets: brief.metrics ?? ["Launch workflows in minutes", "Cut review time by 60%"]
52
+ }
53
+ ];
54
+ return {
55
+ title: brief.title,
56
+ subtitle: brief.summary,
57
+ intro,
58
+ sections,
59
+ outro: brief.callToAction ?? "Ready to see it live? Spin up a sandbox in under 5 minutes."
60
+ };
61
+ }
62
+ renderWhyNow(brief) {
63
+ return `${`${brief.audience.role}${brief.audience.industry ? ` in ${brief.audience.industry}` : ""}`} teams are stuck with ${brief.problems.slice(0, 2).join("; ")}. ${brief.title} delivers guardrails without slowing shipping.`;
64
+ }
65
+ };
66
+
67
+ //#endregion
68
+ export { BlogGenerator };
@@ -1,13 +1,100 @@
1
- var e=class{llm;model;temperature;constructor(e){this.llm=e?.llm,this.model=e?.model,this.temperature=e?.temperature??.6}async generate(e){if(this.llm){let t=await this.generateWithLlm(e);if(t)return t}return this.generateFallback(e)}async generateWithLlm(e){let t=(await this.llm.chat([{role:`system`,content:[{type:`text`,text:`Draft product marketing email as JSON {subject, previewText, body, cta}.`}]},{role:`user`,content:[{type:`text`,text:JSON.stringify(e)}]}],{responseFormat:`json`,model:this.model,temperature:this.temperature})).message.content.find(e=>`text`in e);if(!t||!(`text`in t))return null;let n=JSON.parse(t.text);return!n.subject||!n.body||!n.cta?null:{subject:n.subject,previewText:n.previewText??this.defaultPreview(e),body:n.body,cta:n.cta,variant:e.variant}}generateFallback(e){let{brief:t,variant:n}=e;return{subject:this.subjects(t.title,n)[0]??`${t.title} update`,previewText:this.defaultPreview(e),body:this.renderBody(e),cta:t.callToAction??`Explore the sandbox`,variant:n}}subjects(e,t){switch(t){case`announcement`:return[`Launch: ${e}`,`${e} is live`,`New: ${e}`];case`onboarding`:return[`Get started with ${e}`,`Your ${e} guide`];case`nurture`:default:return[`How ${e} speeds ops`,`Proof ${e} works`]}}defaultPreview(e){return`See how teams ${e.brief.metrics?.[0]??`ship faster without policy gaps`}.`}renderBody(e){let{brief:t,variant:n}=e,r=this.variantHook(n,t),i=t.metrics?.map(e=>`• ${e}`).join(`
2
- `)??``;return`Hi there,
1
+ //#region ../../libs/content-gen/dist/generators/email.js
2
+ var EmailCampaignGenerator = class {
3
+ llm;
4
+ model;
5
+ temperature;
6
+ constructor(options) {
7
+ this.llm = options?.llm;
8
+ this.model = options?.model;
9
+ this.temperature = options?.temperature ?? .6;
10
+ }
11
+ async generate(input) {
12
+ if (this.llm) {
13
+ const draft = await this.generateWithLlm(input);
14
+ if (draft) return draft;
15
+ }
16
+ return this.generateFallback(input);
17
+ }
18
+ async generateWithLlm(input) {
19
+ const jsonPart = (await this.llm.chat([{
20
+ role: "system",
21
+ content: [{
22
+ type: "text",
23
+ text: "Draft product marketing email as JSON {subject, previewText, body, cta}."
24
+ }]
25
+ }, {
26
+ role: "user",
27
+ content: [{
28
+ type: "text",
29
+ text: JSON.stringify(input)
30
+ }]
31
+ }], {
32
+ responseFormat: "json",
33
+ model: this.model,
34
+ temperature: this.temperature
35
+ })).message.content.find((chunk) => "text" in chunk);
36
+ if (!jsonPart || !("text" in jsonPart)) return null;
37
+ const parsed = JSON.parse(jsonPart.text);
38
+ if (!parsed.subject || !parsed.body || !parsed.cta) return null;
39
+ return {
40
+ subject: parsed.subject,
41
+ previewText: parsed.previewText ?? this.defaultPreview(input),
42
+ body: parsed.body,
43
+ cta: parsed.cta,
44
+ variant: input.variant
45
+ };
46
+ }
47
+ generateFallback(input) {
48
+ const { brief, variant } = input;
49
+ return {
50
+ subject: this.subjects(brief.title, variant)[0] ?? `${brief.title} update`,
51
+ previewText: this.defaultPreview(input),
52
+ body: this.renderBody(input),
53
+ cta: brief.callToAction ?? "Explore the sandbox",
54
+ variant
55
+ };
56
+ }
57
+ subjects(title, variant) {
58
+ switch (variant) {
59
+ case "announcement": return [
60
+ `Launch: ${title}`,
61
+ `${title} is live`,
62
+ `New: ${title}`
63
+ ];
64
+ case "onboarding": return [`Get started with ${title}`, `Your ${title} guide`];
65
+ case "nurture":
66
+ default: return [`How ${title} speeds ops`, `Proof ${title} works`];
67
+ }
68
+ }
69
+ defaultPreview(input) {
70
+ return `See how teams ${input.brief.metrics?.[0] ?? "ship faster without policy gaps"}.`;
71
+ }
72
+ renderBody(input) {
73
+ const { brief, variant } = input;
74
+ const greeting = "Hi there,";
75
+ const hook = this.variantHook(variant, brief);
76
+ const proof = brief.metrics?.map((metric) => `• ${metric}`).join("\n") ?? "";
77
+ return `${greeting}
3
78
 
4
- ${r}
79
+ ${hook}
5
80
 
6
- Top reasons teams adopt ${t.title}:
7
- ${t.solutions.map(e=>`• ${e}`).join(`
8
- `)}
81
+ Top reasons teams adopt ${brief.title}:
82
+ ${brief.solutions.map((solution) => `• ${solution}`).join("\n")}
9
83
 
10
- ${i}
84
+ ${proof}
11
85
 
12
- ${t.callToAction??`Spin up a sandbox`} → ${(e.cadenceDay??0)+1}
13
- `}variantHook(e,t){switch(e){case`announcement`:return`${t.title} is live. ${t.summary}`;case`onboarding`:return`Here is your next step to unlock ${t.title}.`;case`nurture`:default:return`Operators like ${t.audience.role} keep asking how to automate policy checks. Here is what works.`}}};export{e};
86
+ ${brief.callToAction ?? "Spin up a sandbox"} → ${(input.cadenceDay ?? 0) + 1}
87
+ `;
88
+ }
89
+ variantHook(variant, brief) {
90
+ switch (variant) {
91
+ case "announcement": return `${brief.title} is live. ${brief.summary}`;
92
+ case "onboarding": return `Here is your next step to unlock ${brief.title}.`;
93
+ case "nurture":
94
+ default: return `Operators like ${brief.audience.role} keep asking how to automate policy checks. Here is what works.`;
95
+ }
96
+ }
97
+ };
98
+
99
+ //#endregion
100
+ export { EmailCampaignGenerator };
@@ -1,2 +1,76 @@
1
- var e=class{llm;model;constructor(e){this.options=e,this.llm=e?.llm,this.model=e?.model}async generate(e){return this.llm?this.generateWithLlm(e):this.generateFallback(e)}async generateWithLlm(e){let t=(await this.llm.chat([{role:`system`,content:[{type:`text`,text:`Write JSON landing page copy with hero/highlights/socialProof/faq arrays.`}]},{role:`user`,content:[{type:`text`,text:JSON.stringify({brief:e})}]}],{responseFormat:`json`,model:this.model,temperature:this.options?.temperature??.5})).message.content.find(e=>`text`in e);return t&&`text`in t?JSON.parse(t.text):this.generateFallback(e)}generateFallback(e){return{hero:{eyebrow:`${e.audience.industry??`Operations`} teams`,title:e.title,subtitle:e.summary,primaryCta:e.callToAction??`Launch a sandbox`,secondaryCta:`View docs`},highlights:e.solutions.slice(0,3).map((e,t)=>({heading:[`Policy-safe by default`,`Auto-adapts per tenant`,`Launch-ready in days`][t]??`Key capability`,body:e})),socialProof:{heading:`Teams using ContractSpec`,body:e.proofPoints?.join(`
2
- `)??`“We ship compliant workflows 5x faster while cutting ops toil in half.”`},faq:this.buildFaq(e)}}buildFaq(e){let t=[{heading:`How does this keep policies enforced?`,body:`All workflows compile from TypeScript specs and pass through PDP checks before execution, so no shadow logic slips through.`},{heading:`Will it fit our existing stack?`,body:`Runtime adapters plug into REST, GraphQL, or MCP. Integrations stay vendor agnostic.`}];return e.complianceNotes?.length&&t.push({heading:`What about compliance requirements?`,body:e.complianceNotes.join(` `)}),t}};export{e};
1
+ //#region ../../libs/content-gen/dist/generators/landing-page.js
2
+ var LandingPageGenerator = class {
3
+ llm;
4
+ model;
5
+ constructor(options) {
6
+ this.options = options;
7
+ this.llm = options?.llm;
8
+ this.model = options?.model;
9
+ }
10
+ async generate(brief) {
11
+ if (this.llm) return this.generateWithLlm(brief);
12
+ return this.generateFallback(brief);
13
+ }
14
+ async generateWithLlm(brief) {
15
+ const part = (await this.llm.chat([{
16
+ role: "system",
17
+ content: [{
18
+ type: "text",
19
+ text: "Write JSON landing page copy with hero/highlights/socialProof/faq arrays."
20
+ }]
21
+ }, {
22
+ role: "user",
23
+ content: [{
24
+ type: "text",
25
+ text: JSON.stringify({ brief })
26
+ }]
27
+ }], {
28
+ responseFormat: "json",
29
+ model: this.model,
30
+ temperature: this.options?.temperature ?? .5
31
+ })).message.content.find((chunk) => "text" in chunk);
32
+ if (part && "text" in part) return JSON.parse(part.text);
33
+ return this.generateFallback(brief);
34
+ }
35
+ generateFallback(brief) {
36
+ return {
37
+ hero: {
38
+ eyebrow: `${brief.audience.industry ?? "Operations"} teams`,
39
+ title: brief.title,
40
+ subtitle: brief.summary,
41
+ primaryCta: brief.callToAction ?? "Launch a sandbox",
42
+ secondaryCta: "View docs"
43
+ },
44
+ highlights: brief.solutions.slice(0, 3).map((solution, index) => ({
45
+ heading: [
46
+ "Policy-safe by default",
47
+ "Auto-adapts per tenant",
48
+ "Launch-ready in days"
49
+ ][index] ?? "Key capability",
50
+ body: solution
51
+ })),
52
+ socialProof: {
53
+ heading: "Teams using ContractSpec",
54
+ body: brief.proofPoints?.join("\n") ?? "“We ship compliant workflows 5x faster while cutting ops toil in half.”"
55
+ },
56
+ faq: this.buildFaq(brief)
57
+ };
58
+ }
59
+ buildFaq(brief) {
60
+ const faqs = [{
61
+ heading: "How does this keep policies enforced?",
62
+ body: "All workflows compile from TypeScript specs and pass through PDP checks before execution, so no shadow logic slips through."
63
+ }, {
64
+ heading: "Will it fit our existing stack?",
65
+ body: "Runtime adapters plug into REST, GraphQL, or MCP. Integrations stay vendor agnostic."
66
+ }];
67
+ if (brief.complianceNotes?.length) faqs.push({
68
+ heading: "What about compliance requirements?",
69
+ body: brief.complianceNotes.join(" ")
70
+ });
71
+ return faqs;
72
+ }
73
+ };
74
+
75
+ //#endregion
76
+ export { LandingPageGenerator };