@contractspec/example.learning-journey-quest-challenges 1.44.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.
@@ -0,0 +1,25 @@
1
+ $ tsdown
2
+ ℹ tsdown v0.18.3 powered by rolldown v1.0.0-beta.57
3
+ ℹ config file: /home/runner/work/contractspec/contractspec/packages/examples/learning-journey-quest-challenges/tsdown.config.js
4
+ ℹ entry: src/example.ts, src/index.ts, src/track.ts, src/docs/index.ts, src/docs/quest-challenges.docblock.ts
5
+ ℹ target: esnext
6
+ ℹ tsconfig: tsconfig.json
7
+ ℹ Build start
8
+ ℹ Cleaning 16 files
9
+ ℹ dist/docs/quest-challenges.docblock.js 1.51 kB │ gzip: 0.78 kB
10
+ ℹ dist/track.js 1.44 kB │ gzip: 0.76 kB
11
+ ℹ dist/example.js 0.82 kB │ gzip: 0.46 kB
12
+ ℹ dist/index.js 0.21 kB │ gzip: 0.13 kB
13
+ ℹ dist/docs/index.js 0.04 kB │ gzip: 0.06 kB
14
+ ℹ dist/track.js.map 2.70 kB │ gzip: 1.16 kB
15
+ ℹ dist/docs/quest-challenges.docblock.js.map 1.93 kB │ gzip: 0.95 kB
16
+ ℹ dist/example.js.map 1.17 kB │ gzip: 0.62 kB
17
+ ℹ dist/example.d.ts.map 0.14 kB │ gzip: 0.13 kB
18
+ ℹ dist/track.d.ts.map 0.14 kB │ gzip: 0.13 kB
19
+ ℹ dist/example.d.ts 1.05 kB │ gzip: 0.45 kB
20
+ ℹ dist/track.d.ts 0.33 kB │ gzip: 0.20 kB
21
+ ℹ dist/index.d.ts 0.15 kB │ gzip: 0.10 kB
22
+ ℹ dist/docs/index.d.ts 0.01 kB │ gzip: 0.03 kB
23
+ ℹ dist/docs/quest-challenges.docblock.d.ts 0.01 kB │ gzip: 0.03 kB
24
+ ℹ 15 files, total: 11.66 kB
25
+ ✔ Build complete in 13446ms
@@ -0,0 +1,26 @@
1
+ $ bun build:types && bun build:bundle
2
+ $ tsc --noEmit
3
+ $ tsdown
4
+ ℹ tsdown v0.18.3 powered by rolldown v1.0.0-beta.57
5
+ ℹ config file: /home/runner/work/contractspec/contractspec/packages/examples/learning-journey-quest-challenges/tsdown.config.js
6
+ ℹ entry: src/example.ts, src/index.ts, src/track.ts, src/docs/index.ts, src/docs/quest-challenges.docblock.ts
7
+ ℹ target: esnext
8
+ ℹ tsconfig: tsconfig.json
9
+ ℹ Build start
10
+ ℹ dist/docs/quest-challenges.docblock.js 1.51 kB │ gzip: 0.78 kB
11
+ ℹ dist/track.js 1.44 kB │ gzip: 0.76 kB
12
+ ℹ dist/example.js 0.82 kB │ gzip: 0.46 kB
13
+ ℹ dist/index.js 0.21 kB │ gzip: 0.13 kB
14
+ ℹ dist/docs/index.js 0.04 kB │ gzip: 0.06 kB
15
+ ℹ dist/track.js.map 2.70 kB │ gzip: 1.16 kB
16
+ ℹ dist/docs/quest-challenges.docblock.js.map 1.93 kB │ gzip: 0.95 kB
17
+ ℹ dist/example.js.map 1.17 kB │ gzip: 0.62 kB
18
+ ℹ dist/example.d.ts.map 0.14 kB │ gzip: 0.13 kB
19
+ ℹ dist/track.d.ts.map 0.14 kB │ gzip: 0.13 kB
20
+ ℹ dist/example.d.ts 1.05 kB │ gzip: 0.45 kB
21
+ ℹ dist/track.d.ts 0.33 kB │ gzip: 0.20 kB
22
+ ℹ dist/index.d.ts 0.15 kB │ gzip: 0.10 kB
23
+ ℹ dist/docs/index.d.ts 0.01 kB │ gzip: 0.03 kB
24
+ ℹ dist/docs/quest-challenges.docblock.d.ts 0.01 kB │ gzip: 0.03 kB
25
+ ℹ 15 files, total: 11.66 kB
26
+ ✔ Build complete in 14470ms
package/CHANGELOG.md ADDED
@@ -0,0 +1,178 @@
1
+ # @contractspec/example.learning-journey-quest-challenges
2
+
3
+ ## 1.44.0
4
+
5
+ ### Minor Changes
6
+
7
+ - 5f3a868: chore: isolate branding to contractspec.io
8
+
9
+ ### Patch Changes
10
+
11
+ - Updated dependencies [5f3a868]
12
+ - @contractspec/module.learning-journey@1.44.0
13
+ - @contractspec/lib.contracts@1.44.0
14
+ - @contractspec/lib.schema@1.44.0
15
+
16
+ ## 1.43.4
17
+
18
+ ### Patch Changes
19
+
20
+ - 9216062: fix: cross-platform compatibility
21
+ - Updated dependencies [9216062]
22
+ - @contractspec/module.learning-journey@1.43.4
23
+ - @contractspec/lib.contracts@1.43.4
24
+ - @contractspec/lib.schema@1.43.3
25
+
26
+ ## 1.43.3
27
+
28
+ ### Patch Changes
29
+
30
+ - 24d9759: improve documentation
31
+ - Updated dependencies [24d9759]
32
+ - @contractspec/module.learning-journey@1.43.3
33
+ - @contractspec/lib.contracts@1.43.3
34
+ - @contractspec/lib.schema@1.43.2
35
+
36
+ ## 1.43.2
37
+
38
+ ### Patch Changes
39
+
40
+ - e147271: fix: improve stability
41
+ - Updated dependencies [e147271]
42
+ - @contractspec/module.learning-journey@1.43.2
43
+ - @contractspec/lib.contracts@1.43.2
44
+ - @contractspec/lib.schema@1.43.1
45
+
46
+ ## 1.43.1
47
+
48
+ ### Patch Changes
49
+
50
+ - Updated dependencies [f28fdad]
51
+ - @contractspec/lib.contracts@1.43.1
52
+ - @contractspec/module.learning-journey@1.43.1
53
+
54
+ ## 1.43.0
55
+
56
+ ### Minor Changes
57
+
58
+ - 042d072: feat: schema declaration using json schema, including zod
59
+
60
+ ### Patch Changes
61
+
62
+ - Updated dependencies [042d072]
63
+ - @contractspec/module.learning-journey@1.43.0
64
+ - @contractspec/lib.contracts@1.43.0
65
+ - @contractspec/lib.schema@1.43.0
66
+
67
+ ## 1.42.10
68
+
69
+ ### Patch Changes
70
+
71
+ - 1e6a0f1: fix: mcp server
72
+ - Updated dependencies [1e6a0f1]
73
+ - @contractspec/module.learning-journey@1.42.10
74
+ - @contractspec/lib.contracts@1.42.10
75
+ - @contractspec/lib.schema@1.42.10
76
+
77
+ ## 1.42.9
78
+
79
+ ### Patch Changes
80
+
81
+ - 9281db7: fix ModelRegistry
82
+ - Updated dependencies [9281db7]
83
+ - @contractspec/module.learning-journey@1.42.9
84
+ - @contractspec/lib.contracts@1.42.9
85
+ - @contractspec/lib.schema@1.42.9
86
+
87
+ ## 1.42.8
88
+
89
+ ### Patch Changes
90
+
91
+ - e07b5ac: fix
92
+ - Updated dependencies [e07b5ac]
93
+ - @contractspec/module.learning-journey@1.42.8
94
+ - @contractspec/lib.contracts@1.42.8
95
+ - @contractspec/lib.schema@1.42.8
96
+
97
+ ## 1.42.7
98
+
99
+ ### Patch Changes
100
+
101
+ - e9b575d: fix release
102
+ - Updated dependencies [e9b575d]
103
+ - @contractspec/module.learning-journey@1.42.7
104
+ - @contractspec/lib.contracts@1.42.7
105
+ - @contractspec/lib.schema@1.42.7
106
+
107
+ ## 1.42.6
108
+
109
+ ### Patch Changes
110
+
111
+ - 1500242: fix tooling
112
+ - Updated dependencies [1500242]
113
+ - @contractspec/module.learning-journey@1.42.6
114
+ - @contractspec/lib.contracts@1.42.6
115
+ - @contractspec/lib.schema@1.42.6
116
+
117
+ ## 1.42.5
118
+
119
+ ### Patch Changes
120
+
121
+ - 1299719: fix vscode
122
+ - Updated dependencies [1299719]
123
+ - @contractspec/module.learning-journey@1.42.5
124
+ - @contractspec/lib.contracts@1.42.5
125
+ - @contractspec/lib.schema@1.42.5
126
+
127
+ ## 1.42.4
128
+
129
+ ### Patch Changes
130
+
131
+ - ac28b99: fix: generate from openapi
132
+ - Updated dependencies [ac28b99]
133
+ - @contractspec/module.learning-journey@1.42.4
134
+ - @contractspec/lib.contracts@1.42.4
135
+ - @contractspec/lib.schema@1.42.4
136
+
137
+ ## 1.42.3
138
+
139
+ ### Patch Changes
140
+
141
+ - 3f5d015: fix(tooling): cicd
142
+ - Updated dependencies [3f5d015]
143
+ - @contractspec/lib.contracts@1.42.3
144
+ - @contractspec/lib.schema@1.42.3
145
+ - @contractspec/module.learning-journey@1.42.3
146
+
147
+ ## 1.42.2
148
+
149
+ ### Patch Changes
150
+
151
+ - 1f9ac4c: fix
152
+ - Updated dependencies [1f9ac4c]
153
+ - @contractspec/lib.contracts@1.42.2
154
+ - @contractspec/lib.schema@1.42.2
155
+ - @contractspec/module.learning-journey@1.42.2
156
+
157
+ ## 1.42.1
158
+
159
+ ### Patch Changes
160
+
161
+ - f043995: Fix release
162
+ - Updated dependencies [f043995]
163
+ - @contractspec/module.learning-journey@1.42.1
164
+ - @contractspec/lib.contracts@1.42.1
165
+ - @contractspec/lib.schema@1.42.1
166
+
167
+ ## 1.42.0
168
+
169
+ ### Minor Changes
170
+
171
+ - 8eefd9c: initial release
172
+
173
+ ### Patch Changes
174
+
175
+ - Updated dependencies [8eefd9c]
176
+ - @contractspec/lib.contracts@1.42.0
177
+ - @contractspec/lib.schema@1.42.0
178
+ - @contractspec/module.learning-journey@1.42.0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 Chaman Ventures, SASU
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,30 @@
1
+ # @contractspec/example.learning-journey-quest-challenges
2
+
3
+ Website: https://contractspec.io/
4
+
5
+
6
+ Time-bound challenge/quest example (7-day money reset) showing day-based unlocks and event-driven completion.
7
+
8
+ ## What it shows
9
+
10
+ - Track steps that unlock by day since quest start
11
+ - Event-based completions for each day
12
+ - XP per day with completion bonus when finished within duration
13
+ - Optional recap via SRS mastery events
14
+
15
+ ## How to run
16
+
17
+ 1. `bun test packages/examples/learning-journey-quest-challenges`
18
+ 2. Emit events in order with `recordEvent` from the registry:
19
+
20
+ ```ts
21
+ recordEvent({ name: 'accounts.mapped', learnerId: 'u1' });
22
+ recordEvent({ name: 'transactions.categorized', learnerId: 'u1' });
23
+ // ...
24
+ ```
25
+
26
+ ## Adapting
27
+
28
+ - Swap events for your vertical (coliving integration week, artisan onboarding).
29
+ - Adjust unlock windows via `availability.unlockOnDay`.
30
+ - Tweak XP/bonus and add recap SRS mastery after completion.
@@ -0,0 +1 @@
1
+ export { };
@@ -0,0 +1 @@
1
+ import "./quest-challenges.docblock.js";
@@ -0,0 +1 @@
1
+ export { };
@@ -0,0 +1,38 @@
1
+ import { registerDocBlocks } from "@contractspec/lib.contracts/docs";
2
+
3
+ //#region src/docs/quest-challenges.docblock.ts
4
+ registerDocBlocks([{
5
+ id: "docs.learning-journey.quest-challenges",
6
+ title: "Learning Journey — Quest Challenges",
7
+ summary: "Time-bound challenge pattern (7-day money reset) with day unlocks and event-driven completion.",
8
+ kind: "reference",
9
+ visibility: "public",
10
+ route: "/docs/learning-journey/quest-challenges",
11
+ tags: [
12
+ "learning",
13
+ "quest",
14
+ "challenge"
15
+ ],
16
+ body: `## Track
17
+ - **Key**: \`money_reset_7day\`
18
+ - **Duration**: 7 days, steps unlock day by day
19
+
20
+ ## Steps & Events
21
+ - Day 1 \`day1_map_accounts\` → event \`accounts.mapped\`
22
+ - Day 2 \`day2_categorize_transactions\` → event \`transactions.categorized\`
23
+ - Day 3 \`day3_define_goals\` → event \`goals.created\`
24
+ - Day 4 \`day4_setup_recurring_savings\` → event \`recurring_rule.created\`
25
+ - Day 5 \`day5_review_subscriptions\` → event \`subscription.flagged_or_cancelled\`
26
+ - Day 6 \`day6_plan_emergency\` → event \`emergency_plan.completed\`
27
+ - Day 7 \`day7_review_commit\` → event \`quest.review.completed\`
28
+
29
+ XP: 15 per day, completion bonus 30 if finished within duration. Optional recap via SRS after completion.
30
+
31
+ ## Usage
32
+ - Exported via \`@contractspec/example.learning-journey-quest-challenges/track\`.
33
+ - Step availability uses \`availability.unlockOnDay\` to gate days.
34
+ - Registry progression handles event matching and XP application.`
35
+ }]);
36
+
37
+ //#endregion
38
+ //# sourceMappingURL=quest-challenges.docblock.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"quest-challenges.docblock.js","names":[],"sources":["../../src/docs/quest-challenges.docblock.ts"],"sourcesContent":["import type { DocBlock } from '@contractspec/lib.contracts/docs';\nimport { registerDocBlocks } from '@contractspec/lib.contracts/docs';\n\nconst questDocBlocks: DocBlock[] = [\n {\n id: 'docs.learning-journey.quest-challenges',\n title: 'Learning Journey — Quest Challenges',\n summary:\n 'Time-bound challenge pattern (7-day money reset) with day unlocks and event-driven completion.',\n kind: 'reference',\n visibility: 'public',\n route: '/docs/learning-journey/quest-challenges',\n tags: ['learning', 'quest', 'challenge'],\n body: `## Track\n- **Key**: \\`money_reset_7day\\`\n- **Duration**: 7 days, steps unlock day by day\n\n## Steps & Events\n- Day 1 \\`day1_map_accounts\\` → event \\`accounts.mapped\\`\n- Day 2 \\`day2_categorize_transactions\\` → event \\`transactions.categorized\\`\n- Day 3 \\`day3_define_goals\\` → event \\`goals.created\\`\n- Day 4 \\`day4_setup_recurring_savings\\` → event \\`recurring_rule.created\\`\n- Day 5 \\`day5_review_subscriptions\\` → event \\`subscription.flagged_or_cancelled\\`\n- Day 6 \\`day6_plan_emergency\\` → event \\`emergency_plan.completed\\`\n- Day 7 \\`day7_review_commit\\` → event \\`quest.review.completed\\`\n\nXP: 15 per day, completion bonus 30 if finished within duration. Optional recap via SRS after completion.\n\n## Usage\n- Exported via \\`@contractspec/example.learning-journey-quest-challenges/track\\`.\n- Step availability uses \\`availability.unlockOnDay\\` to gate days.\n- Registry progression handles event matching and XP application.`,\n },\n];\n\nregisterDocBlocks(questDocBlocks);\n"],"mappings":";;;AAmCA,kBAhCmC,CACjC;CACE,IAAI;CACJ,OAAO;CACP,SACE;CACF,MAAM;CACN,YAAY;CACZ,OAAO;CACP,MAAM;EAAC;EAAY;EAAS;EAAY;CACxC,MAAM;;;;;;;;;;;;;;;;;;;CAmBP,CACF,CAEgC"}
@@ -0,0 +1,33 @@
1
+ //#region src/example.d.ts
2
+ declare const example: {
3
+ readonly id: "learning-journey-quest-challenges";
4
+ readonly title: "Learning Journey — Quest Challenges";
5
+ readonly summary: "Quest/challenge pattern: multi-step goals with progress events, rewards, and streak hooks.";
6
+ readonly tags: readonly ["learning", "quests", "challenges"];
7
+ readonly kind: "template";
8
+ readonly visibility: "public";
9
+ readonly docs: {
10
+ readonly rootDocId: "docs.learning-journey.quest-challenges";
11
+ };
12
+ readonly entrypoints: {
13
+ readonly packageName: "@contractspec/example.learning-journey-quest-challenges";
14
+ readonly docs: "./docs";
15
+ };
16
+ readonly surfaces: {
17
+ readonly templates: true;
18
+ readonly sandbox: {
19
+ readonly enabled: true;
20
+ readonly modes: readonly ["playground", "markdown"];
21
+ };
22
+ readonly studio: {
23
+ readonly enabled: true;
24
+ readonly installable: true;
25
+ };
26
+ readonly mcp: {
27
+ readonly enabled: true;
28
+ };
29
+ };
30
+ };
31
+ //#endregion
32
+ export { example as default };
33
+ //# sourceMappingURL=example.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"example.d.ts","names":[],"sources":["../src/example.ts"],"sourcesContent":[],"mappings":";cAAM;EAAA,SAAA,EAqBI,EAAA,mCAAA"}
@@ -0,0 +1,35 @@
1
+ //#region src/example.ts
2
+ const example = {
3
+ id: "learning-journey-quest-challenges",
4
+ title: "Learning Journey — Quest Challenges",
5
+ summary: "Quest/challenge pattern: multi-step goals with progress events, rewards, and streak hooks.",
6
+ tags: [
7
+ "learning",
8
+ "quests",
9
+ "challenges"
10
+ ],
11
+ kind: "template",
12
+ visibility: "public",
13
+ docs: { rootDocId: "docs.learning-journey.quest-challenges" },
14
+ entrypoints: {
15
+ packageName: "@contractspec/example.learning-journey-quest-challenges",
16
+ docs: "./docs"
17
+ },
18
+ surfaces: {
19
+ templates: true,
20
+ sandbox: {
21
+ enabled: true,
22
+ modes: ["playground", "markdown"]
23
+ },
24
+ studio: {
25
+ enabled: true,
26
+ installable: true
27
+ },
28
+ mcp: { enabled: true }
29
+ }
30
+ };
31
+ var example_default = example;
32
+
33
+ //#endregion
34
+ export { example_default as default };
35
+ //# sourceMappingURL=example.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"example.js","names":[],"sources":["../src/example.ts"],"sourcesContent":["const example = {\n id: 'learning-journey-quest-challenges',\n title: 'Learning Journey — Quest Challenges',\n summary:\n 'Quest/challenge pattern: multi-step goals with progress events, rewards, and streak hooks.',\n tags: ['learning', 'quests', 'challenges'],\n kind: 'template',\n visibility: 'public',\n docs: {\n rootDocId: 'docs.learning-journey.quest-challenges',\n },\n entrypoints: {\n packageName: '@contractspec/example.learning-journey-quest-challenges',\n docs: './docs',\n },\n surfaces: {\n templates: true,\n sandbox: { enabled: true, modes: ['playground', 'markdown'] },\n studio: { enabled: true, installable: true },\n mcp: { enabled: true },\n },\n} as const;\n\nexport default example;\n"],"mappings":";AAAA,MAAM,UAAU;CACd,IAAI;CACJ,OAAO;CACP,SACE;CACF,MAAM;EAAC;EAAY;EAAU;EAAa;CAC1C,MAAM;CACN,YAAY;CACZ,MAAM,EACJ,WAAW,0CACZ;CACD,aAAa;EACX,aAAa;EACb,MAAM;EACP;CACD,UAAU;EACR,WAAW;EACX,SAAS;GAAE,SAAS;GAAM,OAAO,CAAC,cAAc,WAAW;GAAE;EAC7D,QAAQ;GAAE,SAAS;GAAM,aAAa;GAAM;EAC5C,KAAK,EAAE,SAAS,MAAM;EACvB;CACF;AAED,sBAAe"}
@@ -0,0 +1,3 @@
1
+ import example from "./example.js";
2
+ import { moneyResetQuestTrack, questTracks } from "./track.js";
3
+ export { example, moneyResetQuestTrack, questTracks };
package/dist/index.js ADDED
@@ -0,0 +1,5 @@
1
+ import example_default from "./example.js";
2
+ import { moneyResetQuestTrack, questTracks } from "./track.js";
3
+ import "./docs/index.js";
4
+
5
+ export { example_default as example, moneyResetQuestTrack, questTracks };
@@ -0,0 +1,8 @@
1
+ import { LearningJourneyTrackSpec } from "@contractspec/module.learning-journey/track-spec";
2
+
3
+ //#region src/track.d.ts
4
+ declare const moneyResetQuestTrack: LearningJourneyTrackSpec;
5
+ declare const questTracks: LearningJourneyTrackSpec[];
6
+ //#endregion
7
+ export { moneyResetQuestTrack, questTracks };
8
+ //# sourceMappingURL=track.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"track.d.ts","names":[],"sources":["../src/track.ts"],"sourcesContent":[],"mappings":";;;cAqBa,sBAAsB;cAsDtB,aAAa"}
package/dist/track.js ADDED
@@ -0,0 +1,36 @@
1
+ //#region 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 { moneyResetQuestTrack, questTracks };
36
+ //# sourceMappingURL=track.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"track.js","names":["moneyResetQuestTrack: LearningJourneyTrackSpec","questTracks: LearningJourneyTrackSpec[]"],"sources":["../src/track.ts"],"sourcesContent":["import type { LearningJourneyTrackSpec } from '@contractspec/module.learning-journey/track-spec';\n\nconst dayStep = (\n id: string,\n day: number,\n eventName: string,\n description: string\n): LearningJourneyTrackSpec['steps'][number] => ({\n id,\n title: `Day ${day}`,\n description,\n availability: { unlockOnDay: day },\n completion: {\n kind: 'time_window',\n eventName,\n withinHoursOfStart: (day + 1) * 24, // allow grace through next day\n },\n xpReward: 15,\n metadata: { day },\n});\n\nexport const moneyResetQuestTrack: LearningJourneyTrackSpec = {\n id: 'money_reset_7day',\n name: '7-day Money Reset',\n description:\n 'Time-bound quest to reset personal finances over a focused week.',\n targetUserSegment: 'money_user',\n totalXp: 105,\n completionRewards: { xpBonus: 30 },\n steps: [\n dayStep(\n 'day1_map_accounts',\n 1,\n 'accounts.mapped',\n 'Map bank and card accounts.'\n ),\n dayStep(\n 'day2_categorize_transactions',\n 2,\n 'transactions.categorized',\n 'Categorize recent transactions.'\n ),\n dayStep(\n 'day3_define_goals',\n 3,\n 'goals.created',\n 'Define at least one savings goal.'\n ),\n dayStep(\n 'day4_setup_recurring_savings',\n 4,\n 'recurring_rule.created',\n 'Set a recurring savings rule.'\n ),\n dayStep(\n 'day5_review_subscriptions',\n 5,\n 'subscription.flagged_or_cancelled',\n 'Review subscriptions and flag or cancel wasteful ones.'\n ),\n dayStep(\n 'day6_plan_emergency',\n 6,\n 'emergency_plan.completed',\n 'Draft an emergency plan and target buffer.'\n ),\n dayStep(\n 'day7_review_commit',\n 7,\n 'quest.review.completed',\n 'Review week outcomes and commit to the next month.'\n ),\n ],\n};\n\nexport const questTracks: LearningJourneyTrackSpec[] = [moneyResetQuestTrack];\n"],"mappings":";AAEA,MAAM,WACJ,IACA,KACA,WACA,iBAC+C;CAC/C;CACA,OAAO,OAAO;CACd;CACA,cAAc,EAAE,aAAa,KAAK;CAClC,YAAY;EACV,MAAM;EACN;EACA,qBAAqB,MAAM,KAAK;EACjC;CACD,UAAU;CACV,UAAU,EAAE,KAAK;CAClB;AAED,MAAaA,uBAAiD;CAC5D,IAAI;CACJ,MAAM;CACN,aACE;CACF,mBAAmB;CACnB,SAAS;CACT,mBAAmB,EAAE,SAAS,IAAI;CAClC,OAAO;EACL,QACE,qBACA,GACA,mBACA,8BACD;EACD,QACE,gCACA,GACA,4BACA,kCACD;EACD,QACE,qBACA,GACA,iBACA,oCACD;EACD,QACE,gCACA,GACA,0BACA,gCACD;EACD,QACE,6BACA,GACA,qCACA,yDACD;EACD,QACE,uBACA,GACA,4BACA,6CACD;EACD,QACE,sBACA,GACA,0BACA,qDACD;EACF;CACF;AAED,MAAaC,cAA0C,CAAC,qBAAqB"}
package/example.ts ADDED
@@ -0,0 +1 @@
1
+ export { default } from './src/example';
package/package.json ADDED
@@ -0,0 +1,60 @@
1
+ {
2
+ "name": "@contractspec/example.learning-journey-quest-challenges",
3
+ "version": "1.44.0",
4
+ "description": "Time-bound quest/challenge learning journey example.",
5
+ "type": "module",
6
+ "main": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "exports": {
9
+ ".": "./dist/index.js",
10
+ "./docs": "./dist/docs/index.js",
11
+ "./docs/quest-challenges.docblock": "./dist/docs/quest-challenges.docblock.js",
12
+ "./example": "./dist/example.js",
13
+ "./track": "./dist/track.js",
14
+ "./*": "./*"
15
+ },
16
+ "scripts": {
17
+ "publish:pkg": "bun publish --tolerate-republish --ignore-scripts --verbose",
18
+ "publish:pkg:canary": "bun publish:pkg --tag canary",
19
+ "build": "bun build:types && bun build:bundle",
20
+ "build:bundle": "tsdown",
21
+ "build:types": "tsc --noEmit",
22
+ "dev": "bun build:bundle --watch",
23
+ "clean": "rimraf dist .turbo",
24
+ "lint": "bun lint:fix",
25
+ "lint:fix": "eslint src --fix",
26
+ "lint:check": "eslint src",
27
+ "test": "bun test"
28
+ },
29
+ "dependencies": {
30
+ "@contractspec/module.learning-journey": "1.44.0",
31
+ "@contractspec/lib.schema": "1.44.0",
32
+ "@contractspec/lib.contracts": "1.44.0"
33
+ },
34
+ "devDependencies": {
35
+ "@contractspec/tool.tsdown": "1.44.0",
36
+ "@contractspec/tool.typescript": "1.44.0",
37
+ "tsdown": "^0.18.3",
38
+ "typescript": "^5.9.3"
39
+ },
40
+ "module": "./dist/index.js",
41
+ "publishConfig": {
42
+ "exports": {
43
+ ".": "./dist/index.js",
44
+ "./example": "./dist/example.js",
45
+ "./track": "./dist/track.js",
46
+ "./docs": "./dist/docs/index.js",
47
+ "./docs/quest-challenges.docblock": "./dist/docs/quest-challenges.docblock.js",
48
+ "./*": "./*"
49
+ },
50
+ "registry": "https://registry.npmjs.org/",
51
+ "access": "public"
52
+ },
53
+ "license": "MIT",
54
+ "repository": {
55
+ "type": "git",
56
+ "url": "https://github.com/lssm-tech/contractspec.git",
57
+ "directory": "packages/examples/learning-journey-quest-challenges"
58
+ },
59
+ "homepage": "https://contractspec.io"
60
+ }
@@ -0,0 +1 @@
1
+ import './quest-challenges.docblock';
@@ -0,0 +1,36 @@
1
+ import type { DocBlock } from '@contractspec/lib.contracts/docs';
2
+ import { registerDocBlocks } from '@contractspec/lib.contracts/docs';
3
+
4
+ const questDocBlocks: DocBlock[] = [
5
+ {
6
+ id: 'docs.learning-journey.quest-challenges',
7
+ title: 'Learning Journey — Quest Challenges',
8
+ summary:
9
+ 'Time-bound challenge pattern (7-day money reset) with day unlocks and event-driven completion.',
10
+ kind: 'reference',
11
+ visibility: 'public',
12
+ route: '/docs/learning-journey/quest-challenges',
13
+ tags: ['learning', 'quest', 'challenge'],
14
+ body: `## Track
15
+ - **Key**: \`money_reset_7day\`
16
+ - **Duration**: 7 days, steps unlock day by day
17
+
18
+ ## Steps & Events
19
+ - Day 1 \`day1_map_accounts\` → event \`accounts.mapped\`
20
+ - Day 2 \`day2_categorize_transactions\` → event \`transactions.categorized\`
21
+ - Day 3 \`day3_define_goals\` → event \`goals.created\`
22
+ - Day 4 \`day4_setup_recurring_savings\` → event \`recurring_rule.created\`
23
+ - Day 5 \`day5_review_subscriptions\` → event \`subscription.flagged_or_cancelled\`
24
+ - Day 6 \`day6_plan_emergency\` → event \`emergency_plan.completed\`
25
+ - Day 7 \`day7_review_commit\` → event \`quest.review.completed\`
26
+
27
+ XP: 15 per day, completion bonus 30 if finished within duration. Optional recap via SRS after completion.
28
+
29
+ ## Usage
30
+ - Exported via \`@contractspec/example.learning-journey-quest-challenges/track\`.
31
+ - Step availability uses \`availability.unlockOnDay\` to gate days.
32
+ - Registry progression handles event matching and XP application.`,
33
+ },
34
+ ];
35
+
36
+ registerDocBlocks(questDocBlocks);
package/src/example.ts ADDED
@@ -0,0 +1,24 @@
1
+ const example = {
2
+ id: 'learning-journey-quest-challenges',
3
+ title: 'Learning Journey — Quest Challenges',
4
+ summary:
5
+ 'Quest/challenge pattern: multi-step goals with progress events, rewards, and streak hooks.',
6
+ tags: ['learning', 'quests', 'challenges'],
7
+ kind: 'template',
8
+ visibility: 'public',
9
+ docs: {
10
+ rootDocId: 'docs.learning-journey.quest-challenges',
11
+ },
12
+ entrypoints: {
13
+ packageName: '@contractspec/example.learning-journey-quest-challenges',
14
+ docs: './docs',
15
+ },
16
+ surfaces: {
17
+ templates: true,
18
+ sandbox: { enabled: true, modes: ['playground', 'markdown'] },
19
+ studio: { enabled: true, installable: true },
20
+ mcp: { enabled: true },
21
+ },
22
+ } as const;
23
+
24
+ export default example;
package/src/index.ts ADDED
@@ -0,0 +1,3 @@
1
+ export * from './track';
2
+ export { default as example } from './example';
3
+ import './docs';