@nocobase/plugin-workflow 0.10.1-alpha.1 → 0.11.1-alpha.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 (289) hide show
  1. package/client.d.ts +2 -3
  2. package/client.js +1 -30
  3. package/lib/client/AddButton.js +13 -11
  4. package/lib/client/Branch.js +10 -8
  5. package/lib/client/CanvasContent.js +12 -10
  6. package/lib/client/ExecutionCanvas.js +37 -33
  7. package/lib/client/ExecutionPage.js +4 -9
  8. package/lib/client/WorkflowCanvas.js +18 -15
  9. package/lib/client/WorkflowPage.js +4 -9
  10. package/lib/client/WorkflowProvider.js +1 -40
  11. package/lib/client/components/CollectionBlockInitializer.js +3 -3
  12. package/lib/client/components/CollectionFieldset.d.ts +1 -1
  13. package/lib/client/components/CollectionFieldset.js +15 -16
  14. package/lib/client/components/Duration.js +5 -5
  15. package/lib/client/components/DynamicExpression.d.ts +3 -3
  16. package/lib/client/components/FieldsSelect.d.ts +1 -1
  17. package/lib/client/components/FieldsSelect.js +10 -7
  18. package/lib/client/components/NodeDescription.js +45 -31
  19. package/lib/client/components/RadioWithTooltip.js +13 -20
  20. package/lib/client/components/ValueBlock.js +14 -21
  21. package/lib/client/components/renderEngineReference.js +1 -8
  22. package/lib/client/index.d.ts +12 -4
  23. package/lib/client/index.js +78 -15
  24. package/lib/client/locale/zh-CN.d.ts +5 -1
  25. package/lib/client/locale/zh-CN.js +6 -2
  26. package/lib/client/nodes/aggregate.d.ts +8 -3
  27. package/lib/client/nodes/aggregate.js +5 -4
  28. package/lib/client/nodes/calculation.d.ts +6 -4
  29. package/lib/client/nodes/calculation.js +22 -28
  30. package/lib/client/nodes/condition.d.ts +2 -10
  31. package/lib/client/nodes/condition.js +19 -37
  32. package/lib/client/nodes/create.d.ts +5 -6
  33. package/lib/client/nodes/create.js +1 -3
  34. package/lib/client/nodes/destroy.d.ts +1 -1
  35. package/lib/client/nodes/index.d.ts +2 -3
  36. package/lib/client/nodes/index.js +95 -102
  37. package/lib/client/nodes/loop.d.ts +1 -1
  38. package/lib/client/nodes/loop.js +46 -54
  39. package/lib/client/nodes/manual/FormBlockInitializer.js +6 -5
  40. package/lib/client/nodes/manual/ModeConfig.js +23 -30
  41. package/lib/client/nodes/manual/SchemaConfig.d.ts +4 -5
  42. package/lib/client/nodes/manual/SchemaConfig.js +180 -25
  43. package/lib/client/nodes/manual/WorkflowTodo.js +95 -110
  44. package/lib/client/nodes/manual/WorkflowTodoBlockInitializer.d.ts +2 -5
  45. package/lib/client/nodes/manual/WorkflowTodoBlockInitializer.js +6 -5
  46. package/lib/client/nodes/manual/forms/create.js +8 -1
  47. package/lib/client/nodes/manual/forms/custom.js +22 -22
  48. package/lib/client/nodes/manual/forms/update.js +8 -1
  49. package/lib/client/nodes/manual/index.d.ts +6 -1
  50. package/lib/client/nodes/manual/index.js +5 -4
  51. package/lib/client/nodes/parallel.js +23 -20
  52. package/lib/client/nodes/query.d.ts +3 -5
  53. package/lib/client/nodes/query.js +1 -3
  54. package/lib/client/nodes/request.d.ts +2 -2
  55. package/lib/client/nodes/request.js +7 -7
  56. package/lib/client/nodes/sql.d.ts +26 -0
  57. package/lib/client/{triggers/schedule/DateFieldsSelect.js → nodes/sql.js} +37 -46
  58. package/lib/client/nodes/update.d.ts +2 -2
  59. package/lib/client/nodes/update.js +1 -1
  60. package/lib/client/schemas/collection.d.ts +3 -4
  61. package/lib/client/schemas/collection.js +11 -17
  62. package/lib/client/style.d.ts +18 -13
  63. package/lib/client/style.js +315 -292
  64. package/lib/client/triggers/collection.d.ts +13 -13
  65. package/lib/client/triggers/collection.js +5 -1
  66. package/lib/client/triggers/index.d.ts +3 -4
  67. package/lib/client/triggers/index.js +51 -53
  68. package/lib/client/triggers/schedule/EndsByField.js +11 -11
  69. package/lib/client/triggers/schedule/OnField.js +45 -33
  70. package/lib/client/triggers/schedule/RepeatField.js +4 -4
  71. package/lib/client/triggers/schedule/ScheduleConfig.js +24 -31
  72. package/lib/client/triggers/schedule/index.d.ts +1 -1
  73. package/lib/client/triggers/schedule/index.js +32 -20
  74. package/lib/client/variable.d.ts +31 -13
  75. package/lib/client/variable.js +44 -29
  76. package/lib/server/Plugin.d.ts +3 -6
  77. package/lib/server/Plugin.js +15 -12
  78. package/lib/server/Processor.d.ts +3 -5
  79. package/lib/server/Processor.js +2 -2
  80. package/lib/server/actions/nodes.js +7 -7
  81. package/lib/server/fields/expression-field.d.ts +1 -2
  82. package/lib/server/fields/expression-field.js +1 -8
  83. package/lib/server/functions/index.d.ts +2 -3
  84. package/lib/server/index.d.ts +1 -0
  85. package/lib/server/index.js +12 -0
  86. package/lib/server/instructions/aggregate.d.ts +1 -1
  87. package/lib/server/instructions/aggregate.js +5 -5
  88. package/lib/server/instructions/condition.d.ts +2 -1
  89. package/lib/server/instructions/create.d.ts +2 -2
  90. package/lib/server/instructions/create.js +13 -13
  91. package/lib/server/instructions/delay.d.ts +3 -3
  92. package/lib/server/instructions/delay.js +66 -64
  93. package/lib/server/instructions/destroy.d.ts +1 -1
  94. package/lib/server/instructions/index.d.ts +5 -5
  95. package/lib/server/instructions/index.js +1 -1
  96. package/lib/server/instructions/loop.d.ts +1 -2
  97. package/lib/server/instructions/manual/actions.js +19 -7
  98. package/lib/server/instructions/manual/forms/create.js +7 -1
  99. package/lib/server/instructions/manual/forms/index.d.ts +1 -1
  100. package/lib/server/instructions/manual/forms/update.js +7 -1
  101. package/lib/server/instructions/manual/index.d.ts +1 -1
  102. package/lib/server/instructions/parallel.d.ts +1 -2
  103. package/lib/server/instructions/query.d.ts +1 -1
  104. package/lib/server/instructions/query.js +8 -1
  105. package/lib/server/instructions/request.d.ts +3 -3
  106. package/lib/server/instructions/request.js +5 -2
  107. package/lib/server/instructions/sql.d.ts +12 -0
  108. package/lib/server/instructions/sql.js +34 -0
  109. package/lib/server/instructions/update.d.ts +1 -1
  110. package/lib/server/migrations/20230221071831-calculation-expression.js +1 -1
  111. package/lib/server/migrations/20230221121203-condition-calculation.js +1 -1
  112. package/lib/server/migrations/20230221162902-jsonb-to-json.js +7 -7
  113. package/lib/server/migrations/20230411034722-manual-multi-form.js +1 -8
  114. package/lib/server/migrations/20230710115902-manual-action-values.d.ts +4 -0
  115. package/lib/server/migrations/20230710115902-manual-action-values.js +97 -0
  116. package/lib/server/triggers/collection.d.ts +1 -1
  117. package/lib/server/triggers/collection.js +15 -13
  118. package/lib/server/triggers/index.d.ts +1 -1
  119. package/lib/server/triggers/schedule.d.ts +1 -1
  120. package/lib/server/triggers/schedule.js +18 -18
  121. package/lib/server/{models → types}/Execution.d.ts +2 -3
  122. package/lib/server/{models → types}/FlowNode.d.ts +1 -2
  123. package/lib/server/{models → types}/Job.d.ts +1 -2
  124. package/lib/server/{models → types}/Workflow.d.ts +1 -2
  125. package/lib/server/types/index.d.ts +4 -0
  126. package/lib/server/types/index.js +5 -0
  127. package/lib/server/utils.d.ts +2 -0
  128. package/lib/server/utils.js +21 -0
  129. package/package.json +39 -18
  130. package/server.d.ts +2 -3
  131. package/server.js +1 -30
  132. package/src/client/AddButton.tsx +111 -0
  133. package/src/client/Branch.tsx +37 -0
  134. package/src/client/CanvasContent.tsx +25 -0
  135. package/src/client/ExecutionCanvas.tsx +166 -0
  136. package/src/client/ExecutionLink.tsx +16 -0
  137. package/src/client/ExecutionPage.tsx +45 -0
  138. package/src/client/ExecutionResourceProvider.tsx +21 -0
  139. package/src/client/FlowContext.ts +7 -0
  140. package/src/client/WorkflowCanvas.tsx +221 -0
  141. package/src/client/WorkflowLink.tsx +16 -0
  142. package/src/client/WorkflowPage.tsx +52 -0
  143. package/src/client/WorkflowProvider.tsx +84 -0
  144. package/src/client/components/CollectionBlockInitializer.tsx +71 -0
  145. package/src/client/components/CollectionFieldset.tsx +160 -0
  146. package/src/client/components/Duration.tsx +45 -0
  147. package/src/client/components/DynamicExpression.tsx +53 -0
  148. package/src/client/components/FieldsSelect.tsx +32 -0
  149. package/src/client/components/FilterDynamicComponent.tsx +15 -0
  150. package/src/client/components/NodeDescription.tsx +51 -0
  151. package/src/client/components/NullRender.tsx +3 -0
  152. package/src/client/components/OpenDrawer.tsx +24 -0
  153. package/src/client/components/RadioWithTooltip.tsx +38 -0
  154. package/src/client/components/ValueBlock.tsx +67 -0
  155. package/src/client/components/renderEngineReference.tsx +30 -0
  156. package/src/client/constants.tsx +91 -0
  157. package/src/client/index.tsx +51 -0
  158. package/src/client/interfaces/expression.tsx +25 -0
  159. package/src/client/locale/en-US.ts +136 -0
  160. package/src/client/locale/es-ES.ts +129 -0
  161. package/src/client/locale/index.ts +18 -0
  162. package/src/client/locale/ja-JP.ts +90 -0
  163. package/src/client/locale/pt-BR.ts +136 -0
  164. package/src/client/locale/ru-RU.ts +90 -0
  165. package/src/client/locale/tr-TR.ts +90 -0
  166. package/src/client/locale/zh-CN.ts +248 -0
  167. package/src/client/nodes/aggregate.tsx +327 -0
  168. package/src/client/nodes/calculation.tsx +216 -0
  169. package/src/client/nodes/condition.tsx +463 -0
  170. package/src/client/nodes/create.tsx +85 -0
  171. package/src/client/nodes/delay.tsx +37 -0
  172. package/src/client/nodes/destroy.tsx +34 -0
  173. package/src/client/nodes/index.tsx +485 -0
  174. package/src/client/nodes/loop.tsx +144 -0
  175. package/src/client/nodes/manual/AssigneesSelect.tsx +33 -0
  176. package/src/client/nodes/manual/DetailsBlockProvider.tsx +80 -0
  177. package/src/client/nodes/manual/FormBlockInitializer.tsx +69 -0
  178. package/src/client/nodes/manual/FormBlockProvider.tsx +75 -0
  179. package/src/client/nodes/manual/ModeConfig.tsx +84 -0
  180. package/src/client/nodes/manual/SchemaConfig.tsx +509 -0
  181. package/src/client/nodes/manual/WorkflowTodo.tsx +607 -0
  182. package/src/client/nodes/manual/WorkflowTodoBlockInitializer.tsx +28 -0
  183. package/src/client/nodes/manual/forms/create.tsx +92 -0
  184. package/src/client/nodes/manual/forms/custom.tsx +392 -0
  185. package/src/client/nodes/manual/forms/update.tsx +134 -0
  186. package/src/client/nodes/manual/index.tsx +162 -0
  187. package/src/client/nodes/manual/utils.ts +28 -0
  188. package/src/client/nodes/parallel.tsx +138 -0
  189. package/src/client/nodes/query.tsx +88 -0
  190. package/src/client/nodes/request.tsx +185 -0
  191. package/src/client/nodes/sql.tsx +37 -0
  192. package/src/client/nodes/update.tsx +99 -0
  193. package/src/client/schemas/collection.ts +75 -0
  194. package/src/client/schemas/executions.tsx +169 -0
  195. package/src/client/schemas/workflows.ts +364 -0
  196. package/src/client/style.tsx +347 -0
  197. package/src/client/triggers/collection.tsx +190 -0
  198. package/src/client/triggers/index.tsx +311 -0
  199. package/src/client/triggers/schedule/EndsByField.tsx +40 -0
  200. package/src/client/triggers/schedule/OnField.tsx +64 -0
  201. package/src/client/triggers/schedule/RepeatField.tsx +116 -0
  202. package/src/client/triggers/schedule/ScheduleConfig.tsx +227 -0
  203. package/src/client/triggers/schedule/constants.ts +4 -0
  204. package/src/client/triggers/schedule/index.tsx +78 -0
  205. package/src/client/triggers/schedule/locale/Cron.zh-CN.ts +79 -0
  206. package/src/client/utils.ts +36 -0
  207. package/src/client/variable.tsx +318 -0
  208. package/src/index.ts +1 -0
  209. package/src/server/Plugin.ts +355 -0
  210. package/src/server/Processor.ts +354 -0
  211. package/src/server/__tests__/Plugin.test.ts +398 -0
  212. package/src/server/__tests__/Processor.test.ts +474 -0
  213. package/src/server/__tests__/actions/workflows.test.ts +419 -0
  214. package/src/server/__tests__/collections/categories.ts +27 -0
  215. package/src/server/__tests__/collections/comments.ts +24 -0
  216. package/src/server/__tests__/collections/posts.ts +42 -0
  217. package/src/server/__tests__/collections/replies.ts +9 -0
  218. package/src/server/__tests__/collections/tags.ts +15 -0
  219. package/src/server/__tests__/index.ts +89 -0
  220. package/src/server/__tests__/instructions/aggregate.test.ts +294 -0
  221. package/src/server/__tests__/instructions/calculation.test.ts +265 -0
  222. package/src/server/__tests__/instructions/condition.test.ts +335 -0
  223. package/src/server/__tests__/instructions/create.test.ts +129 -0
  224. package/src/server/__tests__/instructions/delay.test.ts +182 -0
  225. package/src/server/__tests__/instructions/destroy.test.ts +58 -0
  226. package/src/server/__tests__/instructions/loop.test.ts +331 -0
  227. package/src/server/__tests__/instructions/manual.test.ts +1173 -0
  228. package/src/server/__tests__/instructions/parallel.test.ts +445 -0
  229. package/src/server/__tests__/instructions/query.test.ts +359 -0
  230. package/src/server/__tests__/instructions/request.test.ts +247 -0
  231. package/src/server/__tests__/instructions/sql.test.ts +162 -0
  232. package/src/server/__tests__/instructions/update.test.ts +189 -0
  233. package/src/server/__tests__/triggers/collection.test.ts +333 -0
  234. package/src/server/__tests__/triggers/schedule.test.ts +369 -0
  235. package/src/server/actions/index.ts +25 -0
  236. package/src/server/actions/nodes.ts +214 -0
  237. package/src/server/actions/workflows.ts +178 -0
  238. package/src/server/collections/executions.ts +35 -0
  239. package/src/server/collections/flow_nodes.ts +54 -0
  240. package/src/server/collections/jobs.ts +31 -0
  241. package/src/server/collections/workflows.ts +88 -0
  242. package/src/server/constants.ts +26 -0
  243. package/src/server/fields/expression-field.ts +11 -0
  244. package/src/server/fields/index.ts +7 -0
  245. package/src/server/functions/index.ts +16 -0
  246. package/src/server/index.ts +6 -0
  247. package/src/server/instructions/aggregate.ts +42 -0
  248. package/src/server/instructions/calculation.ts +41 -0
  249. package/src/server/instructions/condition.ts +172 -0
  250. package/src/server/instructions/create.ts +39 -0
  251. package/src/server/instructions/delay.ts +105 -0
  252. package/src/server/instructions/destroy.ts +23 -0
  253. package/src/server/instructions/index.ts +64 -0
  254. package/src/server/instructions/loop.ts +99 -0
  255. package/src/server/instructions/manual/actions.ts +91 -0
  256. package/src/server/instructions/manual/collecions/jobs.ts +17 -0
  257. package/src/server/instructions/manual/collecions/users.ts +15 -0
  258. package/src/server/instructions/manual/collecions/users_jobs.ts +50 -0
  259. package/src/server/instructions/manual/forms/create.ts +23 -0
  260. package/src/server/instructions/manual/forms/index.ts +12 -0
  261. package/src/server/instructions/manual/forms/update.ts +23 -0
  262. package/src/server/instructions/manual/index.ts +184 -0
  263. package/src/server/instructions/parallel.ts +121 -0
  264. package/src/server/instructions/query.ts +42 -0
  265. package/src/server/instructions/request.ts +88 -0
  266. package/src/server/instructions/sql.ts +25 -0
  267. package/src/server/instructions/update.ts +24 -0
  268. package/src/server/migrations/20221129153547-calculation-variables.ts +64 -0
  269. package/src/server/migrations/20230221032941-change-request-body-type.ts +76 -0
  270. package/src/server/migrations/20230221071831-calculation-expression.ts +102 -0
  271. package/src/server/migrations/20230221121203-condition-calculation.ts +82 -0
  272. package/src/server/migrations/20230221162902-jsonb-to-json.ts +51 -0
  273. package/src/server/migrations/20230411034722-manual-multi-form.ts +282 -0
  274. package/src/server/migrations/20230612021134-manual-collection-block.ts +138 -0
  275. package/src/server/migrations/20230710115902-manual-action-values.ts +78 -0
  276. package/src/server/triggers/collection.ts +146 -0
  277. package/src/server/triggers/index.ts +22 -0
  278. package/src/server/triggers/schedule.ts +567 -0
  279. package/src/server/types/Execution.ts +26 -0
  280. package/src/server/types/FlowNode.ts +21 -0
  281. package/src/server/types/Job.ts +18 -0
  282. package/src/server/types/Workflow.ts +36 -0
  283. package/src/server/types/index.ts +4 -0
  284. package/src/server/utils.ts +17 -0
  285. package/lib/client/triggers/schedule/DateFieldsSelect.d.ts +0 -2
  286. /package/lib/server/{models → types}/Execution.js +0 -0
  287. /package/lib/server/{models → types}/FlowNode.js +0 -0
  288. /package/lib/server/{models → types}/Job.js +0 -0
  289. /package/lib/server/{models → types}/Workflow.js +0 -0
@@ -0,0 +1,509 @@
1
+ import React, { useContext, useEffect, useMemo, useState } from 'react';
2
+ import { createForm } from '@formily/core';
3
+ import { FormProvider, ISchema, Schema, useFieldSchema, useForm } from '@formily/react';
4
+ import { FormLayout } from '@formily/antd-v5';
5
+ import { Alert, Button, Modal, Space } from 'antd';
6
+ import { useTranslation } from 'react-i18next';
7
+
8
+ import {
9
+ Action,
10
+ ActionContextProvider,
11
+ GeneralSchemaDesigner,
12
+ InitializerWithSwitch,
13
+ SchemaComponent,
14
+ SchemaComponentContext,
15
+ SchemaInitializer,
16
+ SchemaInitializerItemOptions,
17
+ SchemaInitializerProvider,
18
+ SchemaSettings,
19
+ VariableScopeProvider,
20
+ gridRowColWrap,
21
+ useCompile,
22
+ useFormBlockContext,
23
+ useSchemaOptionsContext,
24
+ } from '@nocobase/client';
25
+ import { Registry, lodash } from '@nocobase/utils/client';
26
+ import { instructions, useAvailableUpstreams, useNodeContext } from '..';
27
+ import { JOB_STATUS } from '../../constants';
28
+ import { useFlowContext } from '../../FlowContext';
29
+ import { NAMESPACE, lang } from '../../locale';
30
+ import { useTrigger } from '../../triggers';
31
+ import { DetailsBlockProvider } from './DetailsBlockProvider';
32
+ import { FormBlockProvider } from './FormBlockProvider';
33
+ import createRecordForm from './forms/create';
34
+ import customRecordForm from './forms/custom';
35
+ import updateRecordForm from './forms/update';
36
+ import { useWorkflowVariableOptions } from '../../variable';
37
+
38
+ type ValueOf<T> = T[keyof T];
39
+
40
+ export type FormType = {
41
+ type: 'create' | 'update' | 'custom';
42
+ title: string;
43
+ actions: ValueOf<typeof JOB_STATUS>[];
44
+ collection:
45
+ | string
46
+ | {
47
+ name: string;
48
+ fields: any[];
49
+ [key: string]: any;
50
+ };
51
+ };
52
+
53
+ export type ManualFormType = {
54
+ title: string;
55
+ config: {
56
+ useInitializer: () => SchemaInitializerItemOptions;
57
+ initializers?: {
58
+ [key: string]: React.FC;
59
+ };
60
+ components?: {
61
+ [key: string]: React.FC;
62
+ };
63
+ parseFormOptions(root: ISchema): { [key: string]: FormType };
64
+ };
65
+ block: {
66
+ scope?: {
67
+ [key: string]: () => any;
68
+ };
69
+ components?: {
70
+ [key: string]: React.FC;
71
+ };
72
+ };
73
+ };
74
+
75
+ export const manualFormTypes = new Registry<ManualFormType>();
76
+
77
+ manualFormTypes.register('customForm', customRecordForm);
78
+ manualFormTypes.register('createForm', createRecordForm);
79
+ manualFormTypes.register('updateForm', updateRecordForm);
80
+
81
+ function useTriggerInitializers(): SchemaInitializerItemOptions | null {
82
+ const { workflow } = useFlowContext();
83
+ const trigger = useTrigger();
84
+ return trigger.useInitializers ? trigger.useInitializers(workflow.config) : null;
85
+ }
86
+
87
+ const blockTypeNames = {
88
+ customForm: customRecordForm.title,
89
+ record: `{{t("Data record", { ns: "${NAMESPACE}" })}}`,
90
+ };
91
+
92
+ function SimpleDesigner() {
93
+ const schema = useFieldSchema();
94
+ const title = blockTypeNames[schema['x-designer-props']?.type] ?? '{{t("Block")}}';
95
+ const compile = useCompile();
96
+ return (
97
+ <GeneralSchemaDesigner title={compile(title)}>
98
+ <SchemaSettings.BlockTitleItem />
99
+ <SchemaSettings.Divider />
100
+ <SchemaSettings.Remove
101
+ removeParentsIfNoChildren
102
+ breakRemoveOn={{
103
+ 'x-component': 'Grid',
104
+ }}
105
+ />
106
+ </GeneralSchemaDesigner>
107
+ );
108
+ }
109
+
110
+ function AddBlockButton(props: any) {
111
+ const current = useNodeContext();
112
+ const nodes = useAvailableUpstreams(current);
113
+ const triggerInitializers = [useTriggerInitializers()].filter(Boolean);
114
+ const nodeBlockInitializers = nodes
115
+ .map((node) => {
116
+ const instruction = instructions.get(node.type);
117
+ return instruction?.useInitializers?.(node);
118
+ })
119
+ .filter(Boolean);
120
+ const dataBlockInitializers = [
121
+ ...triggerInitializers,
122
+ ...(nodeBlockInitializers.length
123
+ ? [
124
+ {
125
+ key: 'nodes',
126
+ type: 'subMenu',
127
+ title: `{{t("Node result", { ns: "${NAMESPACE}" })}}`,
128
+ children: nodeBlockInitializers,
129
+ },
130
+ ]
131
+ : []),
132
+ ].filter(Boolean);
133
+
134
+ const items = [
135
+ ...(dataBlockInitializers.length
136
+ ? [
137
+ {
138
+ type: 'itemGroup',
139
+ title: '{{t("Data blocks")}}',
140
+ children: dataBlockInitializers,
141
+ },
142
+ ]
143
+ : []),
144
+ {
145
+ type: 'itemGroup',
146
+ title: '{{t("Form")}}',
147
+ children: Array.from(manualFormTypes.getValues()).map((item: ManualFormType) => {
148
+ const { useInitializer: getInitializer } = item.config;
149
+ return getInitializer();
150
+ }),
151
+ },
152
+ {
153
+ type: 'itemGroup',
154
+ title: '{{t("Other blocks")}}',
155
+ children: [
156
+ {
157
+ type: 'item',
158
+ title: '{{t("Markdown")}}',
159
+ component: 'MarkdownBlockInitializer',
160
+ },
161
+ ],
162
+ },
163
+ ] as SchemaInitializerItemOptions[];
164
+
165
+ return <SchemaInitializer.Button {...props} wrap={gridRowColWrap} items={items} title="{{t('Add block')}}" />;
166
+ }
167
+
168
+ function AssignedFieldValues() {
169
+ const ctx = useContext(SchemaComponentContext);
170
+ const { t } = useTranslation();
171
+ const fieldSchema = useFieldSchema();
172
+ const scope = useWorkflowVariableOptions({ fieldNames: { label: 'title', value: 'name' } });
173
+ const [open, setOpen] = useState(false);
174
+ const [initialSchema, setInitialSchema] = useState(fieldSchema?.['x-action-settings']?.assignedValues?.schema ?? {
175
+ type: 'void',
176
+ 'x-component': 'Grid',
177
+ 'x-initializer': 'CustomFormItemInitializers',
178
+ properties: {},
179
+ });
180
+ const [schema, setSchema] = useState<Schema>(null);
181
+ const { components } = useSchemaOptionsContext();
182
+ useEffect(() => {
183
+ setSchema(new Schema({
184
+ properties: {
185
+ grid: initialSchema
186
+ },
187
+ }));
188
+ }, [initialSchema]);
189
+ const form = useMemo(
190
+ () => {
191
+ const initialValues = fieldSchema?.['x-action-settings']?.assignedValues?.values;
192
+ return createForm({
193
+ initialValues: lodash.cloneDeep(initialValues),
194
+ values: lodash.cloneDeep(initialValues),
195
+ });
196
+ },
197
+ [],
198
+ );
199
+
200
+ const title = t('Assign field values');
201
+
202
+ function onCancel() {
203
+ setOpen(false);
204
+ }
205
+
206
+ function onSubmit() {
207
+ if (!fieldSchema['x-action-settings']) {
208
+ fieldSchema['x-action-settings'] = {};
209
+ }
210
+ if (!fieldSchema['x-action-settings'].assignedValues) {
211
+ fieldSchema['x-action-settings'].assignedValues = {};
212
+ }
213
+ fieldSchema['x-action-settings'].assignedValues.schema = initialSchema;
214
+ fieldSchema['x-action-settings'].assignedValues.values = form.values;
215
+ setOpen(false);
216
+ setTimeout(() => {
217
+ ctx.refresh?.();
218
+ }, 300);
219
+ }
220
+
221
+ return (
222
+ <>
223
+ <SchemaSettings.Item onClick={() => setOpen(true)}>
224
+ {title}
225
+ </SchemaSettings.Item>
226
+ <Modal
227
+ width={'50%'}
228
+ title={title}
229
+ open={open}
230
+ onCancel={onCancel}
231
+ footer={
232
+ <Space>
233
+ <Button onClick={onCancel}>{t('Cancel')}</Button>
234
+ <Button type="primary" onClick={onSubmit}>{t('Submit')}</Button>
235
+ </Space>
236
+ }
237
+ >
238
+ <VariableScopeProvider scope={scope}>
239
+ <FormProvider form={form}>
240
+ <FormLayout layout={'vertical'}>
241
+ <Alert message={lang('Values preset in this form will override user submitted ones when continue or reject.')} />
242
+ <br />
243
+ {open && schema && (
244
+ <SchemaComponentContext.Provider
245
+ value={{
246
+ ...ctx,
247
+ refresh() {
248
+ setInitialSchema(lodash.get(schema.toJSON(), 'properties.grid'));
249
+ }
250
+ }}
251
+ >
252
+ <SchemaComponent schema={schema} components={components} />
253
+ </SchemaComponentContext.Provider>
254
+ )}
255
+ </FormLayout>
256
+ </FormProvider>
257
+ </VariableScopeProvider>
258
+ </Modal>
259
+ </>
260
+ );
261
+ }
262
+
263
+ function ManualActionDesigner(props) {
264
+ return (
265
+ <GeneralSchemaDesigner {...props} disableInitializer>
266
+ <Action.Designer.ButtonEditor />
267
+ <AssignedFieldValues />
268
+ <SchemaSettings.Divider />
269
+ <SchemaSettings.Remove
270
+ removeParentsIfNoChildren
271
+ breakRemoveOn={{
272
+ 'x-component': 'ActionBar',
273
+ }}
274
+ />
275
+ </GeneralSchemaDesigner>
276
+ );
277
+ }
278
+
279
+ function ContinueInitializer({ action, actionProps, insert, ...props }) {
280
+ return (
281
+ <SchemaInitializer.Item
282
+ {...props}
283
+ onClick={() => {
284
+ insert({
285
+ type: 'void',
286
+ title: props.title,
287
+ 'x-decorator': 'ManualActionStatusProvider',
288
+ 'x-decorator-props': {
289
+ value: action,
290
+ },
291
+ 'x-component': 'Action',
292
+ 'x-component-props': {
293
+ ...actionProps,
294
+ useAction: '{{ useSubmit }}',
295
+ },
296
+ 'x-designer': 'ManualActionDesigner',
297
+ 'x-action-settings': {},
298
+ });
299
+ }}
300
+ />
301
+ );
302
+ }
303
+
304
+ function ActionInitializer({ action, actionProps, ...props }) {
305
+ return (
306
+ <InitializerWithSwitch
307
+ {...props}
308
+ schema={{
309
+ type: 'void',
310
+ title: props.title,
311
+ 'x-decorator': 'ManualActionStatusProvider',
312
+ 'x-decorator-props': {
313
+ value: action,
314
+ },
315
+ 'x-component': 'Action',
316
+ 'x-component-props': {
317
+ ...actionProps,
318
+ useAction: '{{ useSubmit }}',
319
+ },
320
+ 'x-designer': 'Action.Designer',
321
+ 'x-action': `${action}`,
322
+ }}
323
+ type="x-action"
324
+ />
325
+ );
326
+ }
327
+
328
+ function AddActionButton(props) {
329
+ return (
330
+ <SchemaInitializer.Button
331
+ {...props}
332
+ items={[
333
+ {
334
+ key: JOB_STATUS.RESOLVED,
335
+ type: 'item',
336
+ title: `{{t("Continue the process", { ns: "${NAMESPACE}" })}}`,
337
+ component: ContinueInitializer,
338
+ action: JOB_STATUS.RESOLVED,
339
+ actionProps: {
340
+ type: 'primary',
341
+ },
342
+ },
343
+ {
344
+ key: JOB_STATUS.REJECTED,
345
+ type: 'item',
346
+ title: `{{t("Terminate the process", { ns: "${NAMESPACE}" })}}`,
347
+ component: ActionInitializer,
348
+ action: JOB_STATUS.REJECTED,
349
+ actionProps: {
350
+ danger: true,
351
+ },
352
+ },
353
+ {
354
+ key: JOB_STATUS.PENDING,
355
+ type: 'item',
356
+ title: `{{t("Save temporarily", { ns: "${NAMESPACE}" })}}`,
357
+ component: ActionInitializer,
358
+ action: JOB_STATUS.PENDING,
359
+ },
360
+ ]}
361
+ title="{{t('Configure actions')}}"
362
+ />
363
+ );
364
+ }
365
+
366
+ // NOTE: fake useAction for ui configuration
367
+ function useSubmit() {
368
+ // const { values, submit, id: formId } = useForm();
369
+ // const formSchema = useFieldSchema();
370
+ return {
371
+ run() {},
372
+ };
373
+ }
374
+
375
+ export function SchemaConfig({ value, onChange }) {
376
+ const ctx = useContext(SchemaComponentContext);
377
+ const trigger = useTrigger();
378
+ const node = useNodeContext();
379
+ const nodes = useAvailableUpstreams(node);
380
+ const form = useForm();
381
+ const { workflow } = useFlowContext();
382
+
383
+ const nodeInitializers = {};
384
+ const nodeComponents = {};
385
+ nodes.forEach((item) => {
386
+ const instruction = instructions.get(item.type);
387
+ Object.assign(nodeInitializers, instruction.initializers);
388
+ Object.assign(nodeComponents, instruction.components);
389
+ });
390
+
391
+ const schema = useMemo(
392
+ () =>
393
+ new Schema({
394
+ properties: {
395
+ drawer: {
396
+ type: 'void',
397
+ title: '{{t("Configure form")}}',
398
+ 'x-decorator': 'Form',
399
+ 'x-component': 'Action.Drawer',
400
+ 'x-component-props': {
401
+ className: 'nb-action-popup',
402
+ },
403
+ properties: {
404
+ tabs: {
405
+ type: 'void',
406
+ 'x-component': 'Tabs',
407
+ 'x-component-props': {},
408
+ 'x-initializer': 'TabPaneInitializers',
409
+ 'x-initializer-props': {
410
+ gridInitializer: 'AddBlockButton',
411
+ },
412
+ properties: value ?? {
413
+ tab1: {
414
+ type: 'void',
415
+ title: `{{t("Manual", { ns: "${NAMESPACE}" })}}`,
416
+ 'x-component': 'Tabs.TabPane',
417
+ 'x-designer': 'Tabs.Designer',
418
+ properties: {
419
+ grid: {
420
+ type: 'void',
421
+ 'x-component': 'Grid',
422
+ 'x-initializer': 'AddBlockButton',
423
+ properties: {},
424
+ },
425
+ },
426
+ },
427
+ },
428
+ },
429
+ },
430
+ },
431
+ },
432
+ }),
433
+ [],
434
+ );
435
+
436
+ return (
437
+ <SchemaComponentContext.Provider
438
+ value={{
439
+ ...ctx,
440
+ designable: !workflow.executed,
441
+ refresh() {
442
+ ctx.refresh?.();
443
+ const { tabs } = lodash.get(schema.toJSON(), 'properties.drawer.properties') as { tabs: ISchema };
444
+ const forms = Array.from(manualFormTypes.getValues()).reduce(
445
+ (result, item: ManualFormType) => Object.assign(result, item.config.parseFormOptions(tabs)),
446
+ {},
447
+ );
448
+ form.setValuesIn('forms', forms);
449
+
450
+ onChange(tabs.properties);
451
+ },
452
+ }}
453
+ >
454
+ <SchemaInitializerProvider
455
+ initializers={{
456
+ AddBlockButton,
457
+ AddActionButton,
458
+ ...trigger.initializers,
459
+ ...nodeInitializers,
460
+ // @ts-ignore
461
+ ...Array.from(manualFormTypes.getValues()).reduce(
462
+ (result, item: ManualFormType) => Object.assign(result, item.config.initializers),
463
+ {},
464
+ ),
465
+ }}
466
+ >
467
+ <SchemaComponent
468
+ schema={schema}
469
+ components={{
470
+ ...nodeComponents,
471
+ // @ts-ignore
472
+ ...Array.from(manualFormTypes.getValues()).reduce(
473
+ (result, item: ManualFormType) => Object.assign(result, item.config.components),
474
+ {},
475
+ ),
476
+ FormBlockProvider,
477
+ DetailsBlockProvider,
478
+ // NOTE: fake provider component
479
+ ManualActionStatusProvider(props) {
480
+ return props.children;
481
+ },
482
+ ActionBarProvider(props) {
483
+ return props.children;
484
+ },
485
+ SimpleDesigner,
486
+ ManualActionDesigner,
487
+ }}
488
+ scope={{
489
+ useSubmit,
490
+ useDetailsBlockProps: useFormBlockContext,
491
+ }}
492
+ />
493
+ </SchemaInitializerProvider>
494
+ </SchemaComponentContext.Provider>
495
+ );
496
+ }
497
+
498
+ export function SchemaConfigButton(props) {
499
+ const { workflow } = useFlowContext();
500
+ const [visible, setVisible] = useState(false);
501
+ return (
502
+ <>
503
+ <Button type="primary" onClick={() => setVisible(true)}>
504
+ {workflow.executed ? lang('View user interface') : lang('Configure user interface')}
505
+ </Button>
506
+ <ActionContextProvider value={{ visible, setVisible }}>{props.children}</ActionContextProvider>
507
+ </>
508
+ );
509
+ }