eventmodeler 0.4.7 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (204) hide show
  1. package/dist/api/client-config.js +10 -0
  2. package/dist/api/generated/client/client.gen.js +235 -0
  3. package/dist/api/generated/client/index.js +6 -0
  4. package/dist/api/generated/client/types.gen.js +2 -0
  5. package/dist/api/generated/client/utils.gen.js +228 -0
  6. package/dist/api/generated/client.gen.js +4 -0
  7. package/dist/api/generated/core/auth.gen.js +14 -0
  8. package/dist/api/generated/core/bodySerializer.gen.js +57 -0
  9. package/dist/api/generated/core/params.gen.js +100 -0
  10. package/dist/api/generated/core/pathSerializer.gen.js +106 -0
  11. package/dist/api/generated/core/queryKeySerializer.gen.js +92 -0
  12. package/dist/api/generated/core/serverSentEvents.gen.js +133 -0
  13. package/dist/api/generated/core/types.gen.js +2 -0
  14. package/dist/api/generated/core/utils.gen.js +87 -0
  15. package/dist/api/generated/index.js +2 -0
  16. package/dist/api/generated/sdk.gen.js +4222 -0
  17. package/dist/api/generated/types.gen.js +2 -0
  18. package/dist/api/generated/zod.gen.js +7217 -0
  19. package/dist/commands/add.js +315 -0
  20. package/dist/commands/auth.js +14 -0
  21. package/dist/commands/create.js +192 -0
  22. package/dist/commands/design.js +108 -0
  23. package/dist/commands/guide.js +15 -0
  24. package/dist/commands/init.js +21 -0
  25. package/dist/commands/list-schemas.js +177 -0
  26. package/dist/commands/list.js +39 -0
  27. package/dist/commands/loop.js +101 -0
  28. package/dist/commands/map.js +40 -0
  29. package/dist/commands/mark.js +27 -0
  30. package/dist/commands/move.js +35 -0
  31. package/dist/commands/remove.js +170 -0
  32. package/dist/commands/rename.js +53 -0
  33. package/dist/commands/resize.js +30 -0
  34. package/dist/commands/search.js +14 -0
  35. package/dist/commands/set.js +199 -0
  36. package/dist/commands/show-schemas.js +259 -0
  37. package/dist/commands/show.js +56 -0
  38. package/dist/commands/summary.js +13 -0
  39. package/dist/commands/update.js +240 -0
  40. package/dist/index.js +46 -2379
  41. package/dist/lib/auth.js +1 -1
  42. package/dist/lib/config.js +0 -15
  43. package/dist/lib/excalidraw-schema.js +66 -0
  44. package/dist/lib/globals.js +8 -0
  45. package/dist/lib/model.js +11 -0
  46. package/dist/lib/project-config.js +20 -0
  47. package/dist/lib/resolve.js +59 -0
  48. package/dist/lib/scenario.js +15 -0
  49. package/dist/slices/add-scenario/index.js +2 -206
  50. package/dist/slices/guide/guides/codegen.js +1 -1
  51. package/dist/slices/guide/guides/connect-slices.js +12 -37
  52. package/dist/slices/guide/guides/create-slices.js +110 -140
  53. package/dist/slices/guide/guides/explore.js +37 -26
  54. package/dist/slices/guide/guides/information-flow.js +70 -82
  55. package/dist/slices/guide/guides/scenarios.js +82 -137
  56. package/dist/slices/guide/index.js +6 -6
  57. package/dist/slices/help/index.js +96 -0
  58. package/dist/slices/help/topics/build-codegen.js +109 -0
  59. package/dist/slices/help/topics/build-slice.js +147 -0
  60. package/dist/slices/help/topics/check-completeness.js +57 -0
  61. package/dist/slices/help/topics/connect-slices.js +99 -0
  62. package/dist/slices/help/topics/explore-model.js +112 -0
  63. package/dist/slices/help/topics/json-reference.js +188 -0
  64. package/dist/slices/help/topics/linked-copies.js +89 -0
  65. package/dist/slices/help/topics/manipulate-canvas.js +150 -0
  66. package/dist/slices/help/topics/write-scenarios.js +162 -0
  67. package/dist/slices/init/index.js +10 -4
  68. package/dist/slices/init/loop.js +60 -0
  69. package/dist/slices/login/index.js +2 -2
  70. package/dist/slices/logout/index.js +2 -2
  71. package/dist/slices/whoami/index.js +11 -36
  72. package/package.json +8 -3
  73. package/dist/api/index.d.ts +0 -285
  74. package/dist/api/index.js +0 -323
  75. package/dist/cloud/slices/index.d.ts +0 -276
  76. package/dist/cloud/slices/index.js +0 -406
  77. package/dist/eventmodeler.js +0 -5646
  78. package/dist/formatters.d.ts +0 -17
  79. package/dist/formatters.js +0 -482
  80. package/dist/index.d.ts +0 -2
  81. package/dist/lib/auth.d.ts +0 -24
  82. package/dist/lib/backend.d.ts +0 -43
  83. package/dist/lib/backend.js +0 -73
  84. package/dist/lib/chapter-utils.d.ts +0 -13
  85. package/dist/lib/chapter-utils.js +0 -71
  86. package/dist/lib/cloud-client.d.ts +0 -69
  87. package/dist/lib/cloud-client.js +0 -364
  88. package/dist/lib/config.d.ts +0 -30
  89. package/dist/lib/diff/merge-rules.d.ts +0 -45
  90. package/dist/lib/diff/merge-rules.js +0 -210
  91. package/dist/lib/diff/model-differ.d.ts +0 -8
  92. package/dist/lib/diff/model-differ.js +0 -568
  93. package/dist/lib/diff/three-way-merge.d.ts +0 -7
  94. package/dist/lib/diff/three-way-merge.js +0 -390
  95. package/dist/lib/diff/types.d.ts +0 -75
  96. package/dist/lib/diff/types.js +0 -1
  97. package/dist/lib/element-lookup.d.ts +0 -58
  98. package/dist/lib/element-lookup.js +0 -126
  99. package/dist/lib/file-loader.d.ts +0 -8
  100. package/dist/lib/file-loader.js +0 -108
  101. package/dist/lib/flow-utils.d.ts +0 -53
  102. package/dist/lib/flow-utils.js +0 -348
  103. package/dist/lib/format.d.ts +0 -10
  104. package/dist/lib/format.js +0 -23
  105. package/dist/lib/project-config.d.ts +0 -27
  106. package/dist/lib/slice-utils.d.ts +0 -59
  107. package/dist/lib/slice-utils.js +0 -140
  108. package/dist/local/slices/index.d.ts +0 -11
  109. package/dist/local/slices/index.js +0 -13
  110. package/dist/projection.d.ts +0 -3
  111. package/dist/projection.js +0 -828
  112. package/dist/slices/add-field/index.d.ts +0 -8
  113. package/dist/slices/add-field/index.js +0 -211
  114. package/dist/slices/add-scenario/index.d.ts +0 -27
  115. package/dist/slices/codegen-chapter-events/index.d.ts +0 -2
  116. package/dist/slices/codegen-chapter-events/index.js +0 -145
  117. package/dist/slices/codegen-slice/index.d.ts +0 -2
  118. package/dist/slices/codegen-slice/index.js +0 -448
  119. package/dist/slices/create-automation-slice/index.d.ts +0 -2
  120. package/dist/slices/create-automation-slice/index.js +0 -304
  121. package/dist/slices/create-flow/index.d.ts +0 -2
  122. package/dist/slices/create-flow/index.js +0 -183
  123. package/dist/slices/create-state-change-slice/index.d.ts +0 -2
  124. package/dist/slices/create-state-change-slice/index.js +0 -263
  125. package/dist/slices/create-state-view-slice/index.d.ts +0 -2
  126. package/dist/slices/create-state-view-slice/index.js +0 -128
  127. package/dist/slices/diff/index.d.ts +0 -11
  128. package/dist/slices/diff/index.js +0 -293
  129. package/dist/slices/export-eventmodel-to-json/index.d.ts +0 -2
  130. package/dist/slices/export-eventmodel-to-json/index.js +0 -355
  131. package/dist/slices/git/index.d.ts +0 -2
  132. package/dist/slices/git/index.js +0 -125
  133. package/dist/slices/guide/guides/codegen.d.ts +0 -5
  134. package/dist/slices/guide/guides/connect-slices.d.ts +0 -5
  135. package/dist/slices/guide/guides/create-slices.d.ts +0 -5
  136. package/dist/slices/guide/guides/explore.d.ts +0 -5
  137. package/dist/slices/guide/guides/information-flow.d.ts +0 -5
  138. package/dist/slices/guide/guides/scenarios.d.ts +0 -5
  139. package/dist/slices/guide/index.d.ts +0 -1
  140. package/dist/slices/import/index.d.ts +0 -8
  141. package/dist/slices/import/index.js +0 -63
  142. package/dist/slices/init/index.d.ts +0 -5
  143. package/dist/slices/list-chapters/index.d.ts +0 -3
  144. package/dist/slices/list-chapters/index.js +0 -21
  145. package/dist/slices/list-commands/index.d.ts +0 -3
  146. package/dist/slices/list-commands/index.js +0 -20
  147. package/dist/slices/list-events/index.d.ts +0 -3
  148. package/dist/slices/list-events/index.js +0 -98
  149. package/dist/slices/list-processors/index.d.ts +0 -3
  150. package/dist/slices/list-processors/index.js +0 -20
  151. package/dist/slices/list-readmodels/index.d.ts +0 -3
  152. package/dist/slices/list-readmodels/index.js +0 -21
  153. package/dist/slices/list-scenarios/index.d.ts +0 -3
  154. package/dist/slices/list-scenarios/index.js +0 -35
  155. package/dist/slices/list-screens/index.d.ts +0 -3
  156. package/dist/slices/list-screens/index.js +0 -47
  157. package/dist/slices/list-slices/index.d.ts +0 -3
  158. package/dist/slices/list-slices/index.js +0 -35
  159. package/dist/slices/login/index.d.ts +0 -1
  160. package/dist/slices/logout/index.d.ts +0 -1
  161. package/dist/slices/map-fields/index.d.ts +0 -2
  162. package/dist/slices/map-fields/index.js +0 -269
  163. package/dist/slices/mark-slice-status/index.d.ts +0 -2
  164. package/dist/slices/mark-slice-status/index.js +0 -31
  165. package/dist/slices/merge/index.d.ts +0 -19
  166. package/dist/slices/merge/index.js +0 -147
  167. package/dist/slices/open-app/index.d.ts +0 -1
  168. package/dist/slices/remove-field/index.d.ts +0 -8
  169. package/dist/slices/remove-field/index.js +0 -167
  170. package/dist/slices/remove-scenario/index.d.ts +0 -2
  171. package/dist/slices/remove-scenario/index.js +0 -77
  172. package/dist/slices/search/index.d.ts +0 -3
  173. package/dist/slices/search/index.js +0 -302
  174. package/dist/slices/show-actor/index.d.ts +0 -4
  175. package/dist/slices/show-actor/index.js +0 -115
  176. package/dist/slices/show-aggregate/index.d.ts +0 -3
  177. package/dist/slices/show-aggregate/index.js +0 -108
  178. package/dist/slices/show-aggregate-completeness/index.d.ts +0 -4
  179. package/dist/slices/show-aggregate-completeness/index.js +0 -181
  180. package/dist/slices/show-chapter/index.d.ts +0 -3
  181. package/dist/slices/show-chapter/index.js +0 -195
  182. package/dist/slices/show-command/index.d.ts +0 -3
  183. package/dist/slices/show-command/index.js +0 -133
  184. package/dist/slices/show-completeness/index.d.ts +0 -4
  185. package/dist/slices/show-completeness/index.js +0 -731
  186. package/dist/slices/show-event/index.d.ts +0 -3
  187. package/dist/slices/show-event/index.js +0 -118
  188. package/dist/slices/show-model-summary/index.d.ts +0 -3
  189. package/dist/slices/show-model-summary/index.js +0 -31
  190. package/dist/slices/show-processor/index.d.ts +0 -3
  191. package/dist/slices/show-processor/index.js +0 -111
  192. package/dist/slices/show-readmodel/index.d.ts +0 -3
  193. package/dist/slices/show-readmodel/index.js +0 -158
  194. package/dist/slices/show-scenario/index.d.ts +0 -3
  195. package/dist/slices/show-scenario/index.js +0 -196
  196. package/dist/slices/show-screen/index.d.ts +0 -3
  197. package/dist/slices/show-screen/index.js +0 -139
  198. package/dist/slices/show-slice/index.d.ts +0 -3
  199. package/dist/slices/show-slice/index.js +0 -696
  200. package/dist/slices/update-field/index.d.ts +0 -15
  201. package/dist/slices/update-field/index.js +0 -208
  202. package/dist/slices/whoami/index.d.ts +0 -2
  203. package/dist/types.d.ts +0 -195
  204. package/dist/types.js +0 -1
@@ -1,8 +0,0 @@
1
- import type { EventModel } from '../../types.js';
2
- export declare function addField(model: EventModel, filePath: string, options: {
3
- command?: string;
4
- event?: string;
5
- readModel?: string;
6
- screen?: string;
7
- processor?: string;
8
- }, input: string): void;
@@ -1,211 +0,0 @@
1
- import * as crypto from 'node:crypto';
2
- import { appendEvent } from '../../lib/file-loader.js';
3
- import { findElementOrExit, excludeLinkedCopies } from '../../lib/element-lookup.js';
4
- const validFieldTypes = ['UUID', 'Boolean', 'Double', 'Decimal', 'Date', 'DateTime', 'Long', 'Int', 'String', 'Custom'];
5
- function parseJsonInput(input) {
6
- return JSON.parse(input);
7
- }
8
- function parseXmlInput(input) {
9
- const getAttr = (tag, attr) => {
10
- const match = tag.match(new RegExp(`${attr}="([^"]*)"`));
11
- return match ? match[1] : undefined;
12
- };
13
- const getBoolAttr = (tag, attr) => {
14
- const value = getAttr(tag, attr);
15
- if (value === 'true')
16
- return true;
17
- if (value === 'false')
18
- return false;
19
- return undefined;
20
- };
21
- const fieldMatch = input.match(/<field([^>]*?)(?:\/>|>([\s\S]*?)<\/field>)/);
22
- if (!fieldMatch) {
23
- throw new Error('Invalid XML: missing <field> tag');
24
- }
25
- const name = getAttr(fieldMatch[1], 'name');
26
- if (!name) {
27
- throw new Error('Invalid XML: field must have a name attribute');
28
- }
29
- const type = getAttr(fieldMatch[1], 'type');
30
- if (!type) {
31
- throw new Error('Invalid XML: field must have a type attribute');
32
- }
33
- const fieldInput = {
34
- name,
35
- type,
36
- isList: getBoolAttr(fieldMatch[1], 'isList'),
37
- isGenerated: getBoolAttr(fieldMatch[1], 'isGenerated'),
38
- isOptional: getBoolAttr(fieldMatch[1], 'isOptional'),
39
- isUserInput: getBoolAttr(fieldMatch[1], 'isUserInput'),
40
- };
41
- // Parse nested subfields for Custom type
42
- if (type === 'Custom' && fieldMatch[2]) {
43
- fieldInput.subfields = [];
44
- const subfieldMatches = fieldMatch[2].matchAll(/<field([^>]*?)(?:\/>|>([\s\S]*?)<\/field>)/g);
45
- for (const match of subfieldMatches) {
46
- const subfieldXml = match[0];
47
- fieldInput.subfields.push(parseXmlInput(subfieldXml));
48
- }
49
- }
50
- return fieldInput;
51
- }
52
- function parseInput(input) {
53
- const trimmed = input.trim();
54
- if (trimmed.startsWith('<')) {
55
- return parseXmlInput(trimmed);
56
- }
57
- return parseJsonInput(trimmed);
58
- }
59
- function createFieldFromInput(input) {
60
- return {
61
- id: crypto.randomUUID(),
62
- name: input.name,
63
- fieldType: input.type,
64
- isList: input.isList ?? false,
65
- isGenerated: input.isGenerated ?? false,
66
- isOptional: input.isOptional,
67
- isUserInput: input.isUserInput,
68
- subfields: input.subfields?.map(createFieldFromInput),
69
- };
70
- }
71
- export function addField(model, filePath, options, input) {
72
- // Determine which entity type
73
- const entityCount = [options.command, options.event, options.readModel, options.screen, options.processor].filter(Boolean).length;
74
- if (entityCount === 0) {
75
- console.error('Error: Must specify one of --command, --event, --read-model, --screen, or --processor');
76
- process.exit(1);
77
- }
78
- if (entityCount > 1) {
79
- console.error('Error: Can only specify one of --command, --event, --read-model, --screen, or --processor');
80
- process.exit(1);
81
- }
82
- // Parse input
83
- let fieldInput;
84
- try {
85
- fieldInput = parseInput(input);
86
- }
87
- catch (err) {
88
- console.error(`Error: Invalid input format: ${err.message}`);
89
- process.exit(1);
90
- }
91
- // Validate field type
92
- if (!validFieldTypes.includes(fieldInput.type)) {
93
- console.error(`Error: Invalid field type: ${fieldInput.type}`);
94
- console.error(`Valid types: ${validFieldTypes.join(', ')}`);
95
- const typeLower = fieldInput.type.toLowerCase();
96
- if (typeLower === 'list' || typeLower === 'array') {
97
- console.error(`\nHint: To make a field a list/array, use isList="true" with a valid type:`);
98
- console.error(` <field name="items" type="String" isList="true"/>`);
99
- }
100
- process.exit(1);
101
- }
102
- // Find entity and add field
103
- if (options.command) {
104
- addFieldToCommand(model, filePath, options.command, fieldInput);
105
- }
106
- else if (options.event) {
107
- addFieldToEvent(model, filePath, options.event, fieldInput);
108
- }
109
- else if (options.readModel) {
110
- addFieldToReadModel(model, filePath, options.readModel, fieldInput);
111
- }
112
- else if (options.screen) {
113
- addFieldToScreen(model, filePath, options.screen, fieldInput);
114
- }
115
- else if (options.processor) {
116
- addFieldToProcessor(model, filePath, options.processor, fieldInput);
117
- }
118
- }
119
- function addFieldToCommand(model, filePath, commandName, fieldInput) {
120
- const command = findElementOrExit(model.commands, commandName, 'command');
121
- // Check for duplicate field name
122
- if (command.fields.some(f => f.name.toLowerCase() === fieldInput.name.toLowerCase())) {
123
- console.error(`Error: Field "${fieldInput.name}" already exists on command "${command.name}"`);
124
- process.exit(1);
125
- }
126
- const field = createFieldFromInput(fieldInput);
127
- appendEvent(filePath, {
128
- type: 'CommandFieldAdded',
129
- data: {
130
- commandStickyId: command.id,
131
- field,
132
- timestamp: Date.now(),
133
- },
134
- });
135
- console.log(`Added field "${field.name}" to command "${command.name}"`);
136
- }
137
- function addFieldToEvent(model, filePath, eventName, fieldInput) {
138
- // Exclude linked copies - they share fields with their canonical original
139
- const event = findElementOrExit(excludeLinkedCopies(model.events), eventName, 'event');
140
- // Check for duplicate field name
141
- if (event.fields.some(f => f.name.toLowerCase() === fieldInput.name.toLowerCase())) {
142
- console.error(`Error: Field "${fieldInput.name}" already exists on event "${event.name}"`);
143
- process.exit(1);
144
- }
145
- const field = createFieldFromInput(fieldInput);
146
- appendEvent(filePath, {
147
- type: 'EventFieldAdded',
148
- data: {
149
- eventStickyId: event.id,
150
- field,
151
- timestamp: Date.now(),
152
- },
153
- });
154
- console.log(`Added field "${field.name}" to event "${event.name}"`);
155
- }
156
- function addFieldToReadModel(model, filePath, readModelName, fieldInput) {
157
- // Exclude linked copies - they share fields with their canonical original
158
- const readModel = findElementOrExit(excludeLinkedCopies(model.readModels), readModelName, 'read model');
159
- // Check for duplicate field name
160
- if (readModel.fields.some(f => f.name.toLowerCase() === fieldInput.name.toLowerCase())) {
161
- console.error(`Error: Field "${fieldInput.name}" already exists on read model "${readModel.name}"`);
162
- process.exit(1);
163
- }
164
- const field = createFieldFromInput(fieldInput);
165
- appendEvent(filePath, {
166
- type: 'ReadModelFieldAdded',
167
- data: {
168
- readModelStickyId: readModel.id,
169
- field,
170
- timestamp: Date.now(),
171
- },
172
- });
173
- console.log(`Added field "${field.name}" to read model "${readModel.name}"`);
174
- }
175
- function addFieldToScreen(model, filePath, screenName, fieldInput) {
176
- // Exclude linked copies - they share fields with their canonical original
177
- const screen = findElementOrExit(excludeLinkedCopies(model.screens), screenName, 'screen');
178
- // Check for duplicate field name
179
- if (screen.fields.some(f => f.name.toLowerCase() === fieldInput.name.toLowerCase())) {
180
- console.error(`Error: Field "${fieldInput.name}" already exists on screen "${screen.name}"`);
181
- process.exit(1);
182
- }
183
- const field = createFieldFromInput(fieldInput);
184
- appendEvent(filePath, {
185
- type: 'ScreenFieldAdded',
186
- data: {
187
- screenId: screen.id,
188
- field,
189
- timestamp: Date.now(),
190
- },
191
- });
192
- console.log(`Added field "${field.name}" to screen "${screen.name}"`);
193
- }
194
- function addFieldToProcessor(model, filePath, processorName, fieldInput) {
195
- const processor = findElementOrExit(model.processors, processorName, 'processor');
196
- // Check for duplicate field name
197
- if (processor.fields.some(f => f.name.toLowerCase() === fieldInput.name.toLowerCase())) {
198
- console.error(`Error: Field "${fieldInput.name}" already exists on processor "${processor.name}"`);
199
- process.exit(1);
200
- }
201
- const field = createFieldFromInput(fieldInput);
202
- appendEvent(filePath, {
203
- type: 'ProcessorFieldAdded',
204
- data: {
205
- processorId: processor.id,
206
- field,
207
- timestamp: Date.now(),
208
- },
209
- });
210
- console.log(`Added field "${field.name}" to processor "${processor.name}"`);
211
- }
@@ -1,27 +0,0 @@
1
- export interface ScenarioInput {
2
- name: string;
3
- description?: string;
4
- given?: EventInput[];
5
- when?: {
6
- command?: string;
7
- commandFieldValues?: Record<string, unknown>;
8
- events?: EventInput[];
9
- };
10
- then: {
11
- type: 'error' | 'events' | 'readModelAssertion' | 'command' | 'noCommand';
12
- errorMessage?: string;
13
- errorType?: string;
14
- events?: EventInput[];
15
- command?: string;
16
- commandFieldValues?: Record<string, unknown>;
17
- readModel?: string;
18
- givenEvents?: EventInput[];
19
- expected?: Record<string, unknown>;
20
- };
21
- }
22
- interface EventInput {
23
- event: string;
24
- fieldValues?: Record<string, unknown>;
25
- }
26
- export declare function parseScenarioInput(input: string): ScenarioInput;
27
- export {};
@@ -1,2 +0,0 @@
1
- import type { EventModel } from '../../types.js';
2
- export declare function codegenEvents(model: EventModel, chapterName?: string): void;
@@ -1,145 +0,0 @@
1
- import { outputJson } from '../../lib/format.js';
2
- import { findElementOrExit } from '../../lib/element-lookup.js';
3
- import { getChapterHierarchy } from '../../lib/chapter-utils.js';
4
- function countFieldsDeep(fields) {
5
- if (!fields || fields.length === 0) {
6
- return 0;
7
- }
8
- return fields.reduce((count, field) => count + 1 + countFieldsDeep(field.subfields), 0);
9
- }
10
- function normalizeName(name) {
11
- return name.trim().toLowerCase();
12
- }
13
- function fieldToJson(field) {
14
- const result = {
15
- name: field.name,
16
- type: field.fieldType,
17
- };
18
- if (field.isList)
19
- result.list = true;
20
- if (field.isGenerated)
21
- result.generated = true;
22
- if (field.isOptional)
23
- result.optional = true;
24
- if (field.isUserInput)
25
- result.userInput = true;
26
- if (field.subfields && field.subfields.length > 0) {
27
- result.subfields = field.subfields.map(fieldToJson);
28
- }
29
- return result;
30
- }
31
- function isCenterInSlice(slice, x, y, width, height) {
32
- const centerX = x + width / 2;
33
- const centerY = y + height / 2;
34
- return (centerX >= slice.position.x &&
35
- centerX <= slice.position.x + slice.size.width &&
36
- centerY >= slice.position.y &&
37
- centerY <= slice.position.y + slice.size.height);
38
- }
39
- function findAggregateForEvent(model, event) {
40
- const centerX = event.position.x + event.width / 2;
41
- const centerY = event.position.y + event.height / 2;
42
- for (const aggregate of model.aggregates.values()) {
43
- if (centerX >= aggregate.position.x &&
44
- centerX <= aggregate.position.x + aggregate.size.width &&
45
- centerY >= aggregate.position.y &&
46
- centerY <= aggregate.position.y + aggregate.size.height) {
47
- return aggregate.name;
48
- }
49
- }
50
- return undefined;
51
- }
52
- function determineSliceType(model, slice) {
53
- const hasProcessors = [...model.processors.values()].some(processor => isCenterInSlice(slice, processor.position.x, processor.position.y, processor.width, processor.height));
54
- if (hasProcessors) {
55
- return 'AUTOMATION';
56
- }
57
- const hasCommands = [...model.commands.values()].some(command => isCenterInSlice(slice, command.position.x, command.position.y, command.width, command.height));
58
- const hasEvents = [...model.events.values()].some(event => !event.originalNodeId && isCenterInSlice(slice, event.position.x, event.position.y, event.width, event.height));
59
- if (hasCommands && hasEvents) {
60
- return 'STATE_CHANGE';
61
- }
62
- return 'STATE_VIEW';
63
- }
64
- function getSlicesUnderChapter(model, chapter) {
65
- const chapterLeft = chapter.position.x;
66
- const chapterRight = chapter.position.x + chapter.size.width;
67
- return [...model.slices.values()].filter(slice => {
68
- const sliceCenterX = slice.position.x + slice.size.width / 2;
69
- return sliceCenterX >= chapterLeft && sliceCenterX <= chapterRight;
70
- });
71
- }
72
- function codegenChapterEvents(model, chapterName) {
73
- const chapter = findElementOrExit(model.chapters, chapterName, 'chapter');
74
- const chapterHierarchy = getChapterHierarchy(model, chapter);
75
- const slices = getSlicesUnderChapter(model, chapter).sort((a, b) => a.position.x - b.position.x);
76
- outputEventsFromSlices(model, slices, chapterHierarchy);
77
- }
78
- export function codegenEvents(model, chapterName) {
79
- if (chapterName) {
80
- codegenChapterEvents(model, chapterName);
81
- return;
82
- }
83
- const slices = [...model.slices.values()].sort((a, b) => {
84
- if (a.position.x === b.position.x) {
85
- return a.position.y - b.position.y;
86
- }
87
- return a.position.x - b.position.x;
88
- });
89
- outputEventsFromSlices(model, slices, null);
90
- }
91
- function outputEventsFromSlices(model, slices, chapterHierarchy) {
92
- const eventsByName = new Map();
93
- const sliceSummaries = [];
94
- for (const slice of slices) {
95
- sliceSummaries.push({
96
- id: slice.id,
97
- name: slice.name,
98
- sliceType: determineSliceType(model, slice),
99
- });
100
- const sliceEvents = [...model.events.values()].filter(event => !event.originalNodeId &&
101
- isCenterInSlice(slice, event.position.x, event.position.y, event.width, event.height));
102
- for (const event of sliceEvents) {
103
- const key = normalizeName(event.name);
104
- if (!key) {
105
- continue;
106
- }
107
- const eventFields = event.fields.map(fieldToJson);
108
- const existing = eventsByName.get(key);
109
- if (!existing) {
110
- eventsByName.set(key, {
111
- id: event.id,
112
- name: event.name,
113
- fields: eventFields,
114
- aggregate: findAggregateForEvent(model, event),
115
- sourceSlices: [slice.name],
116
- });
117
- continue;
118
- }
119
- if (!existing.sourceSlices.includes(slice.name)) {
120
- existing.sourceSlices.push(slice.name);
121
- }
122
- if (!existing.aggregate) {
123
- existing.aggregate = findAggregateForEvent(model, event);
124
- }
125
- if (countFieldsDeep(eventFields) > countFieldsDeep(existing.fields)) {
126
- existing.fields = eventFields;
127
- }
128
- if (!existing.id) {
129
- existing.id = event.id;
130
- }
131
- }
132
- }
133
- const events = [...eventsByName.values()]
134
- .map(event => ({ ...event, sourceSlices: [...event.sourceSlices].sort((a, b) => a.localeCompare(b)) }))
135
- .sort((a, b) => a.name.localeCompare(b.name));
136
- const sortedSlices = [...sliceSummaries].sort((a, b) => a.name.localeCompare(b.name));
137
- const output = {
138
- chapter: chapterHierarchy,
139
- sliceCount: sortedSlices.length,
140
- eventCount: events.length,
141
- slices: sortedSlices,
142
- events,
143
- };
144
- outputJson(output);
145
- }
@@ -1,2 +0,0 @@
1
- import type { EventModel } from '../../types.js';
2
- export declare function codegenSlice(model: EventModel, sliceName: string): void;