@media-quest/engine 0.0.14 → 0.0.15
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/package.json +1 -2
- package/src/Delement/DElement.dto.ts +5 -0
- package/src/Delement/DElement.ts +78 -253
- package/src/Delement/DImg.ts +31 -70
- package/src/Delement/DStyle.ts +156 -156
- package/src/Delement/DText.ts +9 -25
- package/src/Delement/Ddiv.ts +10 -23
- package/src/Delement/button-click-action.ts +11 -0
- package/src/Delement/element-factory.ts +40 -0
- package/src/engine/DCommand.ts +21 -0
- package/src/engine/SchemaDto.ts +24 -0
- package/src/engine/SchemaEngine.ts +48 -120
- package/src/{player → engine}/dplayer.spec.ts +20 -17
- package/src/{player → engine}/dplayer.ts +29 -16
- package/src/engine/history-que.spec.ts +59 -0
- package/src/engine/history-que.ts +39 -0
- package/src/{player → engine}/next-que.spec.ts +19 -8
- package/src/engine/next-que.ts +93 -0
- package/src/page/Page.ts +160 -0
- package/src/page/media-player.ts +117 -0
- package/src/page/page-component.ts +113 -0
- package/src/page/page-result.ts +11 -0
- package/src/page/task-manager.ts +203 -0
- package/src/page/task-state.ts +55 -0
- package/src/page/task.ts +87 -0
- package/src/public-api.ts +17 -13
- package/src/rules/__test__/rule-engine.spec.ts +1 -1
- package/src/utils/DUtil.ts +110 -103
- package/tsconfig.tsbuildinfo +1 -0
- package/dist/public-api.js +0 -2245
- package/dist/public-api.mjs +0 -2205
- package/src/Delement/AudioContainer.ts +0 -169
- package/src/Delement/DAuto-play.ts +0 -36
- package/src/Delement/VideoContainer.ts +0 -199
- package/src/commands/DCommand.ts +0 -63
- package/src/commands/DCommandBus.ts +0 -60
- package/src/dto/AnimationDto.ts +0 -4
- package/src/dto/DElement.dto.ts +0 -46
- package/src/dto/SchemaDto.ts +0 -65
- package/src/engine/DPage.ts +0 -60
- package/src/engine/element-factory.ts +0 -52
- package/src/event-handlers/DEventHandler.ts +0 -29
- package/src/events/DEvents.ts +0 -94
- package/src/events/event-bus.spec.ts +0 -21
- package/src/events/event-bus.ts +0 -81
- package/src/kladd/context-menu-manager.ts +0 -56
- package/src/player/history-que.spec.ts +0 -46
- package/src/player/history-que.ts +0 -38
- package/src/player/next-que.ts +0 -93
- package/src/services/DMedia-manager.spec.ts +0 -27
- package/src/services/DMedia-manager.ts +0 -179
- package/src/services/resource-provider.ts +0 -33
- package/src/services/sequence-manager.spec.ts +0 -168
- package/src/services/sequence-manager.ts +0 -133
- package/src/state/Dstate.spec.ts +0 -7
- package/src/state/Dstate.ts +0 -105
- package/src/state/boolean-property.ts +0 -69
- package/src/state/state-service.spec.ts +0 -307
- package/src/state/state-service.ts +0 -251
- package/src/state/state-testing-helpers.ts +0 -59
package/dist/public-api.mjs
DELETED
|
@@ -1,2205 +0,0 @@
|
|
|
1
|
-
// src/dto/SchemaDto.ts
|
|
2
|
-
var SchemaDto;
|
|
3
|
-
((SchemaDto2) => {
|
|
4
|
-
SchemaDto2.getResources = (schema) => {
|
|
5
|
-
const { pages } = schema;
|
|
6
|
-
const videoList = pages.reduce((acc, curr) => {
|
|
7
|
-
if (Array.isArray(curr.video)) {
|
|
8
|
-
acc.push(...curr.video);
|
|
9
|
-
}
|
|
10
|
-
return acc;
|
|
11
|
-
}, []);
|
|
12
|
-
const audioList = pages.reduce((acc, curr) => {
|
|
13
|
-
if (Array.isArray(curr.audio)) {
|
|
14
|
-
acc.push(...curr.audio);
|
|
15
|
-
}
|
|
16
|
-
return acc;
|
|
17
|
-
}, []);
|
|
18
|
-
return { videoList, audioList, imageList: [] };
|
|
19
|
-
};
|
|
20
|
-
})(SchemaDto || (SchemaDto = {}));
|
|
21
|
-
|
|
22
|
-
// src/common/DTimestamp.ts
|
|
23
|
-
var DTimestamp;
|
|
24
|
-
((DTimestamp2) => {
|
|
25
|
-
DTimestamp2.now = () => Date.now();
|
|
26
|
-
DTimestamp2.addMills = (t, ms) => {
|
|
27
|
-
const res = t + Math.abs(ms);
|
|
28
|
-
return res;
|
|
29
|
-
};
|
|
30
|
-
DTimestamp2.diff = (t1, t2) => {
|
|
31
|
-
const t1Abs = Math.abs(t1);
|
|
32
|
-
const t2Abs = Math.abs(t2);
|
|
33
|
-
return Math.abs(t1Abs - t2Abs);
|
|
34
|
-
};
|
|
35
|
-
DTimestamp2.diffNow = (t) => {
|
|
36
|
-
return (0, DTimestamp2.diff)(t, (0, DTimestamp2.now)());
|
|
37
|
-
};
|
|
38
|
-
})(DTimestamp || (DTimestamp = {}));
|
|
39
|
-
|
|
40
|
-
// src/utils/DUtil.ts
|
|
41
|
-
var DUtil;
|
|
42
|
-
((DUtil2) => {
|
|
43
|
-
DUtil2.randomString = (length) => {
|
|
44
|
-
const letters = "abcdefghijklmnopqrstuvxyz";
|
|
45
|
-
const uppercase = letters.toUpperCase();
|
|
46
|
-
const all = letters + uppercase;
|
|
47
|
-
const abs = Math.abs(length);
|
|
48
|
-
let result = "";
|
|
49
|
-
for (let i = 0; i < abs; i++) {
|
|
50
|
-
const char = all.charAt(Math.floor(Math.random() * all.length));
|
|
51
|
-
result += char;
|
|
52
|
-
}
|
|
53
|
-
return result;
|
|
54
|
-
};
|
|
55
|
-
DUtil2.randomObjectId = () => (0, DUtil2.randomString)(32);
|
|
56
|
-
DUtil2.deleteProp = (obj, key) => {
|
|
57
|
-
delete obj[key];
|
|
58
|
-
return obj;
|
|
59
|
-
};
|
|
60
|
-
DUtil2.isInRange = (min, max) => {
|
|
61
|
-
return (value) => value >= min && value <= max;
|
|
62
|
-
};
|
|
63
|
-
DUtil2.isInfinity = (number) => {
|
|
64
|
-
return number === Number.POSITIVE_INFINITY || number === Number.NEGATIVE_INFINITY || number === Infinity;
|
|
65
|
-
};
|
|
66
|
-
DUtil2.isNonEmptyArray = (array) => {
|
|
67
|
-
return array.length > 0;
|
|
68
|
-
};
|
|
69
|
-
DUtil2.neverCheck = (args) => {
|
|
70
|
-
console.log("OOPS: This value slipped through the never-check", args);
|
|
71
|
-
};
|
|
72
|
-
DUtil2.isString = (str) => typeof str === "string";
|
|
73
|
-
DUtil2.hasKey = (obj, key) => {
|
|
74
|
-
if (!(0, DUtil2.isRecord)(obj)) {
|
|
75
|
-
return false;
|
|
76
|
-
}
|
|
77
|
-
return Object.prototype.hasOwnProperty.call(obj, key);
|
|
78
|
-
};
|
|
79
|
-
DUtil2.isRecord = (obj) => {
|
|
80
|
-
if (!obj) {
|
|
81
|
-
return false;
|
|
82
|
-
}
|
|
83
|
-
if (Array.isArray(obj)) {
|
|
84
|
-
return false;
|
|
85
|
-
}
|
|
86
|
-
if (typeof obj !== "object") {
|
|
87
|
-
return false;
|
|
88
|
-
}
|
|
89
|
-
if (obj === null) {
|
|
90
|
-
return false;
|
|
91
|
-
}
|
|
92
|
-
return true;
|
|
93
|
-
};
|
|
94
|
-
DUtil2.isBool = (obj) => typeof obj === "boolean";
|
|
95
|
-
DUtil2.isTrue = (bool) => bool === true;
|
|
96
|
-
DUtil2.isFalse = (bool) => bool === false;
|
|
97
|
-
DUtil2.isDefined = (obj) => {
|
|
98
|
-
const notNull = obj !== null;
|
|
99
|
-
const notUndefined = obj !== void 0;
|
|
100
|
-
return notNull && notUndefined;
|
|
101
|
-
};
|
|
102
|
-
DUtil2.hasKind = (obj) => {
|
|
103
|
-
if (!(0, DUtil2.hasKey)(obj, "kind")) {
|
|
104
|
-
return false;
|
|
105
|
-
}
|
|
106
|
-
if (typeof obj.kind !== "string") {
|
|
107
|
-
return false;
|
|
108
|
-
}
|
|
109
|
-
return obj.kind.length > 0;
|
|
110
|
-
};
|
|
111
|
-
DUtil2.hasValue = (obj) => {
|
|
112
|
-
return (0, DUtil2.hasKey)(obj, "value");
|
|
113
|
-
};
|
|
114
|
-
DUtil2.isNumber = (value) => {
|
|
115
|
-
const isNumber2 = typeof value === "number";
|
|
116
|
-
const notNaN = !Number.isNaN(value);
|
|
117
|
-
return isNumber2 && notNaN;
|
|
118
|
-
};
|
|
119
|
-
DUtil2.maxFn = (upperLimit) => {
|
|
120
|
-
return (value) => {
|
|
121
|
-
return Math.min(value, upperLimit);
|
|
122
|
-
};
|
|
123
|
-
};
|
|
124
|
-
DUtil2.minFn = (lowerLimit) => {
|
|
125
|
-
return (value) => {
|
|
126
|
-
return Math.min(value, lowerLimit);
|
|
127
|
-
};
|
|
128
|
-
};
|
|
129
|
-
})(DUtil || (DUtil = {}));
|
|
130
|
-
|
|
131
|
-
// src/Delement/css.ts
|
|
132
|
-
var DCss;
|
|
133
|
-
((DCss2) => {
|
|
134
|
-
DCss2.toString = (unit, scale) => {
|
|
135
|
-
const clampedScale = Math.max(scale, 0.03);
|
|
136
|
-
if (unit._unit === "px") {
|
|
137
|
-
if (unit.value < 0.1) {
|
|
138
|
-
return "0px";
|
|
139
|
-
}
|
|
140
|
-
const rounded = Math.round(unit.value * clampedScale);
|
|
141
|
-
const clamped = Math.max(rounded, 1);
|
|
142
|
-
return clamped + "px";
|
|
143
|
-
}
|
|
144
|
-
return unit.value + "%";
|
|
145
|
-
};
|
|
146
|
-
DCss2.isLengthUnit = (unit) => {
|
|
147
|
-
if (!unit) {
|
|
148
|
-
return false;
|
|
149
|
-
}
|
|
150
|
-
const unitKey = "_unit";
|
|
151
|
-
const valueKey = "value";
|
|
152
|
-
const hasUnitKey = DUtil.hasKey(unit, unitKey);
|
|
153
|
-
const hasValueKey = DUtil.hasKey(unit, valueKey);
|
|
154
|
-
return hasUnitKey && hasValueKey;
|
|
155
|
-
};
|
|
156
|
-
})(DCss || (DCss = {}));
|
|
157
|
-
|
|
158
|
-
// src/Delement/DStyle.ts
|
|
159
|
-
var DStyle;
|
|
160
|
-
((DStyle2) => {
|
|
161
|
-
DStyle2.normalize = (el) => {
|
|
162
|
-
el.style.padding = "0";
|
|
163
|
-
el.style.margin = "0";
|
|
164
|
-
el.style.position = "absolute";
|
|
165
|
-
el.style.boxSizing = "border-box";
|
|
166
|
-
return el;
|
|
167
|
-
};
|
|
168
|
-
DStyle2.applyStyles = (el, style, scale) => {
|
|
169
|
-
const {
|
|
170
|
-
x,
|
|
171
|
-
y,
|
|
172
|
-
backgroundColor,
|
|
173
|
-
borderColor,
|
|
174
|
-
borderWidth,
|
|
175
|
-
borderRadius,
|
|
176
|
-
borderStyle,
|
|
177
|
-
w,
|
|
178
|
-
opacity,
|
|
179
|
-
cursor,
|
|
180
|
-
fontSize,
|
|
181
|
-
fontWeight,
|
|
182
|
-
textColor,
|
|
183
|
-
textAlign,
|
|
184
|
-
translate,
|
|
185
|
-
margin,
|
|
186
|
-
padding,
|
|
187
|
-
letterSpacing,
|
|
188
|
-
h,
|
|
189
|
-
transform,
|
|
190
|
-
visibility
|
|
191
|
-
} = style;
|
|
192
|
-
if (backgroundColor) {
|
|
193
|
-
el.style.backgroundColor = backgroundColor;
|
|
194
|
-
}
|
|
195
|
-
if (cursor) {
|
|
196
|
-
el.style.cursor = cursor;
|
|
197
|
-
}
|
|
198
|
-
if (transform) {
|
|
199
|
-
el.style.transform = transform;
|
|
200
|
-
}
|
|
201
|
-
if (textColor) {
|
|
202
|
-
el.style.color = textColor;
|
|
203
|
-
}
|
|
204
|
-
if (textAlign) {
|
|
205
|
-
el.style.textAlign = textAlign;
|
|
206
|
-
}
|
|
207
|
-
if (borderColor) {
|
|
208
|
-
el.style.borderColor = borderColor;
|
|
209
|
-
}
|
|
210
|
-
if (borderWidth) {
|
|
211
|
-
el.style.borderWidth = DCss.toString(borderWidth, scale);
|
|
212
|
-
}
|
|
213
|
-
if (fontWeight) {
|
|
214
|
-
el.style.fontWeight = fontWeight + "";
|
|
215
|
-
}
|
|
216
|
-
if (borderStyle) {
|
|
217
|
-
el.style.borderStyle = borderStyle;
|
|
218
|
-
}
|
|
219
|
-
if (fontSize) {
|
|
220
|
-
el.style.fontSize = DCss.toString(fontSize, scale);
|
|
221
|
-
}
|
|
222
|
-
if (DUtil.isNumber(x)) {
|
|
223
|
-
el.style.left = x + "%";
|
|
224
|
-
}
|
|
225
|
-
if (DUtil.isNumber(y)) {
|
|
226
|
-
el.style.bottom = y + "%";
|
|
227
|
-
}
|
|
228
|
-
if (DUtil.isNumber(h)) {
|
|
229
|
-
el.style.height = h + "%";
|
|
230
|
-
}
|
|
231
|
-
if (DUtil.isNumber(w)) {
|
|
232
|
-
el.style.width = w + "%";
|
|
233
|
-
}
|
|
234
|
-
if (DCss.isLengthUnit(borderRadius)) {
|
|
235
|
-
el.style.borderRadius = DCss.toString(borderRadius, scale);
|
|
236
|
-
}
|
|
237
|
-
if (letterSpacing) {
|
|
238
|
-
el.style.letterSpacing = DCss.toString(letterSpacing, scale);
|
|
239
|
-
}
|
|
240
|
-
if (margin) {
|
|
241
|
-
el.style.margin = DCss.toString(margin, scale);
|
|
242
|
-
}
|
|
243
|
-
if (padding) {
|
|
244
|
-
el.style.padding = DCss.toString(padding, scale);
|
|
245
|
-
}
|
|
246
|
-
if (DUtil.isNumber(opacity)) {
|
|
247
|
-
el.style.opacity = opacity + "";
|
|
248
|
-
}
|
|
249
|
-
if (visibility) {
|
|
250
|
-
el.style.visibility = visibility;
|
|
251
|
-
}
|
|
252
|
-
return el;
|
|
253
|
-
};
|
|
254
|
-
})(DStyle || (DStyle = {}));
|
|
255
|
-
|
|
256
|
-
// src/Delement/VideoContainer.ts
|
|
257
|
-
var ABORT_PLAY_TO_END = "ABORT_PLAY_TO_END";
|
|
258
|
-
var VideoContainer = class {
|
|
259
|
-
constructor(el, eventBus, scale) {
|
|
260
|
-
this.el = el;
|
|
261
|
-
this.eventBus = eventBus;
|
|
262
|
-
this.scale = scale;
|
|
263
|
-
this.TAG = "[ D_Video ] : ";
|
|
264
|
-
this.el.controls = false;
|
|
265
|
-
DStyle.normalize(this.el);
|
|
266
|
-
DStyle.applyStyles(this.el, this.defaultStyles, this.scale.scale);
|
|
267
|
-
this.el.onended = () => {
|
|
268
|
-
this.eventBus.emit({
|
|
269
|
-
kind: "VIDEO_ENDED_EVENT",
|
|
270
|
-
timestamp: DTimestamp.now(),
|
|
271
|
-
producer: "DVideo",
|
|
272
|
-
producerId: this.id,
|
|
273
|
-
data: {}
|
|
274
|
-
});
|
|
275
|
-
};
|
|
276
|
-
this.el.onplay = () => {
|
|
277
|
-
};
|
|
278
|
-
this.el.onpause = () => {
|
|
279
|
-
};
|
|
280
|
-
this.el.onerror = () => {
|
|
281
|
-
};
|
|
282
|
-
this.el.oncanplay = () => {
|
|
283
|
-
};
|
|
284
|
-
this.el.onloadedmetadata = () => {
|
|
285
|
-
const duration = this.el.duration;
|
|
286
|
-
const isInfinity = DUtil.isInfinity(duration);
|
|
287
|
-
this.eventBus.emit({
|
|
288
|
-
kind: "VIDEO_LOADED_METADATA_EVENT",
|
|
289
|
-
timestamp: DTimestamp.now(),
|
|
290
|
-
producer: "DVideo",
|
|
291
|
-
producerId: this.id,
|
|
292
|
-
data: { duration, isInfinity }
|
|
293
|
-
});
|
|
294
|
-
};
|
|
295
|
-
this.el.ondurationchange = () => {
|
|
296
|
-
const duration = this.el.duration;
|
|
297
|
-
const isInfinity = DUtil.isInfinity(duration);
|
|
298
|
-
this.eventBus.emit({
|
|
299
|
-
kind: "VIDEO_DURATION_CHANGE_EVENT",
|
|
300
|
-
producer: "DVideo",
|
|
301
|
-
producerId: this.id,
|
|
302
|
-
timestamp: DTimestamp.now(),
|
|
303
|
-
data: { duration, isInfinity }
|
|
304
|
-
});
|
|
305
|
-
};
|
|
306
|
-
}
|
|
307
|
-
TAG;
|
|
308
|
-
dto;
|
|
309
|
-
defaultStyles = { h: 45, w: 100, visibility: "hidden", y: 55 };
|
|
310
|
-
pause() {
|
|
311
|
-
this.eventBus.emit({
|
|
312
|
-
kind: "VIDEO_PAUSED_EVENT",
|
|
313
|
-
data: {},
|
|
314
|
-
producer: "DVideo",
|
|
315
|
-
producerId: this.id,
|
|
316
|
-
timestamp: DTimestamp.now()
|
|
317
|
-
});
|
|
318
|
-
this.el.pause();
|
|
319
|
-
}
|
|
320
|
-
play(url) {
|
|
321
|
-
if (this.el.src !== url) {
|
|
322
|
-
this.el.src = url;
|
|
323
|
-
}
|
|
324
|
-
const producerId = this.dto?.id ?? "DVideo";
|
|
325
|
-
this.eventBus.emit({
|
|
326
|
-
kind: "VIDEO_PLAY_EVENT",
|
|
327
|
-
data: {},
|
|
328
|
-
producer: "DVideo",
|
|
329
|
-
producerId,
|
|
330
|
-
timestamp: DTimestamp.now()
|
|
331
|
-
});
|
|
332
|
-
this.el.play().then((res) => {
|
|
333
|
-
console.log(res);
|
|
334
|
-
}).catch((e) => {
|
|
335
|
-
console.log(e);
|
|
336
|
-
});
|
|
337
|
-
}
|
|
338
|
-
async playToEnd() {
|
|
339
|
-
this.el.volume = 1;
|
|
340
|
-
const url = this.dto?.url;
|
|
341
|
-
if (!url) {
|
|
342
|
-
return false;
|
|
343
|
-
}
|
|
344
|
-
try {
|
|
345
|
-
const endedOrErrored = new Promise((resolve, reject) => {
|
|
346
|
-
this.el.addEventListener(
|
|
347
|
-
"ended",
|
|
348
|
-
(_) => {
|
|
349
|
-
resolve(true);
|
|
350
|
-
},
|
|
351
|
-
{ once: true }
|
|
352
|
-
);
|
|
353
|
-
this.el.addEventListener(
|
|
354
|
-
"error",
|
|
355
|
-
(_) => {
|
|
356
|
-
resolve(false);
|
|
357
|
-
},
|
|
358
|
-
{ once: true }
|
|
359
|
-
);
|
|
360
|
-
this.el.addEventListener(
|
|
361
|
-
ABORT_PLAY_TO_END,
|
|
362
|
-
() => {
|
|
363
|
-
console.log("CATCHED ABBORT.");
|
|
364
|
-
reject("Aborted");
|
|
365
|
-
},
|
|
366
|
-
{ once: true }
|
|
367
|
-
);
|
|
368
|
-
});
|
|
369
|
-
this.play(url);
|
|
370
|
-
await endedOrErrored;
|
|
371
|
-
return true;
|
|
372
|
-
} catch (e) {
|
|
373
|
-
console.log(e);
|
|
374
|
-
return false;
|
|
375
|
-
} finally {
|
|
376
|
-
console.log(this.TAG + " finally block playToEnd() completed videoId: " + this.dto?.id);
|
|
377
|
-
}
|
|
378
|
-
}
|
|
379
|
-
getStats() {
|
|
380
|
-
const duration = this.el.duration;
|
|
381
|
-
const currentTime = this.el.currentTime;
|
|
382
|
-
const volume = this.el.volume;
|
|
383
|
-
const isConnected = this.el.isConnected;
|
|
384
|
-
const playbackQuality = this.el.getVideoPlaybackQuality();
|
|
385
|
-
const defaultPlaybackRate = this.el.defaultPlaybackRate;
|
|
386
|
-
const paused = this.el.paused;
|
|
387
|
-
const played = this.el.played;
|
|
388
|
-
return {
|
|
389
|
-
duration,
|
|
390
|
-
paused,
|
|
391
|
-
played,
|
|
392
|
-
currentTime,
|
|
393
|
-
volume,
|
|
394
|
-
isConnected,
|
|
395
|
-
playbackQuality,
|
|
396
|
-
defaultPlaybackRate
|
|
397
|
-
};
|
|
398
|
-
}
|
|
399
|
-
setDto(dto) {
|
|
400
|
-
this.dto = dto;
|
|
401
|
-
this.el.volume = 1;
|
|
402
|
-
this.setStyle(dto.style);
|
|
403
|
-
this.el.src = dto.url;
|
|
404
|
-
this.el.load();
|
|
405
|
-
}
|
|
406
|
-
getCurrentDto() {
|
|
407
|
-
return this.dto ?? false;
|
|
408
|
-
}
|
|
409
|
-
setStyle(styles) {
|
|
410
|
-
DStyle.applyStyles(this.el, styles, this.scale.scale);
|
|
411
|
-
}
|
|
412
|
-
get id() {
|
|
413
|
-
return this.dto?.id ?? "DVideo";
|
|
414
|
-
}
|
|
415
|
-
destroy() {
|
|
416
|
-
}
|
|
417
|
-
};
|
|
418
|
-
|
|
419
|
-
// src/Delement/AudioContainer.ts
|
|
420
|
-
var AudioContainer = class {
|
|
421
|
-
constructor(eventBus) {
|
|
422
|
-
this.eventBus = eventBus;
|
|
423
|
-
this.el = document.createElement("audio");
|
|
424
|
-
this.el.style.position = "absolute";
|
|
425
|
-
this.el.style.visibility = "hidden";
|
|
426
|
-
this.onLoad = this.onLoad.bind(this);
|
|
427
|
-
this.el.onload = this.onLoad;
|
|
428
|
-
this.onLoadedMetadata = this.onLoadedMetadata.bind(this);
|
|
429
|
-
this.el.onloadedmetadata = this.onLoadedMetadata;
|
|
430
|
-
this.el.onplay = () => {
|
|
431
|
-
};
|
|
432
|
-
this.onCanPlayThrough = this.onCanPlayThrough.bind(this);
|
|
433
|
-
this.el.oncanplaythrough = this.onCanPlayThrough;
|
|
434
|
-
this.el.onended = (_) => {
|
|
435
|
-
const url = this.el.src;
|
|
436
|
-
this.eventBus.emit({
|
|
437
|
-
kind: "AUDIO_ENDED_EVENT",
|
|
438
|
-
data: { url },
|
|
439
|
-
producer: "DAudio",
|
|
440
|
-
timestamp: DTimestamp.now(),
|
|
441
|
-
producerId: this.id
|
|
442
|
-
});
|
|
443
|
-
};
|
|
444
|
-
this.el.ondurationchange = (_) => {
|
|
445
|
-
const duration = this.el.duration;
|
|
446
|
-
const isInfinity = duration === Number.POSITIVE_INFINITY;
|
|
447
|
-
this.eventBus.emit({
|
|
448
|
-
kind: "AUDIO_DURATION_CHANGE_EVENT",
|
|
449
|
-
timestamp: DTimestamp.now(),
|
|
450
|
-
producer: "DAudio",
|
|
451
|
-
producerId: this.id,
|
|
452
|
-
data: { duration: this.el.duration, isInfinity }
|
|
453
|
-
});
|
|
454
|
-
};
|
|
455
|
-
}
|
|
456
|
-
TAG = "[ DAudio ]: ";
|
|
457
|
-
dto = null;
|
|
458
|
-
el;
|
|
459
|
-
setAudio(dto) {
|
|
460
|
-
this.dto = dto;
|
|
461
|
-
this.el.src = dto.url;
|
|
462
|
-
this.el.load();
|
|
463
|
-
}
|
|
464
|
-
destroy() {
|
|
465
|
-
try {
|
|
466
|
-
this.el.pause();
|
|
467
|
-
this.el.src = "";
|
|
468
|
-
this.el.load();
|
|
469
|
-
} catch (e) {
|
|
470
|
-
console.log(e);
|
|
471
|
-
}
|
|
472
|
-
}
|
|
473
|
-
pause() {
|
|
474
|
-
try {
|
|
475
|
-
this.el.pause();
|
|
476
|
-
} catch (e) {
|
|
477
|
-
console.log(e);
|
|
478
|
-
}
|
|
479
|
-
}
|
|
480
|
-
play(url) {
|
|
481
|
-
if (this.el.src !== url) {
|
|
482
|
-
this.el.src = url;
|
|
483
|
-
}
|
|
484
|
-
this.eventBus.emit({
|
|
485
|
-
kind: "AUDIO_PLAY_EVENT",
|
|
486
|
-
producerId: this.id,
|
|
487
|
-
data: {},
|
|
488
|
-
producer: "DAudio",
|
|
489
|
-
timestamp: DTimestamp.now()
|
|
490
|
-
});
|
|
491
|
-
this.el.play().then((res) => {
|
|
492
|
-
console.log(res);
|
|
493
|
-
}).catch((e) => {
|
|
494
|
-
console.log(e);
|
|
495
|
-
});
|
|
496
|
-
}
|
|
497
|
-
onLoadedMetadata(_) {
|
|
498
|
-
this.eventBus.emit({
|
|
499
|
-
kind: "AUDIO_METADATA_LOADED_EVENT",
|
|
500
|
-
timestamp: DTimestamp.now(),
|
|
501
|
-
producer: "DAudio",
|
|
502
|
-
producerId: this.id,
|
|
503
|
-
data: {}
|
|
504
|
-
});
|
|
505
|
-
}
|
|
506
|
-
onLoad(_) {
|
|
507
|
-
this.eventBus.emit({
|
|
508
|
-
kind: "AUDIO_LOAD_EVENT",
|
|
509
|
-
timestamp: DTimestamp.now(),
|
|
510
|
-
producer: "DAudio",
|
|
511
|
-
producerId: this.id,
|
|
512
|
-
data: {}
|
|
513
|
-
});
|
|
514
|
-
}
|
|
515
|
-
get id() {
|
|
516
|
-
return this.dto?.id ?? "DAudio";
|
|
517
|
-
}
|
|
518
|
-
onCanPlayThrough(_) {
|
|
519
|
-
this.eventBus.emit({
|
|
520
|
-
kind: "AUDIO_CAN_PLAY_THROUGH_EVENT",
|
|
521
|
-
data: {},
|
|
522
|
-
producer: "DAudio",
|
|
523
|
-
timestamp: DTimestamp.now(),
|
|
524
|
-
producerId: this.id
|
|
525
|
-
});
|
|
526
|
-
}
|
|
527
|
-
// private onPlay(_: Event) {}
|
|
528
|
-
async playToEnd() {
|
|
529
|
-
const endedOrErrored = new Promise((resolve) => {
|
|
530
|
-
this.el.addEventListener(
|
|
531
|
-
"ended",
|
|
532
|
-
(_) => {
|
|
533
|
-
resolve(true);
|
|
534
|
-
},
|
|
535
|
-
{ once: true }
|
|
536
|
-
);
|
|
537
|
-
this.el.addEventListener(
|
|
538
|
-
"error",
|
|
539
|
-
(_) => {
|
|
540
|
-
resolve(false);
|
|
541
|
-
},
|
|
542
|
-
{ once: true }
|
|
543
|
-
);
|
|
544
|
-
});
|
|
545
|
-
try {
|
|
546
|
-
this.play(this.el.src);
|
|
547
|
-
await endedOrErrored;
|
|
548
|
-
return true;
|
|
549
|
-
} catch (e) {
|
|
550
|
-
console.log(e);
|
|
551
|
-
this.eventBus.emit({
|
|
552
|
-
kind: "AUDIO_ERROR_EVENT",
|
|
553
|
-
timestamp: DTimestamp.now(),
|
|
554
|
-
producer: "DAudio",
|
|
555
|
-
producerId: this.id,
|
|
556
|
-
data: { error: e }
|
|
557
|
-
});
|
|
558
|
-
return false;
|
|
559
|
-
} finally {
|
|
560
|
-
}
|
|
561
|
-
return Promise.resolve(false);
|
|
562
|
-
}
|
|
563
|
-
};
|
|
564
|
-
|
|
565
|
-
// src/services/DMedia-manager.ts
|
|
566
|
-
var DMediaManager = class _DMediaManager {
|
|
567
|
-
constructor(hostEl, commandBus, eventBus, resourceProvider, scale) {
|
|
568
|
-
this.hostEl = hostEl;
|
|
569
|
-
this.commandBus = commandBus;
|
|
570
|
-
this.eventBus = eventBus;
|
|
571
|
-
this.resourceProvider = resourceProvider;
|
|
572
|
-
this.scale = scale;
|
|
573
|
-
_DMediaManager.INSTANCE_COUNT = _DMediaManager.INSTANCE_COUNT + 1;
|
|
574
|
-
this.instanceNumber = _DMediaManager.INSTANCE_COUNT;
|
|
575
|
-
const videoEl = document.createElement("video");
|
|
576
|
-
this.hostEl.append(videoEl);
|
|
577
|
-
this.videoContainer = new VideoContainer(videoEl, eventBus, this.scale);
|
|
578
|
-
this.audioContainer = new AudioContainer(this.eventBus);
|
|
579
|
-
this.tick = this.tick.bind(this);
|
|
580
|
-
this.videoContainer.setStyle({ visibility: "hidden" });
|
|
581
|
-
const now = DTimestamp.now();
|
|
582
|
-
this.pageEnter = now;
|
|
583
|
-
this.sincePageEnter = DTimestamp.diff(now, now);
|
|
584
|
-
this.unsubscribeCommands = this.commandBus.subscribe((action) => {
|
|
585
|
-
this.commandHandler(action);
|
|
586
|
-
}, this.TAG);
|
|
587
|
-
this.tickerRef = window.setInterval(() => {
|
|
588
|
-
}, 1e3);
|
|
589
|
-
}
|
|
590
|
-
static INSTANCE_COUNT = 0;
|
|
591
|
-
instanceNumber;
|
|
592
|
-
TAG = "[ MEDIA_MANAGER ] : ";
|
|
593
|
-
videoContainer;
|
|
594
|
-
audioContainer;
|
|
595
|
-
pageEnter;
|
|
596
|
-
sincePageEnter;
|
|
597
|
-
currentPage = null;
|
|
598
|
-
unsubscribeCommands;
|
|
599
|
-
tickerRef;
|
|
600
|
-
sequenceManager = false;
|
|
601
|
-
/**
|
|
602
|
-
* Stop all media that is playing
|
|
603
|
-
*/
|
|
604
|
-
clearAllMedia() {
|
|
605
|
-
this.videoContainer.pause();
|
|
606
|
-
this.audioContainer.pause();
|
|
607
|
-
}
|
|
608
|
-
destroy() {
|
|
609
|
-
console.log("TODO DESTROY ALL MEDIA");
|
|
610
|
-
this.unsubscribeCommands();
|
|
611
|
-
window.clearInterval(this.tickerRef);
|
|
612
|
-
this.audioContainer.destroy();
|
|
613
|
-
this.videoContainer.destroy();
|
|
614
|
-
}
|
|
615
|
-
setPage(page) {
|
|
616
|
-
this.currentPage = page;
|
|
617
|
-
this.videoContainer.pause();
|
|
618
|
-
this.pageEnter = DTimestamp.now();
|
|
619
|
-
const seq = page.autoPlaySequence;
|
|
620
|
-
const { mainVideoId, audio } = page;
|
|
621
|
-
const audioElements = page.audio;
|
|
622
|
-
if (mainVideoId) {
|
|
623
|
-
const dto = this.resourceProvider.getVideoById(mainVideoId);
|
|
624
|
-
if (dto) {
|
|
625
|
-
this.videoContainer.setDto(dto);
|
|
626
|
-
this.videoContainer.setStyle({ ...dto.style, visibility: "visible" });
|
|
627
|
-
}
|
|
628
|
-
} else {
|
|
629
|
-
this.videoContainer.setStyle({ visibility: "hidden" });
|
|
630
|
-
}
|
|
631
|
-
if (audioElements) {
|
|
632
|
-
const first = audioElements[0];
|
|
633
|
-
if (first) {
|
|
634
|
-
this.audioContainer.setAudio(first);
|
|
635
|
-
}
|
|
636
|
-
}
|
|
637
|
-
if (seq) {
|
|
638
|
-
this.playSequence(seq);
|
|
639
|
-
}
|
|
640
|
-
}
|
|
641
|
-
commandHandler(command) {
|
|
642
|
-
if (command.kind === "VIDEO_PLAY_COMMAND") {
|
|
643
|
-
const video = command.targetId;
|
|
644
|
-
const dto = this.videoContainer.getCurrentDto();
|
|
645
|
-
if (dto && dto.id === command.targetId) {
|
|
646
|
-
console.log(video);
|
|
647
|
-
this.videoContainer.play(dto.url);
|
|
648
|
-
}
|
|
649
|
-
}
|
|
650
|
-
if (command.kind === "VIDEO_PAUSE_COMMAND") {
|
|
651
|
-
this.videoContainer.pause();
|
|
652
|
-
}
|
|
653
|
-
if (command.kind === "AUDIO_PLAY_COMMAND") {
|
|
654
|
-
this.audioContainer.playToEnd().then(() => {
|
|
655
|
-
}).catch().finally(() => {
|
|
656
|
-
});
|
|
657
|
-
}
|
|
658
|
-
if (command.kind === "AUDIO_PAUSE_COMMAND") {
|
|
659
|
-
}
|
|
660
|
-
}
|
|
661
|
-
async playSequence(seq) {
|
|
662
|
-
const elements = seq.items;
|
|
663
|
-
const testClone = [...elements];
|
|
664
|
-
const first = testClone.pop();
|
|
665
|
-
if (!first) {
|
|
666
|
-
return false;
|
|
667
|
-
}
|
|
668
|
-
const now = DTimestamp.now();
|
|
669
|
-
seq.startCommands.forEach((c) => {
|
|
670
|
-
console.log(c);
|
|
671
|
-
this.commandBus.emit(c);
|
|
672
|
-
});
|
|
673
|
-
for (let i = 0; i < elements.length; i++) {
|
|
674
|
-
const item = elements[i];
|
|
675
|
-
if (item.kind === "autoplay-video") {
|
|
676
|
-
const dto = this.resourceProvider.getVideoById(item.videoId);
|
|
677
|
-
if (dto)
|
|
678
|
-
this.videoContainer.setDto(dto);
|
|
679
|
-
await this.videoContainer.playToEnd();
|
|
680
|
-
}
|
|
681
|
-
if (item.kind === "autoplay-audio") {
|
|
682
|
-
console.log(item);
|
|
683
|
-
const dto = this.resourceProvider.getAudioById(item.audioId);
|
|
684
|
-
if (dto)
|
|
685
|
-
this.audioContainer.setAudio(dto);
|
|
686
|
-
await this.audioContainer.playToEnd();
|
|
687
|
-
}
|
|
688
|
-
}
|
|
689
|
-
seq.endCommands.forEach((c) => {
|
|
690
|
-
this.commandBus.emit(c);
|
|
691
|
-
});
|
|
692
|
-
console.log(this.TAG + "SEQUENCE ENDED");
|
|
693
|
-
return true;
|
|
694
|
-
}
|
|
695
|
-
// setPage()
|
|
696
|
-
tick() {
|
|
697
|
-
}
|
|
698
|
-
};
|
|
699
|
-
|
|
700
|
-
// src/commands/DCommandBus.ts
|
|
701
|
-
var DCommandBus = class {
|
|
702
|
-
TAG = "[ COMMAND_BUS ] ";
|
|
703
|
-
logCommands = false;
|
|
704
|
-
commandLog = [];
|
|
705
|
-
subscribers = /* @__PURE__ */ new Set();
|
|
706
|
-
// readonly sub
|
|
707
|
-
subscribe(cb, subscriberId) {
|
|
708
|
-
const sub = {
|
|
709
|
-
subscriberId,
|
|
710
|
-
callback: cb
|
|
711
|
-
};
|
|
712
|
-
this.subscribers.add(sub);
|
|
713
|
-
return () => {
|
|
714
|
-
this.subscribers.delete(sub);
|
|
715
|
-
};
|
|
716
|
-
}
|
|
717
|
-
emit(command) {
|
|
718
|
-
const timestamp = DTimestamp.now();
|
|
719
|
-
this.commandLog.push({ ...command, timestamp });
|
|
720
|
-
if (this.logCommands) {
|
|
721
|
-
this.logCommand(command);
|
|
722
|
-
}
|
|
723
|
-
this.subscribers.forEach((subscriber) => {
|
|
724
|
-
subscriber.callback(command);
|
|
725
|
-
});
|
|
726
|
-
}
|
|
727
|
-
getStats() {
|
|
728
|
-
return {
|
|
729
|
-
commands: [...this.commandLog],
|
|
730
|
-
subscribers: [...this.subscribers],
|
|
731
|
-
subscribersCount: this.subscribers.size
|
|
732
|
-
};
|
|
733
|
-
}
|
|
734
|
-
logCommand(command) {
|
|
735
|
-
console.groupCollapsed(this.TAG + " " + command.kind);
|
|
736
|
-
console.log("TargetID : " + command.targetId);
|
|
737
|
-
console.log(command.payload);
|
|
738
|
-
console.groupEnd();
|
|
739
|
-
}
|
|
740
|
-
};
|
|
741
|
-
|
|
742
|
-
// src/events/event-bus.ts
|
|
743
|
-
var EventBus = class {
|
|
744
|
-
TAG = "[ EVENT_BUS ] :";
|
|
745
|
-
// private readonly subscribers = new Set<(event: DEvent) => void>();
|
|
746
|
-
subscribers = /* @__PURE__ */ new Set();
|
|
747
|
-
/**
|
|
748
|
-
* Emit on module end.
|
|
749
|
-
* @private
|
|
750
|
-
*/
|
|
751
|
-
eventLog = [];
|
|
752
|
-
consoleLogEvents = false;
|
|
753
|
-
// readonly sub
|
|
754
|
-
subscribe(cb, subscriberId) {
|
|
755
|
-
const subscriberData = {
|
|
756
|
-
subscriberId,
|
|
757
|
-
cb
|
|
758
|
-
};
|
|
759
|
-
this.subscribers.add(subscriberData);
|
|
760
|
-
if (this.consoleLogEvents) {
|
|
761
|
-
console.log(this.TAG + "subscription added: " + subscriberId);
|
|
762
|
-
console.log(this.TAG + "subscription count: " + this.subscribers.size);
|
|
763
|
-
}
|
|
764
|
-
return () => {
|
|
765
|
-
if (this.consoleLogEvents) {
|
|
766
|
-
console.log(this.TAG + "subscription removed: " + subscriberId);
|
|
767
|
-
console.log(this.TAG + "subscription count : " + this.subscribers.size);
|
|
768
|
-
}
|
|
769
|
-
this.subscribers.delete(subscriberData);
|
|
770
|
-
};
|
|
771
|
-
}
|
|
772
|
-
getStats() {
|
|
773
|
-
return {
|
|
774
|
-
subscribersCount: this.subscribers.size,
|
|
775
|
-
eventLog: [...this.eventLog],
|
|
776
|
-
subscribers: [...this.subscribers]
|
|
777
|
-
};
|
|
778
|
-
}
|
|
779
|
-
emit(event) {
|
|
780
|
-
if (this.consoleLogEvents) {
|
|
781
|
-
this.logEvent(event);
|
|
782
|
-
}
|
|
783
|
-
this.eventLog.push(event);
|
|
784
|
-
this.subscribers.forEach((data) => {
|
|
785
|
-
data.cb(event);
|
|
786
|
-
});
|
|
787
|
-
}
|
|
788
|
-
logEvent(event) {
|
|
789
|
-
console.groupCollapsed(this.TAG + " " + event.kind);
|
|
790
|
-
console.log("ProducerId: " + event.producerId);
|
|
791
|
-
console.log(event.data);
|
|
792
|
-
console.groupEnd();
|
|
793
|
-
}
|
|
794
|
-
logEvents() {
|
|
795
|
-
console.group(this.TAG + "LOGG");
|
|
796
|
-
console.table(this.eventLog);
|
|
797
|
-
console.groupEnd();
|
|
798
|
-
}
|
|
799
|
-
};
|
|
800
|
-
|
|
801
|
-
// src/player/history-que.ts
|
|
802
|
-
var AnsweredQuestion;
|
|
803
|
-
((AnsweredQuestion3) => {
|
|
804
|
-
AnsweredQuestion3.eq = (a, b) => {
|
|
805
|
-
return a.fact === b.fact;
|
|
806
|
-
};
|
|
807
|
-
})(AnsweredQuestion || (AnsweredQuestion = {}));
|
|
808
|
-
var HistoryQue = class {
|
|
809
|
-
history = [];
|
|
810
|
-
getFacts() {
|
|
811
|
-
const answers = this.history.map((h) => h.answeredQuestions).flat(1);
|
|
812
|
-
const facts = answers.map((a) => a.fact);
|
|
813
|
-
return facts;
|
|
814
|
-
}
|
|
815
|
-
getAnswers() {
|
|
816
|
-
const answers = this.history.map((h) => h.answeredQuestions).flat(1);
|
|
817
|
-
return answers;
|
|
818
|
-
}
|
|
819
|
-
addToHistory(page) {
|
|
820
|
-
this.history.push(page);
|
|
821
|
-
}
|
|
822
|
-
};
|
|
823
|
-
|
|
824
|
-
// src/rules/condition.ts
|
|
825
|
-
var Condition;
|
|
826
|
-
((Condition2) => {
|
|
827
|
-
Condition2.evaluate = (condition, facts) => {
|
|
828
|
-
let result = false;
|
|
829
|
-
switch (condition.kind) {
|
|
830
|
-
case "string-condition":
|
|
831
|
-
result = evaluateSimple(condition, facts);
|
|
832
|
-
break;
|
|
833
|
-
case "numeric-condition":
|
|
834
|
-
result = evaluateSimple(condition, facts);
|
|
835
|
-
break;
|
|
836
|
-
case "complex-condition":
|
|
837
|
-
result = evaluateComplex(condition, facts);
|
|
838
|
-
break;
|
|
839
|
-
default:
|
|
840
|
-
const check = condition;
|
|
841
|
-
}
|
|
842
|
-
return result;
|
|
843
|
-
};
|
|
844
|
-
const evaluateComplex = (condition, facts) => {
|
|
845
|
-
if (condition.some.length === 0 && condition.all.length === 0) {
|
|
846
|
-
return false;
|
|
847
|
-
}
|
|
848
|
-
const allSolved = condition.all.map((condition2) => {
|
|
849
|
-
return evaluateSimple(condition2, facts);
|
|
850
|
-
});
|
|
851
|
-
const someEvaluated = condition.some.map((condition2) => {
|
|
852
|
-
return evaluateSimple(condition2, facts);
|
|
853
|
-
});
|
|
854
|
-
const allResult = allSolved.every(DUtil.isTrue);
|
|
855
|
-
const someResult = someEvaluated.length === 0 || someEvaluated.some(DUtil.isTrue);
|
|
856
|
-
return someResult && allResult;
|
|
857
|
-
};
|
|
858
|
-
const evaluateSimple = (condition, facts) => {
|
|
859
|
-
const fact = facts.find((f) => f.referenceId === condition.referenceId);
|
|
860
|
-
if (!fact) {
|
|
861
|
-
return false;
|
|
862
|
-
}
|
|
863
|
-
let res = false;
|
|
864
|
-
switch (condition.kind) {
|
|
865
|
-
case "numeric-condition":
|
|
866
|
-
if (fact.kind === "numeric-fact") {
|
|
867
|
-
res = evaluateNumeric(condition, fact.value);
|
|
868
|
-
}
|
|
869
|
-
break;
|
|
870
|
-
case "string-condition":
|
|
871
|
-
if (fact.kind === "string-fact") {
|
|
872
|
-
res = evaluateString(condition, fact.value);
|
|
873
|
-
}
|
|
874
|
-
break;
|
|
875
|
-
default:
|
|
876
|
-
const check = condition;
|
|
877
|
-
}
|
|
878
|
-
return res;
|
|
879
|
-
};
|
|
880
|
-
Condition2.isEmpty = (complex) => {
|
|
881
|
-
return complex.all.length === 0 && complex.some.length === 0;
|
|
882
|
-
};
|
|
883
|
-
const evaluateString = (condition, value) => {
|
|
884
|
-
const operator = condition.operator;
|
|
885
|
-
let result = false;
|
|
886
|
-
switch (operator) {
|
|
887
|
-
case "eq":
|
|
888
|
-
result = condition.value === value;
|
|
889
|
-
break;
|
|
890
|
-
case "not-eq":
|
|
891
|
-
result = condition.value !== value;
|
|
892
|
-
break;
|
|
893
|
-
case "shorter-then":
|
|
894
|
-
result = condition.value !== value;
|
|
895
|
-
break;
|
|
896
|
-
case "longer-then":
|
|
897
|
-
result = condition.value !== value;
|
|
898
|
-
break;
|
|
899
|
-
default:
|
|
900
|
-
const check = operator;
|
|
901
|
-
}
|
|
902
|
-
return result;
|
|
903
|
-
};
|
|
904
|
-
const evaluateNumeric = (condition, value) => {
|
|
905
|
-
const op = condition.operator;
|
|
906
|
-
const conditionValue = condition.value;
|
|
907
|
-
let result = false;
|
|
908
|
-
switch (op) {
|
|
909
|
-
case "eq":
|
|
910
|
-
result = value === conditionValue;
|
|
911
|
-
break;
|
|
912
|
-
case "not-eq":
|
|
913
|
-
result = value !== conditionValue;
|
|
914
|
-
break;
|
|
915
|
-
case "greater-then":
|
|
916
|
-
result = value > conditionValue;
|
|
917
|
-
break;
|
|
918
|
-
case "greater-then-inclusive":
|
|
919
|
-
result = value >= conditionValue;
|
|
920
|
-
break;
|
|
921
|
-
case "less-then":
|
|
922
|
-
result = value < conditionValue;
|
|
923
|
-
break;
|
|
924
|
-
case "less-then-inclusive":
|
|
925
|
-
result = value <= conditionValue;
|
|
926
|
-
break;
|
|
927
|
-
default:
|
|
928
|
-
const check = op;
|
|
929
|
-
}
|
|
930
|
-
return result;
|
|
931
|
-
};
|
|
932
|
-
const _getAllSimple = (condition) => {
|
|
933
|
-
const simple = [];
|
|
934
|
-
switch (condition.kind) {
|
|
935
|
-
case "complex-condition":
|
|
936
|
-
simple.push(...condition.all);
|
|
937
|
-
simple.push(...condition.some);
|
|
938
|
-
break;
|
|
939
|
-
case "numeric-condition":
|
|
940
|
-
simple.push(condition);
|
|
941
|
-
break;
|
|
942
|
-
case "string-condition":
|
|
943
|
-
simple.push(condition);
|
|
944
|
-
break;
|
|
945
|
-
default:
|
|
946
|
-
DUtil.neverCheck(condition);
|
|
947
|
-
}
|
|
948
|
-
return simple;
|
|
949
|
-
};
|
|
950
|
-
Condition2.getAllSimpleConditions = (condition) => {
|
|
951
|
-
const simple = [];
|
|
952
|
-
if (Array.isArray(condition)) {
|
|
953
|
-
condition.forEach((c) => {
|
|
954
|
-
simple.push(..._getAllSimple(c));
|
|
955
|
-
});
|
|
956
|
-
} else {
|
|
957
|
-
simple.push(..._getAllSimple(condition));
|
|
958
|
-
}
|
|
959
|
-
return simple;
|
|
960
|
-
};
|
|
961
|
-
})(Condition || (Condition = {}));
|
|
962
|
-
|
|
963
|
-
// src/rules/rule.ts
|
|
964
|
-
var Rule;
|
|
965
|
-
((Rule2) => {
|
|
966
|
-
Rule2.isEmpty = (rule) => {
|
|
967
|
-
const emptyConditions = rule.all.length === 0 && rule.some.length === 0;
|
|
968
|
-
const emptyActions = rule.onSuccess.length === 0 && rule.onFailure.length === 0;
|
|
969
|
-
return emptyConditions || emptyActions;
|
|
970
|
-
};
|
|
971
|
-
Rule2.solve = (rule, facts) => {
|
|
972
|
-
if (rule.some.length === 0 && rule.all.length === 0) {
|
|
973
|
-
return false;
|
|
974
|
-
}
|
|
975
|
-
const someSolved = rule.some.map((condition) => Condition.evaluate(condition, facts));
|
|
976
|
-
const someResult = someSolved.length === 0 || someSolved.some(DUtil.isTrue);
|
|
977
|
-
const allSolved = rule.all.map((condition) => Condition.evaluate(condition, facts)).every(DUtil.isTrue);
|
|
978
|
-
return allSolved && someResult;
|
|
979
|
-
};
|
|
980
|
-
})(Rule || (Rule = {}));
|
|
981
|
-
|
|
982
|
-
// src/rules/rule-engine.ts
|
|
983
|
-
var RuleEngine = class {
|
|
984
|
-
constructor() {
|
|
985
|
-
}
|
|
986
|
-
solveAll(rules, facts) {
|
|
987
|
-
const errors = [];
|
|
988
|
-
const matching = [];
|
|
989
|
-
rules.forEach((rule) => {
|
|
990
|
-
if (Rule.isEmpty(rule)) {
|
|
991
|
-
errors.push({ message: "Empty rule: " + rule.id });
|
|
992
|
-
} else if (Rule.solve(rule, facts)) {
|
|
993
|
-
const match = {
|
|
994
|
-
ruleDescription: rule.description,
|
|
995
|
-
matchingRuleId: rule.id ?? "no-id-given",
|
|
996
|
-
actionList: [...rule.onSuccess]
|
|
997
|
-
};
|
|
998
|
-
matching.push(match);
|
|
999
|
-
}
|
|
1000
|
-
});
|
|
1001
|
-
return { matching, errors };
|
|
1002
|
-
}
|
|
1003
|
-
solve(rule, facts) {
|
|
1004
|
-
return Rule.solve(rule, facts);
|
|
1005
|
-
}
|
|
1006
|
-
};
|
|
1007
|
-
|
|
1008
|
-
// src/player/next-que.ts
|
|
1009
|
-
var NextQue = class {
|
|
1010
|
-
originalOrder = [];
|
|
1011
|
-
allPages = [];
|
|
1012
|
-
excludedTags = /* @__PURE__ */ new Set();
|
|
1013
|
-
excludedByPageId = /* @__PURE__ */ new Set();
|
|
1014
|
-
remaining = [];
|
|
1015
|
-
constructor(pages = []) {
|
|
1016
|
-
this.resetQue(pages);
|
|
1017
|
-
}
|
|
1018
|
-
/**
|
|
1019
|
-
* Will reset que with the new pages.
|
|
1020
|
-
* @param pages
|
|
1021
|
-
*/
|
|
1022
|
-
resetQue(pages) {
|
|
1023
|
-
this.allPages = [...pages];
|
|
1024
|
-
this.remaining = [...pages];
|
|
1025
|
-
this.excludedTags = /* @__PURE__ */ new Set();
|
|
1026
|
-
this.excludedByPageId = /* @__PURE__ */ new Set();
|
|
1027
|
-
this.originalOrder = this.allPages.map((p) => p.id);
|
|
1028
|
-
}
|
|
1029
|
-
pop() {
|
|
1030
|
-
const next = this.remaining.shift();
|
|
1031
|
-
return next ?? false;
|
|
1032
|
-
}
|
|
1033
|
-
peek() {
|
|
1034
|
-
const next = this.remaining[0];
|
|
1035
|
-
return next ?? false;
|
|
1036
|
-
}
|
|
1037
|
-
jumpToPageById(pageId) {
|
|
1038
|
-
const index = this.remaining.findIndex((p) => p.id === pageId);
|
|
1039
|
-
if (index < 0) {
|
|
1040
|
-
return false;
|
|
1041
|
-
}
|
|
1042
|
-
this.remaining = this.remaining.slice(index);
|
|
1043
|
-
return true;
|
|
1044
|
-
}
|
|
1045
|
-
removeByTag(tag) {
|
|
1046
|
-
if (Array.isArray(tag)) {
|
|
1047
|
-
tag.forEach((tag2) => {
|
|
1048
|
-
this.excludedTags.add(tag2);
|
|
1049
|
-
});
|
|
1050
|
-
} else {
|
|
1051
|
-
this.excludedTags.add(tag);
|
|
1052
|
-
}
|
|
1053
|
-
this.filterRemaining();
|
|
1054
|
-
}
|
|
1055
|
-
/**
|
|
1056
|
-
* Will not be included
|
|
1057
|
-
* @param pages
|
|
1058
|
-
*/
|
|
1059
|
-
insertAsNextByForce(pages) {
|
|
1060
|
-
this.remaining.unshift(...pages);
|
|
1061
|
-
}
|
|
1062
|
-
removeByPageId(pageId) {
|
|
1063
|
-
if (Array.isArray(pageId)) {
|
|
1064
|
-
pageId.forEach((id) => {
|
|
1065
|
-
this.excludedByPageId.add(id);
|
|
1066
|
-
});
|
|
1067
|
-
} else {
|
|
1068
|
-
this.excludedByPageId.add(pageId);
|
|
1069
|
-
}
|
|
1070
|
-
this.filterRemaining();
|
|
1071
|
-
}
|
|
1072
|
-
filterRemaining() {
|
|
1073
|
-
this.remaining = this.remaining.filter((p) => {
|
|
1074
|
-
const tags = p.tags ?? [];
|
|
1075
|
-
const isIncluededByTag = !tags.some((tag) => this.excludedTags.has(tag));
|
|
1076
|
-
const isIncludedByPageId = !this.excludedByPageId.has(p.id);
|
|
1077
|
-
return isIncludedByPageId && isIncluededByTag;
|
|
1078
|
-
});
|
|
1079
|
-
}
|
|
1080
|
-
get isEmpty() {
|
|
1081
|
-
return this.remaining.length === 0;
|
|
1082
|
-
}
|
|
1083
|
-
get size() {
|
|
1084
|
-
return this.remaining.length;
|
|
1085
|
-
}
|
|
1086
|
-
get pageCount() {
|
|
1087
|
-
return this.originalOrder.length;
|
|
1088
|
-
}
|
|
1089
|
-
};
|
|
1090
|
-
|
|
1091
|
-
// src/player/dplayer.ts
|
|
1092
|
-
var DPlayer = class {
|
|
1093
|
-
history = new HistoryQue();
|
|
1094
|
-
ruleEngine = new RuleEngine();
|
|
1095
|
-
nextQue = new NextQue();
|
|
1096
|
-
data;
|
|
1097
|
-
constructor(data) {
|
|
1098
|
-
this.data = data;
|
|
1099
|
-
this.nextQue.resetQue(data.pages);
|
|
1100
|
-
}
|
|
1101
|
-
saveHistory(pageHistory) {
|
|
1102
|
-
console.log("SAVE HISTORY", pageHistory);
|
|
1103
|
-
this.history.addToHistory(pageHistory);
|
|
1104
|
-
const facts = this.history.getFacts();
|
|
1105
|
-
const result = this.ruleEngine.solveAll(this.data.rules, facts);
|
|
1106
|
-
const matchingRules = result.matching;
|
|
1107
|
-
const actions = matchingRules.map((r) => r.actionList).flat(1);
|
|
1108
|
-
actions.forEach((a) => {
|
|
1109
|
-
console.log(a.payload);
|
|
1110
|
-
switch (a.kind) {
|
|
1111
|
-
case "PAGE_QUE_JUMP_TO_PAGE_COMMAND":
|
|
1112
|
-
this.nextQue.jumpToPageById(a.payload.pageId);
|
|
1113
|
-
break;
|
|
1114
|
-
case "PAGE_QUE_EXCLUDE_BY_PAGE_ID_COMMAND":
|
|
1115
|
-
this.nextQue.removeByPageId(a.payload.pageIds);
|
|
1116
|
-
break;
|
|
1117
|
-
case "PAGE_QUE_EXCLUDE_BY_TAG_COMMAND":
|
|
1118
|
-
this.nextQue.removeByTag(a.payload.tagIds);
|
|
1119
|
-
break;
|
|
1120
|
-
default:
|
|
1121
|
-
console.log("UNKNOWN ACTION", a);
|
|
1122
|
-
const check = a;
|
|
1123
|
-
}
|
|
1124
|
-
});
|
|
1125
|
-
console.log(actions);
|
|
1126
|
-
}
|
|
1127
|
-
getResults() {
|
|
1128
|
-
return this.history.getAnswers();
|
|
1129
|
-
}
|
|
1130
|
-
goToPageById(pageId) {
|
|
1131
|
-
this.nextQue.jumpToPageById(pageId);
|
|
1132
|
-
}
|
|
1133
|
-
handleNavigationCommand(command) {
|
|
1134
|
-
switch (command.kind) {
|
|
1135
|
-
case "PAGE_QUE_NEXT_PAGE_COMMAND":
|
|
1136
|
-
break;
|
|
1137
|
-
case "PAGE_QUE_GO_TO_PAGE_COMMAND":
|
|
1138
|
-
this.goToPageById(command.payload.pageId);
|
|
1139
|
-
break;
|
|
1140
|
-
case "PAGE_QUE_GO_TO_SEQUENCE_COMMAND":
|
|
1141
|
-
this.insertSequenceById(command.payload.sequenceId);
|
|
1142
|
-
break;
|
|
1143
|
-
default:
|
|
1144
|
-
DUtil.neverCheck(command);
|
|
1145
|
-
}
|
|
1146
|
-
}
|
|
1147
|
-
getNextPage() {
|
|
1148
|
-
return this.nextQue.pop();
|
|
1149
|
-
}
|
|
1150
|
-
insertSequenceById(id) {
|
|
1151
|
-
const seq = this.data.pageSequences?.find((s) => s.id === id);
|
|
1152
|
-
if (seq) {
|
|
1153
|
-
this.nextQue.insertAsNextByForce([...seq.pages]);
|
|
1154
|
-
} else {
|
|
1155
|
-
}
|
|
1156
|
-
}
|
|
1157
|
-
/**
|
|
1158
|
-
* Total number of pages.
|
|
1159
|
-
*/
|
|
1160
|
-
get pageCount() {
|
|
1161
|
-
return this.nextQue.pageCount;
|
|
1162
|
-
}
|
|
1163
|
-
};
|
|
1164
|
-
|
|
1165
|
-
// src/event-handlers/DEventHandler.ts
|
|
1166
|
-
var DEventHandler;
|
|
1167
|
-
((DEventHandler2) => {
|
|
1168
|
-
DEventHandler2.createLookUp = (handlers) => {
|
|
1169
|
-
const map = /* @__PURE__ */ new Map();
|
|
1170
|
-
handlers?.forEach((h) => {
|
|
1171
|
-
const kind = h.onEvent;
|
|
1172
|
-
const current = map.get(kind);
|
|
1173
|
-
const actions = current ? [...current, h] : [h];
|
|
1174
|
-
map.set(kind, actions);
|
|
1175
|
-
});
|
|
1176
|
-
return map;
|
|
1177
|
-
};
|
|
1178
|
-
})(DEventHandler || (DEventHandler = {}));
|
|
1179
|
-
|
|
1180
|
-
// src/Delement/DElement.ts
|
|
1181
|
-
var DElement = class {
|
|
1182
|
-
el;
|
|
1183
|
-
clickHandlerIsEnabled = true;
|
|
1184
|
-
id;
|
|
1185
|
-
isAnimatingSelf = false;
|
|
1186
|
-
currStyle = {
|
|
1187
|
-
fontSize: { _unit: "px", value: 100 },
|
|
1188
|
-
fontWeight: 500,
|
|
1189
|
-
textColor: "black",
|
|
1190
|
-
opacity: 1
|
|
1191
|
-
};
|
|
1192
|
-
// private readonly onQueryChangedHandlers =
|
|
1193
|
-
eventHandlers;
|
|
1194
|
-
commandBus;
|
|
1195
|
-
eventBus;
|
|
1196
|
-
scale;
|
|
1197
|
-
baseDto;
|
|
1198
|
-
subscriptions = /* @__PURE__ */ new Set();
|
|
1199
|
-
constructor(el, eventBus, commandBus, dto, scale) {
|
|
1200
|
-
this.el = el;
|
|
1201
|
-
this.id = dto.id;
|
|
1202
|
-
this.baseDto = dto;
|
|
1203
|
-
this.commandBus = commandBus;
|
|
1204
|
-
this.eventBus = eventBus;
|
|
1205
|
-
this.eventHandlers = DEventHandler.createLookUp(dto.eventHandlers);
|
|
1206
|
-
this.scale = scale;
|
|
1207
|
-
this.onClickHandler = this.onClickHandler.bind(this);
|
|
1208
|
-
this.el.onclick = this.onClickHandler;
|
|
1209
|
-
this.onMouseOver = this.onMouseOver.bind(this);
|
|
1210
|
-
this.el.onmouseover = this.onMouseOver;
|
|
1211
|
-
if (dto) {
|
|
1212
|
-
this.updateStyles(dto?.style);
|
|
1213
|
-
}
|
|
1214
|
-
const commandSubscription = this.commandBus.subscribe((c) => {
|
|
1215
|
-
if (c.kind === "ELEMENT_STYLE_COMMAND" && c.targetId === this.id) {
|
|
1216
|
-
this.setStyle(c.payload.changes);
|
|
1217
|
-
}
|
|
1218
|
-
if (c.kind === "ELEMENT_DISABLE_CLICK_COMMAND" && c.targetId === this.id) {
|
|
1219
|
-
this.clickHandlerIsEnabled = false;
|
|
1220
|
-
}
|
|
1221
|
-
if (c.kind === "ELEMENT_ENABLE_CLICK_COMMAND" && c.targetId === this.id) {
|
|
1222
|
-
this.clickHandlerIsEnabled = true;
|
|
1223
|
-
}
|
|
1224
|
-
if (c.kind === "ELEMENT_ANIMATE_COMMAND" && c.targetId === this.id) {
|
|
1225
|
-
console.log("TODO IMPLEMENT ANIMATION_HANDLER IN DElement.");
|
|
1226
|
-
}
|
|
1227
|
-
}, this.id);
|
|
1228
|
-
const eventSubscription = this.eventBus.subscribe((event) => {
|
|
1229
|
-
const handlers = this.eventHandlers.get(event.kind) ?? [];
|
|
1230
|
-
const commands = handlers.map((h) => h.thenExecute).flat(1);
|
|
1231
|
-
commands.forEach((command) => {
|
|
1232
|
-
this.commandBus.emit(command);
|
|
1233
|
-
});
|
|
1234
|
-
if (event.kind === "HOST_SCALE_CHANGED_EVENT") {
|
|
1235
|
-
console.log("HANDLE THIS SCALE CHANGE!!");
|
|
1236
|
-
this.updateStyles({});
|
|
1237
|
-
}
|
|
1238
|
-
if (event.kind === "STATE_QUERY_RESULT_CHANGED_EVENT") {
|
|
1239
|
-
this.queryChangedHandler(event.data);
|
|
1240
|
-
}
|
|
1241
|
-
}, "ELEMENT: ");
|
|
1242
|
-
this.normalize();
|
|
1243
|
-
this.subscriptions.add(commandSubscription);
|
|
1244
|
-
this.subscriptions.add(eventSubscription);
|
|
1245
|
-
}
|
|
1246
|
-
// abstract setScale(scale: number): void;
|
|
1247
|
-
// /**
|
|
1248
|
-
// * The purpose of this function is to re-emit commands from event-handlers?
|
|
1249
|
-
// * @param command
|
|
1250
|
-
// * @private
|
|
1251
|
-
// */
|
|
1252
|
-
// private handleCommandsEmittedByPrivateEventHandlers(command: DCommand) {
|
|
1253
|
-
// console.log(command);
|
|
1254
|
-
// switch (command.kind) {
|
|
1255
|
-
// case "ELEMENT_STYLE_COMMAND":
|
|
1256
|
-
// if (command.targetId === this.id) {
|
|
1257
|
-
// this.updateStyles(command.payload.changes);
|
|
1258
|
-
// }
|
|
1259
|
-
// break;
|
|
1260
|
-
// case "ELEMENT_ANIMATE_COMMAND":
|
|
1261
|
-
// // TODO CHECK FOR TARGET ID
|
|
1262
|
-
// this.handleAnimateSelfAction(command.payload);
|
|
1263
|
-
// break;
|
|
1264
|
-
// case "ELEMENT_ENABLE_CLICK_COMMAND":
|
|
1265
|
-
// this.clickHandlerIsEnabled = true;
|
|
1266
|
-
// // this.updateStyles(command.payload.changes);
|
|
1267
|
-
// break;
|
|
1268
|
-
// case "ELEMENT_DISABLE_CLICK_COMMAND":
|
|
1269
|
-
// this.clickHandlerIsEnabled = false;
|
|
1270
|
-
// // this.handleAnimateSelfAction(command.payload);
|
|
1271
|
-
// break;
|
|
1272
|
-
// case "VIDEO_PLAY_COMMAND":
|
|
1273
|
-
// this.commandBus.emit(command);
|
|
1274
|
-
// break;
|
|
1275
|
-
// case "VIDEO_PAUSE_COMMAND":
|
|
1276
|
-
// this.commandBus.emit(command);
|
|
1277
|
-
// break;
|
|
1278
|
-
// case "ENGINE_LEAVE_PAGE_COMMAND":
|
|
1279
|
-
// this.commandBus.emit(command);
|
|
1280
|
-
// break;
|
|
1281
|
-
// case "VIDEO_JUMP_TO_COMMAND":
|
|
1282
|
-
// this.commandBus.emit(command);
|
|
1283
|
-
// break;
|
|
1284
|
-
// case "VIDEO_SET_VOLUME_COMMAND":
|
|
1285
|
-
// this.commandBus.emit(command);
|
|
1286
|
-
// break;
|
|
1287
|
-
// case "AUDIO_PLAY_COMMAND":
|
|
1288
|
-
// this.commandBus.emit(command);
|
|
1289
|
-
// break;
|
|
1290
|
-
// case "AUDIO_PAUSE_COMMAND":
|
|
1291
|
-
// this.commandBus.emit(command);
|
|
1292
|
-
// break;
|
|
1293
|
-
// case "AUDIO_SET_VOLUME_COMMAND":
|
|
1294
|
-
// this.commandBus.emit(command);
|
|
1295
|
-
// break;
|
|
1296
|
-
// case "PAGE_QUE_NEXT_PAGE_COMMAND":
|
|
1297
|
-
// this.commandBus.emit(command);
|
|
1298
|
-
// break;
|
|
1299
|
-
// case "PAGE_QUE_GO_TO_SEQUENCE_COMMAND":
|
|
1300
|
-
// this.commandBus.emit(command);
|
|
1301
|
-
// break;
|
|
1302
|
-
// case "PAGE_QUE_GO_TO_PAGE_COMMAND":
|
|
1303
|
-
// this.commandBus.emit(command);
|
|
1304
|
-
// break;
|
|
1305
|
-
// case "PAGE_QUE_EXCLUDE_BY_PAGE_ID_COMMAND":
|
|
1306
|
-
// this.commandBus.emit(command);
|
|
1307
|
-
// break;
|
|
1308
|
-
// case "PAGE_QUE_JUMP_TO_PAGE_COMMAND":
|
|
1309
|
-
// this.commandBus.emit(command);
|
|
1310
|
-
// break;
|
|
1311
|
-
// case "PAGE_QUE_EXCLUDE_BY_TAG_COMMAND":
|
|
1312
|
-
// this.commandBus.emit(command);
|
|
1313
|
-
// break;
|
|
1314
|
-
// case "STATE_MUTATE_COMMAND":
|
|
1315
|
-
// this.commandBus.emit(command);
|
|
1316
|
-
// break;
|
|
1317
|
-
// default:
|
|
1318
|
-
// DUtil.neverCheck(command);
|
|
1319
|
-
// }
|
|
1320
|
-
// }
|
|
1321
|
-
queryChangedHandler(result) {
|
|
1322
|
-
const maybeHandlers = this.baseDto.onStateChange;
|
|
1323
|
-
if (!maybeHandlers) {
|
|
1324
|
-
return;
|
|
1325
|
-
}
|
|
1326
|
-
const queryHandlers = maybeHandlers.filter((h) => h.queryName === result.queryName);
|
|
1327
|
-
queryHandlers.forEach((h) => {
|
|
1328
|
-
if (result.curr) {
|
|
1329
|
-
h.whenTrue.forEach((command) => {
|
|
1330
|
-
this.commandBus.emit(command);
|
|
1331
|
-
});
|
|
1332
|
-
} else {
|
|
1333
|
-
h.whenFalse.forEach((command) => {
|
|
1334
|
-
this.commandBus.emit(command);
|
|
1335
|
-
});
|
|
1336
|
-
}
|
|
1337
|
-
});
|
|
1338
|
-
}
|
|
1339
|
-
onClickHandler(_) {
|
|
1340
|
-
if (!this.clickHandlerIsEnabled) {
|
|
1341
|
-
console.log(this.id + "Click disabled");
|
|
1342
|
-
return;
|
|
1343
|
-
}
|
|
1344
|
-
const clickAction = this.baseDto.onClick;
|
|
1345
|
-
if (clickAction && clickAction.length > 0) {
|
|
1346
|
-
this.eventBus.emit({
|
|
1347
|
-
kind: "USER_CLICKED_EVENT",
|
|
1348
|
-
producer: "DUser",
|
|
1349
|
-
producerId: this.id,
|
|
1350
|
-
data: { elementId: this.id },
|
|
1351
|
-
timestamp: DTimestamp.now()
|
|
1352
|
-
});
|
|
1353
|
-
clickAction.forEach((command) => {
|
|
1354
|
-
this.commandBus.emit(command);
|
|
1355
|
-
});
|
|
1356
|
-
}
|
|
1357
|
-
}
|
|
1358
|
-
onMouseOver(_) {
|
|
1359
|
-
}
|
|
1360
|
-
setStyle(style) {
|
|
1361
|
-
this.updateStyles(style);
|
|
1362
|
-
}
|
|
1363
|
-
appendYourself(parent) {
|
|
1364
|
-
parent.append(this.el);
|
|
1365
|
-
}
|
|
1366
|
-
handleAnimateSelfAction(dto) {
|
|
1367
|
-
this.isAnimatingSelf = true;
|
|
1368
|
-
const { keyframes, options } = dto;
|
|
1369
|
-
const animation = this.el.animate(keyframes, options.duration);
|
|
1370
|
-
animation.onfinish = (e) => {
|
|
1371
|
-
console.log(e.type);
|
|
1372
|
-
this.isAnimatingSelf = false;
|
|
1373
|
-
};
|
|
1374
|
-
animation.onremove = () => {
|
|
1375
|
-
console.warn("ANIMATION REMOVED: " + animation.id);
|
|
1376
|
-
this.isAnimatingSelf = false;
|
|
1377
|
-
};
|
|
1378
|
-
animation.oncancel = () => {
|
|
1379
|
-
console.warn("ANIMATION CANCELED: " + animation.id);
|
|
1380
|
-
this.isAnimatingSelf = false;
|
|
1381
|
-
};
|
|
1382
|
-
}
|
|
1383
|
-
normalize() {
|
|
1384
|
-
DStyle.normalize(this.el);
|
|
1385
|
-
}
|
|
1386
|
-
updateStyles(style) {
|
|
1387
|
-
this.currStyle = Object.assign(this.currStyle, style);
|
|
1388
|
-
DStyle.applyStyles(this.el, this.currStyle, this.scale.scale);
|
|
1389
|
-
window.getComputedStyle(this.el);
|
|
1390
|
-
}
|
|
1391
|
-
};
|
|
1392
|
-
|
|
1393
|
-
// src/Delement/Ddiv.ts
|
|
1394
|
-
var DDiv = class extends DElement {
|
|
1395
|
-
TAG = "[ DDiv ]: ";
|
|
1396
|
-
defaultStyle = { x: 22, y: 4 };
|
|
1397
|
-
children = [];
|
|
1398
|
-
constructor(dto, eventBus, actionService, scale, children) {
|
|
1399
|
-
const d = document.createElement("div");
|
|
1400
|
-
super(d, eventBus, actionService, dto, scale);
|
|
1401
|
-
this.children = children;
|
|
1402
|
-
this.children.forEach((child) => {
|
|
1403
|
-
child.appendYourself(this.el);
|
|
1404
|
-
});
|
|
1405
|
-
}
|
|
1406
|
-
destroy() {
|
|
1407
|
-
this.subscriptions.forEach((unsubscribe) => {
|
|
1408
|
-
unsubscribe();
|
|
1409
|
-
});
|
|
1410
|
-
this.children.forEach((child) => {
|
|
1411
|
-
child.destroy();
|
|
1412
|
-
});
|
|
1413
|
-
}
|
|
1414
|
-
};
|
|
1415
|
-
|
|
1416
|
-
// src/Delement/DImg.ts
|
|
1417
|
-
var DImg = class _DImg extends DElement {
|
|
1418
|
-
constructor(dto, actionSubject, eventBus, scaleService) {
|
|
1419
|
-
super(document.createElement("img"), eventBus, actionSubject, dto, scaleService);
|
|
1420
|
-
this.dto = dto;
|
|
1421
|
-
this.actionSubject = actionSubject;
|
|
1422
|
-
this.eventBus = eventBus;
|
|
1423
|
-
this.scaleService = scaleService;
|
|
1424
|
-
_DImg.IMAGE_COUNT += 1;
|
|
1425
|
-
this.imageCount = _DImg.IMAGE_COUNT;
|
|
1426
|
-
this.TAG = "[D_IMG " + _DImg.IMAGE_COUNT + " ]: ";
|
|
1427
|
-
this.TIMING_TAG = "load-time (" + _DImg.IMAGE_COUNT + ") ";
|
|
1428
|
-
this.el.loading = "eager";
|
|
1429
|
-
this.el.style.position = "absolute";
|
|
1430
|
-
this.setStyle(dto.style);
|
|
1431
|
-
this.loadStart = DTimestamp.now();
|
|
1432
|
-
this.onError = this.onError.bind(this);
|
|
1433
|
-
this.onLoad = this.onLoad.bind(this);
|
|
1434
|
-
this.el.onload = this.onLoad;
|
|
1435
|
-
this.el.onerror = this.onError;
|
|
1436
|
-
this.el.src = dto.url;
|
|
1437
|
-
console.time(this.TIMING_TAG);
|
|
1438
|
-
}
|
|
1439
|
-
static IMAGE_COUNT = 0;
|
|
1440
|
-
imageCount;
|
|
1441
|
-
TAG;
|
|
1442
|
-
TIMING_TAG;
|
|
1443
|
-
loadStart;
|
|
1444
|
-
log() {
|
|
1445
|
-
}
|
|
1446
|
-
setScale(scale) {
|
|
1447
|
-
console.log(scale);
|
|
1448
|
-
this.setStyle(this.currStyle);
|
|
1449
|
-
}
|
|
1450
|
-
destroy() {
|
|
1451
|
-
this.subscriptions.forEach((unsubscribe) => {
|
|
1452
|
-
unsubscribe();
|
|
1453
|
-
});
|
|
1454
|
-
}
|
|
1455
|
-
onError(ev) {
|
|
1456
|
-
if (ev instanceof Event) {
|
|
1457
|
-
console.log(this.TAG + " " + ev.type);
|
|
1458
|
-
} else {
|
|
1459
|
-
console.log(this.TAG + ev);
|
|
1460
|
-
}
|
|
1461
|
-
}
|
|
1462
|
-
onLoad(_) {
|
|
1463
|
-
const loadTime = DTimestamp.diffNow(this.loadStart);
|
|
1464
|
-
this.eventBus.emit({
|
|
1465
|
-
kind: "IMAGE_LOADED_EVENT",
|
|
1466
|
-
producer: "DImage",
|
|
1467
|
-
producerId: this.id,
|
|
1468
|
-
timestamp: DTimestamp.now(),
|
|
1469
|
-
data: {
|
|
1470
|
-
loadTime,
|
|
1471
|
-
naturalHeight: this.el.naturalHeight,
|
|
1472
|
-
naturalWidth: this.el.naturalWidth,
|
|
1473
|
-
height: this.el.height,
|
|
1474
|
-
width: this.el.width
|
|
1475
|
-
}
|
|
1476
|
-
});
|
|
1477
|
-
}
|
|
1478
|
-
};
|
|
1479
|
-
|
|
1480
|
-
// src/Delement/DText.ts
|
|
1481
|
-
var DText = class extends DElement {
|
|
1482
|
-
TAG = "[ DParagraph ]: ";
|
|
1483
|
-
defaultStyle = {};
|
|
1484
|
-
constructor(dto, eventBus, actionService, scale) {
|
|
1485
|
-
super(document.createElement("p"), eventBus, actionService, dto, scale);
|
|
1486
|
-
this.el.style.position = "absolute";
|
|
1487
|
-
this.el.innerText = "" + dto.text;
|
|
1488
|
-
this.setStyle(dto.style);
|
|
1489
|
-
}
|
|
1490
|
-
setScale(scale) {
|
|
1491
|
-
this.setStyle(this.currStyle);
|
|
1492
|
-
const fontSize = this.el.style.fontSize;
|
|
1493
|
-
console.log(this.TAG + "scale: " + scale + " Fontsize: " + fontSize);
|
|
1494
|
-
}
|
|
1495
|
-
destroy() {
|
|
1496
|
-
this.subscriptions.forEach((unsubscribe) => {
|
|
1497
|
-
unsubscribe();
|
|
1498
|
-
});
|
|
1499
|
-
}
|
|
1500
|
-
};
|
|
1501
|
-
|
|
1502
|
-
// src/engine/element-factory.ts
|
|
1503
|
-
var createDElement = (dto, actionBus, eventBus, scale) => {
|
|
1504
|
-
switch (dto._tag) {
|
|
1505
|
-
case "div":
|
|
1506
|
-
const childEls = createChildrenForDiv(dto, actionBus, eventBus, scale);
|
|
1507
|
-
const newDiv = new DDiv(dto, eventBus, actionBus, scale, childEls);
|
|
1508
|
-
return newDiv;
|
|
1509
|
-
case "img":
|
|
1510
|
-
return new DImg(dto, actionBus, eventBus, scale);
|
|
1511
|
-
case "p":
|
|
1512
|
-
return new DText(dto, eventBus, actionBus, scale);
|
|
1513
|
-
default:
|
|
1514
|
-
const check = dto;
|
|
1515
|
-
throw new Error("Unknown dto given to the createDElement function.");
|
|
1516
|
-
}
|
|
1517
|
-
};
|
|
1518
|
-
var createChildrenForDiv = (dto, actionSubject, eventBus, scale) => {
|
|
1519
|
-
const childDto = dto.children;
|
|
1520
|
-
const childEls = [];
|
|
1521
|
-
childDto.forEach((dto2) => {
|
|
1522
|
-
if (dto2._tag === "p") {
|
|
1523
|
-
const newText = new DText(dto2, eventBus, actionSubject, scale);
|
|
1524
|
-
childEls.push(newText);
|
|
1525
|
-
}
|
|
1526
|
-
if (dto2._tag === "img") {
|
|
1527
|
-
const newImage = new DImg(dto2, actionSubject, eventBus, scale);
|
|
1528
|
-
childEls.push(newImage);
|
|
1529
|
-
}
|
|
1530
|
-
});
|
|
1531
|
-
return childEls;
|
|
1532
|
-
};
|
|
1533
|
-
|
|
1534
|
-
// src/engine/DPage.ts
|
|
1535
|
-
var DPage = class {
|
|
1536
|
-
// Todo GLOBAL EVENT_BUSS AND PAGE EVENTS:
|
|
1537
|
-
constructor(dto, eventBus, commandBus, scale) {
|
|
1538
|
-
this.dto = dto;
|
|
1539
|
-
this.eventBus = eventBus;
|
|
1540
|
-
this.commandBus = commandBus;
|
|
1541
|
-
this.scale = scale;
|
|
1542
|
-
this.elements = dto.elements.map((dto2) => createDElement(dto2, this.commandBus, this.eventBus, this.scale));
|
|
1543
|
-
}
|
|
1544
|
-
TAG = "[ DPage ]: ";
|
|
1545
|
-
elements = [];
|
|
1546
|
-
eventBus;
|
|
1547
|
-
commandBus;
|
|
1548
|
-
scale;
|
|
1549
|
-
appendYourself(parent) {
|
|
1550
|
-
this.elements.forEach((el) => {
|
|
1551
|
-
el.appendYourself(parent);
|
|
1552
|
-
});
|
|
1553
|
-
this.eventBus.emit({
|
|
1554
|
-
kind: "PAGE_ENTER_EVENT",
|
|
1555
|
-
timestamp: DTimestamp.now(),
|
|
1556
|
-
producer: "DPage",
|
|
1557
|
-
producerId: this.id,
|
|
1558
|
-
data: { pageId: this.id }
|
|
1559
|
-
});
|
|
1560
|
-
}
|
|
1561
|
-
destroy() {
|
|
1562
|
-
this.elements.forEach((el) => {
|
|
1563
|
-
el.destroy();
|
|
1564
|
-
});
|
|
1565
|
-
}
|
|
1566
|
-
log() {
|
|
1567
|
-
}
|
|
1568
|
-
get id() {
|
|
1569
|
-
return this.dto.id;
|
|
1570
|
-
}
|
|
1571
|
-
};
|
|
1572
|
-
|
|
1573
|
-
// src/engine/scale.ts
|
|
1574
|
-
var ScaleService = class {
|
|
1575
|
-
baseHeight;
|
|
1576
|
-
baseWidth;
|
|
1577
|
-
containerHeight = 1300;
|
|
1578
|
-
containerWidth = 1300;
|
|
1579
|
-
get scale() {
|
|
1580
|
-
return this._scale;
|
|
1581
|
-
}
|
|
1582
|
-
get pageHeight() {
|
|
1583
|
-
return this.baseHeight * this.scale;
|
|
1584
|
-
}
|
|
1585
|
-
get pageWidth() {
|
|
1586
|
-
return this.baseWidth * this._scale;
|
|
1587
|
-
}
|
|
1588
|
-
_scale = 1;
|
|
1589
|
-
subscribers = /* @__PURE__ */ new Set();
|
|
1590
|
-
constructor(config) {
|
|
1591
|
-
this.baseHeight = config.baseHeight;
|
|
1592
|
-
this.baseWidth = config.baseWidth;
|
|
1593
|
-
this.containerHeight = config.containerHeight;
|
|
1594
|
-
this.containerWidth = config.containerWidth;
|
|
1595
|
-
this.updateScale();
|
|
1596
|
-
}
|
|
1597
|
-
setContainerBounds(bounds) {
|
|
1598
|
-
this.containerWidth = bounds.width;
|
|
1599
|
-
this.containerHeight = bounds.height;
|
|
1600
|
-
this.updateScale();
|
|
1601
|
-
}
|
|
1602
|
-
updateScale() {
|
|
1603
|
-
const scaleFn = Scale.calc(this.baseHeight, this.baseWidth);
|
|
1604
|
-
const scale = scaleFn({ height: this.containerHeight, width: this.containerWidth });
|
|
1605
|
-
const hasChanged = this.scale !== scale;
|
|
1606
|
-
this._scale = scale;
|
|
1607
|
-
if (hasChanged) {
|
|
1608
|
-
this.subscribers.forEach((fn) => {
|
|
1609
|
-
fn(this._scale);
|
|
1610
|
-
});
|
|
1611
|
-
}
|
|
1612
|
-
}
|
|
1613
|
-
onChange(scaleChangeHandler, subscriberId) {
|
|
1614
|
-
this.subscribers.add(scaleChangeHandler);
|
|
1615
|
-
scaleChangeHandler(this._scale);
|
|
1616
|
-
return () => {
|
|
1617
|
-
this.subscribers.delete(scaleChangeHandler);
|
|
1618
|
-
};
|
|
1619
|
-
}
|
|
1620
|
-
};
|
|
1621
|
-
var Scale;
|
|
1622
|
-
((Scale2) => {
|
|
1623
|
-
Scale2.calc = (baseHeight, baseWidth) => {
|
|
1624
|
-
return (container) => {
|
|
1625
|
-
const heightRatio = container.height / baseHeight;
|
|
1626
|
-
const widthRatio = container.width / baseWidth;
|
|
1627
|
-
return Math.min(heightRatio, widthRatio);
|
|
1628
|
-
};
|
|
1629
|
-
};
|
|
1630
|
-
Scale2.scaleFunctionCreator = (scale) => {
|
|
1631
|
-
return (value) => value * scale;
|
|
1632
|
-
};
|
|
1633
|
-
})(Scale || (Scale = {}));
|
|
1634
|
-
|
|
1635
|
-
// src/services/resource-provider.ts
|
|
1636
|
-
var ResourceProvider = class {
|
|
1637
|
-
TAG = "[ RESOURCE_PROVIDER ]: ";
|
|
1638
|
-
videoMap = /* @__PURE__ */ new Map();
|
|
1639
|
-
audioMap = /* @__PURE__ */ new Map();
|
|
1640
|
-
constructor(data) {
|
|
1641
|
-
data.videos.forEach((video) => {
|
|
1642
|
-
this.videoMap.set(video.id, video);
|
|
1643
|
-
});
|
|
1644
|
-
data.audio.forEach((audio) => {
|
|
1645
|
-
this.audioMap.set(audio.id, audio);
|
|
1646
|
-
});
|
|
1647
|
-
}
|
|
1648
|
-
getAudioById(id) {
|
|
1649
|
-
const maybeAudio = this.audioMap.get(id);
|
|
1650
|
-
if (!maybeAudio) {
|
|
1651
|
-
console.error(this.TAG + "Audio by id " + id + " dont exist");
|
|
1652
|
-
}
|
|
1653
|
-
return maybeAudio ?? false;
|
|
1654
|
-
}
|
|
1655
|
-
getVideoById(id) {
|
|
1656
|
-
const maybeVideo = this.videoMap.get(id);
|
|
1657
|
-
if (!maybeVideo) {
|
|
1658
|
-
console.error(this.TAG + "Video by id " + id + " dont exist");
|
|
1659
|
-
}
|
|
1660
|
-
return maybeVideo ?? false;
|
|
1661
|
-
}
|
|
1662
|
-
};
|
|
1663
|
-
|
|
1664
|
-
// src/common/result.ts
|
|
1665
|
-
var Ok = class _Ok {
|
|
1666
|
-
constructor(value) {
|
|
1667
|
-
this.value = value;
|
|
1668
|
-
}
|
|
1669
|
-
isOk() {
|
|
1670
|
-
return true;
|
|
1671
|
-
}
|
|
1672
|
-
isFailure() {
|
|
1673
|
-
return false;
|
|
1674
|
-
}
|
|
1675
|
-
map(f) {
|
|
1676
|
-
const value = f(this.value);
|
|
1677
|
-
return new _Ok(value);
|
|
1678
|
-
}
|
|
1679
|
-
};
|
|
1680
|
-
var Failure = class _Failure {
|
|
1681
|
-
constructor(message) {
|
|
1682
|
-
this.message = message;
|
|
1683
|
-
}
|
|
1684
|
-
isFailure() {
|
|
1685
|
-
return true;
|
|
1686
|
-
}
|
|
1687
|
-
isOk() {
|
|
1688
|
-
return false;
|
|
1689
|
-
}
|
|
1690
|
-
map(_f) {
|
|
1691
|
-
return new _Failure(this.message);
|
|
1692
|
-
}
|
|
1693
|
-
};
|
|
1694
|
-
var Result;
|
|
1695
|
-
((Result2) => {
|
|
1696
|
-
Result2.ok = (value) => new Ok(value);
|
|
1697
|
-
Result2.failure = (message) => new Failure(message);
|
|
1698
|
-
})(Result || (Result = {}));
|
|
1699
|
-
|
|
1700
|
-
// src/state/Dstate.ts
|
|
1701
|
-
var DState;
|
|
1702
|
-
((DState2) => {
|
|
1703
|
-
DState2.isNumberMutation = (mutations) => {
|
|
1704
|
-
if (!mutations) {
|
|
1705
|
-
return false;
|
|
1706
|
-
}
|
|
1707
|
-
return mutations.kind === "set-number" || mutations.kind === "decrement-number" || mutations.kind === "increment-number";
|
|
1708
|
-
};
|
|
1709
|
-
DState2.isStringMutation = (mutation) => {
|
|
1710
|
-
return mutation && mutation.kind === "set-string";
|
|
1711
|
-
};
|
|
1712
|
-
DState2.numericPropToFact = (prop, value) => {
|
|
1713
|
-
const fact = {
|
|
1714
|
-
kind: "numeric-fact",
|
|
1715
|
-
referenceId: prop.propName,
|
|
1716
|
-
referenceLabel: prop.propDescription ?? " [STATE_PROPERTY] : " + prop.propName,
|
|
1717
|
-
value,
|
|
1718
|
-
label: " [VALUE] : " + value
|
|
1719
|
-
};
|
|
1720
|
-
return fact;
|
|
1721
|
-
};
|
|
1722
|
-
DState2.stringPropToFact = (prop, value) => {
|
|
1723
|
-
const fact = {
|
|
1724
|
-
kind: "string-fact",
|
|
1725
|
-
referenceId: prop.propName,
|
|
1726
|
-
referenceLabel: " [STATE_PROPERTY] : " + prop.propName,
|
|
1727
|
-
value,
|
|
1728
|
-
label: " [VALUE] : " + value
|
|
1729
|
-
};
|
|
1730
|
-
return fact;
|
|
1731
|
-
};
|
|
1732
|
-
})(DState || (DState = {}));
|
|
1733
|
-
|
|
1734
|
-
// src/state/state-service.ts
|
|
1735
|
-
var StateService = class {
|
|
1736
|
-
constructor(eventBus, commandBus, props, queryList = []) {
|
|
1737
|
-
this.eventBus = eventBus;
|
|
1738
|
-
this.commandBus = commandBus;
|
|
1739
|
-
this.props = props;
|
|
1740
|
-
this.queryList = queryList;
|
|
1741
|
-
props.forEach((prop) => {
|
|
1742
|
-
this.registerProperty(prop);
|
|
1743
|
-
});
|
|
1744
|
-
const facts = this.getAllFacts();
|
|
1745
|
-
queryList.forEach((definition) => {
|
|
1746
|
-
this.registerQuery(definition, facts);
|
|
1747
|
-
});
|
|
1748
|
-
this.evaluateQueries();
|
|
1749
|
-
this.unsubscribeCommands = this.commandBus.subscribe((command) => {
|
|
1750
|
-
if (command.kind === "STATE_MUTATE_COMMAND") {
|
|
1751
|
-
this.mutation(command.payload.mutation);
|
|
1752
|
-
}
|
|
1753
|
-
}, this.TAG);
|
|
1754
|
-
}
|
|
1755
|
-
TAG = " [ STATE_SERVICE ] :";
|
|
1756
|
-
factsString = /* @__PURE__ */ new Map();
|
|
1757
|
-
factsNumeric = /* @__PURE__ */ new Map();
|
|
1758
|
-
propDefinitions = /* @__PURE__ */ new Map();
|
|
1759
|
-
queries = /* @__PURE__ */ new Map();
|
|
1760
|
-
unsubscribeCommands;
|
|
1761
|
-
destroy() {
|
|
1762
|
-
this.unsubscribeCommands();
|
|
1763
|
-
}
|
|
1764
|
-
registerQuery(query, currentFacts) {
|
|
1765
|
-
const result = Condition.evaluate(query.condition, currentFacts);
|
|
1766
|
-
this.queries.set(query.name, { query, lastResult: result });
|
|
1767
|
-
this.emitQueryChangedEvent({ queryName: query.name, prev: result, curr: result });
|
|
1768
|
-
}
|
|
1769
|
-
registerProperty(prop) {
|
|
1770
|
-
if (this.propDefinitions.has(prop.propName)) {
|
|
1771
|
-
console.warn("Prop excists already.", prop.propName);
|
|
1772
|
-
}
|
|
1773
|
-
this.propDefinitions.set(prop.propName, prop);
|
|
1774
|
-
if (prop.initialValue === void 0) {
|
|
1775
|
-
return;
|
|
1776
|
-
}
|
|
1777
|
-
if (prop._type === "string") {
|
|
1778
|
-
const fact = DState.stringPropToFact(prop, prop.initialValue);
|
|
1779
|
-
this.factsString.set(fact.referenceId, fact);
|
|
1780
|
-
}
|
|
1781
|
-
if (prop._type === "number") {
|
|
1782
|
-
const fact = DState.numericPropToFact(prop, prop.initialValue);
|
|
1783
|
-
this.factsNumeric.set(fact.referenceId, fact);
|
|
1784
|
-
}
|
|
1785
|
-
}
|
|
1786
|
-
mutateString(prop, value) {
|
|
1787
|
-
const curr = this.factsString.get(prop.propName);
|
|
1788
|
-
if (curr) {
|
|
1789
|
-
const updated = { ...curr, value };
|
|
1790
|
-
this.setFact(updated);
|
|
1791
|
-
} else {
|
|
1792
|
-
const created = {
|
|
1793
|
-
kind: "string-fact",
|
|
1794
|
-
referenceId: prop.propName,
|
|
1795
|
-
referenceLabel: "label for: " + prop.propName,
|
|
1796
|
-
value,
|
|
1797
|
-
label: "Value: " + value
|
|
1798
|
-
};
|
|
1799
|
-
this.setFact(created);
|
|
1800
|
-
}
|
|
1801
|
-
}
|
|
1802
|
-
mutateNumber(prop, mutation) {
|
|
1803
|
-
const curr = this.factsNumeric.get(prop.propName);
|
|
1804
|
-
if (!curr) {
|
|
1805
|
-
switch (mutation.kind) {
|
|
1806
|
-
case "set-number":
|
|
1807
|
-
this.setFact(DState.numericPropToFact(prop, mutation.value));
|
|
1808
|
-
break;
|
|
1809
|
-
case "decrement-number":
|
|
1810
|
-
this.setFact(DState.numericPropToFact(prop, mutation.ifNotExistThenSetTo));
|
|
1811
|
-
break;
|
|
1812
|
-
case "increment-number":
|
|
1813
|
-
this.setFact(DState.numericPropToFact(prop, mutation.ifNotExistThenSetTo));
|
|
1814
|
-
break;
|
|
1815
|
-
default:
|
|
1816
|
-
const check = mutation;
|
|
1817
|
-
}
|
|
1818
|
-
}
|
|
1819
|
-
if (curr) {
|
|
1820
|
-
switch (mutation.kind) {
|
|
1821
|
-
case "set-number":
|
|
1822
|
-
this.setFact({ ...curr, value: mutation.value });
|
|
1823
|
-
break;
|
|
1824
|
-
case "decrement-number":
|
|
1825
|
-
this.setFact({ ...curr, value: curr.value - mutation.stepSize });
|
|
1826
|
-
break;
|
|
1827
|
-
case "increment-number":
|
|
1828
|
-
this.setFact({ ...curr, value: curr.value + mutation.stepSize });
|
|
1829
|
-
break;
|
|
1830
|
-
default:
|
|
1831
|
-
const check = mutation;
|
|
1832
|
-
}
|
|
1833
|
-
}
|
|
1834
|
-
}
|
|
1835
|
-
evaluateQueries() {
|
|
1836
|
-
const facts = this.getAllFacts();
|
|
1837
|
-
const all = [];
|
|
1838
|
-
this.queries.forEach((q) => {
|
|
1839
|
-
const prev = q.lastResult;
|
|
1840
|
-
const curr = Condition.evaluate(q.query.condition, facts);
|
|
1841
|
-
const didChange = prev !== curr;
|
|
1842
|
-
q.lastResult = curr;
|
|
1843
|
-
all.push({ queryName: q.query.name, prev, curr, didChange });
|
|
1844
|
-
});
|
|
1845
|
-
return all;
|
|
1846
|
-
}
|
|
1847
|
-
mutation(mutation) {
|
|
1848
|
-
const propDef = this.propDefinitions.get(mutation.propName);
|
|
1849
|
-
if (!propDef) {
|
|
1850
|
-
return { success: false };
|
|
1851
|
-
}
|
|
1852
|
-
if (propDef._type === "string" && DState.isStringMutation(mutation)) {
|
|
1853
|
-
this.mutateString(propDef, mutation.value);
|
|
1854
|
-
}
|
|
1855
|
-
if (propDef._type === "number" && DState.isNumberMutation(mutation)) {
|
|
1856
|
-
this.mutateNumber(propDef, mutation);
|
|
1857
|
-
}
|
|
1858
|
-
const queryResults = this.evaluateQueries();
|
|
1859
|
-
const changedResult = queryResults.filter((r) => r.didChange);
|
|
1860
|
-
changedResult.forEach((res) => {
|
|
1861
|
-
this.emitQueryChangedEvent({ queryName: res.queryName, prev: res.prev, curr: res.curr });
|
|
1862
|
-
});
|
|
1863
|
-
return { success: true };
|
|
1864
|
-
}
|
|
1865
|
-
emitQueryChangedEvent(data) {
|
|
1866
|
-
const queryChangedEvent = {
|
|
1867
|
-
kind: "STATE_QUERY_RESULT_CHANGED_EVENT",
|
|
1868
|
-
producer: "STATE-SERVICE",
|
|
1869
|
-
producerId: "STATE-SERVICE",
|
|
1870
|
-
timestamp: DTimestamp.now(),
|
|
1871
|
-
data
|
|
1872
|
-
};
|
|
1873
|
-
const { queryName, curr, prev } = queryChangedEvent.data;
|
|
1874
|
-
this.eventBus.emit(queryChangedEvent);
|
|
1875
|
-
}
|
|
1876
|
-
getPropAsFact(propName) {
|
|
1877
|
-
const propDef = this.propDefinitions.get(propName);
|
|
1878
|
-
if (!propDef) {
|
|
1879
|
-
return Result.failure(
|
|
1880
|
-
"No definition form property ny name " + propName + " is registered. (Pass in constructor.)"
|
|
1881
|
-
);
|
|
1882
|
-
}
|
|
1883
|
-
const value = this.factsString.get(propName) ?? this.factsNumeric.get(propName);
|
|
1884
|
-
return value ? Result.ok(value) : Result.failure("Property " + propName + " has no value.");
|
|
1885
|
-
}
|
|
1886
|
-
setFact(fact) {
|
|
1887
|
-
switch (fact.kind) {
|
|
1888
|
-
case "numeric-fact":
|
|
1889
|
-
this.factsNumeric.set(fact.referenceId, fact);
|
|
1890
|
-
break;
|
|
1891
|
-
case "string-fact":
|
|
1892
|
-
this.factsString.set(fact.referenceId, fact);
|
|
1893
|
-
break;
|
|
1894
|
-
default:
|
|
1895
|
-
const check = fact;
|
|
1896
|
-
}
|
|
1897
|
-
}
|
|
1898
|
-
getState() {
|
|
1899
|
-
const props = {};
|
|
1900
|
-
this.propDefinitions.forEach((def) => {
|
|
1901
|
-
let value = null;
|
|
1902
|
-
const maybeFact = this.getAnyFact(def.propName);
|
|
1903
|
-
if (maybeFact) {
|
|
1904
|
-
value = maybeFact.value;
|
|
1905
|
-
}
|
|
1906
|
-
props[def.propName] = value;
|
|
1907
|
-
});
|
|
1908
|
-
this.queries.forEach((query) => {
|
|
1909
|
-
props[query.query.name] = query.lastResult;
|
|
1910
|
-
});
|
|
1911
|
-
const propNames = Object.keys(props);
|
|
1912
|
-
const propCount = propNames.length;
|
|
1913
|
-
const propArray = [...this.propDefinitions.values()];
|
|
1914
|
-
return { propCount, propNames, propArray, state: props };
|
|
1915
|
-
}
|
|
1916
|
-
getAnyFact(propName) {
|
|
1917
|
-
return this.factsString.get(propName) ?? this.factsNumeric.get(propName) ?? false;
|
|
1918
|
-
}
|
|
1919
|
-
getAllFacts() {
|
|
1920
|
-
return [...this.factsNumeric.values(), ...this.factsString.values()];
|
|
1921
|
-
}
|
|
1922
|
-
/**
|
|
1923
|
-
* Will check that all referenceIds used in Condition is registered as a valid property in state.
|
|
1924
|
-
* @param condition
|
|
1925
|
-
*/
|
|
1926
|
-
canBeMatched(condition) {
|
|
1927
|
-
const simpleConditions = Condition.getAllSimpleConditions(condition);
|
|
1928
|
-
let hasAll = true;
|
|
1929
|
-
const allIds = simpleConditions.map((c) => c.referenceId);
|
|
1930
|
-
const missingIds = [];
|
|
1931
|
-
allIds.forEach((id) => {
|
|
1932
|
-
if (!this.propDefinitions.has(id)) {
|
|
1933
|
-
hasAll = false;
|
|
1934
|
-
missingIds.push(id);
|
|
1935
|
-
}
|
|
1936
|
-
});
|
|
1937
|
-
console.log(this.TAG, missingIds);
|
|
1938
|
-
return hasAll;
|
|
1939
|
-
}
|
|
1940
|
-
isMatched(condition) {
|
|
1941
|
-
return Condition.evaluate(condition, this.getAllFacts());
|
|
1942
|
-
}
|
|
1943
|
-
};
|
|
1944
|
-
|
|
1945
|
-
// src/engine/SchemaEngine.ts
|
|
1946
|
-
var SchemaEngine = class {
|
|
1947
|
-
constructor(hostEl, height, width, schema) {
|
|
1948
|
-
this.height = height;
|
|
1949
|
-
this.width = width;
|
|
1950
|
-
this.schema = schema;
|
|
1951
|
-
this.hostElement = hostEl;
|
|
1952
|
-
this.hostElement.appendChild(this.uiContainer);
|
|
1953
|
-
this.hostElement.appendChild(this.mediaContainer);
|
|
1954
|
-
const stateProps = this.schema.stateProps ?? [];
|
|
1955
|
-
const stateQueries = this.schema.stateQueries ?? [];
|
|
1956
|
-
this.stateService = new StateService(this.eventBus, this.commandBus, stateProps, stateQueries);
|
|
1957
|
-
this.scale = new ScaleService({
|
|
1958
|
-
baseHeight: schema.baseHeight,
|
|
1959
|
-
baseWidth: schema.baseWidth,
|
|
1960
|
-
containerWidth: width,
|
|
1961
|
-
containerHeight: height
|
|
1962
|
-
});
|
|
1963
|
-
const globalEventHandlers = schema.stateFromEvent ?? [];
|
|
1964
|
-
globalEventHandlers.forEach((h) => {
|
|
1965
|
-
this.globalEventToStateHandlers.set(h.onEvent, h.thenExecute);
|
|
1966
|
-
});
|
|
1967
|
-
const resources = SchemaDto.getResources(this.schema);
|
|
1968
|
-
this.resourceProvider = new ResourceProvider({ videos: resources.videoList, audio: resources.audioList });
|
|
1969
|
-
this.mediaManager = new DMediaManager(
|
|
1970
|
-
this.mediaContainer,
|
|
1971
|
-
this.commandBus,
|
|
1972
|
-
this.eventBus,
|
|
1973
|
-
this.resourceProvider,
|
|
1974
|
-
this.scale
|
|
1975
|
-
);
|
|
1976
|
-
this.player = new DPlayer(this.schema);
|
|
1977
|
-
this.styleSelf();
|
|
1978
|
-
this.nextPage();
|
|
1979
|
-
this.hookUpListeners();
|
|
1980
|
-
}
|
|
1981
|
-
TAG = "[ SCHEMA_ENGINE ] :";
|
|
1982
|
-
commandBus = new DCommandBus();
|
|
1983
|
-
eventBus = new EventBus();
|
|
1984
|
-
mediaManager;
|
|
1985
|
-
scale;
|
|
1986
|
-
hostElement;
|
|
1987
|
-
uiContainer = document.createElement("div");
|
|
1988
|
-
mediaContainer = document.createElement("div");
|
|
1989
|
-
resourceProvider;
|
|
1990
|
-
stateService;
|
|
1991
|
-
globalEventToStateHandlers = /* @__PURE__ */ new Map();
|
|
1992
|
-
player;
|
|
1993
|
-
currentPage = false;
|
|
1994
|
-
subs = [];
|
|
1995
|
-
hookUpListeners() {
|
|
1996
|
-
const eventSubscription = this.eventBus.subscribe((ev) => {
|
|
1997
|
-
this.onCommandOrEvent(ev);
|
|
1998
|
-
const globalHandlers = this.globalEventToStateHandlers.get(ev.kind) ?? [];
|
|
1999
|
-
globalHandlers.forEach((stateCommand) => {
|
|
2000
|
-
this.commandBus.emit(stateCommand);
|
|
2001
|
-
});
|
|
2002
|
-
}, this.TAG + "HOOK_UP_LISTENERS");
|
|
2003
|
-
const commandSubscription = this.commandBus.subscribe((command) => {
|
|
2004
|
-
this.onCommandOrEvent(command);
|
|
2005
|
-
if (command.kind === "PAGE_QUE_NEXT_PAGE_COMMAND") {
|
|
2006
|
-
this.nextPage();
|
|
2007
|
-
}
|
|
2008
|
-
if (command.kind === "ENGINE_LEAVE_PAGE_COMMAND") {
|
|
2009
|
-
console.log(this.TAG + "SEQUENCE STARTED -- TODO EVENT FOR THIS??");
|
|
2010
|
-
console.log(command);
|
|
2011
|
-
const pageId = command.payload.pageId;
|
|
2012
|
-
const facts = command.payload.factsCollected;
|
|
2013
|
-
const timestamp = DTimestamp.now();
|
|
2014
|
-
const ans = facts.map((f) => ({
|
|
2015
|
-
timestamp,
|
|
2016
|
-
fact: f
|
|
2017
|
-
}));
|
|
2018
|
-
this.player.saveHistory({
|
|
2019
|
-
answeredQuestions: ans,
|
|
2020
|
-
pageId
|
|
2021
|
-
});
|
|
2022
|
-
this.nextPage();
|
|
2023
|
-
}
|
|
2024
|
-
}, this.TAG);
|
|
2025
|
-
this.subs.push(commandSubscription);
|
|
2026
|
-
this.subs.push(eventSubscription);
|
|
2027
|
-
}
|
|
2028
|
-
styleSelf() {
|
|
2029
|
-
this.hostElement.style.height = this.scale.pageHeight + "px";
|
|
2030
|
-
this.hostElement.style.width = this.scale.pageWidth + "px";
|
|
2031
|
-
this.hostElement.style.backgroundColor = this.schema.backgroundColor ?? "white";
|
|
2032
|
-
this.hostElement.style.position = "relative";
|
|
2033
|
-
const makeStatic = (div) => {
|
|
2034
|
-
div.style.height = "0px";
|
|
2035
|
-
div.style.width = "0px";
|
|
2036
|
-
div.style.position = "static";
|
|
2037
|
-
};
|
|
2038
|
-
makeStatic(this.uiContainer);
|
|
2039
|
-
makeStatic(this.mediaContainer);
|
|
2040
|
-
}
|
|
2041
|
-
nextPage() {
|
|
2042
|
-
this.mediaManager.clearAllMedia();
|
|
2043
|
-
const nextPage = this.player.getNextPage();
|
|
2044
|
-
if (this.currentPage) {
|
|
2045
|
-
this.currentPage.destroy();
|
|
2046
|
-
this.uiContainer.innerHTML = "";
|
|
2047
|
-
}
|
|
2048
|
-
if (!nextPage) {
|
|
2049
|
-
this.player = new DPlayer(this.schema);
|
|
2050
|
-
if (this.schema.pages.length > 0) {
|
|
2051
|
-
this.nextPage();
|
|
2052
|
-
}
|
|
2053
|
-
return false;
|
|
2054
|
-
}
|
|
2055
|
-
const newPage = new DPage(nextPage, this.eventBus, this.commandBus, this.scale);
|
|
2056
|
-
this.currentPage = newPage;
|
|
2057
|
-
newPage.appendYourself(this.uiContainer);
|
|
2058
|
-
this.mediaManager.setPage(nextPage);
|
|
2059
|
-
const s1 = this.stateService.getState();
|
|
2060
|
-
return true;
|
|
2061
|
-
}
|
|
2062
|
-
destroy() {
|
|
2063
|
-
if (this.currentPage) {
|
|
2064
|
-
this.currentPage.destroy();
|
|
2065
|
-
this.uiContainer.innerHTML = "";
|
|
2066
|
-
}
|
|
2067
|
-
this.mediaManager.destroy();
|
|
2068
|
-
this.stateService.destroy();
|
|
2069
|
-
this.subs.forEach((sub) => {
|
|
2070
|
-
sub();
|
|
2071
|
-
});
|
|
2072
|
-
const evStats = this.eventBus.getStats();
|
|
2073
|
-
const cmdStats = this.commandBus.getStats();
|
|
2074
|
-
console.assert(evStats.subscribersCount === 0, this.TAG + " Eventbus should have no subscribers ", evStats);
|
|
2075
|
-
console.assert(cmdStats.subscribersCount === 0, this.TAG + "Commandbus should have no subscribers", cmdStats);
|
|
2076
|
-
}
|
|
2077
|
-
onComplete(handler) {
|
|
2078
|
-
console.log(handler);
|
|
2079
|
-
}
|
|
2080
|
-
onFatalError(handler) {
|
|
2081
|
-
console.log(handler);
|
|
2082
|
-
}
|
|
2083
|
-
onCommandOrEvent(_event_or_command) {
|
|
2084
|
-
}
|
|
2085
|
-
setSchema(schema) {
|
|
2086
|
-
console.log(schema);
|
|
2087
|
-
}
|
|
2088
|
-
};
|
|
2089
|
-
|
|
2090
|
-
// src/state/boolean-property.ts
|
|
2091
|
-
var BooleanStateProperty = class _BooleanStateProperty {
|
|
2092
|
-
constructor(propName, initialValue, description) {
|
|
2093
|
-
this.initialValue = initialValue;
|
|
2094
|
-
this.propName = propName;
|
|
2095
|
-
const initial = initialValue ? 1 : 0;
|
|
2096
|
-
const propDescription = description ? description : "No description given";
|
|
2097
|
-
this.propDefinition = {
|
|
2098
|
-
propDescription,
|
|
2099
|
-
propName,
|
|
2100
|
-
initialValue: initial,
|
|
2101
|
-
options: [
|
|
2102
|
-
{ value: _BooleanStateProperty.FALSE.value, valueLabel: _BooleanStateProperty.FALSE.label },
|
|
2103
|
-
{ value: _BooleanStateProperty.TRUE.value, valueLabel: _BooleanStateProperty.TRUE.label }
|
|
2104
|
-
],
|
|
2105
|
-
_type: "number"
|
|
2106
|
-
};
|
|
2107
|
-
}
|
|
2108
|
-
propName;
|
|
2109
|
-
static TRUE = { value: 1, label: "TRUE" };
|
|
2110
|
-
static FALSE = { value: 0, label: "FALSE" };
|
|
2111
|
-
propDefinition;
|
|
2112
|
-
getIsTrueCondition() {
|
|
2113
|
-
return {
|
|
2114
|
-
kind: "numeric-condition",
|
|
2115
|
-
referenceId: this.propName,
|
|
2116
|
-
referenceLabel: this.propName + "[ BOOLEAN ]",
|
|
2117
|
-
valueLabel: _BooleanStateProperty.TRUE.label,
|
|
2118
|
-
value: _BooleanStateProperty.TRUE.value,
|
|
2119
|
-
operator: "eq"
|
|
2120
|
-
};
|
|
2121
|
-
}
|
|
2122
|
-
getIsFalseCondition() {
|
|
2123
|
-
return {
|
|
2124
|
-
kind: "numeric-condition",
|
|
2125
|
-
referenceId: this.propName,
|
|
2126
|
-
referenceLabel: this.propName + "[ BOOLEAN ]",
|
|
2127
|
-
valueLabel: _BooleanStateProperty.FALSE.label,
|
|
2128
|
-
value: _BooleanStateProperty.FALSE.value,
|
|
2129
|
-
operator: "eq"
|
|
2130
|
-
};
|
|
2131
|
-
}
|
|
2132
|
-
getSetTrueCommand() {
|
|
2133
|
-
return {
|
|
2134
|
-
kind: "STATE_MUTATE_COMMAND",
|
|
2135
|
-
target: "STATE",
|
|
2136
|
-
targetId: "STATE",
|
|
2137
|
-
payload: {
|
|
2138
|
-
mutation: { propName: this.propName, kind: "set-number", value: 1 }
|
|
2139
|
-
}
|
|
2140
|
-
};
|
|
2141
|
-
}
|
|
2142
|
-
getSetFalseCommand() {
|
|
2143
|
-
return {
|
|
2144
|
-
kind: "STATE_MUTATE_COMMAND",
|
|
2145
|
-
target: "STATE",
|
|
2146
|
-
targetId: "STATE",
|
|
2147
|
-
payload: {
|
|
2148
|
-
mutation: { propName: this.propName, kind: "set-number", value: 0 }
|
|
2149
|
-
}
|
|
2150
|
-
};
|
|
2151
|
-
}
|
|
2152
|
-
};
|
|
2153
|
-
|
|
2154
|
-
// src/utils/ID.ts
|
|
2155
|
-
var ID_LENGTH = 32;
|
|
2156
|
-
var MIN_LENGTH = 10;
|
|
2157
|
-
var isID = (idName, id) => {
|
|
2158
|
-
if (typeof id !== "string")
|
|
2159
|
-
return false;
|
|
2160
|
-
return id.length >= MIN_LENGTH;
|
|
2161
|
-
};
|
|
2162
|
-
var createIDByName = (idName) => {
|
|
2163
|
-
const letters = "abcdefghijklmnopqrstuvyz";
|
|
2164
|
-
const all = letters + letters.toUpperCase();
|
|
2165
|
-
let result = "";
|
|
2166
|
-
for (let i = 0; i < ID_LENGTH; i++) {
|
|
2167
|
-
const char = all.charAt(Math.floor(Math.random() * all.length));
|
|
2168
|
-
result += char;
|
|
2169
|
-
}
|
|
2170
|
-
return result;
|
|
2171
|
-
};
|
|
2172
|
-
var createTypedIdSingleton = (idName) => {
|
|
2173
|
-
const create = () => createIDByName(idName);
|
|
2174
|
-
const is = (id) => isID(idName, id);
|
|
2175
|
-
const validateOrThrow = (id) => {
|
|
2176
|
-
if (!is(id)) {
|
|
2177
|
-
throw new Error(`Invalid id: ${id}`);
|
|
2178
|
-
}
|
|
2179
|
-
return id;
|
|
2180
|
-
};
|
|
2181
|
-
const name = idName;
|
|
2182
|
-
const ensure = (id) => {
|
|
2183
|
-
return is(id) ? id : create();
|
|
2184
|
-
};
|
|
2185
|
-
return Object.freeze({ create, is, ensure, validateOrThrow, name });
|
|
2186
|
-
};
|
|
2187
|
-
var SchemaID = createTypedIdSingleton("SCHEMA");
|
|
2188
|
-
var PageID = createTypedIdSingleton("PAGE");
|
|
2189
|
-
export {
|
|
2190
|
-
BooleanStateProperty,
|
|
2191
|
-
Condition,
|
|
2192
|
-
DCss,
|
|
2193
|
-
DEventHandler,
|
|
2194
|
-
DState,
|
|
2195
|
-
DStyle,
|
|
2196
|
-
DUtil,
|
|
2197
|
-
PageID,
|
|
2198
|
-
Rule,
|
|
2199
|
-
RuleEngine,
|
|
2200
|
-
SchemaDto,
|
|
2201
|
-
SchemaEngine,
|
|
2202
|
-
SchemaID,
|
|
2203
|
-
createTypedIdSingleton
|
|
2204
|
-
};
|
|
2205
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/dto/SchemaDto.ts", "../src/common/DTimestamp.ts", "../src/utils/DUtil.ts", "../src/Delement/css.ts", "../src/Delement/DStyle.ts", "../src/Delement/VideoContainer.ts", "../src/Delement/AudioContainer.ts", "../src/services/DMedia-manager.ts", "../src/commands/DCommandBus.ts", "../src/events/event-bus.ts", "../src/player/history-que.ts", "../src/rules/condition.ts", "../src/rules/rule.ts", "../src/rules/rule-engine.ts", "../src/player/next-que.ts", "../src/player/dplayer.ts", "../src/event-handlers/DEventHandler.ts", "../src/Delement/DElement.ts", "../src/Delement/Ddiv.ts", "../src/Delement/DImg.ts", "../src/Delement/DText.ts", "../src/engine/element-factory.ts", "../src/engine/DPage.ts", "../src/engine/scale.ts", "../src/services/resource-provider.ts", "../src/common/result.ts", "../src/state/Dstate.ts", "../src/state/state-service.ts", "../src/engine/SchemaEngine.ts", "../src/state/boolean-property.ts", "../src/utils/ID.ts"],
  "sourcesContent": ["import { DAutoPlaySequence } from \"../Delement/DAuto-play\";\nimport { DAudioDto, DElementDto, DImgDto, DVideoDto } from \"./DElement.dto\";\nimport { Rule } from \"../rules/rule\";\nimport { Fact } from \"../rules/fact\";\nimport { PageQueCommand } from \"../commands/DCommand\";\nimport { DState } from \"../state/Dstate\";\nimport { PageID, SchemaID } from \"../utils/ID\";\n\nexport type PageQueRules = Rule<PageQueCommand, never>;\nexport interface PageDto {\n  readonly id: PageID;\n  readonly elements: Array<DElementDto>;\n  readonly tags?: string[];\n  readonly mainVideoId?: string;\n  readonly backgroundColor?: string;\n  readonly video?: Array<DVideoDto>;\n  readonly audio?: Array<DAudioDto>;\n  readonly autoPlaySequence?: DAutoPlaySequence;\n}\n\nexport interface PageSequenceDto {\n  readonly id: string;\n  readonly rules: Array<PageQueRules>;\n  readonly pages: Array<PageDto>;\n}\n\nexport interface SchemaDto {\n  readonly id: SchemaID;\n  readonly baseHeight: number;\n  readonly baseWidth: number;\n  readonly backgroundColor: string;\n  readonly pages: PageDto[];\n  readonly rules: Array<PageQueRules>;\n  readonly stateProps?: ReadonlyArray<DState.Prop>;\n  readonly stateQueries?: ReadonlyArray<DState.StateQuery>;\n  readonly stateFromEvent: ReadonlyArray<DState.fromEventHandler>;\n  readonly pageSequences?: Array<PageSequenceDto>;\n  readonly predefinedFacts?: ReadonlyArray<Fact>;\n}\n\nexport namespace SchemaDto {\n  export const getResources = (\n    schema: SchemaDto,\n  ): {\n    videoList: ReadonlyArray<DVideoDto>;\n    audioList: ReadonlyArray<DAudioDto>;\n    imageList: ReadonlyArray<DImgDto>;\n  } => {\n    const { pages } = schema;\n    const videoList = pages.reduce<Array<DVideoDto>>((acc, curr) => {\n      if (Array.isArray(curr.video)) {\n        acc.push(...curr.video);\n      }\n      return acc;\n    }, []);\n    const audioList: Array<DAudioDto> = pages.reduce<Array<DAudioDto>>((acc, curr) => {\n      if (Array.isArray(curr.audio)) {\n        acc.push(...curr.audio);\n      }\n      return acc;\n    }, []);\n\n    return { videoList, audioList, imageList: [] };\n  };\n}\n", "export type DTimestamp = number & { __timestamp__: true };\nexport namespace DTimestamp {\n    export const now = () => Date.now() as DTimestamp;\n    export type Diff = number & { __diff__: true };\n\n    export const addMills = (t: DTimestamp, ms: number): DTimestamp => {\n        const res = t + Math.abs(ms);\n        return res as DTimestamp;\n    };\n\n    export const diff = (t1: DTimestamp, t2: DTimestamp): Diff => {\n        const t1Abs = Math.abs(t1);\n        const t2Abs = Math.abs(t2);\n        return Math.abs(t1Abs - t2Abs) as Diff;\n    };\n\n    export const diffNow = (t: DTimestamp): Diff => {\n        return diff(t, now());\n    };\n}\n", "export type RandomObjectId = string & { randomObjectId: true };\nexport namespace DUtil {\n    export const randomString = (length: number): string => {\n        const letters = \"abcdefghijklmnopqrstuvxyz\";\n        const uppercase = letters.toUpperCase();\n        const all = letters + uppercase;\n        const abs = Math.abs(length);\n        let result = \"\";\n\n        for (let i = 0; i < abs; i++) {\n            const char = all.charAt(Math.floor(Math.random() * all.length));\n            result += char;\n        }\n        return result;\n    };\n\n    export const randomObjectId = () => randomString(32) as RandomObjectId;\n\n    export const deleteProp = <Obj, Key extends keyof Obj>(obj: Obj, key: Key): Omit<Obj, Key> => {\n        delete obj[key];\n        return obj;\n    };\n\n    export const isInRange = (min: number, max: number) => {\n        return (value: number) => value >= min && value <= max;\n    };\n    export const isInfinity = (number: number) => {\n        return number === Number.POSITIVE_INFINITY || number === Number.NEGATIVE_INFINITY || number === Infinity;\n    };\n    export type NonEmptyArray<T> = [T, ...T[]];\n    export const isNonEmptyArray = <T>(array: Array<T>): array is NonEmptyArray<T> => {\n        return array.length > 0;\n    };\n\n    export const neverCheck = (args: never) => {\n        console.log(\"OOPS: This value slipped through the never-check\", args);\n    };\n\n    export const isString = (str: unknown): str is string => typeof str === \"string\";\n\n    export const hasKey = <T extends string>(obj: unknown, key: T): obj is Record<typeof key, unknown> => {\n        if (!isRecord(obj)) {\n            return false;\n        }\n        return Object.prototype.hasOwnProperty.call(obj, key);\n    };\n\n    export const isRecord = (obj: unknown): obj is Record<string, unknown> => {\n        if (!obj) {\n            return false;\n        }\n\n        if (Array.isArray(obj)) {\n            return false;\n        }\n\n        if (typeof obj !== \"object\") {\n            return false;\n        }\n\n        if (obj === null) {\n            return false;\n        }\n        return true;\n    };\n\n    export const isBool = (obj: boolean): obj is boolean => typeof obj === \"boolean\";\n\n    export const isTrue = (bool: boolean): bool is true => bool === true;\n\n    export const isFalse = (bool: boolean): bool is false => bool === false;\n\n    export const isDefined = (obj: unknown): boolean => {\n        const notNull = obj !== null;\n        const notUndefined = obj !== undefined;\n        return notNull && notUndefined;\n    };\n\n    export const hasKind = (obj: unknown): obj is { readonly kind: string } => {\n        if (!hasKey(obj, \"kind\")) {\n            return false;\n        }\n        if (typeof obj.kind !== \"string\") {\n            return false;\n        }\n        return obj.kind.length > 0;\n    };\n\n    export const hasValue = (obj: unknown): obj is { value: unknown } => {\n        return hasKey(obj, \"value\");\n    };\n    export const isNumber = (value?: number): value is number => {\n        const isNumber = typeof value === \"number\";\n        const notNaN = !Number.isNaN(value);\n        return isNumber && notNaN;\n    };\n\n    export const maxFn = (upperLimit: number) => {\n        return (value: number) => {\n            return Math.min(value, upperLimit);\n        };\n    };\n\n    export const minFn = (lowerLimit: number) => {\n        return (value: number) => {\n            return Math.min(value, lowerLimit);\n        };\n    };\n}\n", "import { DUtil } from \"../utils/DUtil\";\n\nexport namespace DCss {\n    export interface Px {\n        readonly _unit: \"px\";\n        readonly value: number;\n    }\n\n    export type LengthString = `${number}px` | `${number}%`;\n    export interface Percent {\n        readonly _unit: \"percent\";\n        readonly value: number;\n    }\n\n    export type LengthUnit = Px | Percent;\n\n    /**\n     * Will scale to 3% of baseScale\n     * @param unit\n     * @param scale\n     */\n    export const toString = (unit: Readonly<LengthUnit>, scale: number): LengthString => {\n        const clampedScale = Math.max(scale, 0.03);\n        if (unit._unit === \"px\") {\n            if (unit.value < 0.1) {\n                return \"0px\";\n            }\n\n            const rounded = Math.round(unit.value * clampedScale);\n            const clamped = Math.max(rounded, 1);\n            return (clamped + \"px\") as LengthString;\n        }\n        return (unit.value + \"%\") as LengthString;\n    };\n\n    export const isLengthUnit = (unit?: LengthUnit): unit is LengthUnit => {\n        if (!unit) {\n            return false;\n        }\n        const unitKey: keyof LengthUnit = \"_unit\";\n        const valueKey: keyof LengthUnit = \"value\";\n        const hasUnitKey = DUtil.hasKey(unit, unitKey);\n        const hasValueKey = DUtil.hasKey(unit, valueKey);\n        return hasUnitKey && hasValueKey;\n    };\n}\n", "import { DCss } from \"./css\";\nimport { ElementKeyNames } from \"./DStyle-utils\";\nimport { DUtil } from \"../utils/DUtil\";\n\ntype DStyle2 = CSSStyleDeclaration;\nexport interface DStyle {\n    opacity: number;\n    backgroundColor: string;\n    visibility: \"visible\" | \"hidden\";\n    cursor:\n        | \"pointer\"\n        | \"help\"\n        | \"copy\"\n        | \"wait\"\n        | \"not-allowed\"\n        | \"context-menu\"\n        | \"move\"\n        | \"grabbing\"\n        | \"grab\"\n        | \"zoom-in\"\n        | \"zoom-out\"\n        | \"none\"\n        | \"auto\"\n        | \"default\";\n\n    // POSITION\n    h: number;\n    w: number;\n    x: number;\n    y: number;\n\n    // BORDERS\n    borderStyle: \"solid\" | \"none\" | \"dotted\" | \"dashed\";\n    borderRadius: DCss.Px | DCss.Percent;\n    borderWidth: DCss.Px;\n    borderColor: string;\n\n    margin: DCss.Px | DCss.Percent;\n    padding: DCss.Px | DCss.Percent;\n\n    // Translate\n    transform: string;\n    translate: string;\n\n    // TEXT\n    fontSize: DCss.Px;\n    textColor: string;\n    fontWeight: 100 | 200 | 300 | 400 | 500 | 600 | 700 | 800 | 900;\n    textAlign: \"right\" | \"left\" | \"center\";\n    letterSpacing: DCss.Px;\n}\n\nexport namespace DStyle {\n    export const normalize = <T extends HTMLElement>(el: T): T => {\n        el.style.padding = \"0\";\n        el.style.margin = \"0\";\n        el.style.position = \"absolute\";\n        el.style.boxSizing = \"border-box\";\n        return el;\n    };\n\n    export const applyStyles = <T extends HTMLElement>(el: T, style: Partial<DStyle>, scale: number): T => {\n        // const scalePx = DCss.toStringCre(this.scale);\n        const {\n            x,\n            y,\n            backgroundColor,\n            borderColor,\n            borderWidth,\n            borderRadius,\n            borderStyle,\n            w,\n            opacity,\n            cursor,\n            fontSize,\n            fontWeight,\n            textColor,\n            textAlign,\n            translate,\n            margin,\n            padding,\n            letterSpacing,\n            h,\n            transform,\n            visibility,\n        } = style;\n\n        // this.el.style.fontWeight = '900';\n        if (backgroundColor) {\n            el.style.backgroundColor = backgroundColor;\n        }\n\n        if (cursor) {\n            el.style.cursor = cursor;\n        }\n\n        if (transform) {\n            el.style.transform = transform;\n        }\n\n        if (textColor) {\n            el.style.color = textColor;\n        }\n        if (textAlign) {\n            el.style.textAlign = textAlign;\n        }\n\n        if (borderColor) {\n            el.style.borderColor = borderColor;\n        }\n\n        if (borderWidth) {\n            el.style.borderWidth = DCss.toString(borderWidth, scale);\n        }\n        if (fontWeight) {\n            el.style.fontWeight = fontWeight + \"\";\n        }\n        if (borderStyle) {\n            el.style.borderStyle = borderStyle;\n        }\n        if (fontSize) {\n            el.style.fontSize = DCss.toString(fontSize, scale);\n        }\n\n        if (DUtil.isNumber(x)) {\n            el.style.left = x + \"%\";\n        }\n        if (DUtil.isNumber(y)) {\n            el.style.bottom = y + \"%\";\n        }\n\n        if (DUtil.isNumber(h)) {\n            el.style.height = h + \"%\";\n        }\n        if (DUtil.isNumber(w)) {\n            el.style.width = w + \"%\";\n        }\n\n        if (DCss.isLengthUnit(borderRadius)) {\n            el.style.borderRadius = DCss.toString(borderRadius, scale);\n        }\n\n        if (letterSpacing) {\n            el.style.letterSpacing = DCss.toString(letterSpacing, scale);\n        }\n        if (margin) {\n            el.style.margin = DCss.toString(margin, scale);\n        }\n        if (padding) {\n            el.style.padding = DCss.toString(padding, scale);\n        }\n\n        if (DUtil.isNumber(opacity)) {\n            el.style.opacity = opacity + \"\";\n        }\n\n        if (visibility) {\n            el.style.visibility = visibility;\n        }\n\n        return el;\n    };\n    // const propNames = new Set(...ElementKeyNames);\n    // export const validKey = (keyName: string) => propNames.has(keyName);\n}\n", "import { DVideoDto } from \"../dto/DElement.dto\";\nimport { DTimestamp } from \"../common/DTimestamp\";\nimport { DEventDispatcher } from \"../events/event-bus\";\nimport { ScaleService } from \"../engine/scale\";\nimport { DStyle } from \"./DStyle\";\nimport { DUtil } from \"../utils/DUtil\";\n\nconst ABORT_PLAY_TO_END = \"ABORT_PLAY_TO_END\";\nexport interface CanPlayToEnd {\n    playToEnd(): Promise<boolean>;\n}\n\nexport class VideoContainer implements CanPlayToEnd {\n    private readonly TAG: string;\n    private dto?: DVideoDto;\n    private defaultStyles: Partial<DStyle> = { h: 45, w: 100, visibility: \"hidden\", y: 55 };\n\n    pause() {\n        this.eventBus.emit({\n            kind: \"VIDEO_PAUSED_EVENT\",\n            data: {},\n            producer: \"DVideo\",\n            producerId: this.id,\n            timestamp: DTimestamp.now(),\n        });\n        this.el.pause();\n    }\n\n    play(url: string) {\n        if (this.el.src !== url) {\n            this.el.src = url;\n        }\n        const producerId = this.dto?.id ?? \"DVideo\";\n        this.eventBus.emit({\n            kind: \"VIDEO_PLAY_EVENT\",\n            data: {},\n            producer: \"DVideo\",\n            producerId,\n            timestamp: DTimestamp.now(),\n        });\n        this.el\n            .play()\n            .then((res) => {\n                console.log(res);\n            })\n            .catch((e) => {\n                console.log(e);\n            });\n        // if(this.el.src !== url) {\n        //     this.\n        // }\n    }\n\n    async playToEnd() {\n        this.el.volume = 1;\n        const url = this.dto?.url;\n        if (!url) {\n            return false;\n        }\n\n        try {\n            const endedOrErrored = new Promise<boolean>((resolve, reject) => {\n                this.el.addEventListener(\n                    \"ended\",\n                    (_) => {\n                        resolve(true);\n                    },\n                    { once: true }\n                );\n                this.el.addEventListener(\n                    \"error\",\n                    (_) => {\n                        resolve(false);\n                    },\n                    { once: true }\n                );\n                this.el.addEventListener(\n                    ABORT_PLAY_TO_END,\n                    () => {\n                        console.log(\"CATCHED ABBORT.\");\n                        reject(\"Aborted\");\n                    },\n                    { once: true }\n                );\n            });\n            // console.log(\"PLAY\");\n            this.play(url);\n            await endedOrErrored;\n            return true;\n        } catch (e) {\n            console.log(e);\n            return false;\n        } finally {\n            console.log(this.TAG + \" finally block playToEnd() completed videoId: \" + this.dto?.id);\n        }\n    }\n\n    constructor(\n        private readonly el: HTMLVideoElement,\n        private readonly eventBus: DEventDispatcher,\n        private readonly scale: ScaleService // dto?: DVideoDto\n    ) {\n        this.TAG = \"[ D_Video ] : \";\n        this.el.controls = false;\n        DStyle.normalize(this.el);\n        DStyle.applyStyles(this.el, this.defaultStyles, this.scale.scale);\n\n        this.el.onended = () => {\n            this.eventBus.emit({\n                kind: \"VIDEO_ENDED_EVENT\",\n                timestamp: DTimestamp.now(),\n                producer: \"DVideo\",\n                producerId: this.id,\n                data: {},\n            });\n        };\n        this.el.onplay = () => {\n            // TODO LOGG INTERNAL STATE_CHANGES.\n        };\n\n        this.el.onpause = () => {};\n        this.el.onerror = () => {};\n        this.el.oncanplay = () => {\n            // console.groupCollapsed(this.TAG + \"READY TO PLAY\");\n            // console.log(\"Duration: \" + this.el.duration);\n            // console.log(\"Id: \" + this.id);\n            // console.log(\"Current Time: \" + this.el.currentTime);\n            // console.log(\"AudoPlay: \" + this.el.autoplay);\n            // console.groupEnd();\n        };\n        this.el.onloadedmetadata = () => {\n            const duration = this.el.duration;\n            const isInfinity = DUtil.isInfinity(duration);\n            this.eventBus.emit({\n                kind: \"VIDEO_LOADED_METADATA_EVENT\",\n                timestamp: DTimestamp.now(),\n                producer: \"DVideo\",\n                producerId: this.id,\n                data: { duration, isInfinity },\n            });\n        };\n        // TODO USE THIS SYNTAX?\n        this.el.ondurationchange = () => {\n            const duration = this.el.duration;\n            const isInfinity = DUtil.isInfinity(duration);\n            this.eventBus.emit({\n                kind: \"VIDEO_DURATION_CHANGE_EVENT\",\n                producer: \"DVideo\",\n                producerId: this.id,\n                timestamp: DTimestamp.now(),\n                data: { duration, isInfinity },\n            });\n        };\n    }\n\n    getStats() {\n        const duration = this.el.duration;\n        const currentTime = this.el.currentTime;\n        const volume = this.el.volume;\n        const isConnected = this.el.isConnected;\n        const playbackQuality = this.el.getVideoPlaybackQuality();\n        const defaultPlaybackRate = this.el.defaultPlaybackRate;\n        const paused = this.el.paused;\n        const played = this.el.played;\n\n        return {\n            duration,\n            paused,\n            played,\n            currentTime,\n            volume,\n            isConnected,\n            playbackQuality,\n            defaultPlaybackRate,\n        };\n    }\n\n    setDto(dto: DVideoDto) {\n        this.dto = dto;\n        this.el.volume = 1;\n        this.setStyle(dto.style);\n        this.el.src = dto.url;\n        this.el.load();\n    }\n\n    getCurrentDto(): DVideoDto | false {\n        return this.dto ?? false;\n    }\n\n    setStyle(styles: Partial<DStyle>) {\n        DStyle.applyStyles(this.el, styles, this.scale.scale);\n    }\n\n    private get id() {\n        return this.dto?.id ?? \"DVideo\";\n    }\n\n    destroy() {}\n}\n", "import { CanPlayToEnd } from \"./VideoContainer\";\nimport { DAudioDto } from \"../dto/DElement.dto\";\nimport { DEventDispatcher } from \"../events/event-bus\";\nimport { DTimestamp } from \"../common/DTimestamp\";\n\nexport class AudioContainer implements CanPlayToEnd {\n    private readonly TAG = \"[ DAudio ]: \";\n    protected dto: DAudioDto | null = null;\n    private el: HTMLAudioElement;\n    constructor(private readonly eventBus: DEventDispatcher) {\n        this.el = document.createElement(\"audio\");\n        this.el.style.position = \"absolute\";\n        this.el.style.visibility = \"hidden\";\n        // this.el.on\n        this.onLoad = this.onLoad.bind(this);\n        this.el.onload = this.onLoad;\n        this.onLoadedMetadata = this.onLoadedMetadata.bind(this);\n        this.el.onloadedmetadata = this.onLoadedMetadata;\n        this.el.onplay = () => {\n            // TODO\n        };\n        this.onCanPlayThrough = this.onCanPlayThrough.bind(this);\n        this.el.oncanplaythrough = this.onCanPlayThrough;\n        this.el.onended = (_) => {\n            const url = this.el.src;\n            this.eventBus.emit({\n                kind: \"AUDIO_ENDED_EVENT\",\n                data: { url },\n                producer: \"DAudio\",\n                timestamp: DTimestamp.now(),\n                producerId: this.id,\n            });\n        };\n        this.el.ondurationchange = (_: Event) => {\n            const duration = this.el.duration;\n            const isInfinity = duration === Number.POSITIVE_INFINITY;\n            this.eventBus.emit({\n                kind: \"AUDIO_DURATION_CHANGE_EVENT\",\n                timestamp: DTimestamp.now(),\n                producer: \"DAudio\",\n                producerId: this.id,\n                data: { duration: this.el.duration, isInfinity },\n            });\n        };\n    }\n\n    setAudio(dto: DAudioDto) {\n        this.dto = dto;\n        this.el.src = dto.url;\n        this.el.load();\n    }\n\n    destroy() {\n        try {\n            this.el.pause();\n            this.el.src = \"\";\n            this.el.load();\n        } catch (e) {\n            console.log(e);\n        }\n    }\n\n    pause() {\n        try {\n            this.el.pause();\n        } catch (e) {\n            // TODO EMIT ERROR EVENT.\n            console.log(e);\n        }\n    }\n\n    play(url: string) {\n        if (this.el.src !== url) {\n            this.el.src = url;\n        }\n        this.eventBus.emit({\n            kind: \"AUDIO_PLAY_EVENT\",\n            producerId: this.id,\n            data: {},\n            producer: \"DAudio\",\n            timestamp: DTimestamp.now(),\n        });\n        this.el\n            .play()\n            .then((res) => {\n                console.log(res);\n            })\n            .catch((e) => {\n                console.log(e);\n            });\n    }\n\n    onLoadedMetadata(_: Event) {\n        this.eventBus.emit({\n            kind: \"AUDIO_METADATA_LOADED_EVENT\",\n            timestamp: DTimestamp.now(),\n            producer: \"DAudio\",\n            producerId: this.id,\n            data: {},\n        });\n    }\n\n    onLoad(_: Event) {\n        this.eventBus.emit({\n            kind: \"AUDIO_LOAD_EVENT\",\n            timestamp: DTimestamp.now(),\n            producer: \"DAudio\",\n            producerId: this.id,\n            data: {},\n        });\n        // console.log(this.TAG + event.type);\n    }\n\n    get id() {\n        return this.dto?.id ?? \"DAudio\";\n    }\n\n    private onCanPlayThrough(_: Event) {\n        this.eventBus.emit({\n            kind: \"AUDIO_CAN_PLAY_THROUGH_EVENT\",\n            data: {},\n            producer: \"DAudio\",\n            timestamp: DTimestamp.now(),\n            producerId: this.id,\n        });\n    }\n\n    // private onPlay(_: Event) {}\n\n    async playToEnd(): Promise<boolean> {\n        const endedOrErrored = new Promise<boolean>((resolve) => {\n            this.el.addEventListener(\n                \"ended\",\n                (_) => {\n                    // console.log(e);\n                    resolve(true);\n                },\n                { once: true }\n            );\n            this.el.addEventListener(\n                \"error\",\n                (_) => {\n                    // console.log(e);\n                    resolve(false);\n                },\n                { once: true }\n            );\n        });\n        try {\n            this.play(this.el.src);\n            await endedOrErrored;\n            return true;\n        } catch (e) {\n            // TODO LET PARENT DEAL WITH ERRORS? THE MANAGER?? MANAGERS CALL ABORT.\n            console.log(e);\n            this.eventBus.emit({\n                kind: \"AUDIO_ERROR_EVENT\",\n                timestamp: DTimestamp.now(),\n                producer: \"DAudio\",\n                producerId: this.id,\n                data: { error: e },\n            });\n            return false;\n        } finally {\n        }\n\n        return Promise.resolve(false);\n    }\n}\n", "import { PageDto } from \"../dto/SchemaDto\";\nimport { VideoContainer } from \"../Delement/VideoContainer\";\nimport { AudioContainer } from \"../Delement/AudioContainer\";\nimport { AutoPlayElement, DAutoPlaySequence } from \"../Delement/DAuto-play\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\nimport { DCommand } from \"../commands/DCommand\";\nimport { DTimestamp } from \"../common/DTimestamp\";\nimport { EventBus } from \"../events/event-bus\";\nimport { ScaleService } from \"../engine/scale\";\nimport { ResourceProvider } from \"./resource-provider\";\nimport { AutoplayTask, SequenceManager } from \"./sequence-manager\";\n\nexport interface IMediaManager {\n  setPage(page: PageDto): void;\n  destroy(): void;\n}\n\nexport class DMediaManager implements IMediaManager {\n  private static INSTANCE_COUNT = 0;\n  private readonly instanceNumber: number;\n  private readonly TAG = \"[ MEDIA_MANAGER ] : \";\n  private readonly videoContainer: VideoContainer;\n  private readonly audioContainer: AudioContainer;\n  private pageEnter: DTimestamp;\n  private sincePageEnter: DTimestamp.Diff;\n  private currentPage: PageDto | null = null;\n  private readonly unsubscribeCommands: () => void;\n  private readonly tickerRef: number;\n  private readonly sequenceManager: SequenceManager | false = false;\n  constructor(\n    private hostEl: HTMLDivElement,\n    private readonly commandBus: DCommandBus,\n    private readonly eventBus: EventBus,\n    private readonly resourceProvider: ResourceProvider,\n    private readonly scale: ScaleService,\n  ) {\n    DMediaManager.INSTANCE_COUNT = DMediaManager.INSTANCE_COUNT + 1;\n    this.instanceNumber = DMediaManager.INSTANCE_COUNT;\n    const videoEl = document.createElement(\"video\");\n    this.hostEl.append(videoEl);\n    this.videoContainer = new VideoContainer(videoEl, eventBus, this.scale);\n    this.audioContainer = new AudioContainer(this.eventBus);\n    this.tick = this.tick.bind(this);\n    this.videoContainer.setStyle({ visibility: \"hidden\" });\n    const now = DTimestamp.now();\n    this.pageEnter = now;\n    this.sincePageEnter = DTimestamp.diff(now, now);\n    this.unsubscribeCommands = this.commandBus.subscribe((action) => {\n      this.commandHandler(action);\n    }, this.TAG);\n\n    this.tickerRef = window.setInterval(() => {}, 1000);\n  }\n\n  /**\n   * Stop all media that is playing\n   */\n  clearAllMedia() {\n    this.videoContainer.pause();\n    this.audioContainer.pause();\n  }\n  destroy() {\n    console.log(\"TODO DESTROY ALL MEDIA\");\n    this.unsubscribeCommands();\n    // console.log(this.tickerRef);\n    window.clearInterval(this.tickerRef);\n    this.audioContainer.destroy();\n    this.videoContainer.destroy();\n  }\n\n  setPage(page: PageDto) {\n    // TODO STOP VIDEO/AUDIO THAT MIGHT BE PLAYING IN THE DOM??\n    this.currentPage = page;\n    this.videoContainer.pause();\n    this.pageEnter = DTimestamp.now();\n    // TODO THis might be a bug if someone\n\n    const seq = page.autoPlaySequence;\n    // this.sequence = seq ? [...seq.items] : [];\n    const { mainVideoId, audio } = page;\n    const audioElements = page.audio;\n\n    if (mainVideoId) {\n      const dto = this.resourceProvider.getVideoById(mainVideoId);\n      if (dto) {\n        this.videoContainer.setDto(dto);\n        this.videoContainer.setStyle({ ...dto.style, visibility: \"visible\" });\n      }\n      // this.videoContainer.playToEnd();\n    } else {\n      this.videoContainer.setStyle({ visibility: \"hidden\" });\n      // HIDE?\n    }\n    if (audioElements) {\n      const first = audioElements[0];\n      if (first) {\n        this.audioContainer.setAudio(first);\n      }\n    }\n    if (seq) {\n      this.playSequence(seq);\n    }\n    // const hasVideo =\n  }\n\n  private commandHandler(command: DCommand) {\n    if (command.kind === \"VIDEO_PLAY_COMMAND\") {\n      const video = command.targetId;\n      const dto = this.videoContainer.getCurrentDto();\n\n      if (dto && dto.id === command.targetId) {\n        console.log(video);\n        this.videoContainer.play(dto.url);\n      }\n    }\n    if (command.kind === \"VIDEO_PAUSE_COMMAND\") {\n      this.videoContainer.pause();\n    }\n    if (command.kind === \"AUDIO_PLAY_COMMAND\") {\n      this.audioContainer\n        .playToEnd()\n        .then(() => {})\n        .catch()\n        .finally(() => {});\n    }\n\n    if (command.kind === \"AUDIO_PAUSE_COMMAND\") {\n      // this.audioContainer.\n    }\n  }\n\n  private async playSequence(seq: DAutoPlaySequence) {\n    // console.log(this.TAG + \"SEQUENCE STARTED -- TODO EVENT FOR THIS??\");\n\n    const elements = seq.items;\n    const testClone = [...elements];\n    const first = testClone.pop();\n\n    if (!first) {\n      return false;\n    }\n    const now = DTimestamp.now();\n    seq.startCommands.forEach((c) => {\n      console.log(c);\n      this.commandBus.emit(c);\n    });\n    // this.commandBus.emit(DStateProps.mediaBlockedBySequence.setTrueCommand);\n    // if (seq.blockUserInput) {\n    //     this.commandBus.emit(DStateProps.inputBlockingBySequence.getSetTrueCommand());\n    // }\n    for (let i = 0; i < elements.length; i++) {\n      const item = elements[i];\n      if (item.kind === \"autoplay-video\") {\n        const dto = this.resourceProvider.getVideoById(item.videoId);\n        if (dto) this.videoContainer.setDto(dto);\n        await this.videoContainer.playToEnd();\n      }\n      if (item.kind === \"autoplay-audio\") {\n        console.log(item);\n        const dto = this.resourceProvider.getAudioById(item.audioId);\n        if (dto) this.audioContainer.setAudio(dto);\n        await this.audioContainer.playToEnd();\n      }\n    }\n    seq.endCommands.forEach((c) => {\n      this.commandBus.emit(c);\n    });\n    // this.actionService.emit(DStateProps.mediaBlockedBySequence.setFalseCommand);\n    // this.actionService.emit(DStateProps.inputBlockingBySequence.setFalseCommand);\n    console.log(this.TAG + \"SEQUENCE ENDED\");\n    return true;\n  }\n\n  // setPage()\n\n  private tick() {\n    // console.log(this.video1.getStats());\n  }\n}\n", "import { DCommand } from \"./DCommand\";\nimport { DTimestamp } from \"../common/DTimestamp\";\n\nexport interface DCommandStore {\n  subscribe(callback: () => void, subscriberId: string): void;\n}\n\nexport interface DCommandDispatcher {\n  emit(command: DCommand): void;\n}\n\ninterface CommandSubscriberData {\n  readonly subscriberId: string;\n  readonly callback: (command: DCommand) => void;\n}\nexport class DCommandBus implements DCommandStore, DCommandDispatcher {\n  private readonly TAG = \"[ COMMAND_BUS ] \";\n  logCommands = false;\n  private readonly commandLog: Array<DCommand & { timestamp: DTimestamp }> = [];\n  readonly subscribers = new Set<CommandSubscriberData>();\n  // readonly sub\n\n  subscribe(cb: (command: DCommand) => void, subscriberId: string) {\n    const sub: CommandSubscriberData = {\n      subscriberId,\n      callback: cb,\n    };\n\n    this.subscribers.add(sub);\n    return () => {\n      this.subscribers.delete(sub);\n    };\n  }\n\n  emit(command: DCommand) {\n    const timestamp = DTimestamp.now();\n    this.commandLog.push({ ...command, timestamp });\n    if (this.logCommands) {\n      this.logCommand(command);\n    }\n    this.subscribers.forEach((subscriber) => {\n      subscriber.callback(command);\n    });\n  }\n\n  getStats() {\n    return {\n      commands: [...this.commandLog],\n      subscribers: [...this.subscribers],\n      subscribersCount: this.subscribers.size,\n    };\n  }\n\n  private logCommand(command: DCommand) {\n    console.groupCollapsed(this.TAG + \" \" + command.kind);\n    console.log(\"TargetID : \" + command.targetId);\n    console.log(command.payload);\n    console.groupEnd();\n  }\n}\n", "import { DEvent } from \"./DEvents\";\n\ninterface SubscriberData {\n    readonly subscriberId: string;\n    readonly cb: (event: DEvent) => void;\n}\n\nexport interface DEventStore {\n    subscribe(cb: (event: DEvent) => void, subscriberId: string): void;\n}\n\nexport interface DEventDispatcher {\n    emit(event: DEvent): void;\n}\nexport class EventBus implements DEventStore, DEventDispatcher {\n    private readonly TAG = \"[  EVENT_BUS  ] :\";\n    // private readonly subscribers = new Set<(event: DEvent) => void>();\n    private readonly subscribers = new Set<SubscriberData>();\n\n    /**\n     * Emit on module end.\n     * @private\n     */\n    private readonly eventLog: DEvent[] = [];\n    consoleLogEvents = false;\n    // readonly sub\n\n    subscribe(cb: (event: DEvent) => void, subscriberId: string) {\n        // this.subscribers.add(cb);\n        const subscriberData: SubscriberData = {\n            subscriberId,\n            cb,\n        };\n        this.subscribers.add(subscriberData);\n        if (this.consoleLogEvents) {\n            console.log(this.TAG + \"subscription added: \" + subscriberId);\n            console.log(this.TAG + \"subscription count: \" + this.subscribers.size);\n        }\n        return () => {\n            if (this.consoleLogEvents) {\n                console.log(this.TAG + \"subscription removed: \" + subscriberId);\n                console.log(this.TAG + \"subscription count  : \" + this.subscribers.size);\n            }\n            // this.subscribers.delete(cb);\n            this.subscribers.delete(subscriberData);\n        };\n    }\n\n    getStats() {\n        return {\n            subscribersCount: this.subscribers.size,\n            eventLog: [...this.eventLog],\n            subscribers: [...this.subscribers],\n        };\n    }\n\n    emit(event: DEvent) {\n        if (this.consoleLogEvents) {\n            this.logEvent(event);\n        }\n        this.eventLog.push(event);\n        this.subscribers.forEach((data) => {\n            // console.log('CALLING EMIT');\n            data.cb(event);\n        });\n        // this.logEvents();\n    }\n\n    private logEvent(event: DEvent) {\n        console.groupCollapsed(this.TAG + \" \" + event.kind);\n        console.log(\"ProducerId: \" + event.producerId);\n        console.log(event.data);\n        console.groupEnd();\n    }\n\n    private logEvents() {\n        console.group(this.TAG + \"LOGG\");\n        console.table(this.eventLog);\n        console.groupEnd();\n    }\n}\n", "import { Fact } from \"../rules/fact\";\nimport { DTimestamp } from \"../common/DTimestamp\";\n\nexport interface AnsweredQuestion {\n    readonly timestamp: DTimestamp;\n    readonly fact: Fact;\n}\n\nexport namespace AnsweredQuestion {\n    export const eq = (a: AnsweredQuestion, b: AnsweredQuestion): boolean => {\n        return a.fact === b.fact;\n    };\n}\n\nexport interface PageHistory {\n    readonly pageId: string;\n    readonly answeredQuestions: AnsweredQuestion[];\n}\n\nexport class HistoryQue {\n    private history: PageHistory[] = [];\n\n    getFacts(): Array<Fact> {\n        const answers = this.history.map((h) => h.answeredQuestions).flat(1);\n        const facts = answers.map((a) => a.fact);\n        // TODO FIND LATEST FACT (answer) if have multiple.\n        return facts;\n    }\n\n    getAnswers(): Array<AnsweredQuestion> {\n        const answers = this.history.map((h) => h.answeredQuestions).flat(1);\n        return answers;\n    }\n\n    addToHistory(page: PageHistory) {\n        this.history.push(page);\n    }\n}\n", "import { Fact } from \"./fact\";\nimport { DUtil } from \"../utils/DUtil\";\nexport type Condition = Condition.String | Condition.Numeric | Condition.Complex;\n\nexport namespace Condition {\n    export type StringOperator = \"eq\" | \"not-eq\" | \"longer-then\" | \"shorter-then\";\n\n    export type NumericOperator =\n        | \"eq\"\n        | \"not-eq\"\n        | \"greater-then\"\n        | \"less-then\"\n        | \"greater-then-inclusive\"\n        | \"less-then-inclusive\";\n\n    export interface Numeric {\n        readonly referenceId: string;\n        readonly referenceLabel: string;\n        readonly valueLabel: string;\n        readonly kind: \"numeric-condition\";\n        readonly operator: NumericOperator;\n        readonly value: number;\n    }\n    export interface String {\n        readonly referenceId: string;\n        readonly referenceLabel: string;\n        readonly valueLabel: string;\n        readonly kind: \"string-condition\";\n        readonly operator: StringOperator;\n        readonly value: string;\n    }\n\n    export interface Complex {\n        readonly kind: \"complex-condition\";\n        readonly name: string;\n        readonly all: ReadonlyArray<Condition.Simple>;\n        readonly some: ReadonlyArray<Condition.Simple>;\n    }\n\n    export type Simple = Condition.String | Condition.Numeric;\n\n    /**\n     * An empty condition will evaluate to false,\n     * @param condition: Condition.Any\n     * @param facts\n     */\n    export const evaluate = (condition: Condition, facts: ReadonlyArray<Fact>) => {\n        let result: boolean = false;\n        switch (condition.kind) {\n            case \"string-condition\":\n                result = evaluateSimple(condition, facts);\n                break;\n            case \"numeric-condition\":\n                result = evaluateSimple(condition, facts);\n                break;\n            case \"complex-condition\":\n                result = evaluateComplex(condition, facts);\n                break;\n            default:\n                const check: never = condition;\n        }\n        return result;\n    };\n\n    const evaluateComplex = (condition: Condition.Complex, facts: ReadonlyArray<Fact>): boolean => {\n        if (condition.some.length === 0 && condition.all.length === 0) {\n            return false;\n        }\n        const allSolved = condition.all.map((condition) => {\n            return evaluateSimple(condition, facts);\n        });\n\n        const someEvaluated = condition.some.map((condition) => {\n            return evaluateSimple(condition, facts);\n        });\n        const allResult = allSolved.every(DUtil.isTrue);\n        const someResult = someEvaluated.length === 0 || someEvaluated.some(DUtil.isTrue);\n        return someResult && allResult;\n    };\n\n    const evaluateSimple = (condition: Condition.Simple, facts: ReadonlyArray<Fact>): boolean => {\n        const fact = facts.find((f) => f.referenceId === condition.referenceId);\n        if (!fact) {\n            return false;\n        }\n        let res = false;\n        switch (condition.kind) {\n            case \"numeric-condition\":\n                if (fact.kind === \"numeric-fact\") {\n                    res = evaluateNumeric(condition, fact.value);\n                }\n                break;\n            case \"string-condition\":\n                if (fact.kind === \"string-fact\") {\n                    res = evaluateString(condition, fact.value);\n                }\n                break;\n            default:\n                const check: never = condition;\n        }\n        return res;\n    };\n\n    export const isEmpty = (complex: Complex) => {\n        return complex.all.length === 0 && complex.some.length === 0;\n    };\n\n    const evaluateString = (condition: Readonly<Condition.String>, value: string): boolean => {\n        const operator = condition.operator;\n        let result = false;\n        switch (operator) {\n            case \"eq\":\n                result = condition.value === value;\n                break;\n            case \"not-eq\":\n                result = condition.value !== value;\n                break;\n            case \"shorter-then\":\n                result = condition.value !== value;\n                break;\n            case \"longer-then\":\n                result = condition.value !== value;\n                break;\n            default:\n                const check: never = operator;\n        }\n        return result;\n    };\n\n    const evaluateNumeric = (condition: Numeric, value: number): boolean => {\n        const op = condition.operator;\n        const conditionValue = condition.value;\n        let result = false;\n        switch (op) {\n            case \"eq\":\n                result = value === conditionValue;\n                break;\n            case \"not-eq\":\n                result = value !== conditionValue;\n                break;\n            case \"greater-then\":\n                result = value > conditionValue;\n                break;\n            case \"greater-then-inclusive\":\n                result = value >= conditionValue;\n                break;\n            case \"less-then\":\n                result = value < conditionValue;\n                break;\n            case \"less-then-inclusive\":\n                result = value <= conditionValue;\n                break;\n            default:\n                const check: never = op;\n        }\n        return result;\n    };\n\n    const _getAllSimple = (condition: Condition): ReadonlyArray<Condition.Simple> => {\n        const simple: Array<Condition.Simple> = [];\n        switch (condition.kind) {\n            case \"complex-condition\":\n                simple.push(...condition.all);\n                simple.push(...condition.some);\n                break;\n            case \"numeric-condition\":\n                simple.push(condition);\n                break;\n            case \"string-condition\":\n                simple.push(condition);\n                break;\n            default:\n                DUtil.neverCheck(condition);\n        }\n        return simple;\n    };\n\n    export const getAllSimpleConditions = (\n        condition: Condition | Array<Condition>\n    ): ReadonlyArray<Condition.Simple> => {\n        const simple: Array<Condition.Simple> = [];\n        if (Array.isArray(condition)) {\n            condition.forEach((c) => {\n                simple.push(..._getAllSimple(c));\n            });\n        } else {\n            simple.push(..._getAllSimple(condition));\n        }\n        return simple;\n    };\n}\n", "import { Condition } from \"./condition\";\nimport { Fact } from \"./fact\";\nimport { DUtil } from \"../utils/DUtil\";\n\nexport interface Rule<OnSuccessAction, OnFailureAction> {\n  readonly id?: string;\n  readonly description: string;\n  readonly all: ReadonlyArray<Condition>;\n  readonly some: ReadonlyArray<Condition>;\n  readonly onSuccess: ReadonlyArray<OnSuccessAction>;\n  readonly onFailure: ReadonlyArray<OnFailureAction>;\n}\n\nexport namespace Rule {\n  /**\n   * Validates that the rule is valid.\n   * @param rule\n   */\n\n  export const isEmpty = (rule: Rule<any, any>): boolean => {\n    const emptyConditions = rule.all.length === 0 && rule.some.length === 0;\n    const emptyActions = rule.onSuccess.length === 0 && rule.onFailure.length === 0;\n    return emptyConditions || emptyActions;\n  };\n\n  export const solve = (rule: Rule<any, any>, facts: ReadonlyArray<Fact>): boolean => {\n    if (rule.some.length === 0 && rule.all.length === 0) {\n      // TODO RETURN WARNING? OR LOGGING ?\n      return false;\n    }\n\n    const someSolved = rule.some.map((condition) => Condition.evaluate(condition, facts));\n\n    const someResult = someSolved.length === 0 || someSolved.some(DUtil.isTrue);\n\n    const allSolved = rule.all.map((condition) => Condition.evaluate(condition, facts)).every(DUtil.isTrue);\n\n    return allSolved && someResult;\n  };\n}\n", "import { Fact } from \"./fact\";\nimport { Rule } from \"./rule\";\n\nexport interface SolveResult<S, F> {\n  matching: ReadonlyArray<Match<S, F>>;\n  errors: ReadonlyArray<RuleEngineError>;\n}\n\nexport interface Match<S, F> {\n  readonly matchingRuleId: string;\n  readonly ruleDescription: string;\n  readonly actionList: ReadonlyArray<S> | ReadonlyArray<F>;\n}\n\nexport interface RuleEngineError {\n  readonly kind?: string;\n  readonly message: string;\n}\n\nexport class RuleEngine<S, F> {\n  constructor() {}\n\n  solveAll(rules: Rule<S, F>[], facts: Fact[]): SolveResult<S, F> {\n    const errors: RuleEngineError[] = [];\n    const matching: Match<S, F>[] = [];\n    rules.forEach((rule) => {\n      if (Rule.isEmpty(rule)) {\n        errors.push({ message: \"Empty rule: \" + rule.id });\n      } else if (Rule.solve(rule, facts)) {\n        const match: Match<S, F> = {\n          ruleDescription: rule.description,\n          matchingRuleId: rule.id ?? \"no-id-given\",\n          actionList: [...rule.onSuccess],\n        };\n        matching.push(match);\n      }\n    });\n    return { matching, errors };\n  }\n\n  solve(rule: Rule<S, F>, facts: Fact[]): boolean {\n    // TODO Validate, and Return result\n    return Rule.solve(rule, facts);\n  }\n}\n", "import { PageDto } from \"../dto/SchemaDto\";\n\nexport class NextQue {\n    private originalOrder: ReadonlyArray<string> = [];\n    private allPages: PageDto[] = [];\n    private excludedTags = new Set<string>();\n    private excludedByPageId = new Set<string>();\n    private remaining: PageDto[] = [];\n    constructor(pages: PageDto[] = []) {\n        this.resetQue(pages);\n    }\n\n    /**\n     * Will reset que with the new pages.\n     * @param pages\n     */\n    resetQue(pages: PageDto[]) {\n        this.allPages = [...pages];\n        this.remaining = [...pages];\n        this.excludedTags = new Set();\n        this.excludedByPageId = new Set();\n        this.originalOrder = this.allPages.map((p) => p.id);\n    }\n\n    pop(): PageDto | false {\n        const next = this.remaining.shift();\n        // TODO CLONE??\n        return next ?? false;\n    }\n\n    peek(): PageDto | false {\n        const next = this.remaining[0];\n        return next ?? false;\n    }\n\n    jumpToPageById(pageId: string): boolean {\n        const index = this.remaining.findIndex((p) => p.id === pageId);\n        if (index < 0) {\n            return false;\n        }\n        this.remaining = this.remaining.slice(index);\n        return true;\n    }\n\n    removeByTag(tag: string | string[]) {\n        if (Array.isArray(tag)) {\n            tag.forEach((tag) => {\n                this.excludedTags.add(tag);\n            });\n        } else {\n            this.excludedTags.add(tag);\n        }\n        this.filterRemaining();\n    }\n\n    /**\n     * Will not be included\n     * @param pages\n     */\n    insertAsNextByForce(pages: PageDto[]) {\n        this.remaining.unshift(...pages);\n    }\n\n    removeByPageId(pageId: string | string[]) {\n        if (Array.isArray(pageId)) {\n            pageId.forEach((id) => {\n                this.excludedByPageId.add(id);\n            });\n        } else {\n            this.excludedByPageId.add(pageId);\n        }\n        this.filterRemaining();\n        // this.excludedByPageId.add(pageId);\n    }\n\n    private filterRemaining() {\n        this.remaining = this.remaining.filter((p) => {\n            const tags = p.tags ?? [];\n            const isIncluededByTag = !tags.some((tag) => this.excludedTags.has(tag));\n            const isIncludedByPageId = !this.excludedByPageId.has(p.id);\n            return isIncludedByPageId && isIncluededByTag;\n        });\n    }\n    get isEmpty(): boolean {\n        return this.remaining.length === 0;\n    }\n    get size(): number {\n        return this.remaining.length;\n    }\n    get pageCount(): number {\n        return this.originalOrder.length;\n    }\n}\n", "import { AnsweredQuestion, HistoryQue, PageHistory } from \"./history-que\";\nimport { RuleEngine } from \"../rules/rule-engine\";\nimport { NextQue } from \"./next-que\";\nimport { PageDto, SchemaDto } from \"../dto/SchemaDto\";\nimport { NavigationCommand, PageQueCommand } from \"../commands/DCommand\";\nimport { DUtil } from \"../utils/DUtil\";\n\nexport type DPlayerData = Pick<SchemaDto, \"pages\" | \"pageSequences\" | \"rules\">;\nexport class DPlayer {\n  private history = new HistoryQue();\n  private ruleEngine = new RuleEngine<PageQueCommand, PageQueCommand>();\n  private nextQue = new NextQue();\n  private data: DPlayerData;\n\n  constructor(data: DPlayerData) {\n    this.data = data;\n    this.nextQue.resetQue(data.pages);\n  }\n\n  saveHistory(pageHistory: PageHistory) {\n    console.log(\"SAVE HISTORY\", pageHistory);\n    this.history.addToHistory(pageHistory);\n    const facts = this.history.getFacts();\n    const result = this.ruleEngine.solveAll(this.data.rules, facts);\n    const matchingRules = result.matching;\n    const actions = matchingRules.map((r) => r.actionList).flat(1);\n    actions.forEach((a) => {\n      console.log(a.payload);\n      switch (a.kind) {\n        case \"PAGE_QUE_JUMP_TO_PAGE_COMMAND\":\n          this.nextQue.jumpToPageById(a.payload.pageId);\n          break;\n        case \"PAGE_QUE_EXCLUDE_BY_PAGE_ID_COMMAND\":\n          this.nextQue.removeByPageId(a.payload.pageIds);\n          break;\n        case \"PAGE_QUE_EXCLUDE_BY_TAG_COMMAND\":\n          this.nextQue.removeByTag(a.payload.tagIds);\n          break;\n        default:\n          console.log(\"UNKNOWN ACTION\", a);\n          const check: never = a;\n      }\n    });\n    console.log(actions);\n  }\n\n  getResults(): AnsweredQuestion[] {\n    return this.history.getAnswers();\n  }\n\n  private goToPageById(pageId: string) {\n    this.nextQue.jumpToPageById(pageId);\n  }\n\n  handleNavigationCommand(command: NavigationCommand) {\n    switch (command.kind) {\n      case \"PAGE_QUE_NEXT_PAGE_COMMAND\":\n        // NO NEED TO DO ANYTHING\n        break;\n      case \"PAGE_QUE_GO_TO_PAGE_COMMAND\":\n        this.goToPageById(command.payload.pageId);\n        break;\n      case \"PAGE_QUE_GO_TO_SEQUENCE_COMMAND\":\n        this.insertSequenceById(command.payload.sequenceId);\n        break;\n\n      default:\n        DUtil.neverCheck(command);\n    }\n  }\n\n  getNextPage(): PageDto | false {\n    // TODO HANDLE RULES!!\n    return this.nextQue.pop();\n  }\n\n  private insertSequenceById(id: string) {\n    const seq = this.data.pageSequences?.find((s) => s.id === id);\n    if (seq) {\n      this.nextQue.insertAsNextByForce([...seq.pages]);\n    } else {\n      // HOW TO HANDLE INVALID ID_REFS?? LOGGER??\n      // LOG INVALID COMMAND.\n    }\n  }\n\n  /**\n   * Total number of pages.\n   */\n  get pageCount(): number {\n    return this.nextQue.pageCount;\n  }\n}\n", "import { DCommand, ElementCommand, StateCommand } from \"../commands/DCommand\";\nimport { DEvent } from \"../events/DEvents\";\nimport { Condition } from \"../rules/condition\";\n\nexport interface DEventHandler<E extends DEvent = DEvent> {\n    readonly onEvent: E[\"kind\"];\n    readonly when?: { producerId?: string; condition?: Condition };\n    readonly thenExecute: ReadonlyArray<DCommand>;\n}\n\nexport interface QueryChangedHandler {\n    readonly queryName: string;\n    readonly whenTrue: ReadonlyArray<ElementCommand>;\n    readonly whenFalse: ReadonlyArray<ElementCommand>;\n}\n\nexport namespace DEventHandler {\n    export type LookUp = Map<DEventHandler[\"onEvent\"], Array<DEventHandler>>;\n    export const createLookUp = (handlers?: ReadonlyArray<DEventHandler>): LookUp => {\n        const map = new Map<DEventHandler[\"onEvent\"], Array<DEventHandler>>();\n        handlers?.forEach((h) => {\n            const kind = h.onEvent;\n            const current = map.get(kind);\n            const actions = current ? [...current, h] : [h];\n            map.set(kind, actions);\n        });\n        return map;\n    };\n}\n", "import { DStyle } from \"./DStyle\";\nimport { DElementBaseDto } from \"../dto/DElement.dto\";\nimport { DCommand, ElementCommand } from \"../commands/DCommand\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\nimport { DEventHandler } from \"../event-handlers/DEventHandler\";\nimport { DUtil } from \"../utils/DUtil\";\nimport { EventBus } from \"../events/event-bus\";\nimport { DTimestamp } from \"../common/DTimestamp\";\nimport { AnimationDto } from \"../dto/AnimationDto\";\nimport { ScaleService } from \"../engine/scale\";\nimport { DState } from \"../state/Dstate\";\n\nexport abstract class DElement<T extends HTMLElement> {\n    protected readonly el: T;\n    private clickHandlerIsEnabled = true;\n    readonly id: string;\n    private isAnimatingSelf = false;\n    protected currStyle: Partial<DStyle> = {\n        fontSize: { _unit: \"px\", value: 100 },\n        fontWeight: 500,\n        textColor: \"black\",\n        opacity: 1,\n    };\n\n    // private readonly onQueryChangedHandlers =\n    private readonly eventHandlers: DEventHandler.LookUp;\n    protected readonly commandBus: DCommandBus;\n    protected readonly eventBus: EventBus;\n    protected scale: ScaleService;\n    private readonly baseDto: DElementBaseDto;\n    protected readonly subscriptions = new Set<() => void>();\n\n    protected constructor(\n        el: T,\n        eventBus: EventBus,\n        commandBus: DCommandBus,\n        dto: DElementBaseDto,\n        scale: ScaleService\n    ) {\n        this.el = el;\n        this.id = dto.id;\n        this.baseDto = dto;\n        // this.el.style.position = \"absolute\";\n        this.commandBus = commandBus;\n        this.eventBus = eventBus;\n        this.eventHandlers = DEventHandler.createLookUp(dto.eventHandlers);\n        this.scale = scale;\n        // CLICK\n        this.onClickHandler = this.onClickHandler.bind(this);\n        this.el.onclick = this.onClickHandler;\n\n        // HOVER\n        this.onMouseOver = this.onMouseOver.bind(this);\n        this.el.onmouseover = this.onMouseOver;\n\n        if (dto) {\n            this.updateStyles(dto?.style);\n        }\n        const commandSubscription = this.commandBus.subscribe((c) => {\n            if (c.kind === \"ELEMENT_STYLE_COMMAND\" && c.targetId === this.id) {\n                this.setStyle(c.payload.changes);\n            }\n            if (c.kind === \"ELEMENT_DISABLE_CLICK_COMMAND\" && c.targetId === this.id) {\n                this.clickHandlerIsEnabled = false;\n            }\n            if (c.kind === \"ELEMENT_ENABLE_CLICK_COMMAND\" && c.targetId === this.id) {\n                this.clickHandlerIsEnabled = true;\n            }\n            if (c.kind === \"ELEMENT_ANIMATE_COMMAND\" && c.targetId === this.id) {\n                console.log(\"TODO IMPLEMENT ANIMATION_HANDLER IN DElement.\");\n            }\n        }, this.id);\n        // TODO MEMORY LEAK\n        const eventSubscription = this.eventBus.subscribe((event) => {\n            const handlers = this.eventHandlers.get(event.kind) ?? [];\n            // TODO Apply Conditions in WHEN.\n            const commands = handlers.map((h) => h.thenExecute).flat(1);\n            commands.forEach((command) => {\n                this.commandBus.emit(command);\n                // this.doAction(command);\n            });\n\n            if (event.kind === \"HOST_SCALE_CHANGED_EVENT\") {\n                console.log(\"HANDLE THIS SCALE CHANGE!!\");\n                this.updateStyles({});\n            }\n\n            if (event.kind === \"STATE_QUERY_RESULT_CHANGED_EVENT\") {\n                this.queryChangedHandler(event.data);\n            }\n        }, \"ELEMENT: \");\n        this.normalize();\n        this.subscriptions.add(commandSubscription);\n        this.subscriptions.add(eventSubscription);\n    }\n\n    abstract destroy(): void;\n\n    // abstract setScale(scale: number): void;\n\n    // /**\n    //  * The purpose of this function is to re-emit commands from event-handlers?\n    //  * @param command\n    //  * @private\n    //  */\n    // private handleCommandsEmittedByPrivateEventHandlers(command: DCommand) {\n    //     console.log(command);\n    //     switch (command.kind) {\n    //         case \"ELEMENT_STYLE_COMMAND\":\n    //             if (command.targetId === this.id) {\n    //                 this.updateStyles(command.payload.changes);\n    //             }\n    //             break;\n    //         case \"ELEMENT_ANIMATE_COMMAND\":\n    //             // TODO CHECK FOR TARGET ID\n    //             this.handleAnimateSelfAction(command.payload);\n    //             break;\n    //         case \"ELEMENT_ENABLE_CLICK_COMMAND\":\n    //             this.clickHandlerIsEnabled = true;\n    //             // this.updateStyles(command.payload.changes);\n    //             break;\n    //         case \"ELEMENT_DISABLE_CLICK_COMMAND\":\n    //             this.clickHandlerIsEnabled = false;\n    //             // this.handleAnimateSelfAction(command.payload);\n    //             break;\n    //         case \"VIDEO_PLAY_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"VIDEO_PAUSE_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"ENGINE_LEAVE_PAGE_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"VIDEO_JUMP_TO_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"VIDEO_SET_VOLUME_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"AUDIO_PLAY_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"AUDIO_PAUSE_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"AUDIO_SET_VOLUME_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"PAGE_QUE_NEXT_PAGE_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"PAGE_QUE_GO_TO_SEQUENCE_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"PAGE_QUE_GO_TO_PAGE_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"PAGE_QUE_EXCLUDE_BY_PAGE_ID_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"PAGE_QUE_JUMP_TO_PAGE_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"PAGE_QUE_EXCLUDE_BY_TAG_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         case \"STATE_MUTATE_COMMAND\":\n    //             this.commandBus.emit(command);\n    //             break;\n    //         default:\n    //             DUtil.neverCheck(command);\n    //     }\n    // }\n\n    private queryChangedHandler(result: DState.StateQueryResult) {\n        const maybeHandlers = this.baseDto.onStateChange;\n        if (!maybeHandlers) {\n            return;\n        }\n        const queryHandlers = maybeHandlers.filter((h) => h.queryName === result.queryName);\n        queryHandlers.forEach((h) => {\n            if (result.curr) {\n                h.whenTrue.forEach((command) => {\n                    // this.doAction(command);\n                    this.commandBus.emit(command);\n                });\n            } else {\n                h.whenFalse.forEach((command) => {\n                    // this.doAction(command);\n                    this.commandBus.emit(command);\n                });\n            }\n        });\n        // console.log(findByQuery, value);\n        // const all = this.baseDto.stateQueryChange ?? [];\n    }\n\n    private onClickHandler(_: MouseEvent) {\n        // console.log();\n        if (!this.clickHandlerIsEnabled) {\n            console.log(this.id + \"Click disabled\");\n            return;\n        }\n        const clickAction = this.baseDto.onClick;\n        // console.log(\"NATIVE CLICK ELEMENT: Handlers \" + clickAction?.length);\n        if (clickAction && clickAction.length > 0) {\n            // console.log(\"TARGETID: \" + clickAction[0].targetId + \" \" + this.id);\n            this.eventBus.emit({\n                kind: \"USER_CLICKED_EVENT\",\n                producer: \"DUser\",\n                producerId: this.id,\n                data: { elementId: this.id },\n                timestamp: DTimestamp.now(),\n            });\n            clickAction.forEach((command) => {\n                this.commandBus.emit(command);\n            });\n        }\n    }\n\n    private onMouseOver(_: MouseEvent) {\n        // console.log(ev);\n    }\n\n    setStyle(style: Partial<DStyle>) {\n        this.updateStyles(style);\n    }\n\n    appendYourself(parent: HTMLElement) {\n        parent.append(this.el);\n        // console.log(parent);\n    }\n\n    private handleAnimateSelfAction(dto: AnimationDto) {\n        this.isAnimatingSelf = true;\n        const { keyframes, options } = dto;\n\n        const animation = this.el.animate(keyframes, options.duration);\n        animation.onfinish = (e: AnimationPlaybackEvent) => {\n            console.log(e.type);\n            this.isAnimatingSelf = false;\n        };\n        animation.onremove = () => {\n            console.warn(\"ANIMATION REMOVED: \" + animation.id);\n            this.isAnimatingSelf = false;\n        };\n        animation.oncancel = () => {\n            console.warn(\"ANIMATION CANCELED: \" + animation.id);\n            this.isAnimatingSelf = false;\n        };\n    }\n\n    private normalize() {\n        DStyle.normalize(this.el);\n    }\n\n    protected updateStyles(style: Partial<DStyle>) {\n        this.currStyle = Object.assign(this.currStyle, style);\n        DStyle.applyStyles(this.el, this.currStyle, this.scale.scale);\n        window.getComputedStyle(this.el);\n    }\n}\n", "import { DElement } from \"./DElement\";\nimport { DDivDto } from \"../dto/DElement.dto\";\nimport { DText } from \"./DText\";\nimport { DImg } from \"./DImg\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\nimport { EventBus } from \"../events/event-bus\";\nimport { ScaleService } from \"../engine/scale\";\n\nexport class DDiv extends DElement<HTMLDivElement> {\n  private readonly TAG = \"[ DDiv ]: \";\n  protected readonly defaultStyle = { x: 22, y: 4 };\n  private children: Array<DText | DImg> = [];\n\n  constructor(\n    dto: DDivDto,\n    eventBus: EventBus,\n    actionService: DCommandBus,\n    scale: ScaleService,\n    children: Array<DText | DImg>,\n  ) {\n    const d = document.createElement(\"div\");\n    super(d, eventBus, actionService, dto, scale);\n    this.children = children;\n\n    this.children.forEach((child) => {\n      child.appendYourself(this.el);\n    });\n  }\n\n  destroy(): void {\n    this.subscriptions.forEach((unsubscribe) => {\n      unsubscribe();\n    });\n    this.children.forEach((child) => {\n      child.destroy();\n    });\n  }\n}\n", "import { DElement } from \"./DElement\";\nimport { DImgDto } from \"../dto/DElement.dto\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\nimport { EventBus } from \"../events/event-bus\";\nimport { ScaleService } from \"../engine/scale\";\nimport { DTimestamp } from \"../common/DTimestamp\";\n\nexport class DImg extends DElement<HTMLImageElement> {\n    private static IMAGE_COUNT = 0;\n    private readonly imageCount: number;\n    readonly TAG: string;\n    readonly TIMING_TAG: string;\n    private readonly loadStart: DTimestamp;\n\n    constructor(\n        private readonly dto: DImgDto,\n        private readonly actionSubject: DCommandBus,\n        readonly eventBus: EventBus,\n        readonly scaleService: ScaleService\n    ) {\n        super(document.createElement(\"img\"), eventBus, actionSubject, dto, scaleService);\n        DImg.IMAGE_COUNT += 1;\n        this.imageCount = DImg.IMAGE_COUNT;\n        this.TAG = \"[D_IMG \" + DImg.IMAGE_COUNT + \" ]: \";\n        this.TIMING_TAG = \"load-time (\" + DImg.IMAGE_COUNT + \") \";\n        this.el.loading = \"eager\";\n        this.el.style.position = \"absolute\";\n        this.setStyle(dto.style);\n        this.loadStart = DTimestamp.now();\n        // Bind Handlers\n        this.onError = this.onError.bind(this);\n        this.onLoad = this.onLoad.bind(this);\n        // this.onClick = this.onClick.bind(this);\n        this.el.onload = this.onLoad;\n        this.el.onerror = this.onError;\n        // this.el.onclick = this.onClick;\n        this.el.src = dto.url;\n        console.time(this.TIMING_TAG);\n    }\n\n    log(): void {}\n\n    setScale(scale: number) {\n        console.log(scale);\n        this.setStyle(this.currStyle);\n    }\n    destroy() {\n        this.subscriptions.forEach((unsubscribe) => {\n            unsubscribe();\n        });\n    }\n\n    private onError(ev: Event | string) {\n        if (ev instanceof Event) {\n            console.log(this.TAG + \" \" + ev.type);\n        } else {\n            console.log(this.TAG + ev);\n        }\n    }\n\n    private onLoad(_: Event) {\n        const loadTime = DTimestamp.diffNow(this.loadStart);\n\n        this.eventBus.emit({\n            kind: \"IMAGE_LOADED_EVENT\",\n            producer: \"DImage\",\n            producerId: this.id,\n            timestamp: DTimestamp.now(),\n            data: {\n                loadTime,\n                naturalHeight: this.el.naturalHeight,\n                naturalWidth: this.el.naturalWidth,\n                height: this.el.height,\n                width: this.el.width,\n            },\n        });\n    }\n}\n", "import { DElement } from \"./DElement\";\nimport { DTextDto } from \"../dto/DElement.dto\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\nimport { EventBus } from \"../events/event-bus\";\nimport { ScaleService } from \"../engine/scale\";\n\nexport class DText extends DElement<HTMLParagraphElement> {\n    private readonly TAG = \"[ DParagraph ]: \";\n    protected defaultStyle = {};\n\n    constructor(dto: DTextDto, eventBus: EventBus, actionService: DCommandBus, scale: ScaleService) {\n        super(document.createElement(\"p\"), eventBus, actionService, dto, scale);\n        this.el.style.position = \"absolute\";\n        this.el.innerText = \"\" + dto.text;\n        this.setStyle(dto.style);\n    }\n\n    setScale(scale: number) {\n        this.setStyle(this.currStyle);\n        const fontSize = this.el.style.fontSize;\n        console.log(this.TAG + \"scale: \" + scale + \" Fontsize: \" + fontSize);\n    }\n\n    destroy() {\n        this.subscriptions.forEach((unsubscribe) => {\n            unsubscribe();\n        });\n    }\n}\n", "import { DElement } from \"../Delement/DElement\";\nimport { DDiv } from \"../Delement/Ddiv\";\nimport { DImg } from \"../Delement/DImg\";\nimport { DText } from \"../Delement/DText\";\nimport { DDivDto, DElementDto } from \"../dto/DElement.dto\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\nimport { EventBus } from \"../events/event-bus\";\nimport { ScaleService } from \"./scale\";\n\nexport const createDElement = (\n    dto: DElementDto,\n    actionBus: DCommandBus,\n    eventBus: EventBus,\n    scale: ScaleService\n): DElement<any> => {\n    switch (dto._tag) {\n        case \"div\":\n            const childEls = createChildrenForDiv(dto, actionBus, eventBus, scale);\n            const newDiv = new DDiv(dto, eventBus, actionBus, scale, childEls);\n            return newDiv;\n        case \"img\":\n            return new DImg(dto, actionBus, eventBus, scale);\n        case \"p\":\n            return new DText(dto, eventBus, actionBus, scale);\n        default:\n            const check: never = dto;\n            throw new Error(\"Unknown dto given to the createDElement function.\");\n        // TODO LOGGING or create any HTML-ELEMENT??\n    }\n};\n\nconst createChildrenForDiv = (\n    dto: DDivDto,\n    actionSubject: DCommandBus,\n    eventBus: EventBus,\n    scale: ScaleService\n): DDiv[\"children\"] => {\n    const childDto = dto.children;\n    const childEls: Array<DImg | DText> = [];\n    // console.log(childElements);\n    childDto.forEach((dto) => {\n        if (dto._tag === \"p\") {\n            const newText = new DText(dto, eventBus, actionSubject, scale);\n            childEls.push(newText);\n        }\n        if (dto._tag === \"img\") {\n            const newImage = new DImg(dto, actionSubject, eventBus, scale);\n            childEls.push(newImage);\n        }\n    });\n    return childEls;\n};\n", "import { DElement } from \"../Delement/DElement\";\nimport { PageDto } from \"../dto/SchemaDto\";\nimport { createDElement } from \"./element-factory\";\nimport { EventBus } from \"../events/event-bus\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\nimport { DTimestamp } from \"../common/DTimestamp\";\nimport { ScaleService } from \"./scale\";\n\nexport class DPage {\n  private readonly TAG = \"[ DPage ]: \";\n  private elements: DElement<HTMLElement>[] = [];\n  private readonly eventBus;\n  private readonly commandBus;\n  private readonly scale: ScaleService;\n  // Todo GLOBAL EVENT_BUSS AND PAGE EVENTS:\n\n  constructor(\n    private readonly dto: PageDto,\n    eventBus: EventBus,\n    commandBus: DCommandBus,\n    scale: ScaleService,\n  ) {\n    this.eventBus = eventBus;\n    this.commandBus = commandBus;\n    this.scale = scale;\n    this.elements = dto.elements.map((dto) => createDElement(dto, this.commandBus, this.eventBus, this.scale));\n  }\n\n  appendYourself(parent: HTMLElement) {\n    // console.log(this.TAG + \" APPENDING TO PARENT\");\n    this.elements.forEach((el) => {\n      el.appendYourself(parent);\n      // parent.appendChild(el.el);\n    });\n\n    // if (!preloadMode) {\n    this.eventBus.emit({\n      kind: \"PAGE_ENTER_EVENT\",\n      timestamp: DTimestamp.now(),\n      producer: \"DPage\",\n      producerId: this.id,\n      data: { pageId: this.id },\n    });\n    // }\n  }\n\n  destroy() {\n    this.elements.forEach((el) => {\n      el.destroy();\n    });\n  }\n\n  log(): void {\n    // console.log(this.TAG + 'scale - ' + this.scale);\n  }\n\n  get id() {\n    return this.dto.id;\n  }\n}\n", "export class ScaleService {\n  private readonly baseHeight;\n  private readonly baseWidth;\n  private containerHeight = 1300;\n  private containerWidth = 1300;\n\n  get scale() {\n    return this._scale;\n  }\n\n  get pageHeight() {\n    return this.baseHeight * this.scale;\n  }\n  get pageWidth() {\n    return this.baseWidth * this._scale;\n  }\n\n  private _scale = 1;\n\n  private readonly subscribers = new Set<(scale: number) => void>();\n\n  constructor(config: { baseHeight: number; baseWidth: number; containerHeight: number; containerWidth: number }) {\n    this.baseHeight = config.baseHeight;\n    this.baseWidth = config.baseWidth;\n    this.containerHeight = config.containerHeight;\n    this.containerWidth = config.containerWidth;\n    this.updateScale();\n  }\n\n  setContainerBounds(bounds: { height: number; width: number }) {\n    this.containerWidth = bounds.width;\n    this.containerHeight = bounds.height;\n    this.updateScale();\n  }\n  private updateScale() {\n    const scaleFn = Scale.calc(this.baseHeight, this.baseWidth);\n    const scale = scaleFn({ height: this.containerHeight, width: this.containerWidth });\n    const hasChanged = this.scale !== scale;\n    this._scale = scale;\n    if (hasChanged) {\n      this.subscribers.forEach((fn) => {\n        fn(this._scale);\n      });\n    }\n  }\n\n  onChange(scaleChangeHandler: (scale: number) => void, subscriberId: string) {\n    // console.log(subscriberId);\n    this.subscribers.add(scaleChangeHandler);\n    scaleChangeHandler(this._scale);\n    return () => {\n      this.subscribers.delete(scaleChangeHandler);\n    };\n  }\n}\nexport namespace Scale {\n  export const calc = (baseHeight: number, baseWidth: number) => {\n    return (container: { height: number; width: number }) => {\n      const heightRatio = container.height / baseHeight;\n      const widthRatio = container.width / baseWidth;\n      return Math.min(heightRatio, widthRatio);\n    };\n  };\n\n  type ScalePosInput = { x: number; y: number; h: number; w: number };\n\n  export const scaleFunctionCreator = (scale: number) => {\n    return (value: number) => value * scale;\n  };\n}\n", "import { DAudioDto, DImgDto, DVideoDto } from \"../dto/DElement.dto\";\n\nexport class ResourceProvider {\n    private readonly TAG = \"[ RESOURCE_PROVIDER ]: \";\n    private readonly videoMap = new Map<string, DVideoDto>();\n    private readonly audioMap = new Map<string, DAudioDto>();\n    constructor(data: { videos: ReadonlyArray<DVideoDto>; audio: ReadonlyArray<DAudioDto> }) {\n        // console.log(this.TAG + \"VIDEO_COUNT \" + data.videos.length);\n        // console.log(this.TAG + \"AUDIO_COUNT \" + data.audio.length);\n        data.videos.forEach((video) => {\n            this.videoMap.set(video.id, video);\n        });\n        data.audio.forEach((audio) => {\n            this.audioMap.set(audio.id, audio);\n        });\n    }\n\n    getAudioById(id: string): DAudioDto | false {\n        const maybeAudio = this.audioMap.get(id);\n        if (!maybeAudio) {\n            console.error(this.TAG + \"Audio by id \" + id + \" dont exist\");\n        }\n        return maybeAudio ?? false;\n    }\n\n    getVideoById(id: string): DVideoDto | false {\n        const maybeVideo = this.videoMap.get(id);\n        if (!maybeVideo) {\n            console.error(this.TAG + \"Video by id \" + id + \" dont exist\");\n        }\n        return maybeVideo ?? false;\n    }\n}\n", "export class Ok<T> implements IResult<T> {\n    constructor(readonly value: T) {}\n    isOk(): this is Ok<T> {\n        return true;\n    }\n    isFailure(): this is Failure<T> {\n        return false;\n    }\n\n    map<A>(f: (t: T) => A): IResult<A> {\n        const value = f(this.value);\n        return new Ok<A>(value);\n    }\n}\n\nexport class Failure<T> implements IResult<T> {\n    constructor(readonly message: string) {}\n    isFailure(): this is Failure<T> {\n        return true;\n    }\n\n    isOk(): this is Ok<T> {\n        return false;\n    }\n\n    map<A>(_f: (t: T) => A): IResult<A> {\n        return new Failure<A>(this.message);\n    }\n}\n\ninterface IResult<T> {\n    isOk(): this is Ok<T>;\n    isFailure(): this is Failure<T>;\n    map<A>(f: (t: T) => A): IResult<A>;\n}\n\nexport type Result<T> = Failure<T> | Ok<T>;\nexport namespace Result {\n    export const ok = <T>(value: T) => new Ok<T>(value);\n    export const failure = <T>(message: string) => new Failure<T>(message);\n}\n", "import { Fact } from \"../rules/fact\";\nimport { Condition } from \"../rules/condition\";\nimport { DEvent } from \"../events/DEvents\";\nimport { StateCommand } from \"../commands/DCommand\";\n\nexport namespace DState {\n    interface PropDefinition<TypeName, Type extends string | number> {\n        readonly _type: TypeName;\n        readonly propName: string;\n        readonly propDescription: string;\n        readonly initialValue?: Type;\n        readonly options?: ReadonlyArray<PropValue<Type>>;\n    }\n\n    export type NumericProp = PropDefinition<\"number\", number>;\n    export type StringProp = PropDefinition<\"string\", string>;\n\n    export interface fromEventHandler {\n        readonly onEvent: DEvent[\"kind\"];\n        readonly thenExecute: ReadonlyArray<StateCommand>;\n    }\n\n    export interface PropValue<T> {\n        readonly value: T;\n        readonly valueLabel: string;\n    }\n    export type Prop = NumericProp | StringProp;\n\n    export interface SetStringMutation {\n        readonly kind: \"set-string\";\n        readonly propName: string;\n        readonly value: string;\n    }\n\n    export interface IncrementNumberMutation {\n        readonly kind: \"increment-number\";\n        readonly propName: string;\n        readonly stepSize: number;\n        readonly ifNotExistThenSetTo: number;\n    }\n    export interface DecrementNumberMutation {\n        readonly kind: \"decrement-number\";\n        readonly propName: string;\n        readonly stepSize: number;\n        readonly ifNotExistThenSetTo: number;\n    }\n\n    export interface SetNumberMutation {\n        readonly kind: \"set-number\";\n        readonly propName: string;\n        readonly value: number;\n    }\n    export type NumberMutations = IncrementNumberMutation | DecrementNumberMutation | SetNumberMutation;\n\n    export type StateMutation = SetStringMutation | NumberMutations;\n\n    export const isNumberMutation = (mutations: StateMutation): mutations is NumberMutations => {\n        if (!mutations) {\n            return false;\n        }\n\n        return (\n            mutations.kind === \"set-number\" ||\n            mutations.kind === \"decrement-number\" ||\n            mutations.kind === \"increment-number\"\n        );\n    };\n\n    export const isStringMutation = (mutation: StateMutation): mutation is SetStringMutation => {\n        return mutation && mutation.kind === \"set-string\";\n    };\n\n    export interface StateQuery {\n        readonly name: string;\n        readonly condition: Condition;\n    }\n\n    export interface StateQueryResult {\n        readonly queryName: string;\n        readonly prev: boolean;\n        readonly curr: boolean;\n    }\n\n    export const numericPropToFact = (prop: NumericProp, value: number) => {\n        const fact: Fact.Numeric = {\n            kind: \"numeric-fact\",\n            referenceId: prop.propName,\n            referenceLabel: prop.propDescription ?? \" [STATE_PROPERTY] : \" + prop.propName,\n            value,\n            label: \" [VALUE] : \" + value,\n        };\n        return fact;\n    };\n\n    export const stringPropToFact = (prop: StringProp, value: string) => {\n        const fact: Fact.String = {\n            kind: \"string-fact\",\n            referenceId: prop.propName,\n            referenceLabel: \" [STATE_PROPERTY] : \" + prop.propName,\n            value,\n            label: \" [VALUE] : \" + value,\n        };\n        return fact;\n    };\n}\n", "import { Fact } from \"../rules/fact\";\nimport { Result } from \"../common/result\";\nimport { Condition } from \"../rules/condition\";\nimport { DState } from \"./Dstate\";\nimport { DEventDispatcher } from \"../events/event-bus\";\nimport { DTimestamp } from \"../common/DTimestamp\";\nimport { QueryChangedEvent } from \"../events/DEvents\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\n\nexport class StateService {\n  private readonly TAG = \" [ STATE_SERVICE ] :\";\n  private readonly factsString = new Map<string, Fact.String>();\n  private readonly factsNumeric = new Map<string, Fact.Numeric>();\n  private readonly propDefinitions = new Map<string, DState.Prop>();\n  private readonly queries = new Map<string, { query: DState.StateQuery; lastResult: boolean }>();\n  private readonly unsubscribeCommands: () => void;\n  constructor(\n    private readonly eventBus: DEventDispatcher,\n    private readonly commandBus: DCommandBus,\n    private readonly props: ReadonlyArray<DState.Prop>,\n    private readonly queryList: ReadonlyArray<DState.StateQuery> = [],\n  ) {\n    props.forEach((prop) => {\n      this.registerProperty(prop);\n    });\n    const facts = this.getAllFacts();\n    queryList.forEach((definition) => {\n      this.registerQuery(definition, facts);\n    });\n\n    this.evaluateQueries();\n    this.unsubscribeCommands = this.commandBus.subscribe((command) => {\n      if (command.kind === \"STATE_MUTATE_COMMAND\") {\n        this.mutation(command.payload.mutation);\n      }\n    }, this.TAG);\n  }\n\n  destroy() {\n    this.unsubscribeCommands();\n  }\n\n  private registerQuery(query: DState.StateQuery, currentFacts: ReadonlyArray<Fact>) {\n    const result = Condition.evaluate(query.condition, currentFacts);\n    this.queries.set(query.name, { query: query, lastResult: result });\n    this.emitQueryChangedEvent({ queryName: query.name, prev: result, curr: result });\n  }\n\n  private registerProperty(prop: DState.Prop) {\n    if (this.propDefinitions.has(prop.propName)) {\n      // LOGGING\n      console.warn(\"Prop excists already.\", prop.propName);\n    }\n\n    this.propDefinitions.set(prop.propName, prop);\n\n    if (prop.initialValue === undefined) {\n      return;\n    }\n\n    if (prop._type === \"string\") {\n      const fact = DState.stringPropToFact(prop, prop.initialValue);\n      this.factsString.set(fact.referenceId, fact);\n    }\n    if (prop._type === \"number\") {\n      const fact = DState.numericPropToFact(prop, prop.initialValue);\n      this.factsNumeric.set(fact.referenceId, fact);\n    }\n  }\n\n  private mutateString(prop: DState.StringProp, value: string) {\n    const curr = this.factsString.get(prop.propName);\n    if (curr) {\n      const updated: Fact.String = { ...curr, value };\n      this.setFact(updated);\n    } else {\n      const created: Fact.String = {\n        kind: \"string-fact\",\n        referenceId: prop.propName,\n        referenceLabel: \"label for: \" + prop.propName,\n        value,\n        label: \"Value: \" + value,\n      };\n      this.setFact(created);\n    }\n  }\n\n  private mutateNumber(prop: DState.NumericProp, mutation: DState.NumberMutations) {\n    const curr = this.factsNumeric.get(prop.propName);\n    if (!curr) {\n      switch (mutation.kind) {\n        case \"set-number\":\n          this.setFact(DState.numericPropToFact(prop, mutation.value));\n          break;\n        case \"decrement-number\":\n          this.setFact(DState.numericPropToFact(prop, mutation.ifNotExistThenSetTo));\n          break;\n        case \"increment-number\":\n          this.setFact(DState.numericPropToFact(prop, mutation.ifNotExistThenSetTo));\n          break;\n        default:\n          const check: never = mutation;\n      }\n    }\n    if (curr) {\n      switch (mutation.kind) {\n        case \"set-number\":\n          this.setFact({ ...curr, value: mutation.value });\n          break;\n        case \"decrement-number\":\n          this.setFact({ ...curr, value: curr.value - mutation.stepSize });\n          break;\n        case \"increment-number\":\n          this.setFact({ ...curr, value: curr.value + mutation.stepSize });\n          break;\n        default:\n          const check: never = mutation;\n      }\n    }\n  }\n\n  private evaluateQueries(): ReadonlyArray<{ queryName: string; prev: boolean; curr: boolean; didChange: boolean }> {\n    const facts = this.getAllFacts();\n    const all: Array<{ queryName: string; prev: boolean; curr: boolean; didChange: boolean }> = [];\n    this.queries.forEach((q) => {\n      const prev = q.lastResult;\n\n      const curr = Condition.evaluate(q.query.condition, facts);\n      const didChange = prev !== curr;\n      q.lastResult = curr;\n      all.push({ queryName: q.query.name, prev, curr, didChange });\n      // def.value = value;\n    });\n    return all;\n  }\n\n  private mutation(mutation: DState.StateMutation): { success: boolean } {\n    const propDef = this.propDefinitions.get(mutation.propName);\n    if (!propDef) {\n      // TODO LOGGING\n      return { success: false };\n    }\n\n    if (propDef._type === \"string\" && DState.isStringMutation(mutation)) {\n      this.mutateString(propDef, mutation.value);\n    }\n\n    if (propDef._type === \"number\" && DState.isNumberMutation(mutation)) {\n      this.mutateNumber(propDef, mutation);\n    }\n    const queryResults = this.evaluateQueries();\n    const changedResult = queryResults.filter((r) => r.didChange);\n    changedResult.forEach((res) => {\n      this.emitQueryChangedEvent({ queryName: res.queryName, prev: res.prev, curr: res.curr });\n    });\n\n    return { success: true };\n  }\n\n  private emitQueryChangedEvent(data: { queryName: string; prev: boolean; curr: boolean }) {\n    const queryChangedEvent: QueryChangedEvent = {\n      kind: \"STATE_QUERY_RESULT_CHANGED_EVENT\",\n      producer: \"STATE-SERVICE\",\n      producerId: \"STATE-SERVICE\",\n      timestamp: DTimestamp.now(),\n      data,\n    };\n    const { queryName, curr, prev } = queryChangedEvent.data;\n    // console.log(\"[ QUERY_CHANGED \" + queryName + \"] : \" + prev + \" -> \" + curr);\n    this.eventBus.emit(queryChangedEvent);\n  }\n\n  getPropAsFact(propName: string): Result<Fact> {\n    const propDef = this.propDefinitions.get(propName);\n    if (!propDef) {\n      return Result.failure(\n        \"No definition form property ny name \" + propName + \" is registered. (Pass in constructor.)\",\n      );\n    }\n    const value = this.factsString.get(propName) ?? this.factsNumeric.get(propName);\n\n    return value ? Result.ok(value) : Result.failure(\"Property \" + propName + \" has no value.\");\n  }\n\n  private setFact(fact: Fact) {\n    switch (fact.kind) {\n      case \"numeric-fact\":\n        this.factsNumeric.set(fact.referenceId, fact);\n        break;\n      case \"string-fact\":\n        this.factsString.set(fact.referenceId, fact);\n        break;\n      default:\n        const check: never = fact;\n    }\n  }\n\n  getState() {\n    const props: Record<string, string | number | null | boolean> = {};\n    this.propDefinitions.forEach((def) => {\n      let value: string | number | null = null;\n      const maybeFact = this.getAnyFact(def.propName);\n      if (maybeFact) {\n        value = maybeFact.value;\n      }\n      props[def.propName] = value;\n    });\n    this.queries.forEach((query) => {\n      props[query.query.name] = query.lastResult;\n    });\n\n    const propNames = Object.keys(props);\n    const propCount = propNames.length;\n    const propArray = [...this.propDefinitions.values()];\n\n    return { propCount, propNames, propArray, state: props };\n  }\n\n  private getAnyFact(propName: string): Fact | false {\n    return this.factsString.get(propName) ?? this.factsNumeric.get(propName) ?? false;\n  }\n\n  private getAllFacts(): ReadonlyArray<Fact> {\n    return [...this.factsNumeric.values(), ...this.factsString.values()];\n  }\n\n  /**\n   * Will check that all referenceIds used in Condition is registered as a valid property in state.\n   * @param condition\n   */\n  canBeMatched(condition: Condition): boolean {\n    const simpleConditions = Condition.getAllSimpleConditions(condition);\n    let hasAll = true;\n\n    const allIds = simpleConditions.map((c) => c.referenceId);\n\n    const missingIds: string[] = [];\n    allIds.forEach((id) => {\n      if (!this.propDefinitions.has(id)) {\n        hasAll = false;\n        missingIds.push(id);\n      }\n    });\n    console.log(this.TAG, missingIds);\n\n    return hasAll;\n  }\n  isMatched(condition: Condition) {\n    return Condition.evaluate(condition, this.getAllFacts());\n  }\n}\n", "import { SchemaDto } from \"../dto/SchemaDto\";\nimport { DMediaManager } from \"../services/DMedia-manager\";\nimport { DCommandBus } from \"../commands/DCommandBus\";\nimport { EventBus } from \"../events/event-bus\";\nimport { DPlayer } from \"../player/dplayer\";\nimport { AnsweredQuestion } from \"../player/history-que\";\nimport { DTimestamp } from \"../common/DTimestamp\";\nimport { DPage } from \"./DPage\";\nimport { ScaleService } from \"./scale\";\nimport { ResourceProvider } from \"../services/resource-provider\";\nimport { StateService } from \"../state/state-service\";\nimport { DCommand, StateCommand } from \"../commands/DCommand\";\nimport { DEvent } from \"../events/DEvents\";\n\nexport interface EngineLogger {\n  error(message: string): void;\n  warn(message: string): void;\n  appEvent(event: DEvent): void;\n  appCommand(command: DCommand): void;\n}\n\nexport interface SchemaResult {\n  readonly eventLog: ReadonlyArray<DEvent>;\n  readonly commandLog: ReadonlyArray<DCommand>;\n  readonly answers: ReadonlyArray<any>;\n}\nexport interface ISchemaEngine {\n  onComplete(handler: (result: SchemaResult) => void): void;\n  onCommandOrEvent(item: DEvent | DCommand): void;\n  setSchema(schema: SchemaDto): void;\n  onFatalError(handler: (error: { message: string }) => void): void;\n}\n\nexport class SchemaEngine implements ISchemaEngine {\n  private readonly TAG = \"[ SCHEMA_ENGINE ] :\";\n  private readonly commandBus = new DCommandBus();\n  private readonly eventBus = new EventBus();\n  private readonly mediaManager: DMediaManager;\n  private readonly scale: ScaleService;\n  private readonly hostElement: HTMLDivElement;\n  private readonly uiContainer: HTMLDivElement = document.createElement(\"div\");\n  private readonly mediaContainer: HTMLDivElement = document.createElement(\"div\");\n  private readonly resourceProvider: ResourceProvider;\n  private readonly stateService: StateService;\n  private readonly globalEventToStateHandlers = new Map<string, ReadonlyArray<StateCommand>>();\n  private player: DPlayer;\n  private currentPage: DPage | false = false;\n  private readonly subs: Array<() => void> = [];\n\n  constructor(\n    hostEl: HTMLDivElement,\n    private readonly height: number,\n    private readonly width: number,\n    private readonly schema: SchemaDto,\n  ) {\n    this.hostElement = hostEl;\n    this.hostElement.appendChild(this.uiContainer);\n    this.hostElement.appendChild(this.mediaContainer);\n    const stateProps = this.schema.stateProps ?? [];\n    const stateQueries = this.schema.stateQueries ?? [];\n    this.stateService = new StateService(this.eventBus, this.commandBus, stateProps, stateQueries);\n    this.scale = new ScaleService({\n      baseHeight: schema.baseHeight,\n      baseWidth: schema.baseWidth,\n      containerWidth: width,\n      containerHeight: height,\n    });\n    // this.commandBus.logCommands = true;\n    const globalEventHandlers = schema.stateFromEvent ?? [];\n\n    globalEventHandlers.forEach((h) => {\n      this.globalEventToStateHandlers.set(h.onEvent, h.thenExecute);\n    });\n\n    const resources = SchemaDto.getResources(this.schema);\n    this.resourceProvider = new ResourceProvider({ videos: resources.videoList, audio: resources.audioList });\n    this.mediaManager = new DMediaManager(\n      this.mediaContainer,\n      this.commandBus,\n      this.eventBus,\n      this.resourceProvider,\n      this.scale,\n    );\n    this.player = new DPlayer(this.schema);\n    this.styleSelf();\n    this.nextPage();\n    this.hookUpListeners();\n  }\n\n  private hookUpListeners() {\n    const eventSubscription = this.eventBus.subscribe((ev) => {\n      this.onCommandOrEvent(ev);\n      const globalHandlers = this.globalEventToStateHandlers.get(ev.kind) ?? [];\n      globalHandlers.forEach((stateCommand) => {\n        this.commandBus.emit(stateCommand);\n      });\n    }, this.TAG + \"HOOK_UP_LISTENERS\");\n    const commandSubscription = this.commandBus.subscribe((command) => {\n      // switch (command.kind) {\n      //\n      // }\n      this.onCommandOrEvent(command);\n      if (command.kind === \"PAGE_QUE_NEXT_PAGE_COMMAND\") {\n        this.nextPage();\n      }\n\n      if (command.kind === \"ENGINE_LEAVE_PAGE_COMMAND\") {\n        console.log(this.TAG + \"SEQUENCE STARTED -- TODO EVENT FOR THIS??\");\n        console.log(command);\n        const pageId = command.payload.pageId;\n        const facts = command.payload.factsCollected;\n        const timestamp = DTimestamp.now();\n        const ans: AnsweredQuestion[] = facts.map((f) => ({\n          timestamp,\n          fact: f,\n        }));\n        this.player.saveHistory({\n          answeredQuestions: ans,\n          pageId,\n        });\n\n        this.nextPage();\n        // const history: PageHistory = { page: {}, answeredQuestions: [] };\n      }\n    }, this.TAG);\n\n    this.subs.push(commandSubscription);\n    this.subs.push(eventSubscription);\n  }\n\n  private styleSelf() {\n    this.hostElement.style.height = this.scale.pageHeight + \"px\";\n    this.hostElement.style.width = this.scale.pageWidth + \"px\";\n    this.hostElement.style.backgroundColor = this.schema.backgroundColor ?? \"white\";\n    this.hostElement.style.position = \"relative\";\n    // this.hostElement.style.overflow = \"hidden\";\n    const makeStatic = (div: HTMLDivElement) => {\n      div.style.height = \"0px\";\n      div.style.width = \"0px\";\n      div.style.position = \"static\";\n    };\n\n    makeStatic(this.uiContainer);\n    makeStatic(this.mediaContainer);\n  }\n\n  private nextPage() {\n    // TODO SHOULD THIS BE PART OF THE SCHEMA?? THIS IS CLEANUP LOGIC\n    // this.commandBus.emit({ kind: \"VIDEO_PAUSE_COMMAND\", target: \"VIDEO\", targetId: \"VIDEO\", payload: {} });\n    // this.commandBus.emit({ kind: \"AUDIO_PAUSE_COMMAND\", target: \"AUDIO\", targetId: \"AUDIO\", payload: {} });\n    // const currPageId = this.currentPage ? this.currentPage.id : \"NO_PAGE\";\n    // console.groupCollapsed(\"NEXT_PAGE FROM: \" + currPageId);\n    // console.log(this.TAG + \" NEXT_PAGE STARTED AT: \" + currPageId);\n    this.mediaManager.clearAllMedia();\n    const nextPage = this.player.getNextPage();\n    // const state = this.stateService.getState();\n    // console.log(state);\n    // TODO CLEAN UP PAGE COMPONENTS this.page.CleanUp()\n    if (this.currentPage) {\n      this.currentPage.destroy();\n      this.uiContainer.innerHTML = \"\";\n    }\n    if (!nextPage) {\n      // TODO FIGURE OUT WHAQT TO DO AT END OF TEST!! Start over??\n      this.player = new DPlayer(this.schema);\n      if (this.schema.pages.length > 0) {\n        this.nextPage();\n      }\n      return false;\n    }\n    const newPage = new DPage(nextPage, this.eventBus, this.commandBus, this.scale);\n\n    this.currentPage = newPage;\n    newPage.appendYourself(this.uiContainer);\n\n    this.mediaManager.setPage(nextPage);\n    const s1 = this.stateService.getState();\n    // console.log(s1);\n    // console.log(\"Next-page: \" + newPage.id);\n    // console.groupEnd();\n    return true;\n  }\n\n  destroy() {\n    if (this.currentPage) {\n      this.currentPage.destroy();\n      this.uiContainer.innerHTML = \"\";\n    }\n    this.mediaManager.destroy();\n    this.stateService.destroy();\n    this.subs.forEach((sub) => {\n      sub();\n    });\n    const evStats = this.eventBus.getStats();\n    const cmdStats = this.commandBus.getStats();\n    console.assert(evStats.subscribersCount === 0, this.TAG + \" Eventbus should have no subscribers \", evStats);\n    console.assert(cmdStats.subscribersCount === 0, this.TAG + \"Commandbus should have no subscribers\", cmdStats);\n  }\n  onComplete(handler: (result: SchemaResult) => void) {\n    console.log(handler);\n  }\n\n  onFatalError(handler: (error: { message: string }) => void): void {\n    console.log(handler);\n  }\n\n  onCommandOrEvent(_event_or_command: DEvent | DCommand) {}\n\n  setSchema(schema: SchemaDto): void {\n    console.log(schema);\n  }\n}\n", "import { DState } from \"./Dstate\";\nimport { Condition } from \"../rules/condition\";\nimport { StateCommand } from \"../commands/DCommand\";\n\nexport class BooleanStateProperty<PropName extends string> {\n    readonly propName: PropName;\n    private static readonly TRUE = { value: 1, label: \"TRUE\" };\n    private static readonly FALSE = { value: 0, label: \"FALSE\" };\n    readonly propDefinition: DState.NumericProp;\n\n    getIsTrueCondition(): Condition.Numeric {\n        return {\n            kind: \"numeric-condition\",\n            referenceId: this.propName,\n            referenceLabel: this.propName + \"[ BOOLEAN ]\",\n            valueLabel: BooleanStateProperty.TRUE.label,\n            value: BooleanStateProperty.TRUE.value,\n            operator: \"eq\",\n        };\n    }\n    getIsFalseCondition(): Condition.Numeric {\n        return {\n            kind: \"numeric-condition\",\n            referenceId: this.propName,\n            referenceLabel: this.propName + \"[ BOOLEAN ]\",\n            valueLabel: BooleanStateProperty.FALSE.label,\n            value: BooleanStateProperty.FALSE.value,\n            operator: \"eq\",\n        };\n    }\n\n    getSetTrueCommand(): StateCommand {\n        return {\n            kind: \"STATE_MUTATE_COMMAND\",\n            target: \"STATE\",\n            targetId: \"STATE\",\n            payload: {\n                mutation: { propName: this.propName, kind: \"set-number\", value: 1 },\n            },\n        };\n    }\n\n    getSetFalseCommand(): StateCommand {\n        return {\n            kind: \"STATE_MUTATE_COMMAND\",\n            target: \"STATE\",\n            targetId: \"STATE\",\n            payload: {\n                mutation: { propName: this.propName, kind: \"set-number\", value: 0 },\n            },\n        };\n    }\n\n    constructor(propName: PropName, private readonly initialValue: boolean, description: string) {\n        this.propName = propName;\n        const initial = initialValue ? 1 : 0;\n        const propDescription = description ? description : \"No description given\";\n        this.propDefinition = {\n            propDescription,\n            propName: propName,\n            initialValue: initial,\n            options: [\n                { value: BooleanStateProperty.FALSE.value, valueLabel: BooleanStateProperty.FALSE.label },\n                { value: BooleanStateProperty.TRUE.value, valueLabel: BooleanStateProperty.TRUE.label },\n            ],\n            _type: \"number\",\n        };\n    }\n}\n", "// The default length of an ID\nconst ID_LENGTH = 32;\n\n// The minimum length of an ID\nconst MIN_LENGTH = 10;\n\nexport type ID<B extends string> = string & { __ID__: B };\n\nconst isID = <const B extends string>(idName: B, id?: string): id is ID<B> => {\n  if (typeof id !== \"string\") return false;\n  return id.length >= MIN_LENGTH;\n};\n\nconst createIDByName = <const B extends string>(idName: B): ID<B> => {\n  const letters = \"abcdefghijklmnopqrstuvyz\";\n  const all = letters + letters.toUpperCase();\n  let result = \"\";\n  for (let i = 0; i < ID_LENGTH; i++) {\n    const char = all.charAt(Math.floor(Math.random() * all.length));\n    result += char;\n  }\n  return result as ID<B>;\n};\n\n/**\n * Creates a object with helper functions for a specific ID type\n * @param idName\n */\nexport const createTypedIdSingleton = <const B extends string>(idName: B) => {\n  /**\n   * Creates a new ID of the correct type\n   */\n  const create = (): ID<B> => createIDByName(idName);\n\n  /**\n   * Checks if the id is of the correct type\n   * @param id\n   */\n  const is = (id: string): id is ID<B> => isID(idName, id);\n\n  /**\n   * Checks if the id is of the correct type, if not it throws an error\n   * @param id\n   */\n  const validateOrThrow = (id: string): ID<B> => {\n    if (!is(id)) {\n      throw new Error(`Invalid id: ${id}`);\n    }\n    return id;\n  };\n\n  /**\n   * The lowercase name of the id (SCHEMA, PAGE, etc)\n   */\n  const name: B = idName;\n\n  /**\n   * Ensures that the id is of the correct type, if not it creates a new one\n   * @param id\n   */\n  const ensure = (id: string): ID<B> => {\n    return is(id) ? id : create();\n  };\n\n  return Object.freeze({ create, is, ensure, validateOrThrow, name });\n};\n\nexport type SchemaID = ID<\"SCHEMA\">;\nexport const SchemaID = createTypedIdSingleton(\"SCHEMA\");\nexport type PageID = ID<\"PAGE\">;\nexport const PageID = createTypedIdSingleton(\"PAGE\");\n"],
  "mappings": "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",
  "names": ["SchemaDto", "DTimestamp", "DUtil", "isNumber", "DCss", "DStyle", "AnsweredQuestion", "Condition", "condition", "Rule", "tag", "DEventHandler", "dto", "dto", "Scale", "Result", "DState"]
}

|