@lssm/module.learning-journey 0.0.0-canary-20251217062943 → 0.0.0-canary-20251217072406
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/contracts/index.js +6 -1
- package/dist/contracts/models.d.ts +118 -118
- package/dist/contracts/models.js +389 -1
- package/dist/contracts/onboarding.d.ts +168 -168
- package/dist/contracts/onboarding.js +404 -1
- package/dist/contracts/operations.d.ts +71 -71
- package/dist/contracts/operations.js +151 -1
- package/dist/contracts/shared.js +5 -1
- package/dist/docs/index.js +1 -1
- package/dist/docs/learning-journey.docblock.js +61 -5
- package/dist/engines/index.js +5 -1
- package/dist/engines/srs.js +219 -1
- package/dist/engines/streak.js +193 -1
- package/dist/engines/xp.js +212 -1
- package/dist/entities/ai.d.ts +200 -200
- package/dist/entities/ai.js +376 -1
- package/dist/entities/course.d.ts +150 -150
- package/dist/entities/course.js +316 -1
- package/dist/entities/flashcard.d.ts +145 -145
- package/dist/entities/flashcard.js +249 -1
- package/dist/entities/gamification.d.ts +198 -198
- package/dist/entities/gamification.js +392 -1
- package/dist/entities/index.d.ts +605 -605
- package/dist/entities/index.js +44 -1
- package/dist/entities/learner.d.ts +192 -192
- package/dist/entities/learner.js +365 -1
- package/dist/entities/onboarding.d.ts +165 -165
- package/dist/entities/onboarding.js +307 -1
- package/dist/entities/quiz.d.ts +185 -185
- package/dist/entities/quiz.js +370 -1
- package/dist/events.d.ts +213 -213
- package/dist/events.js +583 -1
- package/dist/index.js +22 -1
- package/dist/learning-journey.feature.js +148 -1
- package/dist/libs/contracts/dist/capabilities/openbanking.js +88 -1
- package/dist/libs/contracts/dist/client/index.js +5 -1
- package/dist/libs/contracts/dist/client/react/feature-render.js +2 -1
- package/dist/libs/contracts/dist/client/react/form-render.js +4 -1
- package/dist/libs/contracts/dist/client/react/index.js +4 -1
- package/dist/libs/contracts/dist/contract-registry/index.js +1 -1
- package/dist/libs/contracts/dist/contract-registry/schemas.js +60 -1
- package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +16 -76
- package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +16 -350
- package/dist/libs/contracts/dist/docs/index.js +29 -1
- package/dist/libs/contracts/dist/docs/presentations.js +71 -1
- package/dist/libs/contracts/dist/docs/registry.js +44 -1
- package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +16 -383
- package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +16 -68
- package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +16 -140
- package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +16 -86
- package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +16 -1
- package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +24 -2
- package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +21 -2
- package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +16 -213
- package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +73 -5
- package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +37 -1
- package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +16 -1
- package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +20 -262
- package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +48 -1
- package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +24 -2
- package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +23 -2
- package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +25 -16
- package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +67 -1
- package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +22 -2
- package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +40 -36
- package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +47 -1
- package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +23 -2
- package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +36 -3
- package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +20 -1
- package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +36 -3
- package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +20 -1
- package/dist/libs/contracts/dist/events.js +10 -1
- package/dist/libs/contracts/dist/experiments/evaluator.js +1 -1
- package/dist/libs/contracts/dist/index.js +71 -1
- package/dist/libs/contracts/dist/install.js +2 -1
- package/dist/libs/contracts/dist/integrations/contracts.js +377 -1
- package/dist/libs/contracts/dist/integrations/index.js +18 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/accounts.js +228 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/balances.js +159 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/index.js +3 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/transactions.js +210 -1
- package/dist/libs/contracts/dist/integrations/openbanking/models.js +242 -1
- package/dist/libs/contracts/dist/integrations/openbanking/telemetry.js +13 -1
- package/dist/libs/contracts/dist/integrations/providers/elevenlabs.js +52 -1
- package/dist/libs/contracts/dist/integrations/providers/gcs-storage.js +75 -1
- package/dist/libs/contracts/dist/integrations/providers/gmail.js +87 -1
- package/dist/libs/contracts/dist/integrations/providers/google-calendar.js +66 -1
- package/dist/libs/contracts/dist/integrations/providers/index.js +11 -1
- package/dist/libs/contracts/dist/integrations/providers/mistral.js +68 -1
- package/dist/libs/contracts/dist/integrations/providers/postmark.js +68 -1
- package/dist/libs/contracts/dist/integrations/providers/powens.js +116 -1
- package/dist/libs/contracts/dist/integrations/providers/qdrant.js +73 -1
- package/dist/libs/contracts/dist/integrations/providers/registry.js +10 -1
- package/dist/libs/contracts/dist/integrations/providers/stripe.js +83 -1
- package/dist/libs/contracts/dist/integrations/providers/twilio-sms.js +61 -1
- package/dist/libs/contracts/dist/jsonschema.js +1 -1
- package/dist/libs/contracts/dist/knowledge/contracts.js +306 -1
- package/dist/libs/contracts/dist/knowledge/index.js +7 -1
- package/dist/libs/contracts/dist/knowledge/spaces/email-threads.js +34 -1
- package/dist/libs/contracts/dist/knowledge/spaces/financial-docs.js +34 -1
- package/dist/libs/contracts/dist/knowledge/spaces/financial-overview.js +38 -1
- package/dist/libs/contracts/dist/knowledge/spaces/index.js +6 -1
- package/dist/libs/contracts/dist/knowledge/spaces/product-canon.js +34 -1
- package/dist/libs/contracts/dist/knowledge/spaces/support-faq.js +37 -1
- package/dist/libs/contracts/dist/knowledge/spaces/uploaded-docs.js +34 -1
- package/dist/libs/contracts/dist/llm/exporters.js +19 -1
- package/dist/libs/contracts/dist/llm/index.js +2 -1
- package/dist/libs/contracts/dist/llm/prompts.js +1 -1
- package/dist/libs/contracts/dist/onboarding-base.js +196 -1
- package/dist/libs/contracts/dist/openapi.js +1 -1
- package/dist/libs/contracts/dist/ownership.js +21 -1
- package/dist/libs/contracts/dist/presentations.js +1 -1
- package/dist/libs/contracts/dist/presentations.v2.js +11 -1
- package/dist/libs/contracts/dist/prompt.js +1 -1
- package/dist/libs/contracts/dist/promptRegistry.js +1 -1
- package/dist/libs/contracts/dist/regenerator/index.js +1 -1
- package/dist/libs/contracts/dist/regenerator/service.js +6 -1
- package/dist/libs/contracts/dist/registry.js +2 -1
- package/dist/libs/contracts/dist/resources.js +1 -1
- package/dist/libs/contracts/dist/schema/dist/EnumType.js +2 -1
- package/dist/libs/contracts/dist/schema/dist/FieldType.js +49 -1
- package/dist/libs/contracts/dist/schema/dist/ScalarTypeEnum.js +236 -1
- package/dist/libs/contracts/dist/schema/dist/SchemaModel.js +34 -1
- package/dist/libs/contracts/dist/schema/dist/entity/defineEntity.js +1 -1
- package/dist/libs/contracts/dist/schema/dist/entity/index.js +2 -1
- package/dist/libs/contracts/dist/schema/dist/entity/types.js +1 -1
- package/dist/libs/contracts/dist/schema/dist/index.js +6 -1
- package/dist/libs/contracts/dist/server/graphql-pothos.js +6 -1
- package/dist/libs/contracts/dist/server/index.js +8 -1
- package/dist/libs/contracts/dist/server/mcp/createMcpServer.js +4 -1
- package/dist/libs/contracts/dist/server/mcp/registerPresentations.js +2 -1
- package/dist/libs/contracts/dist/server/mcp/registerPrompts.js +1 -1
- package/dist/libs/contracts/dist/server/mcp/registerResources.js +2 -1
- package/dist/libs/contracts/dist/server/mcp/registerTools.js +1 -1
- package/dist/libs/contracts/dist/server/provider-mcp.js +1 -1
- package/dist/libs/contracts/dist/server/rest-elysia.js +1 -1
- package/dist/libs/contracts/dist/server/rest-express.js +1 -1
- package/dist/libs/contracts/dist/server/rest-generic.js +1 -1
- package/dist/libs/contracts/dist/server/rest-next-app.js +1 -1
- package/dist/libs/contracts/dist/server/rest-next-pages.js +1 -1
- package/dist/libs/contracts/dist/spec.js +34 -1
- package/dist/libs/contracts/dist/telemetry/index.js +1 -1
- package/dist/libs/contracts/dist/telemetry/tracker.js +1 -1
- package/dist/libs/contracts/dist/tests/index.js +1 -1
- package/dist/libs/contracts/dist/tests/runner.js +2 -1
- package/dist/libs/contracts/dist/workflow/index.js +1 -1
- package/dist/libs/contracts/dist/workflow/runner.js +1 -1
- package/dist/libs/schema/dist/EnumType.js +2 -1
- package/dist/libs/schema/dist/FieldType.js +49 -1
- package/dist/libs/schema/dist/ScalarTypeEnum.js +236 -1
- package/dist/libs/schema/dist/SchemaModel.js +39 -1
- package/dist/libs/schema/dist/entity/defineEntity.js +236 -1
- package/dist/libs/schema/dist/entity/index.js +2 -1
- package/dist/libs/schema/dist/entity/types.js +1 -1
- package/dist/libs/schema/dist/index.js +6 -1
- package/package.json +5 -5
package/dist/entities/ai.js
CHANGED
|
@@ -1 +1,376 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import { defineEntity, defineEntityEnum, field, index } from "../libs/schema/dist/entity/defineEntity.js";
|
|
2
|
+
import "../libs/schema/dist/index.js";
|
|
3
|
+
|
|
4
|
+
//#region src/entities/ai.ts
|
|
5
|
+
/**
|
|
6
|
+
* Learning style enum.
|
|
7
|
+
*/
|
|
8
|
+
const LearningStyleEnum = defineEntityEnum({
|
|
9
|
+
name: "LearningStyle",
|
|
10
|
+
values: [
|
|
11
|
+
"VISUAL",
|
|
12
|
+
"AUDITORY",
|
|
13
|
+
"READING",
|
|
14
|
+
"KINESTHETIC",
|
|
15
|
+
"MIXED"
|
|
16
|
+
],
|
|
17
|
+
schema: "lssm_learning",
|
|
18
|
+
description: "Preferred learning style."
|
|
19
|
+
});
|
|
20
|
+
/**
|
|
21
|
+
* Recommendation type enum.
|
|
22
|
+
*/
|
|
23
|
+
const RecommendationTypeEnum = defineEntityEnum({
|
|
24
|
+
name: "RecommendationType",
|
|
25
|
+
values: [
|
|
26
|
+
"COURSE",
|
|
27
|
+
"LESSON",
|
|
28
|
+
"REVIEW",
|
|
29
|
+
"PRACTICE",
|
|
30
|
+
"ASSESSMENT",
|
|
31
|
+
"DECK"
|
|
32
|
+
],
|
|
33
|
+
schema: "lssm_learning",
|
|
34
|
+
description: "Type of learning recommendation."
|
|
35
|
+
});
|
|
36
|
+
/**
|
|
37
|
+
* LearnerProfile entity - AI personalization profile.
|
|
38
|
+
*/
|
|
39
|
+
const LearnerProfileEntity = defineEntity({
|
|
40
|
+
name: "LearnerProfile",
|
|
41
|
+
description: "AI personalization profile for a learner.",
|
|
42
|
+
schema: "lssm_learning",
|
|
43
|
+
map: "learner_profile",
|
|
44
|
+
fields: {
|
|
45
|
+
id: field.id({ description: "Unique profile identifier" }),
|
|
46
|
+
learnerId: field.foreignKey({ description: "Learner" }),
|
|
47
|
+
learningStyle: field.enum("LearningStyle", {
|
|
48
|
+
default: "MIXED",
|
|
49
|
+
description: "Preferred learning style"
|
|
50
|
+
}),
|
|
51
|
+
preferredDifficulty: field.string({
|
|
52
|
+
default: "\"adaptive\"",
|
|
53
|
+
description: "Difficulty preference"
|
|
54
|
+
}),
|
|
55
|
+
preferredSessionLength: field.int({
|
|
56
|
+
default: 30,
|
|
57
|
+
description: "Preferred session length in minutes"
|
|
58
|
+
}),
|
|
59
|
+
interests: field.json({
|
|
60
|
+
isOptional: true,
|
|
61
|
+
description: "Topic interests"
|
|
62
|
+
}),
|
|
63
|
+
goals: field.json({
|
|
64
|
+
isOptional: true,
|
|
65
|
+
description: "Learning goals"
|
|
66
|
+
}),
|
|
67
|
+
pacePreference: field.string({
|
|
68
|
+
default: "\"normal\"",
|
|
69
|
+
description: "Learning pace: slow, normal, fast"
|
|
70
|
+
}),
|
|
71
|
+
bestTimeOfDay: field.string({
|
|
72
|
+
isOptional: true,
|
|
73
|
+
description: "Best time for learning"
|
|
74
|
+
}),
|
|
75
|
+
averageSessionLength: field.int({
|
|
76
|
+
isOptional: true,
|
|
77
|
+
description: "Average session length"
|
|
78
|
+
}),
|
|
79
|
+
daysActivePerWeek: field.int({
|
|
80
|
+
isOptional: true,
|
|
81
|
+
description: "Days active per week"
|
|
82
|
+
}),
|
|
83
|
+
avgQuizScore: field.int({
|
|
84
|
+
isOptional: true,
|
|
85
|
+
description: "Average quiz score"
|
|
86
|
+
}),
|
|
87
|
+
avgLessonCompletionTime: field.int({
|
|
88
|
+
isOptional: true,
|
|
89
|
+
description: "Avg lesson completion time"
|
|
90
|
+
}),
|
|
91
|
+
strengths: field.json({
|
|
92
|
+
isOptional: true,
|
|
93
|
+
description: "Identified strengths"
|
|
94
|
+
}),
|
|
95
|
+
weaknesses: field.json({
|
|
96
|
+
isOptional: true,
|
|
97
|
+
description: "Areas for improvement"
|
|
98
|
+
}),
|
|
99
|
+
lastAnalyzedAt: field.dateTime({
|
|
100
|
+
isOptional: true,
|
|
101
|
+
description: "Last AI analysis"
|
|
102
|
+
}),
|
|
103
|
+
metadata: field.json({
|
|
104
|
+
isOptional: true,
|
|
105
|
+
description: "Additional metadata"
|
|
106
|
+
}),
|
|
107
|
+
createdAt: field.createdAt(),
|
|
108
|
+
updatedAt: field.updatedAt(),
|
|
109
|
+
learner: field.belongsTo("Learner", ["learnerId"], ["id"], { onDelete: "Cascade" })
|
|
110
|
+
},
|
|
111
|
+
indexes: [index.unique(["learnerId"], { name: "learner_profile_unique" }), index.on(["learningStyle"])],
|
|
112
|
+
enums: [LearningStyleEnum]
|
|
113
|
+
});
|
|
114
|
+
/**
|
|
115
|
+
* SkillMap entity - tracks skill proficiency.
|
|
116
|
+
*/
|
|
117
|
+
const SkillMapEntity = defineEntity({
|
|
118
|
+
name: "SkillMap",
|
|
119
|
+
description: "Maps learner proficiency across skills.",
|
|
120
|
+
schema: "lssm_learning",
|
|
121
|
+
map: "skill_map",
|
|
122
|
+
fields: {
|
|
123
|
+
id: field.id({ description: "Unique skill map identifier" }),
|
|
124
|
+
learnerId: field.foreignKey({ description: "Learner" }),
|
|
125
|
+
skillId: field.string({ description: "Skill identifier" }),
|
|
126
|
+
skillName: field.string({ description: "Skill name" }),
|
|
127
|
+
skillCategory: field.string({
|
|
128
|
+
isOptional: true,
|
|
129
|
+
description: "Skill category"
|
|
130
|
+
}),
|
|
131
|
+
level: field.int({
|
|
132
|
+
default: 0,
|
|
133
|
+
description: "Proficiency level (0-100)"
|
|
134
|
+
}),
|
|
135
|
+
confidence: field.decimal({
|
|
136
|
+
default: .5,
|
|
137
|
+
description: "Confidence in assessment"
|
|
138
|
+
}),
|
|
139
|
+
lessonsCompleted: field.int({
|
|
140
|
+
default: 0,
|
|
141
|
+
description: "Related lessons completed"
|
|
142
|
+
}),
|
|
143
|
+
quizzesCompleted: field.int({
|
|
144
|
+
default: 0,
|
|
145
|
+
description: "Related quizzes completed"
|
|
146
|
+
}),
|
|
147
|
+
practiceTime: field.int({
|
|
148
|
+
default: 0,
|
|
149
|
+
description: "Practice time in minutes"
|
|
150
|
+
}),
|
|
151
|
+
lastPracticedAt: field.dateTime({
|
|
152
|
+
isOptional: true,
|
|
153
|
+
description: "Last practice time"
|
|
154
|
+
}),
|
|
155
|
+
learningVelocity: field.decimal({
|
|
156
|
+
isOptional: true,
|
|
157
|
+
description: "Learning speed for this skill"
|
|
158
|
+
}),
|
|
159
|
+
predictedTimeToMastery: field.int({
|
|
160
|
+
isOptional: true,
|
|
161
|
+
description: "Predicted time to mastery (minutes)"
|
|
162
|
+
}),
|
|
163
|
+
createdAt: field.createdAt(),
|
|
164
|
+
updatedAt: field.updatedAt(),
|
|
165
|
+
learner: field.belongsTo("Learner", ["learnerId"], ["id"], { onDelete: "Cascade" })
|
|
166
|
+
},
|
|
167
|
+
indexes: [
|
|
168
|
+
index.unique(["learnerId", "skillId"], { name: "skill_map_unique" }),
|
|
169
|
+
index.on(["skillId", "level"]),
|
|
170
|
+
index.on(["learnerId", "level"])
|
|
171
|
+
]
|
|
172
|
+
});
|
|
173
|
+
/**
|
|
174
|
+
* LearningPath entity - AI-generated learning paths.
|
|
175
|
+
*/
|
|
176
|
+
const LearningPathEntity = defineEntity({
|
|
177
|
+
name: "LearningPath",
|
|
178
|
+
description: "AI-generated personalized learning path.",
|
|
179
|
+
schema: "lssm_learning",
|
|
180
|
+
map: "learning_path",
|
|
181
|
+
fields: {
|
|
182
|
+
id: field.id({ description: "Unique path identifier" }),
|
|
183
|
+
learnerId: field.foreignKey({ description: "Learner" }),
|
|
184
|
+
name: field.string({ description: "Path name" }),
|
|
185
|
+
description: field.string({
|
|
186
|
+
isOptional: true,
|
|
187
|
+
description: "Path description"
|
|
188
|
+
}),
|
|
189
|
+
goal: field.string({
|
|
190
|
+
isOptional: true,
|
|
191
|
+
description: "Path goal"
|
|
192
|
+
}),
|
|
193
|
+
steps: field.json({ description: "Ordered list of learning steps" }),
|
|
194
|
+
currentStepIndex: field.int({
|
|
195
|
+
default: 0,
|
|
196
|
+
description: "Current step index"
|
|
197
|
+
}),
|
|
198
|
+
progress: field.int({
|
|
199
|
+
default: 0,
|
|
200
|
+
description: "Completion percentage"
|
|
201
|
+
}),
|
|
202
|
+
completedSteps: field.int({
|
|
203
|
+
default: 0,
|
|
204
|
+
description: "Steps completed"
|
|
205
|
+
}),
|
|
206
|
+
totalSteps: field.int({
|
|
207
|
+
default: 0,
|
|
208
|
+
description: "Total steps"
|
|
209
|
+
}),
|
|
210
|
+
generatedAt: field.dateTime({ description: "When path was generated" }),
|
|
211
|
+
adaptedFrom: field.string({
|
|
212
|
+
isOptional: true,
|
|
213
|
+
description: "Original path ID if adapted"
|
|
214
|
+
}),
|
|
215
|
+
generationParams: field.json({
|
|
216
|
+
isOptional: true,
|
|
217
|
+
description: "AI generation parameters"
|
|
218
|
+
}),
|
|
219
|
+
adaptationHistory: field.json({
|
|
220
|
+
isOptional: true,
|
|
221
|
+
description: "Path adaptation history"
|
|
222
|
+
}),
|
|
223
|
+
isActive: field.boolean({
|
|
224
|
+
default: true,
|
|
225
|
+
description: "Whether path is active"
|
|
226
|
+
}),
|
|
227
|
+
isCompleted: field.boolean({
|
|
228
|
+
default: false,
|
|
229
|
+
description: "Whether path is completed"
|
|
230
|
+
}),
|
|
231
|
+
startedAt: field.dateTime({
|
|
232
|
+
isOptional: true,
|
|
233
|
+
description: "When started"
|
|
234
|
+
}),
|
|
235
|
+
completedAt: field.dateTime({
|
|
236
|
+
isOptional: true,
|
|
237
|
+
description: "When completed"
|
|
238
|
+
}),
|
|
239
|
+
estimatedCompletionDate: field.dateTime({
|
|
240
|
+
isOptional: true,
|
|
241
|
+
description: "Estimated completion"
|
|
242
|
+
}),
|
|
243
|
+
createdAt: field.createdAt(),
|
|
244
|
+
updatedAt: field.updatedAt(),
|
|
245
|
+
learner: field.belongsTo("Learner", ["learnerId"], ["id"], { onDelete: "Cascade" })
|
|
246
|
+
},
|
|
247
|
+
indexes: [index.on(["learnerId", "isActive"]), index.on(["generatedAt"])]
|
|
248
|
+
});
|
|
249
|
+
/**
|
|
250
|
+
* Recommendation entity - AI-powered learning recommendations.
|
|
251
|
+
*/
|
|
252
|
+
const RecommendationEntity = defineEntity({
|
|
253
|
+
name: "Recommendation",
|
|
254
|
+
description: "AI-powered learning recommendation.",
|
|
255
|
+
schema: "lssm_learning",
|
|
256
|
+
map: "recommendation",
|
|
257
|
+
fields: {
|
|
258
|
+
id: field.id({ description: "Unique recommendation identifier" }),
|
|
259
|
+
learnerId: field.foreignKey({ description: "Learner" }),
|
|
260
|
+
type: field.enum("RecommendationType", { description: "Recommendation type" }),
|
|
261
|
+
itemId: field.string({ description: "Recommended item ID" }),
|
|
262
|
+
itemType: field.string({ description: "Item type (course, lesson, deck, etc.)" }),
|
|
263
|
+
score: field.decimal({ description: "Recommendation score (0-1)" }),
|
|
264
|
+
confidence: field.decimal({ description: "Confidence in recommendation" }),
|
|
265
|
+
reason: field.string({ description: "Human-readable reason" }),
|
|
266
|
+
factors: field.json({
|
|
267
|
+
isOptional: true,
|
|
268
|
+
description: "Factors that contributed to recommendation"
|
|
269
|
+
}),
|
|
270
|
+
status: field.string({
|
|
271
|
+
default: "\"pending\"",
|
|
272
|
+
description: "Status: pending, viewed, accepted, dismissed"
|
|
273
|
+
}),
|
|
274
|
+
viewedAt: field.dateTime({
|
|
275
|
+
isOptional: true,
|
|
276
|
+
description: "When viewed"
|
|
277
|
+
}),
|
|
278
|
+
acceptedAt: field.dateTime({
|
|
279
|
+
isOptional: true,
|
|
280
|
+
description: "When accepted"
|
|
281
|
+
}),
|
|
282
|
+
dismissedAt: field.dateTime({
|
|
283
|
+
isOptional: true,
|
|
284
|
+
description: "When dismissed"
|
|
285
|
+
}),
|
|
286
|
+
feedback: field.string({
|
|
287
|
+
isOptional: true,
|
|
288
|
+
description: "User feedback"
|
|
289
|
+
}),
|
|
290
|
+
feedbackRating: field.int({
|
|
291
|
+
isOptional: true,
|
|
292
|
+
description: "Feedback rating (1-5)"
|
|
293
|
+
}),
|
|
294
|
+
expiresAt: field.dateTime({
|
|
295
|
+
isOptional: true,
|
|
296
|
+
description: "When recommendation expires"
|
|
297
|
+
}),
|
|
298
|
+
createdAt: field.createdAt(),
|
|
299
|
+
updatedAt: field.updatedAt(),
|
|
300
|
+
learner: field.belongsTo("Learner", ["learnerId"], ["id"], { onDelete: "Cascade" })
|
|
301
|
+
},
|
|
302
|
+
indexes: [
|
|
303
|
+
index.on([
|
|
304
|
+
"learnerId",
|
|
305
|
+
"status",
|
|
306
|
+
"score"
|
|
307
|
+
]),
|
|
308
|
+
index.on(["type", "status"]),
|
|
309
|
+
index.on(["expiresAt"])
|
|
310
|
+
],
|
|
311
|
+
enums: [RecommendationTypeEnum]
|
|
312
|
+
});
|
|
313
|
+
/**
|
|
314
|
+
* LearningGap entity - identified knowledge gaps.
|
|
315
|
+
*/
|
|
316
|
+
const LearningGapEntity = defineEntity({
|
|
317
|
+
name: "LearningGap",
|
|
318
|
+
description: "Identified learning gap.",
|
|
319
|
+
schema: "lssm_learning",
|
|
320
|
+
map: "learning_gap",
|
|
321
|
+
fields: {
|
|
322
|
+
id: field.id({ description: "Unique gap identifier" }),
|
|
323
|
+
learnerId: field.foreignKey({ description: "Learner" }),
|
|
324
|
+
skillId: field.string({ description: "Skill with gap" }),
|
|
325
|
+
skillName: field.string({ description: "Skill name" }),
|
|
326
|
+
severity: field.string({
|
|
327
|
+
default: "\"moderate\"",
|
|
328
|
+
description: "Gap severity: minor, moderate, major"
|
|
329
|
+
}),
|
|
330
|
+
confidence: field.decimal({ description: "Confidence in gap detection" }),
|
|
331
|
+
evidence: field.json({
|
|
332
|
+
isOptional: true,
|
|
333
|
+
description: "Evidence for gap"
|
|
334
|
+
}),
|
|
335
|
+
relatedQuestions: field.json({
|
|
336
|
+
isOptional: true,
|
|
337
|
+
description: "Questions that revealed gap"
|
|
338
|
+
}),
|
|
339
|
+
suggestedRemediation: field.json({
|
|
340
|
+
isOptional: true,
|
|
341
|
+
description: "Suggested remediation"
|
|
342
|
+
}),
|
|
343
|
+
remediationProgress: field.int({
|
|
344
|
+
default: 0,
|
|
345
|
+
description: "Remediation progress"
|
|
346
|
+
}),
|
|
347
|
+
status: field.string({
|
|
348
|
+
default: "\"open\"",
|
|
349
|
+
description: "Status: open, in_progress, resolved"
|
|
350
|
+
}),
|
|
351
|
+
resolvedAt: field.dateTime({
|
|
352
|
+
isOptional: true,
|
|
353
|
+
description: "When resolved"
|
|
354
|
+
}),
|
|
355
|
+
detectedAt: field.dateTime({ description: "When gap was detected" }),
|
|
356
|
+
createdAt: field.createdAt(),
|
|
357
|
+
updatedAt: field.updatedAt(),
|
|
358
|
+
learner: field.belongsTo("Learner", ["learnerId"], ["id"], { onDelete: "Cascade" })
|
|
359
|
+
},
|
|
360
|
+
indexes: [
|
|
361
|
+
index.on(["learnerId", "status"]),
|
|
362
|
+
index.on(["skillId", "status"]),
|
|
363
|
+
index.on(["severity", "status"])
|
|
364
|
+
]
|
|
365
|
+
});
|
|
366
|
+
const aiEntities = [
|
|
367
|
+
LearnerProfileEntity,
|
|
368
|
+
SkillMapEntity,
|
|
369
|
+
LearningPathEntity,
|
|
370
|
+
RecommendationEntity,
|
|
371
|
+
LearningGapEntity
|
|
372
|
+
];
|
|
373
|
+
const aiEnums = [LearningStyleEnum, RecommendationTypeEnum];
|
|
374
|
+
|
|
375
|
+
//#endregion
|
|
376
|
+
export { LearnerProfileEntity, LearningGapEntity, LearningPathEntity, LearningStyleEnum, RecommendationEntity, RecommendationTypeEnum, SkillMapEntity, aiEntities, aiEnums };
|