@contractspec/example.workflow-system 1.57.0 → 1.59.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 (209) hide show
  1. package/dist/approval/approval.enum.d.ts +2 -7
  2. package/dist/approval/approval.enum.d.ts.map +1 -1
  3. package/dist/approval/approval.enum.js +20 -26
  4. package/dist/approval/approval.event.d.ts +108 -114
  5. package/dist/approval/approval.event.d.ts.map +1 -1
  6. package/dist/approval/approval.event.js +103 -210
  7. package/dist/approval/approval.handler.d.ts +17 -18
  8. package/dist/approval/approval.handler.d.ts.map +1 -1
  9. package/dist/approval/approval.operations.d.ts +429 -435
  10. package/dist/approval/approval.operations.d.ts.map +1 -1
  11. package/dist/approval/approval.operations.js +364 -339
  12. package/dist/approval/approval.schema.d.ts +86 -91
  13. package/dist/approval/approval.schema.d.ts.map +1 -1
  14. package/dist/approval/approval.schema.js +71 -107
  15. package/dist/approval/index.d.ts +8 -5
  16. package/dist/approval/index.d.ts.map +1 -0
  17. package/dist/approval/index.js +484 -5
  18. package/dist/browser/approval/approval.enum.js +22 -0
  19. package/dist/browser/approval/approval.event.js +112 -0
  20. package/dist/browser/approval/approval.operations.js +369 -0
  21. package/dist/browser/approval/approval.schema.js +73 -0
  22. package/dist/browser/approval/index.js +484 -0
  23. package/dist/browser/docs/index.js +103 -0
  24. package/dist/browser/docs/workflow-system.docblock.js +103 -0
  25. package/dist/browser/entities/approval.js +119 -0
  26. package/dist/browser/entities/index.js +508 -0
  27. package/dist/browser/entities/instance.js +161 -0
  28. package/dist/browser/entities/step.js +124 -0
  29. package/dist/browser/entities/workflow.js +82 -0
  30. package/dist/browser/example.js +42 -0
  31. package/dist/browser/handlers/index.js +253 -0
  32. package/dist/browser/handlers/workflow.handlers.js +253 -0
  33. package/dist/browser/index.js +3120 -0
  34. package/dist/browser/instance/index.js +677 -0
  35. package/dist/browser/instance/instance.enum.js +15 -0
  36. package/dist/browser/instance/instance.event.js +164 -0
  37. package/dist/browser/instance/instance.handler.js +356 -0
  38. package/dist/browser/instance/instance.operations.js +9 -0
  39. package/dist/browser/instance/instance.schema.js +101 -0
  40. package/dist/browser/presentations/index.js +109 -0
  41. package/dist/browser/seeders/index.js +3 -0
  42. package/dist/browser/shared/index.js +3 -0
  43. package/dist/browser/shared/mock-data.js +11 -0
  44. package/dist/browser/shared/types.js +0 -0
  45. package/dist/browser/state-machine/index.js +6 -0
  46. package/dist/browser/tests/operations.test-spec.js +6 -0
  47. package/dist/browser/ui/WorkflowDashboard.js +3 -0
  48. package/dist/browser/ui/hooks/index.js +50 -0
  49. package/dist/browser/ui/hooks/useWorkflowList.js +50 -0
  50. package/dist/browser/ui/index.js +54 -0
  51. package/dist/browser/ui/renderers/index.js +227 -0
  52. package/dist/browser/ui/renderers/workflow.markdown.js +227 -0
  53. package/dist/browser/workflow/index.js +21 -0
  54. package/dist/browser/workflow/workflow.enum.js +36 -0
  55. package/dist/browser/workflow/workflow.event.js +6 -0
  56. package/dist/browser/workflow/workflow.handler.js +5 -0
  57. package/dist/browser/workflow/workflow.operations.js +8 -0
  58. package/dist/browser/workflow/workflow.schema.js +151 -0
  59. package/dist/browser/workflow-system.capability.js +5 -0
  60. package/dist/browser/workflow-system.feature.js +3 -0
  61. package/dist/docs/index.d.ts +2 -1
  62. package/dist/docs/index.d.ts.map +1 -0
  63. package/dist/docs/index.js +104 -1
  64. package/dist/docs/workflow-system.docblock.d.ts +2 -1
  65. package/dist/docs/workflow-system.docblock.d.ts.map +1 -0
  66. package/dist/docs/workflow-system.docblock.js +45 -56
  67. package/dist/entities/approval.d.ts +35 -40
  68. package/dist/entities/approval.d.ts.map +1 -1
  69. package/dist/entities/approval.js +116 -124
  70. package/dist/entities/index.d.ts +132 -137
  71. package/dist/entities/index.d.ts.map +1 -1
  72. package/dist/entities/index.js +506 -29
  73. package/dist/entities/instance.d.ts +46 -51
  74. package/dist/entities/instance.d.ts.map +1 -1
  75. package/dist/entities/instance.js +158 -164
  76. package/dist/entities/step.d.ts +31 -36
  77. package/dist/entities/step.d.ts.map +1 -1
  78. package/dist/entities/step.js +122 -132
  79. package/dist/entities/workflow.d.ts +22 -27
  80. package/dist/entities/workflow.d.ts.map +1 -1
  81. package/dist/entities/workflow.js +80 -99
  82. package/dist/example.d.ts +2 -6
  83. package/dist/example.d.ts.map +1 -1
  84. package/dist/example.js +41 -55
  85. package/dist/handlers/index.d.ts +2 -2
  86. package/dist/handlers/index.d.ts.map +1 -0
  87. package/dist/handlers/index.js +254 -3
  88. package/dist/handlers/workflow.handlers.d.ts +107 -106
  89. package/dist/handlers/workflow.handlers.d.ts.map +1 -1
  90. package/dist/handlers/workflow.handlers.js +237 -246
  91. package/dist/index.d.ts +15 -26
  92. package/dist/index.d.ts.map +1 -0
  93. package/dist/index.js +3121 -26
  94. package/dist/instance/index.d.ts +8 -5
  95. package/dist/instance/index.d.ts.map +1 -0
  96. package/dist/instance/index.js +677 -5
  97. package/dist/instance/instance.enum.d.ts +1 -6
  98. package/dist/instance/instance.enum.d.ts.map +1 -1
  99. package/dist/instance/instance.enum.js +14 -18
  100. package/dist/instance/instance.event.d.ts +313 -319
  101. package/dist/instance/instance.event.d.ts.map +1 -1
  102. package/dist/instance/instance.event.js +151 -279
  103. package/dist/instance/instance.handler.d.ts +21 -22
  104. package/dist/instance/instance.handler.d.ts.map +1 -1
  105. package/dist/instance/instance.handler.js +352 -89
  106. package/dist/instance/instance.operations.d.ts +819 -825
  107. package/dist/instance/instance.operations.d.ts.map +1 -1
  108. package/dist/instance/instance.operations.js +10 -464
  109. package/dist/instance/instance.schema.d.ts +196 -201
  110. package/dist/instance/instance.schema.d.ts.map +1 -1
  111. package/dist/instance/instance.schema.js +97 -167
  112. package/dist/presentations/index.d.ts +23 -28
  113. package/dist/presentations/index.d.ts.map +1 -1
  114. package/dist/presentations/index.js +104 -334
  115. package/dist/seeders/index.d.ts +4 -8
  116. package/dist/seeders/index.d.ts.map +1 -1
  117. package/dist/seeders/index.js +4 -19
  118. package/dist/shared/index.d.ts +6 -3
  119. package/dist/shared/index.d.ts.map +1 -0
  120. package/dist/shared/index.js +4 -3
  121. package/dist/shared/mock-data.d.ts +16 -16
  122. package/dist/shared/mock-data.d.ts.map +1 -1
  123. package/dist/shared/mock-data.js +11 -11
  124. package/dist/shared/types.d.ts +69 -72
  125. package/dist/shared/types.d.ts.map +1 -1
  126. package/dist/shared/types.js +1 -0
  127. package/dist/state-machine/index.d.ts +92 -95
  128. package/dist/state-machine/index.d.ts.map +1 -1
  129. package/dist/state-machine/index.js +6 -157
  130. package/dist/tests/operations.test-spec.d.ts +4 -9
  131. package/dist/tests/operations.test-spec.d.ts.map +1 -1
  132. package/dist/tests/operations.test-spec.js +7 -123
  133. package/dist/ui/WorkflowDashboard.d.ts +1 -6
  134. package/dist/ui/WorkflowDashboard.d.ts.map +1 -1
  135. package/dist/ui/WorkflowDashboard.js +3 -222
  136. package/dist/ui/hooks/index.d.ts +2 -2
  137. package/dist/ui/hooks/index.d.ts.map +1 -0
  138. package/dist/ui/hooks/index.js +51 -5
  139. package/dist/ui/hooks/useWorkflowList.d.ts +15 -19
  140. package/dist/ui/hooks/useWorkflowList.d.ts.map +1 -1
  141. package/dist/ui/hooks/useWorkflowList.js +47 -51
  142. package/dist/ui/index.d.ts +7 -6
  143. package/dist/ui/index.d.ts.map +1 -0
  144. package/dist/ui/index.js +55 -6
  145. package/dist/ui/renderers/index.d.ts +2 -2
  146. package/dist/ui/renderers/index.d.ts.map +1 -0
  147. package/dist/ui/renderers/index.js +227 -2
  148. package/dist/ui/renderers/workflow.markdown.d.ts +13 -14
  149. package/dist/ui/renderers/workflow.markdown.d.ts.map +1 -1
  150. package/dist/ui/renderers/workflow.markdown.js +223 -229
  151. package/dist/workflow/index.d.ts +8 -5
  152. package/dist/workflow/index.d.ts.map +1 -0
  153. package/dist/workflow/index.js +22 -6
  154. package/dist/workflow/workflow.enum.d.ts +4 -9
  155. package/dist/workflow/workflow.enum.d.ts.map +1 -1
  156. package/dist/workflow/workflow.enum.js +32 -42
  157. package/dist/workflow/workflow.event.d.ts +112 -118
  158. package/dist/workflow/workflow.event.d.ts.map +1 -1
  159. package/dist/workflow/workflow.event.js +7 -150
  160. package/dist/workflow/workflow.handler.d.ts +23 -24
  161. package/dist/workflow/workflow.handler.d.ts.map +1 -1
  162. package/dist/workflow/workflow.handler.js +6 -66
  163. package/dist/workflow/workflow.operations.d.ts +847 -853
  164. package/dist/workflow/workflow.operations.d.ts.map +1 -1
  165. package/dist/workflow/workflow.operations.js +9 -345
  166. package/dist/workflow/workflow.schema.d.ts +229 -234
  167. package/dist/workflow/workflow.schema.d.ts.map +1 -1
  168. package/dist/workflow/workflow.schema.js +146 -243
  169. package/dist/workflow-system.capability.d.ts +3 -8
  170. package/dist/workflow-system.capability.d.ts.map +1 -1
  171. package/dist/workflow-system.capability.js +6 -34
  172. package/dist/workflow-system.feature.d.ts +1 -6
  173. package/dist/workflow-system.feature.d.ts.map +1 -1
  174. package/dist/workflow-system.feature.js +4 -346
  175. package/package.json +415 -93
  176. package/dist/approval/approval.enum.js.map +0 -1
  177. package/dist/approval/approval.event.js.map +0 -1
  178. package/dist/approval/approval.handler.js +0 -72
  179. package/dist/approval/approval.handler.js.map +0 -1
  180. package/dist/approval/approval.operations.js.map +0 -1
  181. package/dist/approval/approval.schema.js.map +0 -1
  182. package/dist/docs/workflow-system.docblock.js.map +0 -1
  183. package/dist/entities/approval.js.map +0 -1
  184. package/dist/entities/index.js.map +0 -1
  185. package/dist/entities/instance.js.map +0 -1
  186. package/dist/entities/step.js.map +0 -1
  187. package/dist/entities/workflow.js.map +0 -1
  188. package/dist/example.js.map +0 -1
  189. package/dist/handlers/workflow.handlers.js.map +0 -1
  190. package/dist/instance/instance.enum.js.map +0 -1
  191. package/dist/instance/instance.event.js.map +0 -1
  192. package/dist/instance/instance.handler.js.map +0 -1
  193. package/dist/instance/instance.operations.js.map +0 -1
  194. package/dist/instance/instance.schema.js.map +0 -1
  195. package/dist/presentations/index.js.map +0 -1
  196. package/dist/seeders/index.js.map +0 -1
  197. package/dist/shared/mock-data.js.map +0 -1
  198. package/dist/state-machine/index.js.map +0 -1
  199. package/dist/tests/operations.test-spec.js.map +0 -1
  200. package/dist/ui/WorkflowDashboard.js.map +0 -1
  201. package/dist/ui/hooks/useWorkflowList.js.map +0 -1
  202. package/dist/ui/renderers/workflow.markdown.js.map +0 -1
  203. package/dist/workflow/workflow.enum.js.map +0 -1
  204. package/dist/workflow/workflow.event.js.map +0 -1
  205. package/dist/workflow/workflow.handler.js.map +0 -1
  206. package/dist/workflow/workflow.operations.js.map +0 -1
  207. package/dist/workflow/workflow.schema.js.map +0 -1
  208. package/dist/workflow-system.capability.js.map +0 -1
  209. package/dist/workflow-system.feature.js.map +0 -1
@@ -0,0 +1,369 @@
1
+ // src/approval/approval.enum.ts
2
+ import { defineEnum } from "@contractspec/lib.schema";
3
+ var ApprovalStatusEnum = defineEnum("ApprovalStatus", [
4
+ "PENDING",
5
+ "APPROVED",
6
+ "REJECTED",
7
+ "DELEGATED",
8
+ "ESCALATED",
9
+ "WITHDRAWN",
10
+ "EXPIRED"
11
+ ]);
12
+ var ApprovalDecisionEnum = defineEnum("ApprovalDecision", [
13
+ "APPROVE",
14
+ "REJECT",
15
+ "REQUEST_CHANGES",
16
+ "DELEGATE",
17
+ "ABSTAIN"
18
+ ]);
19
+
20
+ // src/approval/approval.schema.ts
21
+ import { defineSchemaModel, ScalarTypeEnum } from "@contractspec/lib.schema";
22
+ var ApprovalRequestModel = defineSchemaModel({
23
+ name: "ApprovalRequestModel",
24
+ description: "An approval request",
25
+ fields: {
26
+ id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
27
+ workflowInstanceId: {
28
+ type: ScalarTypeEnum.String_unsecure(),
29
+ isOptional: false
30
+ },
31
+ stepExecutionId: {
32
+ type: ScalarTypeEnum.String_unsecure(),
33
+ isOptional: false
34
+ },
35
+ approverId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
36
+ approverRole: {
37
+ type: ScalarTypeEnum.String_unsecure(),
38
+ isOptional: true
39
+ },
40
+ title: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
41
+ description: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },
42
+ status: { type: ApprovalStatusEnum, isOptional: false },
43
+ decision: { type: ApprovalDecisionEnum, isOptional: true },
44
+ decisionComment: {
45
+ type: ScalarTypeEnum.String_unsecure(),
46
+ isOptional: true
47
+ },
48
+ decidedAt: { type: ScalarTypeEnum.DateTime(), isOptional: true },
49
+ dueAt: { type: ScalarTypeEnum.DateTime(), isOptional: true },
50
+ contextSnapshot: { type: ScalarTypeEnum.JSON(), isOptional: true },
51
+ sequenceOrder: { type: ScalarTypeEnum.Int_unsecure(), isOptional: false },
52
+ createdAt: { type: ScalarTypeEnum.DateTime(), isOptional: false }
53
+ }
54
+ });
55
+ var ApprovalCommentModel = defineSchemaModel({
56
+ name: "ApprovalCommentModel",
57
+ description: "A comment on an approval",
58
+ fields: {
59
+ id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
60
+ approvalRequestId: {
61
+ type: ScalarTypeEnum.String_unsecure(),
62
+ isOptional: false
63
+ },
64
+ authorId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
65
+ content: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
66
+ isInternal: { type: ScalarTypeEnum.Boolean(), isOptional: false },
67
+ createdAt: { type: ScalarTypeEnum.DateTime(), isOptional: false }
68
+ }
69
+ });
70
+
71
+ // src/approval/approval.operations.ts
72
+ import {
73
+ defineCommand,
74
+ defineQuery
75
+ } from "@contractspec/lib.contracts/operations";
76
+ import { defineSchemaModel as defineSchemaModel2, ScalarTypeEnum as ScalarTypeEnum2 } from "@contractspec/lib.schema";
77
+ var OWNERS = ["@example.workflow-system"];
78
+ var SubmitDecisionContract = defineCommand({
79
+ meta: {
80
+ key: "workflow.approval.decide",
81
+ version: "1.0.0",
82
+ stability: "stable",
83
+ owners: [...OWNERS],
84
+ tags: ["workflow", "approval", "decision"],
85
+ description: "Submit an approval decision (approve/reject).",
86
+ goal: "Allow approvers to make decisions on requests.",
87
+ context: "Approval inbox, workflow detail."
88
+ },
89
+ io: {
90
+ input: defineSchemaModel2({
91
+ name: "ApproveRejectInput",
92
+ fields: {
93
+ requestId: {
94
+ type: ScalarTypeEnum2.String_unsecure(),
95
+ isOptional: false
96
+ },
97
+ decision: { type: ApprovalDecisionEnum, isOptional: false },
98
+ comment: { type: ScalarTypeEnum2.String_unsecure(), isOptional: true },
99
+ data: { type: ScalarTypeEnum2.JSON(), isOptional: true }
100
+ }
101
+ }),
102
+ output: ApprovalRequestModel
103
+ },
104
+ policy: { auth: "user" },
105
+ sideEffects: {
106
+ emits: [
107
+ {
108
+ key: "workflow.approval.decided",
109
+ version: "1.0.0",
110
+ when: "Decision is made",
111
+ payload: ApprovalRequestModel
112
+ }
113
+ ],
114
+ audit: ["workflow.approval.decided"]
115
+ },
116
+ acceptance: {
117
+ scenarios: [
118
+ {
119
+ key: "approve-request-happy-path",
120
+ given: ["Approval request is pending", "User is assignee"],
121
+ when: ["User approves request"],
122
+ then: ["Request is approved", "ApprovalDecided event is emitted"]
123
+ }
124
+ ],
125
+ examples: [
126
+ {
127
+ key: "approve-basic",
128
+ input: {
129
+ requestId: "req-123",
130
+ decision: "approve",
131
+ comment: "Looks good"
132
+ },
133
+ output: { id: "req-123", status: "approved" }
134
+ }
135
+ ]
136
+ }
137
+ });
138
+ var DelegateApprovalContract = defineCommand({
139
+ meta: {
140
+ key: "workflow.approval.delegate",
141
+ version: "1.0.0",
142
+ stability: "stable",
143
+ owners: [...OWNERS],
144
+ tags: ["workflow", "approval", "delegate"],
145
+ description: "Delegate an approval request to another user.",
146
+ goal: "Allow approvers to pass approval to others.",
147
+ context: "Approval inbox."
148
+ },
149
+ io: {
150
+ input: defineSchemaModel2({
151
+ name: "DelegateInput",
152
+ fields: {
153
+ requestId: {
154
+ type: ScalarTypeEnum2.String_unsecure(),
155
+ isOptional: false
156
+ },
157
+ delegateTo: {
158
+ type: ScalarTypeEnum2.String_unsecure(),
159
+ isOptional: false
160
+ },
161
+ reason: { type: ScalarTypeEnum2.String_unsecure(), isOptional: true }
162
+ }
163
+ }),
164
+ output: ApprovalRequestModel
165
+ },
166
+ policy: { auth: "user" },
167
+ sideEffects: {
168
+ emits: [
169
+ {
170
+ key: "workflow.approval.delegated",
171
+ version: "1.0.0",
172
+ when: "Approval is delegated",
173
+ payload: ApprovalRequestModel
174
+ }
175
+ ],
176
+ audit: ["workflow.approval.delegated"]
177
+ },
178
+ acceptance: {
179
+ scenarios: [
180
+ {
181
+ key: "delegate-approval-happy-path",
182
+ given: ["Approval request is pending", "User is assignee"],
183
+ when: ["User delegates to another user"],
184
+ then: ["Assignee is updated", "ApprovalDelegated event is emitted"]
185
+ }
186
+ ],
187
+ examples: [
188
+ {
189
+ key: "delegate-to-manager",
190
+ input: {
191
+ requestId: "req-123",
192
+ delegateTo: "user-456",
193
+ reason: "Out of office"
194
+ },
195
+ output: { id: "req-123", assigneeId: "user-456" }
196
+ }
197
+ ]
198
+ }
199
+ });
200
+ var AddApprovalCommentContract = defineCommand({
201
+ meta: {
202
+ key: "workflow.approval.comment.add",
203
+ version: "1.0.0",
204
+ stability: "stable",
205
+ owners: [...OWNERS],
206
+ tags: ["workflow", "approval", "comment"],
207
+ description: "Add a comment to an approval request.",
208
+ goal: "Allow discussion on approval requests.",
209
+ context: "Approval detail view."
210
+ },
211
+ io: {
212
+ input: defineSchemaModel2({
213
+ name: "AddCommentInput",
214
+ fields: {
215
+ requestId: {
216
+ type: ScalarTypeEnum2.String_unsecure(),
217
+ isOptional: false
218
+ },
219
+ content: { type: ScalarTypeEnum2.NonEmptyString(), isOptional: false },
220
+ isInternal: { type: ScalarTypeEnum2.Boolean(), isOptional: true }
221
+ }
222
+ }),
223
+ output: ApprovalCommentModel
224
+ },
225
+ policy: { auth: "user" },
226
+ sideEffects: {
227
+ emits: [
228
+ {
229
+ key: "workflow.approval.comment.added",
230
+ version: "1.0.0",
231
+ when: "Comment is added",
232
+ payload: ApprovalCommentModel
233
+ }
234
+ ]
235
+ },
236
+ acceptance: {
237
+ scenarios: [
238
+ {
239
+ key: "add-comment-happy-path",
240
+ given: ["Approval request exists"],
241
+ when: ["User adds a comment"],
242
+ then: ["Comment is added", "CommentAdded event is emitted"]
243
+ }
244
+ ],
245
+ examples: [
246
+ {
247
+ key: "add-question",
248
+ input: {
249
+ requestId: "req-123",
250
+ content: "Can you clarify budget?",
251
+ isInternal: false
252
+ },
253
+ output: { id: "com-789", content: "Can you clarify budget?" }
254
+ }
255
+ ]
256
+ }
257
+ });
258
+ var ListMyApprovalsContract = defineQuery({
259
+ meta: {
260
+ key: "workflow.approval.list.mine",
261
+ version: "1.0.0",
262
+ stability: "stable",
263
+ owners: [...OWNERS],
264
+ tags: ["workflow", "approval", "list", "inbox"],
265
+ description: "List approval requests assigned to current user.",
266
+ goal: "Show pending approvals in user inbox.",
267
+ context: "Approval inbox, dashboard widget."
268
+ },
269
+ io: {
270
+ input: defineSchemaModel2({
271
+ name: "ListMyApprovalsInput",
272
+ fields: {
273
+ status: { type: ApprovalStatusEnum, isOptional: true },
274
+ limit: {
275
+ type: ScalarTypeEnum2.Int_unsecure(),
276
+ isOptional: true,
277
+ defaultValue: 20
278
+ },
279
+ offset: {
280
+ type: ScalarTypeEnum2.Int_unsecure(),
281
+ isOptional: true,
282
+ defaultValue: 0
283
+ }
284
+ }
285
+ }),
286
+ output: defineSchemaModel2({
287
+ name: "ListMyApprovalsOutput",
288
+ fields: {
289
+ requests: {
290
+ type: ApprovalRequestModel,
291
+ isArray: true,
292
+ isOptional: false
293
+ },
294
+ total: { type: ScalarTypeEnum2.Int_unsecure(), isOptional: false },
295
+ pendingCount: {
296
+ type: ScalarTypeEnum2.Int_unsecure(),
297
+ isOptional: false
298
+ }
299
+ }
300
+ })
301
+ },
302
+ policy: { auth: "user" },
303
+ acceptance: {
304
+ scenarios: [
305
+ {
306
+ key: "list-approvals-happy-path",
307
+ given: ["User has assigned approvals"],
308
+ when: ["User lists approvals"],
309
+ then: ["List of requests is returned"]
310
+ }
311
+ ],
312
+ examples: [
313
+ {
314
+ key: "list-pending",
315
+ input: { status: "pending", limit: 10 },
316
+ output: { requests: [], total: 2, pendingCount: 2 }
317
+ }
318
+ ]
319
+ }
320
+ });
321
+ var GetApprovalContract = defineQuery({
322
+ meta: {
323
+ key: "workflow.approval.get",
324
+ version: "1.0.0",
325
+ stability: "stable",
326
+ owners: [...OWNERS],
327
+ tags: ["workflow", "approval", "get"],
328
+ description: "Get an approval request with details.",
329
+ goal: "View approval request details.",
330
+ context: "Approval detail view."
331
+ },
332
+ io: {
333
+ input: defineSchemaModel2({
334
+ name: "GetApprovalInput",
335
+ fields: {
336
+ requestId: {
337
+ type: ScalarTypeEnum2.String_unsecure(),
338
+ isOptional: false
339
+ }
340
+ }
341
+ }),
342
+ output: ApprovalRequestModel
343
+ },
344
+ policy: { auth: "user" },
345
+ acceptance: {
346
+ scenarios: [
347
+ {
348
+ key: "get-approval-happy-path",
349
+ given: ["Approval request exists"],
350
+ when: ["User requests approval details"],
351
+ then: ["Approval details are returned"]
352
+ }
353
+ ],
354
+ examples: [
355
+ {
356
+ key: "get-basic",
357
+ input: { requestId: "req-123" },
358
+ output: { id: "req-123", status: "pending" }
359
+ }
360
+ ]
361
+ }
362
+ });
363
+ export {
364
+ SubmitDecisionContract,
365
+ ListMyApprovalsContract,
366
+ GetApprovalContract,
367
+ DelegateApprovalContract,
368
+ AddApprovalCommentContract
369
+ };
@@ -0,0 +1,73 @@
1
+ // src/approval/approval.enum.ts
2
+ import { defineEnum } from "@contractspec/lib.schema";
3
+ var ApprovalStatusEnum = defineEnum("ApprovalStatus", [
4
+ "PENDING",
5
+ "APPROVED",
6
+ "REJECTED",
7
+ "DELEGATED",
8
+ "ESCALATED",
9
+ "WITHDRAWN",
10
+ "EXPIRED"
11
+ ]);
12
+ var ApprovalDecisionEnum = defineEnum("ApprovalDecision", [
13
+ "APPROVE",
14
+ "REJECT",
15
+ "REQUEST_CHANGES",
16
+ "DELEGATE",
17
+ "ABSTAIN"
18
+ ]);
19
+
20
+ // src/approval/approval.schema.ts
21
+ import { defineSchemaModel, ScalarTypeEnum } from "@contractspec/lib.schema";
22
+ var ApprovalRequestModel = defineSchemaModel({
23
+ name: "ApprovalRequestModel",
24
+ description: "An approval request",
25
+ fields: {
26
+ id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
27
+ workflowInstanceId: {
28
+ type: ScalarTypeEnum.String_unsecure(),
29
+ isOptional: false
30
+ },
31
+ stepExecutionId: {
32
+ type: ScalarTypeEnum.String_unsecure(),
33
+ isOptional: false
34
+ },
35
+ approverId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
36
+ approverRole: {
37
+ type: ScalarTypeEnum.String_unsecure(),
38
+ isOptional: true
39
+ },
40
+ title: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
41
+ description: { type: ScalarTypeEnum.String_unsecure(), isOptional: true },
42
+ status: { type: ApprovalStatusEnum, isOptional: false },
43
+ decision: { type: ApprovalDecisionEnum, isOptional: true },
44
+ decisionComment: {
45
+ type: ScalarTypeEnum.String_unsecure(),
46
+ isOptional: true
47
+ },
48
+ decidedAt: { type: ScalarTypeEnum.DateTime(), isOptional: true },
49
+ dueAt: { type: ScalarTypeEnum.DateTime(), isOptional: true },
50
+ contextSnapshot: { type: ScalarTypeEnum.JSON(), isOptional: true },
51
+ sequenceOrder: { type: ScalarTypeEnum.Int_unsecure(), isOptional: false },
52
+ createdAt: { type: ScalarTypeEnum.DateTime(), isOptional: false }
53
+ }
54
+ });
55
+ var ApprovalCommentModel = defineSchemaModel({
56
+ name: "ApprovalCommentModel",
57
+ description: "A comment on an approval",
58
+ fields: {
59
+ id: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
60
+ approvalRequestId: {
61
+ type: ScalarTypeEnum.String_unsecure(),
62
+ isOptional: false
63
+ },
64
+ authorId: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
65
+ content: { type: ScalarTypeEnum.String_unsecure(), isOptional: false },
66
+ isInternal: { type: ScalarTypeEnum.Boolean(), isOptional: false },
67
+ createdAt: { type: ScalarTypeEnum.DateTime(), isOptional: false }
68
+ }
69
+ });
70
+ export {
71
+ ApprovalRequestModel,
72
+ ApprovalCommentModel
73
+ };