@media-quest/engine 0.0.38 → 0.0.40

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.
@@ -1,101 +1,101 @@
1
- import { PageDto } from "../page/Page";
2
-
3
- export class NextQue {
4
- private originalOrder: ReadonlyArray<string> = [];
5
- private allPages: PageDto[] = [];
6
- private excludedTags = new Set<string>();
7
- private excludedByPageId = new Set<string>();
8
- private remaining: PageDto[] = [];
9
- constructor(pages: PageDto[] = []) {
10
- this.resetQue(pages);
11
- }
12
-
13
- /**
14
- * Will reset que with the new pages.
15
- * @param pages
16
- */
17
- resetQue(pages: PageDto[]) {
18
- this.allPages = [...pages];
19
- this.remaining = [...pages];
20
- this.excludedTags = new Set();
21
- this.excludedByPageId = new Set();
22
- this.originalOrder = this.allPages.map((p) => p.id);
23
- }
24
-
25
- pop(): PageDto | false {
26
- const next = this.remaining.shift();
27
- // TODO CLONE??
28
- return next ?? false;
29
- }
30
-
31
- peek(): PageDto | false {
32
- const next = this.remaining[0];
33
- return next ?? false;
34
- }
35
-
36
- jumpToPageById(pageId: string): boolean {
37
- const index = this.remaining.findIndex((p) => p.id === pageId);
38
- if (index < 0) {
39
- return false;
40
- }
41
- this.remaining = this.remaining.slice(index);
42
- return true;
43
- }
44
-
45
- removeByTag(tag: string | string[]) {
46
- if (Array.isArray(tag)) {
47
- tag.forEach((tag) => {
48
- this.excludedTags.add(tag);
49
- });
50
- } else {
51
- this.excludedTags.add(tag);
52
- }
53
- this.filterRemaining();
54
- }
55
-
56
- /**
57
- * Will not be included
58
- * @param pages
59
- */
60
- insertAsNextByForce(pages: PageDto[]) {
61
- this.remaining.unshift(...pages);
62
- }
63
-
64
- removeByPageId(pageId: string | string[]) {
65
- if (Array.isArray(pageId)) {
66
- pageId.forEach((id) => {
67
- this.excludedByPageId.add(id);
68
- });
69
- } else {
70
- this.excludedByPageId.add(pageId);
71
- }
72
- this.filterRemaining();
73
- // this.excludedByPageId.add(pageId);
74
- }
75
-
76
- private filterRemaining() {
77
- this.remaining = this.remaining.filter((p) => {
78
- const tags = p.tags ?? [];
79
- const isIncluededByTag = !tags.some((tag) => this.excludedTags.has(tag));
80
- const isIncludedByPageId = !this.excludedByPageId.has(p.id);
81
- return isIncludedByPageId && isIncluededByTag;
82
- });
83
- }
84
- get isEmpty(): boolean {
85
- return this.remaining.length === 0;
86
- }
87
-
88
- /**
89
- * Total number of pages left in que
90
- */
91
- get size(): number {
92
- return this.remaining.length;
93
- }
94
-
95
- /**
96
- * Total number of pages in test
97
- */
98
- get pageCount(): number {
99
- return this.originalOrder.length;
100
- }
101
- }
1
+ import { PageDto } from "../page/Page";
2
+
3
+ export class NextQue {
4
+ private originalOrder: ReadonlyArray<string> = [];
5
+ private allPages: PageDto[] = [];
6
+ private excludedTags = new Set<string>();
7
+ private excludedByPageId = new Set<string>();
8
+ private remaining: PageDto[] = [];
9
+ constructor(pages: PageDto[] = []) {
10
+ this.resetQue(pages);
11
+ }
12
+
13
+ /**
14
+ * Will reset que with the new pages.
15
+ * @param pages
16
+ */
17
+ resetQue(pages: PageDto[]) {
18
+ this.allPages = [...pages];
19
+ this.remaining = [...pages];
20
+ this.excludedTags = new Set();
21
+ this.excludedByPageId = new Set();
22
+ this.originalOrder = this.allPages.map((p) => p.id);
23
+ }
24
+
25
+ pop(): PageDto | false {
26
+ const next = this.remaining.shift();
27
+ // TODO CLONE??
28
+ return next ?? false;
29
+ }
30
+
31
+ peek(): PageDto | false {
32
+ const next = this.remaining[0];
33
+ return next ?? false;
34
+ }
35
+
36
+ jumpToPageById(pageId: string): boolean {
37
+ const index = this.remaining.findIndex((p) => p.id === pageId);
38
+ if (index < 0) {
39
+ return false;
40
+ }
41
+ this.remaining = this.remaining.slice(index);
42
+ return true;
43
+ }
44
+
45
+ removeByTag(tag: string | string[]) {
46
+ if (Array.isArray(tag)) {
47
+ tag.forEach((tag) => {
48
+ this.excludedTags.add(tag);
49
+ });
50
+ } else {
51
+ this.excludedTags.add(tag);
52
+ }
53
+ this.filterRemaining();
54
+ }
55
+
56
+ /**
57
+ * Will not be included
58
+ * @param pages
59
+ */
60
+ insertAsNextByForce(pages: PageDto[]) {
61
+ this.remaining.unshift(...pages);
62
+ }
63
+
64
+ removeByPageId(pageId: string | string[]) {
65
+ if (Array.isArray(pageId)) {
66
+ pageId.forEach((id) => {
67
+ this.excludedByPageId.add(id);
68
+ });
69
+ } else {
70
+ this.excludedByPageId.add(pageId);
71
+ }
72
+ this.filterRemaining();
73
+ // this.excludedByPageId.add(pageId);
74
+ }
75
+
76
+ private filterRemaining() {
77
+ this.remaining = this.remaining.filter((p) => {
78
+ const tags = p.tags ?? [];
79
+ const isIncluededByTag = !tags.some((tag) => this.excludedTags.has(tag));
80
+ const isIncludedByPageId = !this.excludedByPageId.has(p.id);
81
+ return isIncludedByPageId && isIncluededByTag;
82
+ });
83
+ }
84
+ get isEmpty(): boolean {
85
+ return this.remaining.length === 0;
86
+ }
87
+
88
+ /**
89
+ * Total number of pages left in que
90
+ */
91
+ get size(): number {
92
+ return this.remaining.length;
93
+ }
94
+
95
+ /**
96
+ * Total number of pages in test
97
+ */
98
+ get pageCount(): number {
99
+ return this.originalOrder.length;
100
+ }
101
+ }
@@ -1,76 +1,63 @@
1
- import { DTimestamp } from "../common/DTimestamp";
2
- interface _MqEvent<K extends string, P extends object> {
3
- readonly kind: K;
4
- readonly timestamp: DTimestamp;
5
- readonly payload: P;
6
- }
7
-
8
- export type MqEventEngineStart = _MqEvent<
9
- "engine-start",
10
- {
11
- readonly schemaId: string;
12
- readonly schemaPrefix: string;
13
- }
14
- >;
15
- export interface MqEventPageEnter
16
- extends _MqEvent<
17
- "page-enter",
18
- { readonly pageId: string; readonly pageNumber: number; readonly pagePrefix: string }
19
- > {}
20
-
21
- export interface MqEventPageLeave
22
- extends _MqEvent<
23
- "page-leave",
24
- { readonly pageId: string; readonly pageNumber: number; readonly pagePrefix: string }
25
- > {}
26
-
27
- export type MqEventUserClicked = _MqEvent<
28
- "user-clicked",
29
- {
30
- readonly pageId: string;
31
- readonly pagePrefix: string;
32
- readonly pageNumber: number;
33
- action: string;
34
- descriptions: string;
35
- }
36
- >;
37
-
38
- export type MqEvent = MqEventPageEnter | MqEventPageLeave | MqEventEngineStart | MqEventUserClicked;
39
-
40
- export const MqEvent = {
41
- engineStart(schemaId: string, schemaPrefix: string): MqEventEngineStart {
42
- return {
43
- kind: "engine-start",
44
- timestamp: DTimestamp.now(),
45
- payload: { schemaId, schemaPrefix },
46
- };
47
- },
48
- pageEnter(pageId: string, pagePrefix: string, pageNumber: number): MqEventPageEnter {
49
- return {
50
- kind: "page-enter",
51
- timestamp: DTimestamp.now(),
52
- payload: { pageId, pagePrefix, pageNumber },
53
- };
54
- },
55
- pageLeave(pageId: string, pagePrefix: string, pageNumber: number): MqEventPageLeave {
56
- return {
57
- kind: "page-leave",
58
- timestamp: DTimestamp.now(),
59
- payload: { pageId, pagePrefix, pageNumber },
60
- };
61
- },
62
- userClicked(data: {
63
- pageId: string;
64
- pagePrefix: string;
65
- pageNumber: number;
66
- action: string;
67
- descriptions: string;
68
- }): MqEventUserClicked {
69
- const { pageId, pageNumber, pagePrefix, action, descriptions } = data;
70
- return {
71
- kind: "user-clicked",
72
- timestamp: DTimestamp.now(),
73
- payload: { pageId, pagePrefix, action, descriptions, pageNumber },
74
- };
75
- },
76
- } as const;
1
+ import { DTimestamp } from "../common/DTimestamp";
2
+
3
+ interface _MqEvent<K extends string, P extends object> {
4
+ readonly kind: K;
5
+ readonly timestamp: DTimestamp;
6
+ readonly payload: P;
7
+ }
8
+
9
+ export type MqEventEngineStart = _MqEvent<
10
+ "engine-start",
11
+ {
12
+ readonly schemaId: string;
13
+ readonly schemaPrefix: string;
14
+ }
15
+ >;
16
+ export interface MqEventPageEnter
17
+ extends _MqEvent<"page-enter", { readonly pageId: string; readonly pagePrefix: string }> {}
18
+ export interface MqEventPageLeave
19
+ extends _MqEvent<"page-leave", { readonly pageId: string; readonly pagePrefix: string }> {}
20
+
21
+ export type MqEventUserClicked = _MqEvent<
22
+ "user-clicked",
23
+ { readonly pageId: string; pagePrefix: string; action: string; descriptions: string }
24
+ >;
25
+
26
+ export type MqEvent = MqEventPageEnter | MqEventPageLeave | MqEventEngineStart | MqEventUserClicked;
27
+
28
+ export const MqEvent = {
29
+ engineStart(schemaId: string, schemaPrefix: string): MqEventEngineStart {
30
+ return {
31
+ kind: "engine-start",
32
+ timestamp: DTimestamp.now(),
33
+ payload: { schemaId, schemaPrefix },
34
+ };
35
+ },
36
+ pageEnter(pageId: string, pagePrefix: string): MqEventPageEnter {
37
+ return {
38
+ kind: "page-enter",
39
+ timestamp: DTimestamp.now(),
40
+ payload: { pageId, pagePrefix },
41
+ };
42
+ },
43
+ pageLeave(pageId: string, pagePrefix: string): MqEventPageLeave {
44
+ return {
45
+ kind: "page-leave",
46
+ timestamp: DTimestamp.now(),
47
+ payload: { pageId, pagePrefix },
48
+ };
49
+ },
50
+ userClicked(data: {
51
+ pageId: string;
52
+ pagePrefix: string;
53
+ action: string;
54
+ descriptions: string;
55
+ }): MqEventUserClicked {
56
+ const { pageId, pagePrefix, action, descriptions } = data;
57
+ return {
58
+ kind: "user-clicked",
59
+ timestamp: DTimestamp.now(),
60
+ payload: { pageId, pagePrefix, action, descriptions },
61
+ };
62
+ },
63
+ } as const;