@lssm/example.learning-journey-registry 0.0.0-canary-20251217060834 → 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 (112) hide show
  1. package/.turbo/turbo-build$colon$bundle.log +410 -64
  2. package/.turbo/turbo-build.log +55 -65
  3. package/CHANGELOG.md +14 -12
  4. package/dist/api.js +170 -1
  5. package/dist/docs/index.js +1 -1
  6. package/dist/docs/learning-journey-registry.docblock.js +38 -1
  7. package/dist/example.js +34 -1
  8. package/dist/examples/learning-journey-ambient-coach/src/track.js +41 -0
  9. package/dist/examples/learning-journey-crm-onboarding/dist/track.js +98 -0
  10. package/dist/examples/learning-journey-duo-drills/src/track.js +65 -0
  11. package/dist/examples/learning-journey-platform-tour/dist/track.js +105 -0
  12. package/dist/examples/learning-journey-quest-challenges/src/track.js +35 -0
  13. package/dist/examples/learning-journey-studio-onboarding/dist/track.js +90 -0
  14. package/dist/examples/learning-journey-ui-coaching/src/CoachingMiniApp.js +64 -0
  15. package/dist/examples/learning-journey-ui-coaching/src/components/EngagementMeter.js +107 -0
  16. package/dist/examples/learning-journey-ui-coaching/src/components/TipCard.js +75 -0
  17. package/dist/examples/learning-journey-ui-coaching/src/components/TipFeed.js +65 -0
  18. package/dist/examples/learning-journey-ui-coaching/src/components/index.js +3 -0
  19. package/dist/examples/learning-journey-ui-coaching/src/docs/index.js +1 -0
  20. package/dist/examples/learning-journey-ui-coaching/src/docs/learning-journey-ui-coaching.docblock.js +20 -0
  21. package/dist/examples/learning-journey-ui-coaching/src/index.js +11 -0
  22. package/dist/examples/learning-journey-ui-coaching/src/views/Overview.js +152 -0
  23. package/dist/examples/learning-journey-ui-coaching/src/views/Progress.js +117 -0
  24. package/dist/examples/learning-journey-ui-coaching/src/views/Steps.js +68 -0
  25. package/dist/examples/learning-journey-ui-coaching/src/views/Timeline.js +112 -0
  26. package/dist/examples/learning-journey-ui-coaching/src/views/index.js +4 -0
  27. package/dist/examples/learning-journey-ui-gamified/src/GamifiedMiniApp.js +64 -0
  28. package/dist/examples/learning-journey-ui-gamified/src/components/DayCalendar.js +32 -0
  29. package/dist/examples/learning-journey-ui-gamified/src/components/FlashCard.js +79 -0
  30. package/dist/examples/learning-journey-ui-gamified/src/components/MasteryRing.js +81 -0
  31. package/dist/examples/learning-journey-ui-gamified/src/components/index.js +3 -0
  32. package/dist/examples/learning-journey-ui-gamified/src/docs/index.js +1 -0
  33. package/dist/examples/learning-journey-ui-gamified/src/docs/learning-journey-ui-gamified.docblock.js +20 -0
  34. package/dist/examples/learning-journey-ui-gamified/src/index.js +11 -0
  35. package/dist/examples/learning-journey-ui-gamified/src/views/Overview.js +163 -0
  36. package/dist/examples/learning-journey-ui-gamified/src/views/Progress.js +144 -0
  37. package/dist/examples/learning-journey-ui-gamified/src/views/Steps.js +55 -0
  38. package/dist/examples/learning-journey-ui-gamified/src/views/Timeline.js +132 -0
  39. package/dist/examples/learning-journey-ui-gamified/src/views/index.js +4 -0
  40. package/dist/examples/learning-journey-ui-onboarding/src/OnboardingMiniApp.js +64 -0
  41. package/dist/examples/learning-journey-ui-onboarding/src/components/CodeSnippet.js +4 -0
  42. package/dist/examples/learning-journey-ui-onboarding/src/components/JourneyMap.js +48 -0
  43. package/dist/examples/learning-journey-ui-onboarding/src/components/StepChecklist.js +79 -0
  44. package/dist/examples/learning-journey-ui-onboarding/src/components/index.js +3 -0
  45. package/dist/examples/learning-journey-ui-onboarding/src/docs/index.js +1 -0
  46. package/dist/examples/learning-journey-ui-onboarding/src/docs/learning-journey-ui-onboarding.docblock.js +20 -0
  47. package/dist/examples/learning-journey-ui-onboarding/src/index.js +10 -0
  48. package/dist/examples/learning-journey-ui-onboarding/src/views/Overview.js +180 -0
  49. package/dist/examples/learning-journey-ui-onboarding/src/views/Progress.js +162 -0
  50. package/dist/examples/learning-journey-ui-onboarding/src/views/Steps.js +91 -0
  51. package/dist/examples/learning-journey-ui-onboarding/src/views/Timeline.js +97 -0
  52. package/dist/examples/learning-journey-ui-onboarding/src/views/index.js +4 -0
  53. package/dist/examples/learning-journey-ui-shared/src/components/BadgeDisplay.js +44 -0
  54. package/dist/examples/learning-journey-ui-shared/src/components/StreakCounter.js +45 -0
  55. package/dist/examples/learning-journey-ui-shared/src/components/ViewTabs.js +48 -0
  56. package/dist/examples/learning-journey-ui-shared/src/components/XpBar.js +46 -0
  57. package/dist/examples/learning-journey-ui-shared/src/components/index.js +4 -0
  58. package/dist/examples/learning-journey-ui-shared/src/docs/index.js +1 -0
  59. package/dist/examples/learning-journey-ui-shared/src/docs/learning-journey-ui-shared.docblock.js +20 -0
  60. package/dist/examples/learning-journey-ui-shared/src/hooks/index.js +1 -0
  61. package/dist/examples/learning-journey-ui-shared/src/hooks/useLearningProgress.js +73 -0
  62. package/dist/examples/learning-journey-ui-shared/src/index.js +8 -0
  63. package/dist/index.js +13 -1
  64. package/dist/learning-journey-registry.feature.js +66 -1
  65. package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +16 -76
  66. package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +16 -350
  67. package/dist/libs/contracts/dist/docs/index.js +29 -1
  68. package/dist/libs/contracts/dist/docs/presentations.js +71 -1
  69. package/dist/libs/contracts/dist/docs/registry.js +44 -1
  70. package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +16 -383
  71. package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +16 -68
  72. package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +16 -140
  73. package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +16 -86
  74. package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +16 -1
  75. package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +24 -2
  76. package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +21 -2
  77. package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +16 -213
  78. package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +73 -5
  79. package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +37 -1
  80. package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +16 -1
  81. package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +20 -262
  82. package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +48 -1
  83. package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +24 -2
  84. package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +23 -2
  85. package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +25 -16
  86. package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +67 -1
  87. package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +22 -2
  88. package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +40 -36
  89. package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +47 -1
  90. package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +23 -2
  91. package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +36 -3
  92. package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +20 -1
  93. package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +36 -3
  94. package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +20 -1
  95. package/dist/libs/design-system/dist/_virtual/rolldown_runtime.js +5 -0
  96. package/dist/libs/design-system/dist/components/atoms/Button.js +33 -0
  97. package/dist/libs/design-system/dist/ui-kit-web/dist/ui/button.js +55 -0
  98. package/dist/libs/design-system/dist/ui-kit-web/dist/ui-kit-core/dist/utils.js +13 -0
  99. package/dist/libs/ui-kit-core/dist/utils.js +10 -0
  100. package/dist/libs/ui-kit-web/dist/ui/card.js +36 -0
  101. package/dist/libs/ui-kit-web/dist/ui/progress.js +23 -0
  102. package/dist/libs/ui-kit-web/dist/ui/utils.js +10 -0
  103. package/dist/libs/ui-kit-web/dist/ui-kit-core/dist/utils.js +10 -0
  104. package/dist/presentations/index.js +64 -1
  105. package/dist/progress-store.js +30 -1
  106. package/dist/tracks.d.ts +1 -1
  107. package/dist/tracks.js +47 -1
  108. package/dist/ui/LearningMiniApp.d.ts +0 -1
  109. package/dist/ui/LearningMiniApp.js +82 -1
  110. package/dist/ui/index.js +3 -1
  111. package/package.json +16 -14
  112. package/tsconfig.tsbuildinfo +1 -1
@@ -0,0 +1,105 @@
1
+ //#region ../learning-journey-platform-tour/dist/track.js
2
+ const platformPrimitivesTourTrack = {
3
+ id: "platform_primitives_tour",
4
+ productId: "contractspec-platform",
5
+ name: "Platform Primitives Tour",
6
+ description: "Hands-on tour across identity, audit, notifications, jobs, flags, files, and metering.",
7
+ targetUserSegment: "platform_developer",
8
+ targetRole: "developer",
9
+ totalXp: 140,
10
+ completionRewards: {
11
+ xpBonus: 20,
12
+ badgeKey: "platform_primitives"
13
+ },
14
+ steps: [
15
+ {
16
+ id: "identity_rbac",
17
+ title: "Create org and member",
18
+ description: "Create an org and add at least one member.",
19
+ order: 1,
20
+ completion: {
21
+ eventName: "org.member.added",
22
+ sourceModule: "@lssm/lib.identity-rbac"
23
+ },
24
+ xpReward: 20,
25
+ metadata: { surface: "identity" }
26
+ },
27
+ {
28
+ id: "event_bus_audit",
29
+ title: "Emit an auditable event",
30
+ description: "Emit an event that lands in the audit log.",
31
+ order: 2,
32
+ completion: {
33
+ eventName: "audit_log.created",
34
+ sourceModule: "@lssm/module.audit-trail"
35
+ },
36
+ xpReward: 20,
37
+ metadata: { surface: "bus+audit" }
38
+ },
39
+ {
40
+ id: "notifications",
41
+ title: "Send a notification",
42
+ description: "Send yourself a notification and verify delivery.",
43
+ order: 3,
44
+ completion: {
45
+ eventName: "notification.sent",
46
+ sourceModule: "@lssm/module.notifications"
47
+ },
48
+ xpReward: 20,
49
+ metadata: { surface: "notifications" }
50
+ },
51
+ {
52
+ id: "jobs_scheduler",
53
+ title: "Schedule and run a job",
54
+ description: "Schedule a background job and let it run once.",
55
+ order: 4,
56
+ completion: {
57
+ eventName: "job.completed",
58
+ sourceModule: "@lssm/lib.jobs"
59
+ },
60
+ xpReward: 20,
61
+ metadata: { surface: "jobs" }
62
+ },
63
+ {
64
+ id: "feature_flags",
65
+ title: "Create and toggle a feature flag",
66
+ description: "Create a feature flag and toggle it at least once.",
67
+ order: 5,
68
+ completion: {
69
+ eventName: "flag.toggled",
70
+ sourceModule: "@lssm/lib.feature-flags"
71
+ },
72
+ xpReward: 20,
73
+ metadata: { surface: "feature-flags" }
74
+ },
75
+ {
76
+ id: "files_attachments",
77
+ title: "Attach a file",
78
+ description: "Upload and attach a file to any entity.",
79
+ order: 6,
80
+ completion: {
81
+ eventName: "attachment.attached",
82
+ sourceModule: "@lssm/lib.files"
83
+ },
84
+ xpReward: 20,
85
+ metadata: { surface: "files" }
86
+ },
87
+ {
88
+ id: "usage_metering",
89
+ title: "Record usage",
90
+ description: "Emit a usage metric (regeneration, agent run, or similar).",
91
+ order: 7,
92
+ completion: {
93
+ eventName: "usage.recorded",
94
+ sourceModule: "@lssm/lib.metering"
95
+ },
96
+ xpReward: 20,
97
+ metadata: { surface: "metering" }
98
+ }
99
+ ],
100
+ metadata: { surfacedIn: ["studio/learning", "platform/dev-center"] }
101
+ };
102
+ const platformLearningTracks = [platformPrimitivesTourTrack];
103
+
104
+ //#endregion
105
+ export { platformLearningTracks };
@@ -0,0 +1,35 @@
1
+ //#region ../learning-journey-quest-challenges/src/track.ts
2
+ const dayStep = (id, day, eventName, description) => ({
3
+ id,
4
+ title: `Day ${day}`,
5
+ description,
6
+ availability: { unlockOnDay: day },
7
+ completion: {
8
+ kind: "time_window",
9
+ eventName,
10
+ withinHoursOfStart: (day + 1) * 24
11
+ },
12
+ xpReward: 15,
13
+ metadata: { day }
14
+ });
15
+ const moneyResetQuestTrack = {
16
+ id: "money_reset_7day",
17
+ name: "7-day Money Reset",
18
+ description: "Time-bound quest to reset personal finances over a focused week.",
19
+ targetUserSegment: "money_user",
20
+ totalXp: 105,
21
+ completionRewards: { xpBonus: 30 },
22
+ steps: [
23
+ dayStep("day1_map_accounts", 1, "accounts.mapped", "Map bank and card accounts."),
24
+ dayStep("day2_categorize_transactions", 2, "transactions.categorized", "Categorize recent transactions."),
25
+ dayStep("day3_define_goals", 3, "goals.created", "Define at least one savings goal."),
26
+ dayStep("day4_setup_recurring_savings", 4, "recurring_rule.created", "Set a recurring savings rule."),
27
+ dayStep("day5_review_subscriptions", 5, "subscription.flagged_or_cancelled", "Review subscriptions and flag or cancel wasteful ones."),
28
+ dayStep("day6_plan_emergency", 6, "emergency_plan.completed", "Draft an emergency plan and target buffer."),
29
+ dayStep("day7_review_commit", 7, "quest.review.completed", "Review week outcomes and commit to the next month.")
30
+ ]
31
+ };
32
+ const questTracks = [moneyResetQuestTrack];
33
+
34
+ //#endregion
35
+ export { questTracks };
@@ -0,0 +1,90 @@
1
+ //#region ../learning-journey-studio-onboarding/dist/track.js
2
+ const studioGettingStartedTrack = {
3
+ id: "studio_getting_started",
4
+ productId: "contractspec-studio",
5
+ name: "Studio Getting Started",
6
+ description: "First 30 minutes in Studio: create a project, edit the spec, deploy/regenerate, and try key modules.",
7
+ targetUserSegment: "new_studio_user",
8
+ targetRole: "developer",
9
+ totalXp: 110,
10
+ streakRule: {
11
+ hoursWindow: 48,
12
+ bonusXp: 25
13
+ },
14
+ completionRewards: {
15
+ xpBonus: 25,
16
+ badgeKey: "studio_first_30m"
17
+ },
18
+ steps: [
19
+ {
20
+ id: "choose_template",
21
+ title: "Choose a template",
22
+ description: "Create your first Studio project (starter template).",
23
+ order: 1,
24
+ completion: {
25
+ eventName: "studio.template.instantiated",
26
+ sourceModule: "@lssm/bundle.contractspec-studio"
27
+ },
28
+ xpReward: 20,
29
+ metadata: { surface: "projects" }
30
+ },
31
+ {
32
+ id: "edit_spec",
33
+ title: "Edit the spec",
34
+ description: "Change the spec (not generated code) and save.",
35
+ instructions: "Open spec editor, tweak a contract or presentation, save.",
36
+ order: 2,
37
+ completion: {
38
+ eventName: "spec.changed",
39
+ sourceModule: "@lssm/bundle.contractspec-studio"
40
+ },
41
+ xpReward: 20,
42
+ metadata: { surface: "spec-editor" }
43
+ },
44
+ {
45
+ id: "regenerate_app",
46
+ title: "Regenerate the app",
47
+ description: "Regenerate artifacts from the updated spec.",
48
+ order: 3,
49
+ completion: {
50
+ eventName: "regeneration.completed",
51
+ sourceModule: "@lssm/lib.contracts/regenerator"
52
+ },
53
+ xpReward: 20,
54
+ metadata: { surface: "regenerator" }
55
+ },
56
+ {
57
+ id: "open_canvas",
58
+ title: "Open the canvas",
59
+ description: "Visit the canvas module for your project.",
60
+ order: 4,
61
+ completion: {
62
+ eventName: "module.navigated",
63
+ sourceModule: "@lssm/bundle.contractspec-studio",
64
+ payloadFilter: { moduleId: "canvas" }
65
+ },
66
+ xpReward: 20,
67
+ metadata: { surface: "canvas" }
68
+ },
69
+ {
70
+ id: "try_evolution_mode",
71
+ title: "Try evolution mode",
72
+ description: "Request a change via Evolution, then regenerate.",
73
+ order: 5,
74
+ completion: {
75
+ eventName: "studio.evolution.applied",
76
+ sourceModule: "@lssm/lib.evolution"
77
+ },
78
+ xpReward: 30,
79
+ metadata: { surface: "evolution" }
80
+ }
81
+ ],
82
+ metadata: {
83
+ persona: "first_run",
84
+ surfacedIn: ["studio/home", "studio/sidebar/learning"]
85
+ }
86
+ };
87
+ const studioLearningTracks = [studioGettingStartedTrack];
88
+
89
+ //#endregion
90
+ export { studioLearningTracks };
@@ -0,0 +1,64 @@
1
+ 'use client';
2
+
3
+ import { Card, CardContent } from "../../../libs/ui-kit-web/dist/ui/card.js";
4
+ import { useLearningProgress } from "../../learning-journey-ui-shared/src/hooks/useLearningProgress.js";
5
+ import { ViewTabs } from "../../learning-journey-ui-shared/src/components/ViewTabs.js";
6
+ import "../../learning-journey-ui-shared/src/index.js";
7
+ import { Overview } from "./views/Overview.js";
8
+ import { Steps } from "./views/Steps.js";
9
+ import { ProgressView } from "./views/Progress.js";
10
+ import { Timeline } from "./views/Timeline.js";
11
+ import { useCallback, useState } from "react";
12
+ import { jsx, jsxs } from "react/jsx-runtime";
13
+
14
+ //#region ../learning-journey-ui-coaching/src/CoachingMiniApp.tsx
15
+ function CoachingMiniApp({ track, progress: externalProgress, onStepComplete: externalOnStepComplete, onViewChange, initialView = "overview" }) {
16
+ const [currentView, setCurrentView] = useState(initialView);
17
+ const { progress: internalProgress, completeStep: internalCompleteStep } = useLearningProgress(track);
18
+ const progress = externalProgress ?? internalProgress;
19
+ const handleViewChange = useCallback((view) => {
20
+ setCurrentView(view);
21
+ onViewChange?.(view);
22
+ }, [onViewChange]);
23
+ const handleStepComplete = useCallback((stepId) => {
24
+ if (externalOnStepComplete) externalOnStepComplete(stepId);
25
+ else internalCompleteStep(stepId);
26
+ }, [externalOnStepComplete, internalCompleteStep]);
27
+ const handleStartFromOverview = useCallback(() => {
28
+ setCurrentView("steps");
29
+ onViewChange?.("steps");
30
+ }, [onViewChange]);
31
+ const renderView = () => {
32
+ const viewProps = {
33
+ track,
34
+ progress,
35
+ onStepComplete: handleStepComplete
36
+ };
37
+ switch (currentView) {
38
+ case "overview": return /* @__PURE__ */ jsx(Overview, {
39
+ ...viewProps,
40
+ onStart: handleStartFromOverview
41
+ });
42
+ case "steps": return /* @__PURE__ */ jsx(Steps, { ...viewProps });
43
+ case "progress": return /* @__PURE__ */ jsx(ProgressView, { ...viewProps });
44
+ case "timeline": return /* @__PURE__ */ jsx(Timeline, { ...viewProps });
45
+ default: return /* @__PURE__ */ jsx(Overview, {
46
+ ...viewProps,
47
+ onStart: handleStartFromOverview
48
+ });
49
+ }
50
+ };
51
+ return /* @__PURE__ */ jsxs("div", {
52
+ className: "space-y-6",
53
+ children: [/* @__PURE__ */ jsx(Card, { children: /* @__PURE__ */ jsx(CardContent, {
54
+ className: "p-4",
55
+ children: /* @__PURE__ */ jsx(ViewTabs, {
56
+ currentView,
57
+ onViewChange: handleViewChange
58
+ })
59
+ }) }), renderView()]
60
+ });
61
+ }
62
+
63
+ //#endregion
64
+ export { CoachingMiniApp };
@@ -0,0 +1,107 @@
1
+ 'use client';
2
+
3
+ import { jsx, jsxs } from "react/jsx-runtime";
4
+
5
+ //#region ../learning-journey-ui-coaching/src/components/EngagementMeter.tsx
6
+ function EngagementMeter({ acknowledged, actioned, pending, streak = 0 }) {
7
+ const total = acknowledged + actioned + pending;
8
+ const actionedPercent = total > 0 ? actioned / total * 100 : 0;
9
+ const acknowledgedPercent = total > 0 ? acknowledged / total * 100 : 0;
10
+ return /* @__PURE__ */ jsxs("div", {
11
+ className: "space-y-4",
12
+ children: [
13
+ /* @__PURE__ */ jsx("div", {
14
+ className: "flex items-center justify-center",
15
+ children: /* @__PURE__ */ jsxs("div", {
16
+ className: "relative h-32 w-32",
17
+ children: [/* @__PURE__ */ jsxs("svg", {
18
+ className: "h-full w-full -rotate-90",
19
+ viewBox: "0 0 100 100",
20
+ children: [
21
+ /* @__PURE__ */ jsx("circle", {
22
+ cx: "50",
23
+ cy: "50",
24
+ r: "40",
25
+ fill: "none",
26
+ strokeWidth: "12",
27
+ className: "stroke-muted"
28
+ }),
29
+ /* @__PURE__ */ jsx("circle", {
30
+ cx: "50",
31
+ cy: "50",
32
+ r: "40",
33
+ fill: "none",
34
+ strokeWidth: "12",
35
+ strokeLinecap: "round",
36
+ strokeDasharray: `${actionedPercent * 2.51} 251`,
37
+ className: "stroke-green-500 transition-all duration-500"
38
+ }),
39
+ /* @__PURE__ */ jsx("circle", {
40
+ cx: "50",
41
+ cy: "50",
42
+ r: "40",
43
+ fill: "none",
44
+ strokeWidth: "12",
45
+ strokeLinecap: "round",
46
+ strokeDasharray: `${acknowledgedPercent * 2.51} 251`,
47
+ strokeDashoffset: `${-actionedPercent * 2.51}`,
48
+ className: "stroke-amber-500 transition-all duration-500"
49
+ })
50
+ ]
51
+ }), /* @__PURE__ */ jsxs("div", {
52
+ className: "absolute inset-0 flex flex-col items-center justify-center",
53
+ children: [/* @__PURE__ */ jsx("span", {
54
+ className: "text-2xl font-bold",
55
+ children: total
56
+ }), /* @__PURE__ */ jsx("span", {
57
+ className: "text-muted-foreground text-xs",
58
+ children: "tips"
59
+ })]
60
+ })]
61
+ })
62
+ }),
63
+ /* @__PURE__ */ jsxs("div", {
64
+ className: "flex justify-center gap-4 text-sm",
65
+ children: [
66
+ /* @__PURE__ */ jsxs("div", {
67
+ className: "flex items-center gap-1.5",
68
+ children: [/* @__PURE__ */ jsx("div", { className: "h-3 w-3 rounded-full bg-green-500" }), /* @__PURE__ */ jsxs("span", { children: [
69
+ "Actioned (",
70
+ actioned,
71
+ ")"
72
+ ] })]
73
+ }),
74
+ /* @__PURE__ */ jsxs("div", {
75
+ className: "flex items-center gap-1.5",
76
+ children: [/* @__PURE__ */ jsx("div", { className: "h-3 w-3 rounded-full bg-amber-500" }), /* @__PURE__ */ jsxs("span", { children: [
77
+ "Acknowledged (",
78
+ acknowledged,
79
+ ")"
80
+ ] })]
81
+ }),
82
+ /* @__PURE__ */ jsxs("div", {
83
+ className: "flex items-center gap-1.5",
84
+ children: [/* @__PURE__ */ jsx("div", { className: "bg-muted h-3 w-3 rounded-full" }), /* @__PURE__ */ jsxs("span", { children: [
85
+ "Pending (",
86
+ pending,
87
+ ")"
88
+ ] })]
89
+ })
90
+ ]
91
+ }),
92
+ streak > 0 && /* @__PURE__ */ jsxs("div", {
93
+ className: "flex items-center justify-center gap-2 rounded-lg bg-orange-500/10 px-4 py-2",
94
+ children: [/* @__PURE__ */ jsx("span", {
95
+ className: "text-xl",
96
+ children: "🔥"
97
+ }), /* @__PURE__ */ jsxs("span", {
98
+ className: "font-semibold text-orange-500",
99
+ children: [streak, " day engagement streak!"]
100
+ })]
101
+ })
102
+ ]
103
+ });
104
+ }
105
+
106
+ //#endregion
107
+ export { EngagementMeter };
@@ -0,0 +1,75 @@
1
+ 'use client';
2
+
3
+ import { Card, CardContent } from "../../../../libs/ui-kit-web/dist/ui/card.js";
4
+ import { cn } from "../../../../libs/ui-kit-web/dist/ui/utils.js";
5
+ import { Button$1 } from "../../../../libs/design-system/dist/components/atoms/Button.js";
6
+ import { jsx, jsxs } from "react/jsx-runtime";
7
+
8
+ //#region ../learning-journey-ui-coaching/src/components/TipCard.tsx
9
+ const TIP_ICONS = {
10
+ cash_buffer_too_high: "💰",
11
+ no_savings_goal: "🎯",
12
+ irregular_savings: "📅",
13
+ noise_late_evening: "🔇",
14
+ guest_frequency_high: "👥",
15
+ shared_space_conflicts: "🏠",
16
+ default: "💡"
17
+ };
18
+ function TipCard({ step, isCompleted, isCurrent, onComplete, onDismiss }) {
19
+ const icon = TIP_ICONS[step.metadata?.tipId ?? "default"] ?? TIP_ICONS.default;
20
+ return /* @__PURE__ */ jsx(Card, {
21
+ className: cn("transition-all", isCompleted && "opacity-60", isCurrent && "ring-2 ring-amber-500"),
22
+ children: /* @__PURE__ */ jsx(CardContent, {
23
+ className: "p-4",
24
+ children: /* @__PURE__ */ jsxs("div", {
25
+ className: "flex gap-4",
26
+ children: [/* @__PURE__ */ jsx("div", {
27
+ className: cn("flex h-12 w-12 shrink-0 items-center justify-center rounded-xl text-2xl", isCompleted ? "bg-green-500/10" : isCurrent ? "bg-amber-500/10" : "bg-muted"),
28
+ children: isCompleted ? "✓" : icon
29
+ }), /* @__PURE__ */ jsxs("div", {
30
+ className: "min-w-0 flex-1",
31
+ children: [
32
+ /* @__PURE__ */ jsxs("div", {
33
+ className: "flex items-start justify-between gap-2",
34
+ children: [/* @__PURE__ */ jsx("h4", {
35
+ className: "font-semibold",
36
+ children: step.title
37
+ }), step.xpReward && /* @__PURE__ */ jsxs("span", {
38
+ className: cn("shrink-0 rounded-full px-2 py-0.5 text-xs font-semibold", isCompleted ? "bg-green-500/10 text-green-500" : "bg-amber-500/10 text-amber-500"),
39
+ children: [
40
+ "+",
41
+ step.xpReward,
42
+ " XP"
43
+ ]
44
+ })]
45
+ }),
46
+ /* @__PURE__ */ jsx("p", {
47
+ className: "text-muted-foreground mt-1 text-sm",
48
+ children: step.description
49
+ }),
50
+ !isCompleted && /* @__PURE__ */ jsxs("div", {
51
+ className: "mt-3 flex flex-wrap gap-2",
52
+ children: [/* @__PURE__ */ jsx(Button$1, {
53
+ size: "sm",
54
+ onClick: onComplete,
55
+ children: "Take Action"
56
+ }), /* @__PURE__ */ jsx(Button$1, {
57
+ variant: "outline",
58
+ size: "sm",
59
+ onClick: onDismiss,
60
+ children: "Dismiss"
61
+ })]
62
+ }),
63
+ isCompleted && /* @__PURE__ */ jsx("p", {
64
+ className: "mt-2 text-sm text-green-500",
65
+ children: "✓ Tip acknowledged"
66
+ })
67
+ ]
68
+ })]
69
+ })
70
+ })
71
+ });
72
+ }
73
+
74
+ //#endregion
75
+ export { TipCard };
@@ -0,0 +1,65 @@
1
+ 'use client';
2
+
3
+ import { cn } from "../../../../libs/ui-kit-web/dist/ui/utils.js";
4
+ import { jsx, jsxs } from "react/jsx-runtime";
5
+
6
+ //#region ../learning-journey-ui-coaching/src/components/TipFeed.tsx
7
+ const TIP_ICONS = {
8
+ cash_buffer_too_high: "💰",
9
+ no_savings_goal: "🎯",
10
+ irregular_savings: "📅",
11
+ noise_late_evening: "🔇",
12
+ guest_frequency_high: "👥",
13
+ shared_space_conflicts: "🏠",
14
+ default: "💡"
15
+ };
16
+ function TipFeed({ items }) {
17
+ if (items.length === 0) return /* @__PURE__ */ jsx("div", {
18
+ className: "text-muted-foreground py-8 text-center",
19
+ children: "No tips yet. Start engaging with coaching tips!"
20
+ });
21
+ return /* @__PURE__ */ jsxs("div", {
22
+ className: "relative",
23
+ children: [/* @__PURE__ */ jsx("div", { className: "bg-border absolute top-0 left-4 h-full w-0.5" }), /* @__PURE__ */ jsx("div", {
24
+ className: "space-y-4",
25
+ children: items.map((item, index) => {
26
+ const icon = TIP_ICONS[item.step.metadata?.tipId ?? "default"] ?? TIP_ICONS.default;
27
+ return /* @__PURE__ */ jsxs("div", {
28
+ className: "relative flex gap-4 pl-2",
29
+ children: [/* @__PURE__ */ jsx("div", {
30
+ className: cn("relative z-10 flex h-8 w-8 shrink-0 items-center justify-center rounded-full text-sm", item.isCompleted ? "bg-green-500 text-white" : "bg-muted text-muted-foreground"),
31
+ children: item.isCompleted ? "✓" : icon
32
+ }), /* @__PURE__ */ jsxs("div", {
33
+ className: "bg-card flex-1 rounded-lg border p-3",
34
+ children: [/* @__PURE__ */ jsxs("div", {
35
+ className: "flex items-start justify-between gap-2",
36
+ children: [/* @__PURE__ */ jsxs("div", { children: [/* @__PURE__ */ jsx("p", {
37
+ className: "font-medium",
38
+ children: item.step.title
39
+ }), /* @__PURE__ */ jsx("p", {
40
+ className: "text-muted-foreground mt-0.5 text-sm",
41
+ children: item.step.description
42
+ })] }), item.step.xpReward && /* @__PURE__ */ jsxs("span", {
43
+ className: cn("shrink-0 text-xs font-medium", item.isCompleted ? "text-green-500" : "text-muted-foreground"),
44
+ children: [
45
+ "+",
46
+ item.step.xpReward,
47
+ " XP"
48
+ ]
49
+ })]
50
+ }), /* @__PURE__ */ jsx("div", {
51
+ className: "text-muted-foreground mt-2 flex items-center gap-2 text-xs",
52
+ children: item.isCompleted ? /* @__PURE__ */ jsxs("span", {
53
+ className: "text-green-500",
54
+ children: ["✓ Completed", item.completedAt && ` • ${item.completedAt}`]
55
+ }) : /* @__PURE__ */ jsx("span", { children: "Pending action" })
56
+ })]
57
+ })]
58
+ }, item.step.id);
59
+ })
60
+ })]
61
+ });
62
+ }
63
+
64
+ //#endregion
65
+ export { TipFeed };
@@ -0,0 +1,3 @@
1
+ import { TipCard } from "./TipCard.js";
2
+ import { EngagementMeter } from "./EngagementMeter.js";
3
+ import { TipFeed } from "./TipFeed.js";
@@ -0,0 +1 @@
1
+ import "./learning-journey-ui-coaching.docblock.js";
@@ -0,0 +1,20 @@
1
+ import { registerDocBlocks } from "../../../../libs/contracts/dist/docs/registry.js";
2
+ import "../../../../libs/contracts/dist/docs/index.js";
3
+
4
+ //#region ../learning-journey-ui-coaching/src/docs/learning-journey-ui-coaching.docblock.ts
5
+ registerDocBlocks([{
6
+ id: "docs.examples.learning-journey-ui-coaching",
7
+ title: "Learning Journey UI — Coaching",
8
+ summary: "UI mini-app components for coaching: tips, engagement, progress.",
9
+ kind: "reference",
10
+ visibility: "public",
11
+ route: "/docs/examples/learning-journey-ui-coaching",
12
+ tags: [
13
+ "learning",
14
+ "ui",
15
+ "coaching"
16
+ ],
17
+ body: `## Includes\n- Coaching mini-app shell\n- Views: overview, steps, progress, timeline\n- Components: tip card, engagement meter, tip feed\n\n## Notes\n- Compose using design system components.\n- Keep accessibility and mobile-friendly tap targets.`
18
+ }]);
19
+
20
+ //#endregion
@@ -0,0 +1,11 @@
1
+ import { TipCard } from "./components/TipCard.js";
2
+ import { Overview } from "./views/Overview.js";
3
+ import { Steps } from "./views/Steps.js";
4
+ import { EngagementMeter } from "./components/EngagementMeter.js";
5
+ import { ProgressView } from "./views/Progress.js";
6
+ import { TipFeed } from "./components/TipFeed.js";
7
+ import { Timeline } from "./views/Timeline.js";
8
+ import { CoachingMiniApp } from "./CoachingMiniApp.js";
9
+ import "./views/index.js";
10
+ import "./components/index.js";
11
+ import "./docs/index.js";