@lssm/example.workflow-system 1.41.0 → 1.42.1

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 (123) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +3 -0
  3. package/dist/approval/approval.enum.d.ts +14 -0
  4. package/dist/approval/approval.enum.d.ts.map +1 -0
  5. package/dist/approval/approval.enum.js +29 -1
  6. package/dist/approval/approval.enum.js.map +1 -0
  7. package/dist/approval/approval.event.d.ts +131 -0
  8. package/dist/approval/approval.event.d.ts.map +1 -0
  9. package/dist/approval/approval.event.js +220 -1
  10. package/dist/approval/approval.event.js.map +1 -0
  11. package/dist/approval/approval.handler.d.ts +23 -0
  12. package/dist/approval/approval.handler.d.ts.map +1 -0
  13. package/dist/approval/approval.handler.js +72 -1
  14. package/dist/approval/approval.handler.js.map +1 -0
  15. package/dist/approval/approval.operations.d.ts +535 -0
  16. package/dist/approval/approval.operations.d.ts.map +1 -0
  17. package/dist/approval/approval.operations.js +345 -0
  18. package/dist/approval/approval.operations.js.map +1 -0
  19. package/dist/approval/approval.schema.d.ts +100 -0
  20. package/dist/approval/approval.schema.d.ts.map +1 -0
  21. package/dist/approval/approval.schema.js +110 -1
  22. package/dist/approval/approval.schema.js.map +1 -0
  23. package/dist/approval/index.d.ts +5 -0
  24. package/dist/approval/index.js +6 -1
  25. package/dist/docs/index.d.ts +1 -0
  26. package/dist/docs/index.js +1 -1
  27. package/dist/docs/workflow-system.docblock.d.ts +1 -0
  28. package/dist/docs/workflow-system.docblock.js +61 -5
  29. package/dist/docs/workflow-system.docblock.js.map +1 -0
  30. package/dist/entities/approval.d.ts +58 -0
  31. package/dist/entities/approval.d.ts.map +1 -0
  32. package/dist/entities/approval.js +128 -1
  33. package/dist/entities/approval.js.map +1 -0
  34. package/dist/entities/index.d.ts +139 -0
  35. package/dist/entities/index.d.ts.map +1 -0
  36. package/dist/entities/index.js +32 -1
  37. package/dist/entities/index.js.map +1 -0
  38. package/dist/entities/instance.d.ts +69 -0
  39. package/dist/entities/instance.d.ts.map +1 -0
  40. package/dist/entities/instance.js +168 -1
  41. package/dist/entities/instance.js.map +1 -0
  42. package/dist/entities/step.d.ts +50 -0
  43. package/dist/entities/step.d.ts.map +1 -0
  44. package/dist/entities/step.js +135 -1
  45. package/dist/entities/step.js.map +1 -0
  46. package/dist/entities/workflow.d.ts +41 -0
  47. package/dist/entities/workflow.d.ts.map +1 -0
  48. package/dist/entities/workflow.js +102 -1
  49. package/dist/entities/workflow.js.map +1 -0
  50. package/dist/example.d.ts +40 -0
  51. package/dist/example.d.ts.map +1 -0
  52. package/dist/example.js +51 -1
  53. package/dist/example.js.map +1 -0
  54. package/dist/index.d.ts +21 -0
  55. package/dist/index.js +21 -1
  56. package/dist/instance/index.d.ts +5 -0
  57. package/dist/instance/index.js +6 -1
  58. package/dist/instance/instance.enum.d.ts +10 -0
  59. package/dist/instance/instance.enum.d.ts.map +1 -0
  60. package/dist/instance/instance.enum.js +20 -1
  61. package/dist/instance/instance.enum.js.map +1 -0
  62. package/dist/instance/instance.event.d.ts +356 -0
  63. package/dist/instance/instance.event.d.ts.map +1 -0
  64. package/dist/instance/instance.event.js +293 -1
  65. package/dist/instance/instance.event.js.map +1 -0
  66. package/dist/instance/instance.handler.d.ts +27 -0
  67. package/dist/instance/instance.handler.d.ts.map +1 -0
  68. package/dist/instance/instance.handler.js +94 -1
  69. package/dist/instance/instance.handler.js.map +1 -0
  70. package/dist/instance/instance.operations.d.ts +1024 -0
  71. package/dist/instance/instance.operations.d.ts.map +1 -0
  72. package/dist/instance/instance.operations.js +464 -0
  73. package/dist/instance/instance.operations.js.map +1 -0
  74. package/dist/instance/instance.schema.d.ts +223 -0
  75. package/dist/instance/instance.schema.d.ts.map +1 -0
  76. package/dist/instance/instance.schema.js +172 -1
  77. package/dist/instance/instance.schema.js.map +1 -0
  78. package/dist/presentations/index.d.ts +64 -0
  79. package/dist/presentations/index.d.ts.map +1 -0
  80. package/dist/presentations/index.js +337 -1
  81. package/dist/presentations/index.js.map +1 -0
  82. package/dist/shared/index.d.ts +3 -0
  83. package/dist/shared/index.js +3 -1
  84. package/dist/shared/mock-data.d.ts +19 -0
  85. package/dist/shared/mock-data.d.ts.map +1 -0
  86. package/dist/shared/mock-data.js +12 -1
  87. package/dist/shared/mock-data.js.map +1 -0
  88. package/dist/shared/types.d.ts +81 -0
  89. package/dist/shared/types.d.ts.map +1 -0
  90. package/dist/state-machine/index.d.ts +148 -0
  91. package/dist/state-machine/index.d.ts.map +1 -0
  92. package/dist/state-machine/index.js +158 -1
  93. package/dist/state-machine/index.js.map +1 -0
  94. package/dist/workflow/index.d.ts +5 -0
  95. package/dist/workflow/index.js +6 -1
  96. package/dist/workflow/workflow.enum.d.ts +22 -0
  97. package/dist/workflow/workflow.enum.d.ts.map +1 -0
  98. package/dist/workflow/workflow.enum.js +47 -1
  99. package/dist/workflow/workflow.enum.js.map +1 -0
  100. package/dist/workflow/workflow.event.d.ts +135 -0
  101. package/dist/workflow/workflow.event.d.ts.map +1 -0
  102. package/dist/workflow/workflow.event.js +150 -1
  103. package/dist/workflow/workflow.event.js.map +1 -0
  104. package/dist/workflow/workflow.handler.d.ts +29 -0
  105. package/dist/workflow/workflow.handler.d.ts.map +1 -0
  106. package/dist/workflow/workflow.handler.js +66 -1
  107. package/dist/workflow/workflow.handler.js.map +1 -0
  108. package/dist/workflow/workflow.operations.d.ts +1011 -0
  109. package/dist/workflow/workflow.operations.d.ts.map +1 -0
  110. package/dist/workflow/workflow.operations.js +345 -0
  111. package/dist/workflow/workflow.operations.js.map +1 -0
  112. package/dist/workflow/workflow.schema.d.ts +265 -0
  113. package/dist/workflow/workflow.schema.d.ts.map +1 -0
  114. package/dist/workflow/workflow.schema.js +249 -1
  115. package/dist/workflow/workflow.schema.js.map +1 -0
  116. package/dist/workflow-system.feature.d.ts +12 -0
  117. package/dist/workflow-system.feature.d.ts.map +1 -0
  118. package/dist/workflow-system.feature.js +339 -1
  119. package/dist/workflow-system.feature.js.map +1 -0
  120. package/package.json +57 -49
  121. package/dist/approval/approval.contracts.js +0 -1
  122. package/dist/instance/instance.contracts.js +0 -1
  123. package/dist/workflow/workflow.contracts.js +0 -1
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 Chaman Ventures, SASU
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md CHANGED
@@ -1,5 +1,8 @@
1
1
  # @lssm/example.workflow-system
2
2
 
3
+ Website: https://contractspec.lssm.tech/
4
+
5
+
3
6
  A comprehensive workflow and approval system example demonstrating ContractSpec principles.
4
7
 
5
8
  ## Features
@@ -0,0 +1,14 @@
1
+ import * as _lssm_lib_schema61 from "@lssm/lib.schema";
2
+
3
+ //#region src/approval/approval.enum.d.ts
4
+ /**
5
+ * Approval status enum.
6
+ */
7
+ declare const ApprovalStatusEnum: _lssm_lib_schema61.EnumType<[string, string, string, string, string, string, string]>;
8
+ /**
9
+ * Approval decision enum.
10
+ */
11
+ declare const ApprovalDecisionEnum: _lssm_lib_schema61.EnumType<[string, string, string, string, string]>;
12
+ //#endregion
13
+ export { ApprovalDecisionEnum, ApprovalStatusEnum };
14
+ //# sourceMappingURL=approval.enum.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approval.enum.d.ts","names":[],"sources":["../../src/approval/approval.enum.ts"],"sourcesContent":[],"mappings":";;;;;;AAKa,cAAA,kBAQX,EAAA,kBAAA,CAR6B,QAAA,CAAA,CAAA,MAAA,EAAA,MAAA,EAAA,MAAA,EAAA,MAAA,EAAA,MAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA;AAa/B;;;cAAa,sBAMX,kBAAA,CAN+B"}
@@ -1 +1,29 @@
1
- import{defineEnum as e}from"@lssm/lib.schema";const t=e(`ApprovalStatus`,[`PENDING`,`APPROVED`,`REJECTED`,`DELEGATED`,`ESCALATED`,`WITHDRAWN`,`EXPIRED`]),n=e(`ApprovalDecision`,[`APPROVE`,`REJECT`,`REQUEST_CHANGES`,`DELEGATE`,`ABSTAIN`]);export{n as ApprovalDecisionEnum,t as ApprovalStatusEnum};
1
+ import { defineEnum } from "@lssm/lib.schema";
2
+
3
+ //#region src/approval/approval.enum.ts
4
+ /**
5
+ * Approval status enum.
6
+ */
7
+ const ApprovalStatusEnum = defineEnum("ApprovalStatus", [
8
+ "PENDING",
9
+ "APPROVED",
10
+ "REJECTED",
11
+ "DELEGATED",
12
+ "ESCALATED",
13
+ "WITHDRAWN",
14
+ "EXPIRED"
15
+ ]);
16
+ /**
17
+ * Approval decision enum.
18
+ */
19
+ const ApprovalDecisionEnum = defineEnum("ApprovalDecision", [
20
+ "APPROVE",
21
+ "REJECT",
22
+ "REQUEST_CHANGES",
23
+ "DELEGATE",
24
+ "ABSTAIN"
25
+ ]);
26
+
27
+ //#endregion
28
+ export { ApprovalDecisionEnum, ApprovalStatusEnum };
29
+ //# sourceMappingURL=approval.enum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approval.enum.js","names":[],"sources":["../../src/approval/approval.enum.ts"],"sourcesContent":["import { defineEnum } from '@lssm/lib.schema';\n\n/**\n * Approval status enum.\n */\nexport const ApprovalStatusEnum = defineEnum('ApprovalStatus', [\n 'PENDING',\n 'APPROVED',\n 'REJECTED',\n 'DELEGATED',\n 'ESCALATED',\n 'WITHDRAWN',\n 'EXPIRED',\n]);\n\n/**\n * Approval decision enum.\n */\nexport const ApprovalDecisionEnum = defineEnum('ApprovalDecision', [\n 'APPROVE',\n 'REJECT',\n 'REQUEST_CHANGES',\n 'DELEGATE',\n 'ABSTAIN',\n]);\n"],"mappings":";;;;;;AAKA,MAAa,qBAAqB,WAAW,kBAAkB;CAC7D;CACA;CACA;CACA;CACA;CACA;CACA;CACD,CAAC;;;;AAKF,MAAa,uBAAuB,WAAW,oBAAoB;CACjE;CACA;CACA;CACA;CACA;CACD,CAAC"}
@@ -0,0 +1,131 @@
1
+ import * as _lssm_lib_schema63 from "@lssm/lib.schema";
2
+ import * as _lssm_lib_contracts0 from "@lssm/lib.contracts";
3
+
4
+ //#region src/approval/approval.event.d.ts
5
+ /**
6
+ * ApprovalRequestedEvent - An approval has been requested.
7
+ */
8
+ declare const ApprovalRequestedEvent: _lssm_lib_contracts0.EventSpec<_lssm_lib_schema63.SchemaModel<{
9
+ requestId: {
10
+ type: _lssm_lib_schema63.FieldType<string, string>;
11
+ isOptional: false;
12
+ };
13
+ instanceId: {
14
+ type: _lssm_lib_schema63.FieldType<string, string>;
15
+ isOptional: false;
16
+ };
17
+ workflowKey: {
18
+ type: _lssm_lib_schema63.FieldType<string, string>;
19
+ isOptional: false;
20
+ };
21
+ approverId: {
22
+ type: _lssm_lib_schema63.FieldType<string, string>;
23
+ isOptional: false;
24
+ };
25
+ approverRole: {
26
+ type: _lssm_lib_schema63.FieldType<string, string>;
27
+ isOptional: true;
28
+ };
29
+ title: {
30
+ type: _lssm_lib_schema63.FieldType<string, string>;
31
+ isOptional: false;
32
+ };
33
+ dueAt: {
34
+ type: _lssm_lib_schema63.FieldType<Date, string>;
35
+ isOptional: true;
36
+ };
37
+ timestamp: {
38
+ type: _lssm_lib_schema63.FieldType<Date, string>;
39
+ isOptional: false;
40
+ };
41
+ }>>;
42
+ /**
43
+ * ApprovalDecidedEvent - An approval decision has been made.
44
+ */
45
+ declare const ApprovalDecidedEvent: _lssm_lib_contracts0.EventSpec<_lssm_lib_schema63.SchemaModel<{
46
+ requestId: {
47
+ type: _lssm_lib_schema63.FieldType<string, string>;
48
+ isOptional: false;
49
+ };
50
+ instanceId: {
51
+ type: _lssm_lib_schema63.FieldType<string, string>;
52
+ isOptional: false;
53
+ };
54
+ decision: {
55
+ type: _lssm_lib_schema63.FieldType<string, string>;
56
+ isOptional: false;
57
+ };
58
+ decidedBy: {
59
+ type: _lssm_lib_schema63.FieldType<string, string>;
60
+ isOptional: false;
61
+ };
62
+ comment: {
63
+ type: _lssm_lib_schema63.FieldType<string, string>;
64
+ isOptional: true;
65
+ };
66
+ timestamp: {
67
+ type: _lssm_lib_schema63.FieldType<Date, string>;
68
+ isOptional: false;
69
+ };
70
+ }>>;
71
+ /**
72
+ * ApprovalDelegatedEvent - An approval has been delegated.
73
+ */
74
+ declare const ApprovalDelegatedEvent: _lssm_lib_contracts0.EventSpec<_lssm_lib_schema63.SchemaModel<{
75
+ requestId: {
76
+ type: _lssm_lib_schema63.FieldType<string, string>;
77
+ isOptional: false;
78
+ };
79
+ instanceId: {
80
+ type: _lssm_lib_schema63.FieldType<string, string>;
81
+ isOptional: false;
82
+ };
83
+ fromUserId: {
84
+ type: _lssm_lib_schema63.FieldType<string, string>;
85
+ isOptional: false;
86
+ };
87
+ toUserId: {
88
+ type: _lssm_lib_schema63.FieldType<string, string>;
89
+ isOptional: false;
90
+ };
91
+ reason: {
92
+ type: _lssm_lib_schema63.FieldType<string, string>;
93
+ isOptional: true;
94
+ };
95
+ timestamp: {
96
+ type: _lssm_lib_schema63.FieldType<Date, string>;
97
+ isOptional: false;
98
+ };
99
+ }>>;
100
+ /**
101
+ * ApprovalEscalatedEvent - An approval has been escalated.
102
+ */
103
+ declare const ApprovalEscalatedEvent: _lssm_lib_contracts0.EventSpec<_lssm_lib_schema63.SchemaModel<{
104
+ requestId: {
105
+ type: _lssm_lib_schema63.FieldType<string, string>;
106
+ isOptional: false;
107
+ };
108
+ instanceId: {
109
+ type: _lssm_lib_schema63.FieldType<string, string>;
110
+ isOptional: false;
111
+ };
112
+ escalationLevel: {
113
+ type: _lssm_lib_schema63.FieldType<number, number>;
114
+ isOptional: false;
115
+ };
116
+ escalatedTo: {
117
+ type: _lssm_lib_schema63.FieldType<string, string>;
118
+ isOptional: false;
119
+ };
120
+ reason: {
121
+ type: _lssm_lib_schema63.FieldType<string, string>;
122
+ isOptional: false;
123
+ };
124
+ timestamp: {
125
+ type: _lssm_lib_schema63.FieldType<Date, string>;
126
+ isOptional: false;
127
+ };
128
+ }>>;
129
+ //#endregion
130
+ export { ApprovalDecidedEvent, ApprovalDelegatedEvent, ApprovalEscalatedEvent, ApprovalRequestedEvent };
131
+ //# sourceMappingURL=approval.event.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approval.event.d.ts","names":[],"sources":["../../src/approval/approval.event.ts"],"sourcesContent":[],"mappings":";;;;;;;cAiFa,wBAAsB,oBAAA,CAAA,6BAAA;EAAtB,SAAA,EAAA;IAUX,IAAA,EAAA,kBAAA,CAAA,SAAA,CAAA,MAAA,EAAA,MAAA,CAAA;;;;;;;;;;;EAViC,UAAA,EAAA;IAAA,IAAA,8BAAA,CAAA,MAAA,EAAA,MAAA,CAAA;IAetB,UAAA,EAAA,KAAA;EAUX,CAAA;;;;;;;gBAV+B,KAAA;EAAA,CAAA;EAAA,KAAA,EAAA;IAepB,IAAA,8BAUX,KAAA,EAAA,MAAA,CAAA;IAAA,UAAA,EAAA,IAAA;;;;;;;;;;AAKW,cA9BA,oBAwCX,EAxC+B,oBAAA,CAAA,SAwC/B,oBAxC+B,WAwC/B,CAAA;EAAA,SAAA,EAAA;UA9BA,kBAAA,CAAA;;;;;;;EAoBiC,QAAA,EAAA;IAAA,IAAA,8BAAA,CAAA,MAAA,EAAA,MAAA,CAAA;;;;;;;;;;;;;;;;;;;cAftB,wBAAsB,oBAAA,CAAA,6BAAA;;UAUjC,kBAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;cAKW,wBAAsB,oBAAA,CAAA,6BAAA;;UAUjC,kBAAA,CAAA"}
@@ -1 +1,220 @@
1
- import{ScalarTypeEnum as e}from"@lssm/lib.schema";import{defineEvent as t,defineSchemaModel as n}from"@lssm/lib.contracts";const r=n({name:`ApprovalRequestedEventPayload`,description:`Payload when approval is requested`,fields:{requestId:{type:e.String_unsecure(),isOptional:!1},instanceId:{type:e.String_unsecure(),isOptional:!1},workflowKey:{type:e.String_unsecure(),isOptional:!1},approverId:{type:e.String_unsecure(),isOptional:!1},approverRole:{type:e.String_unsecure(),isOptional:!0},title:{type:e.String_unsecure(),isOptional:!1},dueAt:{type:e.DateTime(),isOptional:!0},timestamp:{type:e.DateTime(),isOptional:!1}}}),i=n({name:`ApprovalDecidedEventPayload`,description:`Payload when approval decision is made`,fields:{requestId:{type:e.String_unsecure(),isOptional:!1},instanceId:{type:e.String_unsecure(),isOptional:!1},decision:{type:e.String_unsecure(),isOptional:!1},decidedBy:{type:e.String_unsecure(),isOptional:!1},comment:{type:e.String_unsecure(),isOptional:!0},timestamp:{type:e.DateTime(),isOptional:!1}}}),a=n({name:`ApprovalDelegatedEventPayload`,description:`Payload when approval is delegated`,fields:{requestId:{type:e.String_unsecure(),isOptional:!1},instanceId:{type:e.String_unsecure(),isOptional:!1},fromUserId:{type:e.String_unsecure(),isOptional:!1},toUserId:{type:e.String_unsecure(),isOptional:!1},reason:{type:e.String_unsecure(),isOptional:!0},timestamp:{type:e.DateTime(),isOptional:!1}}}),o=n({name:`ApprovalEscalatedEventPayload`,description:`Payload when approval is escalated`,fields:{requestId:{type:e.String_unsecure(),isOptional:!1},instanceId:{type:e.String_unsecure(),isOptional:!1},escalationLevel:{type:e.Int_unsecure(),isOptional:!1},escalatedTo:{type:e.String_unsecure(),isOptional:!1},reason:{type:e.String_unsecure(),isOptional:!1},timestamp:{type:e.DateTime(),isOptional:!1}}}),s=t({name:`workflow.approval.requested`,version:1,description:`An approval has been requested.`,payload:r}),c=t({name:`workflow.approval.decided`,version:1,description:`An approval decision has been made.`,payload:i}),l=t({name:`workflow.approval.delegated`,version:1,description:`An approval has been delegated.`,payload:a}),u=t({name:`workflow.approval.escalated`,version:1,description:`An approval has been escalated.`,payload:o});export{c as ApprovalDecidedEvent,l as ApprovalDelegatedEvent,u as ApprovalEscalatedEvent,s as ApprovalRequestedEvent};
1
+ import { ScalarTypeEnum } from "@lssm/lib.schema";
2
+ import { defineEvent, defineSchemaModel as defineSchemaModel$1 } from "@lssm/lib.contracts";
3
+
4
+ //#region src/approval/approval.event.ts
5
+ /**
6
+ * Payload when approval is requested.
7
+ */
8
+ const ApprovalRequestedPayload = defineSchemaModel$1({
9
+ name: "ApprovalRequestedEventPayload",
10
+ description: "Payload when approval is requested",
11
+ fields: {
12
+ requestId: {
13
+ type: ScalarTypeEnum.String_unsecure(),
14
+ isOptional: false
15
+ },
16
+ instanceId: {
17
+ type: ScalarTypeEnum.String_unsecure(),
18
+ isOptional: false
19
+ },
20
+ workflowKey: {
21
+ type: ScalarTypeEnum.String_unsecure(),
22
+ isOptional: false
23
+ },
24
+ approverId: {
25
+ type: ScalarTypeEnum.String_unsecure(),
26
+ isOptional: false
27
+ },
28
+ approverRole: {
29
+ type: ScalarTypeEnum.String_unsecure(),
30
+ isOptional: true
31
+ },
32
+ title: {
33
+ type: ScalarTypeEnum.String_unsecure(),
34
+ isOptional: false
35
+ },
36
+ dueAt: {
37
+ type: ScalarTypeEnum.DateTime(),
38
+ isOptional: true
39
+ },
40
+ timestamp: {
41
+ type: ScalarTypeEnum.DateTime(),
42
+ isOptional: false
43
+ }
44
+ }
45
+ });
46
+ /**
47
+ * Payload when approval decision is made.
48
+ */
49
+ const ApprovalDecidedPayload = defineSchemaModel$1({
50
+ name: "ApprovalDecidedEventPayload",
51
+ description: "Payload when approval decision is made",
52
+ fields: {
53
+ requestId: {
54
+ type: ScalarTypeEnum.String_unsecure(),
55
+ isOptional: false
56
+ },
57
+ instanceId: {
58
+ type: ScalarTypeEnum.String_unsecure(),
59
+ isOptional: false
60
+ },
61
+ decision: {
62
+ type: ScalarTypeEnum.String_unsecure(),
63
+ isOptional: false
64
+ },
65
+ decidedBy: {
66
+ type: ScalarTypeEnum.String_unsecure(),
67
+ isOptional: false
68
+ },
69
+ comment: {
70
+ type: ScalarTypeEnum.String_unsecure(),
71
+ isOptional: true
72
+ },
73
+ timestamp: {
74
+ type: ScalarTypeEnum.DateTime(),
75
+ isOptional: false
76
+ }
77
+ }
78
+ });
79
+ /**
80
+ * Payload when approval is delegated.
81
+ */
82
+ const ApprovalDelegatedPayload = defineSchemaModel$1({
83
+ name: "ApprovalDelegatedEventPayload",
84
+ description: "Payload when approval is delegated",
85
+ fields: {
86
+ requestId: {
87
+ type: ScalarTypeEnum.String_unsecure(),
88
+ isOptional: false
89
+ },
90
+ instanceId: {
91
+ type: ScalarTypeEnum.String_unsecure(),
92
+ isOptional: false
93
+ },
94
+ fromUserId: {
95
+ type: ScalarTypeEnum.String_unsecure(),
96
+ isOptional: false
97
+ },
98
+ toUserId: {
99
+ type: ScalarTypeEnum.String_unsecure(),
100
+ isOptional: false
101
+ },
102
+ reason: {
103
+ type: ScalarTypeEnum.String_unsecure(),
104
+ isOptional: true
105
+ },
106
+ timestamp: {
107
+ type: ScalarTypeEnum.DateTime(),
108
+ isOptional: false
109
+ }
110
+ }
111
+ });
112
+ /**
113
+ * Payload when approval is escalated.
114
+ */
115
+ const ApprovalEscalatedPayload = defineSchemaModel$1({
116
+ name: "ApprovalEscalatedEventPayload",
117
+ description: "Payload when approval is escalated",
118
+ fields: {
119
+ requestId: {
120
+ type: ScalarTypeEnum.String_unsecure(),
121
+ isOptional: false
122
+ },
123
+ instanceId: {
124
+ type: ScalarTypeEnum.String_unsecure(),
125
+ isOptional: false
126
+ },
127
+ escalationLevel: {
128
+ type: ScalarTypeEnum.Int_unsecure(),
129
+ isOptional: false
130
+ },
131
+ escalatedTo: {
132
+ type: ScalarTypeEnum.String_unsecure(),
133
+ isOptional: false
134
+ },
135
+ reason: {
136
+ type: ScalarTypeEnum.String_unsecure(),
137
+ isOptional: false
138
+ },
139
+ timestamp: {
140
+ type: ScalarTypeEnum.DateTime(),
141
+ isOptional: false
142
+ }
143
+ }
144
+ });
145
+ /**
146
+ * ApprovalRequestedEvent - An approval has been requested.
147
+ */
148
+ const ApprovalRequestedEvent = defineEvent({
149
+ meta: {
150
+ key: "workflow.approval.requested",
151
+ version: 1,
152
+ description: "An approval has been requested.",
153
+ stability: "stable",
154
+ owners: ["@workflow-team"],
155
+ tags: [
156
+ "workflow",
157
+ "approval",
158
+ "requested"
159
+ ]
160
+ },
161
+ payload: ApprovalRequestedPayload
162
+ });
163
+ /**
164
+ * ApprovalDecidedEvent - An approval decision has been made.
165
+ */
166
+ const ApprovalDecidedEvent = defineEvent({
167
+ meta: {
168
+ key: "workflow.approval.decided",
169
+ version: 1,
170
+ description: "An approval decision has been made.",
171
+ stability: "stable",
172
+ owners: ["@workflow-team"],
173
+ tags: [
174
+ "workflow",
175
+ "approval",
176
+ "decided"
177
+ ]
178
+ },
179
+ payload: ApprovalDecidedPayload
180
+ });
181
+ /**
182
+ * ApprovalDelegatedEvent - An approval has been delegated.
183
+ */
184
+ const ApprovalDelegatedEvent = defineEvent({
185
+ meta: {
186
+ key: "workflow.approval.delegated",
187
+ version: 1,
188
+ description: "An approval has been delegated.",
189
+ stability: "stable",
190
+ owners: ["@workflow-team"],
191
+ tags: [
192
+ "workflow",
193
+ "approval",
194
+ "delegated"
195
+ ]
196
+ },
197
+ payload: ApprovalDelegatedPayload
198
+ });
199
+ /**
200
+ * ApprovalEscalatedEvent - An approval has been escalated.
201
+ */
202
+ const ApprovalEscalatedEvent = defineEvent({
203
+ meta: {
204
+ key: "workflow.approval.escalated",
205
+ version: 1,
206
+ description: "An approval has been escalated.",
207
+ stability: "stable",
208
+ owners: ["@workflow-team"],
209
+ tags: [
210
+ "workflow",
211
+ "approval",
212
+ "escalated"
213
+ ]
214
+ },
215
+ payload: ApprovalEscalatedPayload
216
+ });
217
+
218
+ //#endregion
219
+ export { ApprovalDecidedEvent, ApprovalDelegatedEvent, ApprovalEscalatedEvent, ApprovalRequestedEvent };
220
+ //# sourceMappingURL=approval.event.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approval.event.js","names":["defineSchemaModel"],"sources":["../../src/approval/approval.event.ts"],"sourcesContent":["import { defineEvent, defineSchemaModel } from '@lssm/lib.contracts';\nimport { ScalarTypeEnum } from '@lssm/lib.schema';\n\n/**\n * Payload when approval is requested.\n */\nconst ApprovalRequestedPayload = defineSchemaModel({\n name: 'ApprovalRequestedEventPayload',\n description: 'Payload when approval is requested',\n fields: {\n requestId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n instanceId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n workflowKey: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n approverId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n approverRole: {\n type: ScalarTypeEnum.String_unsecure(),\n isOptional: true,\n },\n title: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n dueAt: { type: ScalarTypeEnum.DateTime(), isOptional: true },\n timestamp: { type: ScalarTypeEnum.DateTime(), isOptional: false },\n },\n});\n\n/**\n * Payload when approval decision is made.\n */\nconst ApprovalDecidedPayload = defineSchemaModel({\n name: 'ApprovalDecidedEventPayload',\n description: 'Payload when approval decision is made',\n fields: {\n requestId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n instanceId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n decision: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n decidedBy: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n comment: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },\n timestamp: { type: ScalarTypeEnum.DateTime(), isOptional: false },\n },\n});\n\n/**\n * Payload when approval is delegated.\n */\nconst ApprovalDelegatedPayload = defineSchemaModel({\n name: 'ApprovalDelegatedEventPayload',\n description: 'Payload when approval is delegated',\n fields: {\n requestId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n instanceId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n fromUserId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n toUserId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n reason: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },\n timestamp: { type: ScalarTypeEnum.DateTime(), isOptional: false },\n },\n});\n\n/**\n * Payload when approval is escalated.\n */\nconst ApprovalEscalatedPayload = defineSchemaModel({\n name: 'ApprovalEscalatedEventPayload',\n description: 'Payload when approval is escalated',\n fields: {\n requestId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n instanceId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n escalationLevel: {\n type: ScalarTypeEnum.Int_unsecure(),\n isOptional: false,\n },\n escalatedTo: {\n type: ScalarTypeEnum.String_unsecure(),\n isOptional: false,\n },\n reason: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },\n timestamp: { type: ScalarTypeEnum.DateTime(), isOptional: false },\n },\n});\n\n/**\n * ApprovalRequestedEvent - An approval has been requested.\n */\nexport const ApprovalRequestedEvent = defineEvent({\n meta: {\n key: 'workflow.approval.requested',\n version: 1,\n description: 'An approval has been requested.',\n stability: 'stable',\n owners: ['@workflow-team'],\n tags: ['workflow', 'approval', 'requested'],\n },\n payload: ApprovalRequestedPayload,\n});\n\n/**\n * ApprovalDecidedEvent - An approval decision has been made.\n */\nexport const ApprovalDecidedEvent = defineEvent({\n meta: {\n key: 'workflow.approval.decided',\n version: 1,\n description: 'An approval decision has been made.',\n stability: 'stable',\n owners: ['@workflow-team'],\n tags: ['workflow', 'approval', 'decided'],\n },\n payload: ApprovalDecidedPayload,\n});\n\n/**\n * ApprovalDelegatedEvent - An approval has been delegated.\n */\nexport const ApprovalDelegatedEvent = defineEvent({\n meta: {\n key: 'workflow.approval.delegated',\n version: 1,\n description: 'An approval has been delegated.',\n stability: 'stable',\n owners: ['@workflow-team'],\n tags: ['workflow', 'approval', 'delegated'],\n },\n payload: ApprovalDelegatedPayload,\n});\n\n/**\n * ApprovalEscalatedEvent - An approval has been escalated.\n */\nexport const ApprovalEscalatedEvent = defineEvent({\n meta: {\n key: 'workflow.approval.escalated',\n version: 1,\n description: 'An approval has been escalated.',\n stability: 'stable',\n owners: ['@workflow-team'],\n tags: ['workflow', 'approval', 'escalated'],\n },\n payload: ApprovalEscalatedPayload,\n});\n"],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ import { ApprovalRequestRecord, HandlerContext, WorkflowInstanceRecord, WorkflowStepRecord } from "../shared/types.js";
2
+
3
+ //#region src/approval/approval.handler.d.ts
4
+
5
+ declare function createApprovalRequests(instance: WorkflowInstanceRecord, step: WorkflowStepRecord, _context: HandlerContext): Promise<void>;
6
+ declare function handleSubmitDecision(input: {
7
+ requestId: string;
8
+ decision: 'APPROVE' | 'REJECT' | 'REQUEST_CHANGES' | 'DELEGATE' | 'ABSTAIN';
9
+ comment?: string;
10
+ data?: Record<string, unknown>;
11
+ }, context: HandlerContext): Promise<ApprovalRequestRecord>;
12
+ declare function handleListMyApprovals(input: {
13
+ status?: 'PENDING' | 'APPROVED' | 'REJECTED' | 'DELEGATED' | 'ESCALATED' | 'WITHDRAWN' | 'EXPIRED';
14
+ limit?: number;
15
+ offset?: number;
16
+ }, context: HandlerContext): Promise<{
17
+ requests: ApprovalRequestRecord[];
18
+ total: number;
19
+ pendingCount: number;
20
+ }>;
21
+ //#endregion
22
+ export { createApprovalRequests, handleListMyApprovals, handleSubmitDecision };
23
+ //# sourceMappingURL=approval.handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approval.handler.d.ts","names":[],"sources":["../../src/approval/approval.handler.ts"],"sourcesContent":[],"mappings":";;;;AAcY,iBADU,sBAAA,CACV,QAAA,EAAA,sBAAA,EAAA,IAAA,EACJ,kBADI,EAAA,QAAA,EAEA,cAFA,CAAA,EAGT,OAHS,CAAA,IAAA,CAAA;AACJ,iBA8Bc,oBAAA,CA9Bd,KAAA,EAAA;EACI,SAAA,EAAA,MAAA;EACT,QAAA,EAAA,SAAA,GAAA,QAAA,GAAA,iBAAA,GAAA,UAAA,GAAA,SAAA;EAAO,OAAA,CAAA,EAAA,MAAA;EA4BY,IAAA,CAAA,EAKX,MALW,CAAA,MAAA,EAAA,OAAoB,CAAA;CAK/B,EAAA,OAAA,EAEA,cAFA,CAAA,EAGR,OAHQ,CAGA,qBAHA,CAAA;AAEA,iBAiDW,qBAAA,CAjDX,KAAA,EAAA;EACA,MAAA,CAAA,EAAA,SAAA,GAAA,UAAA,GAAA,UAAA,GAAA,WAAA,GAAA,WAAA,GAAA,WAAA,GAAA,SAAA;EAAR,KAAA,CAAA,EAAA,MAAA;EAAO,MAAA,CAAA,EAAA,MAAA;AAgDV,CAAA,EAAA,OAAsB,EAaX,cAbW,CAAA,EAcnB,OAdwC,CAAA;EAahC,QAAA,EAEC,qBAFD,EAAA;EAEC,KAAA,EAAA,MAAA;EADT,YAAA,EAAA,MAAA;CAAO,CAAA"}
@@ -1 +1,72 @@
1
- import{mockDataStore as e}from"../shared/mock-data.js";import{handleTransitionWorkflow as t}from"../instance/instance.handler.js";async function n(t,n,r){let i=new Date;for(let r=0;r<n.approverRoles.length;r++){let a=n.approverRoles[r],o=`approval_${Date.now()}_${r}`,s={id:o,workflowInstanceId:t.id,stepExecutionId:`exec_${t.id}_${n.id}`,approverId:`user_${a}`,approverRole:a,title:`Approval required for ${n.name}`,description:n.description,status:`PENDING`,contextSnapshot:t.contextData,sequenceOrder:r,createdAt:i,updatedAt:i};e.approvals.set(o,s)}}async function r(n,r){let i=e.approvals.get(n.requestId);if(!i)throw Error(`Approval request ${n.requestId} not found`);if(i.approverId!==r.userId&&!r.userRoles.includes(i.approverRole??``))throw Error(`User is not authorized to make this decision`);let a=new Date;return i.decision=n.decision,i.decisionComment=n.comment,i.decidedAt=a,i.updatedAt=a,n.decision===`APPROVE`?(i.status=`APPROVED`,await t({instanceId:i.workflowInstanceId,action:`approve`,data:n.data,comment:n.comment},r)):n.decision===`REJECT`&&(i.status=`REJECTED`,await t({instanceId:i.workflowInstanceId,action:`reject`,data:n.data,comment:n.comment},r)),i}async function i(t,n){let r=Array.from(e.approvals.values()).filter(e=>e.approverId===n.userId||n.userRoles.includes(e.approverRole??``)),i=r.filter(e=>e.status===`PENDING`).length;t.status&&(r=r.filter(e=>e.status===t.status));let a=r.length,o=t.offset??0,s=t.limit??20;return r=r.sort((e,t)=>t.createdAt.getTime()-e.createdAt.getTime()).slice(o,o+s),{requests:r,total:a,pendingCount:i}}export{n as createApprovalRequests,i as handleListMyApprovals,r as handleSubmitDecision};
1
+ import { mockDataStore } from "../shared/mock-data.js";
2
+ import { handleTransitionWorkflow } from "../instance/instance.handler.js";
3
+
4
+ //#region src/approval/approval.handler.ts
5
+ async function createApprovalRequests(instance, step, _context) {
6
+ const now = /* @__PURE__ */ new Date();
7
+ for (let i = 0; i < step.approverRoles.length; i++) {
8
+ const role = step.approverRoles[i];
9
+ const id = `approval_${Date.now()}_${i}`;
10
+ const request = {
11
+ id,
12
+ workflowInstanceId: instance.id,
13
+ stepExecutionId: `exec_${instance.id}_${step.id}`,
14
+ approverId: `user_${role}`,
15
+ approverRole: role,
16
+ title: `Approval required for ${step.name}`,
17
+ description: step.description,
18
+ status: "PENDING",
19
+ contextSnapshot: instance.contextData,
20
+ sequenceOrder: i,
21
+ createdAt: now,
22
+ updatedAt: now
23
+ };
24
+ mockDataStore.approvals.set(id, request);
25
+ }
26
+ }
27
+ async function handleSubmitDecision(input, context) {
28
+ const request = mockDataStore.approvals.get(input.requestId);
29
+ if (!request) throw new Error(`Approval request ${input.requestId} not found`);
30
+ if (request.approverId !== context.userId && !context.userRoles.includes(request.approverRole ?? "")) throw new Error("User is not authorized to make this decision");
31
+ const now = /* @__PURE__ */ new Date();
32
+ request.decision = input.decision;
33
+ request.decisionComment = input.comment;
34
+ request.decidedAt = now;
35
+ request.updatedAt = now;
36
+ if (input.decision === "APPROVE") {
37
+ request.status = "APPROVED";
38
+ await handleTransitionWorkflow({
39
+ instanceId: request.workflowInstanceId,
40
+ action: "approve",
41
+ data: input.data,
42
+ comment: input.comment
43
+ }, context);
44
+ } else if (input.decision === "REJECT") {
45
+ request.status = "REJECTED";
46
+ await handleTransitionWorkflow({
47
+ instanceId: request.workflowInstanceId,
48
+ action: "reject",
49
+ data: input.data,
50
+ comment: input.comment
51
+ }, context);
52
+ }
53
+ return request;
54
+ }
55
+ async function handleListMyApprovals(input, context) {
56
+ let requests = Array.from(mockDataStore.approvals.values()).filter((r) => r.approverId === context.userId || context.userRoles.includes(r.approverRole ?? ""));
57
+ const pendingCount = requests.filter((r) => r.status === "PENDING").length;
58
+ if (input.status) requests = requests.filter((r) => r.status === input.status);
59
+ const total = requests.length;
60
+ const offset = input.offset ?? 0;
61
+ const limit = input.limit ?? 20;
62
+ requests = requests.sort((a, b) => b.createdAt.getTime() - a.createdAt.getTime()).slice(offset, offset + limit);
63
+ return {
64
+ requests,
65
+ total,
66
+ pendingCount
67
+ };
68
+ }
69
+
70
+ //#endregion
71
+ export { createApprovalRequests, handleListMyApprovals, handleSubmitDecision };
72
+ //# sourceMappingURL=approval.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"approval.handler.js","names":["request: ApprovalRequestRecord"],"sources":["../../src/approval/approval.handler.ts"],"sourcesContent":["/**\n * Approval handlers.\n */\n\nimport type {\n ApprovalRequestRecord,\n WorkflowInstanceRecord,\n WorkflowStepRecord,\n HandlerContext,\n} from '../shared/types';\nimport { mockDataStore } from '../shared/mock-data';\nimport { handleTransitionWorkflow } from '../instance/instance.handler';\n\nexport async function createApprovalRequests(\n instance: WorkflowInstanceRecord,\n step: WorkflowStepRecord,\n _context: HandlerContext\n): Promise<void> {\n const now = new Date();\n\n // Create approval request for each approver role\n // In production, this would resolve roles to actual users\n for (let i = 0; i < step.approverRoles.length; i++) {\n const role = step.approverRoles[i];\n const id = `approval_${Date.now()}_${i}`;\n\n const request: ApprovalRequestRecord = {\n id,\n workflowInstanceId: instance.id,\n stepExecutionId: `exec_${instance.id}_${step.id}`,\n approverId: `user_${role}`, // In production, resolve to actual user\n approverRole: role,\n title: `Approval required for ${step.name}`,\n description: step.description,\n status: 'PENDING',\n contextSnapshot: instance.contextData,\n sequenceOrder: i,\n createdAt: now,\n updatedAt: now,\n };\n\n mockDataStore.approvals.set(id, request);\n }\n}\n\nexport async function handleSubmitDecision(\n input: {\n requestId: string;\n decision: 'APPROVE' | 'REJECT' | 'REQUEST_CHANGES' | 'DELEGATE' | 'ABSTAIN';\n comment?: string;\n data?: Record<string, unknown>;\n },\n context: HandlerContext\n): Promise<ApprovalRequestRecord> {\n const request = mockDataStore.approvals.get(input.requestId);\n if (!request) {\n throw new Error(`Approval request ${input.requestId} not found`);\n }\n\n // Verify approver\n if (\n request.approverId !== context.userId &&\n !context.userRoles.includes(request.approverRole ?? '')\n ) {\n throw new Error('User is not authorized to make this decision');\n }\n\n const now = new Date();\n request.decision = input.decision;\n request.decisionComment = input.comment;\n request.decidedAt = now;\n request.updatedAt = now;\n\n if (input.decision === 'APPROVE') {\n request.status = 'APPROVED';\n // Trigger workflow transition\n await handleTransitionWorkflow(\n {\n instanceId: request.workflowInstanceId,\n action: 'approve',\n data: input.data,\n comment: input.comment,\n },\n context\n );\n } else if (input.decision === 'REJECT') {\n request.status = 'REJECTED';\n await handleTransitionWorkflow(\n {\n instanceId: request.workflowInstanceId,\n action: 'reject',\n data: input.data,\n comment: input.comment,\n },\n context\n );\n }\n\n return request;\n}\n\nexport async function handleListMyApprovals(\n input: {\n status?:\n | 'PENDING'\n | 'APPROVED'\n | 'REJECTED'\n | 'DELEGATED'\n | 'ESCALATED'\n | 'WITHDRAWN'\n | 'EXPIRED';\n limit?: number;\n offset?: number;\n },\n context: HandlerContext\n): Promise<{\n requests: ApprovalRequestRecord[];\n total: number;\n pendingCount: number;\n}> {\n let requests = Array.from(mockDataStore.approvals.values()).filter(\n (r) =>\n r.approverId === context.userId ||\n context.userRoles.includes(r.approverRole ?? '')\n );\n\n const pendingCount = requests.filter((r) => r.status === 'PENDING').length;\n\n if (input.status) {\n requests = requests.filter((r) => r.status === input.status);\n }\n\n const total = requests.length;\n const offset = input.offset ?? 0;\n const limit = input.limit ?? 20;\n\n requests = requests\n .sort((a, b) => b.createdAt.getTime() - a.createdAt.getTime())\n .slice(offset, offset + limit);\n\n return { requests, total, pendingCount };\n}\n"],"mappings":";;;;AAaA,eAAsB,uBACpB,UACA,MACA,UACe;CACf,MAAM,sBAAM,IAAI,MAAM;AAItB,MAAK,IAAI,IAAI,GAAG,IAAI,KAAK,cAAc,QAAQ,KAAK;EAClD,MAAM,OAAO,KAAK,cAAc;EAChC,MAAM,KAAK,YAAY,KAAK,KAAK,CAAC,GAAG;EAErC,MAAMA,UAAiC;GACrC;GACA,oBAAoB,SAAS;GAC7B,iBAAiB,QAAQ,SAAS,GAAG,GAAG,KAAK;GAC7C,YAAY,QAAQ;GACpB,cAAc;GACd,OAAO,yBAAyB,KAAK;GACrC,aAAa,KAAK;GAClB,QAAQ;GACR,iBAAiB,SAAS;GAC1B,eAAe;GACf,WAAW;GACX,WAAW;GACZ;AAED,gBAAc,UAAU,IAAI,IAAI,QAAQ;;;AAI5C,eAAsB,qBACpB,OAMA,SACgC;CAChC,MAAM,UAAU,cAAc,UAAU,IAAI,MAAM,UAAU;AAC5D,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,oBAAoB,MAAM,UAAU,YAAY;AAIlE,KACE,QAAQ,eAAe,QAAQ,UAC/B,CAAC,QAAQ,UAAU,SAAS,QAAQ,gBAAgB,GAAG,CAEvD,OAAM,IAAI,MAAM,+CAA+C;CAGjE,MAAM,sBAAM,IAAI,MAAM;AACtB,SAAQ,WAAW,MAAM;AACzB,SAAQ,kBAAkB,MAAM;AAChC,SAAQ,YAAY;AACpB,SAAQ,YAAY;AAEpB,KAAI,MAAM,aAAa,WAAW;AAChC,UAAQ,SAAS;AAEjB,QAAM,yBACJ;GACE,YAAY,QAAQ;GACpB,QAAQ;GACR,MAAM,MAAM;GACZ,SAAS,MAAM;GAChB,EACD,QACD;YACQ,MAAM,aAAa,UAAU;AACtC,UAAQ,SAAS;AACjB,QAAM,yBACJ;GACE,YAAY,QAAQ;GACpB,QAAQ;GACR,MAAM,MAAM;GACZ,SAAS,MAAM;GAChB,EACD,QACD;;AAGH,QAAO;;AAGT,eAAsB,sBACpB,OAYA,SAKC;CACD,IAAI,WAAW,MAAM,KAAK,cAAc,UAAU,QAAQ,CAAC,CAAC,QACzD,MACC,EAAE,eAAe,QAAQ,UACzB,QAAQ,UAAU,SAAS,EAAE,gBAAgB,GAAG,CACnD;CAED,MAAM,eAAe,SAAS,QAAQ,MAAM,EAAE,WAAW,UAAU,CAAC;AAEpE,KAAI,MAAM,OACR,YAAW,SAAS,QAAQ,MAAM,EAAE,WAAW,MAAM,OAAO;CAG9D,MAAM,QAAQ,SAAS;CACvB,MAAM,SAAS,MAAM,UAAU;CAC/B,MAAM,QAAQ,MAAM,SAAS;AAE7B,YAAW,SACR,MAAM,GAAG,MAAM,EAAE,UAAU,SAAS,GAAG,EAAE,UAAU,SAAS,CAAC,CAC7D,MAAM,QAAQ,SAAS,MAAM;AAEhC,QAAO;EAAE;EAAU;EAAO;EAAc"}