@nocobase/client 0.7.0-alpha.13 → 0.7.0-alpha.16
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.
- package/esm/acl/Configuration/RoleConfigure.js +4 -4
- package/esm/acl/Configuration/RoleConfigure.js.map +1 -1
- package/esm/acl/Configuration/schemas/roles.js +1 -1
- package/esm/acl/Configuration/schemas/roles.js.map +1 -1
- package/esm/locale/index.d.ts +5 -0
- package/esm/locale/zh_CN.d.ts +5 -0
- package/esm/locale/zh_CN.js +5 -0
- package/esm/locale/zh_CN.js.map +1 -1
- package/esm/workflow/calculators.js +3 -2
- package/esm/workflow/calculators.js.map +1 -1
- package/esm/workflow/nodes/calculation.d.ts +1 -1
- package/esm/workflow/nodes/calculation.js +9 -3
- package/esm/workflow/nodes/calculation.js.map +1 -1
- package/esm/workflow/nodes/condition.d.ts +3 -3
- package/esm/workflow/nodes/condition.js +15 -9
- package/esm/workflow/nodes/condition.js.map +1 -1
- package/esm/workflow/nodes/create.d.ts +2 -2
- package/esm/workflow/nodes/create.js +5 -5
- package/esm/workflow/nodes/create.js.map +1 -1
- package/esm/workflow/nodes/destroy.d.ts +2 -2
- package/esm/workflow/nodes/destroy.js +3 -3
- package/esm/workflow/nodes/destroy.js.map +1 -1
- package/esm/workflow/nodes/index.d.ts +1 -1
- package/esm/workflow/nodes/index.js +82 -58
- package/esm/workflow/nodes/index.js.map +1 -1
- package/esm/workflow/nodes/parallel.d.ts +2 -2
- package/esm/workflow/nodes/parallel.js +11 -5
- package/esm/workflow/nodes/parallel.js.map +1 -1
- package/esm/workflow/nodes/query.d.ts +3 -3
- package/esm/workflow/nodes/query.js +5 -5
- package/esm/workflow/nodes/query.js.map +1 -1
- package/esm/workflow/nodes/update.d.ts +2 -2
- package/esm/workflow/nodes/update.js +3 -3
- package/esm/workflow/nodes/update.js.map +1 -1
- package/esm/workflow/schemas/collection.js +7 -6
- package/esm/workflow/schemas/collection.js.map +1 -1
- package/esm/workflow/schemas/workflows.js +20 -12
- package/esm/workflow/schemas/workflows.js.map +1 -1
- package/esm/workflow/triggers/index.js +9 -6
- package/esm/workflow/triggers/index.js.map +1 -1
- package/esm/workflow/triggers/model.js +4 -4
- package/esm/workflow/triggers/model.js.map +1 -1
- package/lib/acl/Configuration/RoleConfigure.js +4 -4
- package/lib/acl/Configuration/RoleConfigure.js.map +1 -1
- package/lib/acl/Configuration/schemas/roles.js +1 -1
- package/lib/acl/Configuration/schemas/roles.js.map +1 -1
- package/lib/locale/index.d.ts +5 -0
- package/lib/locale/zh_CN.d.ts +5 -0
- package/lib/locale/zh_CN.js +5 -0
- package/lib/locale/zh_CN.js.map +1 -1
- package/lib/workflow/calculators.js +3 -2
- package/lib/workflow/calculators.js.map +1 -1
- package/lib/workflow/nodes/calculation.d.ts +1 -1
- package/lib/workflow/nodes/calculation.js +9 -3
- package/lib/workflow/nodes/calculation.js.map +1 -1
- package/lib/workflow/nodes/condition.d.ts +3 -3
- package/lib/workflow/nodes/condition.js +13 -7
- package/lib/workflow/nodes/condition.js.map +1 -1
- package/lib/workflow/nodes/create.d.ts +2 -2
- package/lib/workflow/nodes/create.js +5 -5
- package/lib/workflow/nodes/create.js.map +1 -1
- package/lib/workflow/nodes/destroy.d.ts +2 -2
- package/lib/workflow/nodes/destroy.js +3 -3
- package/lib/workflow/nodes/destroy.js.map +1 -1
- package/lib/workflow/nodes/index.d.ts +1 -1
- package/lib/workflow/nodes/index.js +85 -61
- package/lib/workflow/nodes/index.js.map +1 -1
- package/lib/workflow/nodes/parallel.d.ts +2 -2
- package/lib/workflow/nodes/parallel.js +10 -4
- package/lib/workflow/nodes/parallel.js.map +1 -1
- package/lib/workflow/nodes/query.d.ts +3 -3
- package/lib/workflow/nodes/query.js +5 -5
- package/lib/workflow/nodes/query.js.map +1 -1
- package/lib/workflow/nodes/update.d.ts +2 -2
- package/lib/workflow/nodes/update.js +3 -3
- package/lib/workflow/nodes/update.js.map +1 -1
- package/lib/workflow/schemas/collection.js +7 -6
- package/lib/workflow/schemas/collection.js.map +1 -1
- package/lib/workflow/schemas/workflows.js +20 -12
- package/lib/workflow/schemas/workflows.js.map +1 -1
- package/lib/workflow/triggers/index.js +9 -6
- package/lib/workflow/triggers/index.js.map +1 -1
- package/lib/workflow/triggers/model.js +4 -4
- package/lib/workflow/triggers/model.js.map +1 -1
- package/package.json +3 -3
- package/src/acl/Configuration/RoleConfigure.tsx +4 -4
- package/src/acl/Configuration/schemas/roles.ts +1 -1
- package/src/locale/zh_CN.ts +5 -1
- package/src/workflow/calculators.tsx +5 -2
- package/src/workflow/nodes/calculation.tsx +4 -3
- package/src/workflow/nodes/condition.tsx +35 -12
- package/src/workflow/nodes/create.tsx +10 -7
- package/src/workflow/nodes/destroy.tsx +3 -3
- package/src/workflow/nodes/index.tsx +82 -62
- package/src/workflow/nodes/parallel.tsx +25 -5
- package/src/workflow/nodes/query.tsx +5 -5
- package/src/workflow/nodes/update.tsx +3 -3
- package/src/workflow/schemas/collection.ts +5 -7
- package/src/workflow/schemas/workflows.ts +20 -12
- package/src/workflow/triggers/index.tsx +1 -0
- package/src/workflow/triggers/model.tsx +4 -4
|
@@ -8,10 +8,10 @@ exports.default = {
|
|
|
8
8
|
type: 'destroy',
|
|
9
9
|
group: 'model',
|
|
10
10
|
fieldset: {
|
|
11
|
-
collection: collection_1.collection,
|
|
12
|
-
params: {
|
|
11
|
+
'config.collection': collection_1.collection,
|
|
12
|
+
'config.params': {
|
|
13
13
|
type: 'object',
|
|
14
|
-
name: 'params',
|
|
14
|
+
name: 'config.params',
|
|
15
15
|
title: '',
|
|
16
16
|
'x-decorator': 'FormItem',
|
|
17
17
|
properties: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"destroy.js","sourceRoot":"","sources":["../../../src/workflow/nodes/destroy.tsx"],"names":[],"mappings":";;AAAA,2BAAgD;AAEhD,8CAAmD;AACnD,oDAA2D;AAE3D,kBAAe;IACb,KAAK,EAAE,MAAM;IACb,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,OAAO;IACd,QAAQ,EAAE;QACR,
|
|
1
|
+
{"version":3,"file":"destroy.js","sourceRoot":"","sources":["../../../src/workflow/nodes/destroy.tsx"],"names":[],"mappings":";;AAAA,2BAAgD;AAEhD,8CAAmD;AACnD,oDAA2D;AAE3D,kBAAe;IACb,KAAK,EAAE,MAAM;IACb,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,OAAO;IACd,QAAQ,EAAE;QACR,mBAAmB,EAAE,uBAAU;QAC/B,eAAe,EAAE;YACf,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,eAAe;YACrB,KAAK,EAAE,EAAE;YACT,aAAa,EAAE,UAAU;YACzB,UAAU,EAAE;gBACV,MAAM,qBAAA;aACP;SACF;KACF;IACD,IAAI,EAAE,EAEL;IACD,KAAK,EAAE;QACL,uBAAuB,6BAAA;KACxB;IACD,UAAU,EAAE;QACV,iBAAiB,iCAAA;KAClB;CACF,CAAC","sourcesContent":["import { useCollectionDataSource } from '../..';\n\nimport { VariableComponent } from '../calculators';\nimport { collection, filter } from '../schemas/collection';\n\nexport default {\n title: '删除数据',\n type: 'destroy',\n group: 'model',\n fieldset: {\n 'config.collection': collection,\n 'config.params': {\n type: 'object',\n name: 'config.params',\n title: '',\n 'x-decorator': 'FormItem',\n properties: {\n filter\n }\n }\n },\n view: {\n\n },\n scope: {\n useCollectionDataSource\n },\n components: {\n VariableComponent\n }\n};\n"]}
|
|
@@ -75,22 +75,22 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
75
75
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
76
76
|
exports.NodeDefaultView = exports.RemoveButton = exports.Node = exports.useNodeContext = exports.instructions = void 0;
|
|
77
77
|
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
78
|
-
var react_1 = __importStar(require("react"));
|
|
79
|
-
var css_1 = require("@emotion/css");
|
|
80
|
-
var antd_1 = require("antd");
|
|
81
78
|
var icons_1 = require("@ant-design/icons");
|
|
82
|
-
var
|
|
79
|
+
var css_1 = require("@emotion/css");
|
|
80
|
+
var react_1 = require("@formily/react");
|
|
83
81
|
var utils_1 = require("@nocobase/utils");
|
|
82
|
+
var antd_1 = require("antd");
|
|
83
|
+
var react_2 = __importStar(require("react"));
|
|
84
84
|
var __1 = require("../..");
|
|
85
|
-
var WorkflowCanvas_1 = require("../WorkflowCanvas");
|
|
86
85
|
var style_1 = require("../style");
|
|
87
|
-
var
|
|
86
|
+
var WorkflowCanvas_1 = require("../WorkflowCanvas");
|
|
87
|
+
var calculation_1 = __importDefault(require("./calculation"));
|
|
88
|
+
var condition_1 = __importDefault(require("./condition"));
|
|
88
89
|
var create_1 = __importDefault(require("./create"));
|
|
89
|
-
var update_1 = __importDefault(require("./update"));
|
|
90
90
|
var destroy_1 = __importDefault(require("./destroy"));
|
|
91
|
-
var condition_1 = __importDefault(require("./condition"));
|
|
92
91
|
var parallel_1 = __importDefault(require("./parallel"));
|
|
93
|
-
var
|
|
92
|
+
var query_1 = __importDefault(require("./query"));
|
|
93
|
+
var update_1 = __importDefault(require("./update"));
|
|
94
94
|
;
|
|
95
95
|
exports.instructions = new utils_1.Registry();
|
|
96
96
|
exports.instructions.register('query', query_1.default);
|
|
@@ -100,8 +100,8 @@ exports.instructions.register('destroy', destroy_1.default);
|
|
|
100
100
|
exports.instructions.register('condition', condition_1.default);
|
|
101
101
|
exports.instructions.register('parallel', parallel_1.default);
|
|
102
102
|
exports.instructions.register('calculation', calculation_1.default);
|
|
103
|
-
function
|
|
104
|
-
var form = (0,
|
|
103
|
+
function useUpdateAction() {
|
|
104
|
+
var form = (0, react_1.useForm)();
|
|
105
105
|
var api = (0, __1.useAPIClient)();
|
|
106
106
|
var ctx = (0, __1.useActionContext)();
|
|
107
107
|
var refresh = (0, __1.useResourceActionContext)().refresh;
|
|
@@ -111,13 +111,17 @@ function useUpdateConfigAction() {
|
|
|
111
111
|
return __awaiter(this, void 0, void 0, function () {
|
|
112
112
|
return __generator(this, function (_a) {
|
|
113
113
|
switch (_a.label) {
|
|
114
|
-
case 0: return [4 /*yield*/,
|
|
115
|
-
filterByTk: data.id,
|
|
116
|
-
values: {
|
|
117
|
-
config: __assign(__assign({}, data.config), form.values)
|
|
118
|
-
},
|
|
119
|
-
})];
|
|
114
|
+
case 0: return [4 /*yield*/, form.submit()];
|
|
120
115
|
case 1:
|
|
116
|
+
_a.sent();
|
|
117
|
+
return [4 /*yield*/, api.resource('flow_nodes', data.id).update({
|
|
118
|
+
filterByTk: data.id,
|
|
119
|
+
values: {
|
|
120
|
+
title: form.values.title,
|
|
121
|
+
config: form.values.config
|
|
122
|
+
}
|
|
123
|
+
})];
|
|
124
|
+
case 2:
|
|
121
125
|
_a.sent();
|
|
122
126
|
ctx.setVisible(false);
|
|
123
127
|
refresh();
|
|
@@ -129,9 +133,9 @@ function useUpdateConfigAction() {
|
|
|
129
133
|
};
|
|
130
134
|
}
|
|
131
135
|
;
|
|
132
|
-
var NodeContext =
|
|
136
|
+
var NodeContext = react_2.default.createContext(null);
|
|
133
137
|
function useNodeContext() {
|
|
134
|
-
return (0,
|
|
138
|
+
return (0, react_2.useContext)(NodeContext);
|
|
135
139
|
}
|
|
136
140
|
exports.useNodeContext = useNodeContext;
|
|
137
141
|
function Node(_a) {
|
|
@@ -184,60 +188,80 @@ function RemoveButton() {
|
|
|
184
188
|
return ((0, jsx_runtime_1.jsx)(antd_1.Button, { type: "text", shape: "circle", icon: (0, jsx_runtime_1.jsx)(icons_1.DeleteOutlined, {}, void 0), onClick: onRemove, className: "workflow-node-remove-button" }, void 0));
|
|
185
189
|
}
|
|
186
190
|
exports.RemoveButton = RemoveButton;
|
|
191
|
+
function Fieldset(_a) {
|
|
192
|
+
var schema = _a.schema;
|
|
193
|
+
var field = (0, react_1.useField)();
|
|
194
|
+
return ((0, jsx_runtime_1.jsx)(react_1.RecursionField, { basePath: field.address, schema: schema }, void 0));
|
|
195
|
+
}
|
|
187
196
|
function NodeDefaultView(props) {
|
|
188
197
|
var data = props.data, children = props.children;
|
|
189
198
|
var instruction = exports.instructions.get(data.type);
|
|
190
|
-
return ((0, jsx_runtime_1.jsx)(NodeContext.Provider, __assign({ value: data }, { children: (0, jsx_runtime_1.jsxs)("div", __assign({ className: (0, css_1.cx)(style_1.nodeClass, "workflow-node-type-" + data.type) }, { children: [(0, jsx_runtime_1.jsxs)("div", __assign({ className: (0, css_1.cx)(style_1.nodeCardClass) }, { children: [(0, jsx_runtime_1.jsxs)("div", __assign({ className: (0, css_1.cx)(style_1.nodeHeaderClass) }, { children: [(0, jsx_runtime_1.jsxs)("h4", __assign({ className: (0, css_1.cx)(style_1.nodeTitleClass) }, { children: [(0, jsx_runtime_1.jsx)(antd_1.Tag, { children: instruction.title }, void 0), (0, jsx_runtime_1.jsx)("strong", { children: data.title }, void 0), (0, jsx_runtime_1.jsxs)("span", __assign({ className: "workflow-node-id" }, { children: ["#", data.id] }), void 0)] }), void 0), (0, jsx_runtime_1.jsx)(RemoveButton, {}, void 0)] }), void 0), (0, jsx_runtime_1.jsx)(__1.SchemaComponent, { scope: instruction.scope, components: instruction.components, schema: {
|
|
199
|
+
return ((0, jsx_runtime_1.jsx)(NodeContext.Provider, __assign({ value: data }, { children: (0, jsx_runtime_1.jsxs)("div", __assign({ className: (0, css_1.cx)(style_1.nodeClass, "workflow-node-type-" + data.type) }, { children: [(0, jsx_runtime_1.jsxs)("div", __assign({ className: (0, css_1.cx)(style_1.nodeCardClass) }, { children: [(0, jsx_runtime_1.jsxs)("div", __assign({ className: (0, css_1.cx)(style_1.nodeHeaderClass) }, { children: [(0, jsx_runtime_1.jsxs)("h4", __assign({ className: (0, css_1.cx)(style_1.nodeTitleClass) }, { children: [(0, jsx_runtime_1.jsx)(antd_1.Tag, { children: instruction.title }, void 0), (0, jsx_runtime_1.jsx)("strong", { children: data.title }, void 0), (0, jsx_runtime_1.jsxs)("span", __assign({ className: "workflow-node-id" }, { children: ["#", data.id] }), void 0)] }), void 0), (0, jsx_runtime_1.jsx)(RemoveButton, {}, void 0)] }), void 0), (0, jsx_runtime_1.jsx)(__1.SchemaComponent, { scope: instruction.scope, components: __assign(__assign({}, instruction.components), { Fieldset: Fieldset }), schema: {
|
|
191
200
|
type: 'void',
|
|
192
|
-
properties:
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
201
|
+
properties: {
|
|
202
|
+
view: instruction.view,
|
|
203
|
+
config: {
|
|
204
|
+
type: 'void',
|
|
205
|
+
title: '配置节点',
|
|
206
|
+
'x-component': 'Action.Link',
|
|
207
|
+
'x-component-props': {
|
|
208
|
+
type: 'primary',
|
|
209
|
+
},
|
|
210
|
+
properties: {
|
|
211
|
+
drawer: {
|
|
212
|
+
type: 'void',
|
|
213
|
+
title: '配置节点',
|
|
214
|
+
'x-component': 'Action.Drawer',
|
|
215
|
+
'x-decorator': 'Form',
|
|
216
|
+
'x-decorator-props': {
|
|
217
|
+
useValues: function (options) {
|
|
218
|
+
var data = useNodeContext();
|
|
219
|
+
return (0, __1.useRequest)(function () {
|
|
220
|
+
return Promise.resolve({ data: data });
|
|
221
|
+
}, options);
|
|
222
|
+
}
|
|
223
|
+
},
|
|
224
|
+
properties: {
|
|
225
|
+
title: {
|
|
226
|
+
type: 'string',
|
|
227
|
+
name: 'title',
|
|
228
|
+
title: '节点名称',
|
|
229
|
+
'x-decorator': 'FormItem',
|
|
230
|
+
'x-component': 'Input',
|
|
214
231
|
},
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
232
|
+
config: {
|
|
233
|
+
type: 'void',
|
|
234
|
+
name: 'config',
|
|
235
|
+
'x-component': 'fieldset',
|
|
236
|
+
'x-component-props': {},
|
|
237
|
+
properties: instruction.fieldset
|
|
238
|
+
},
|
|
239
|
+
actions: {
|
|
240
|
+
type: 'void',
|
|
241
|
+
'x-component': 'Action.Drawer.Footer',
|
|
242
|
+
properties: {
|
|
243
|
+
cancel: {
|
|
244
|
+
title: '{{t("Cancel")}}',
|
|
245
|
+
'x-component': 'Action',
|
|
246
|
+
'x-component-props': {
|
|
247
|
+
useAction: '{{ cm.useCancelAction }}',
|
|
225
248
|
},
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
249
|
+
},
|
|
250
|
+
submit: {
|
|
251
|
+
title: '{{t("Submit")}}',
|
|
252
|
+
'x-component': 'Action',
|
|
253
|
+
'x-component-props': {
|
|
254
|
+
type: 'primary',
|
|
255
|
+
useAction: useUpdateAction,
|
|
233
256
|
},
|
|
234
257
|
},
|
|
235
|
-
}
|
|
258
|
+
},
|
|
259
|
+
}
|
|
236
260
|
}
|
|
237
261
|
}
|
|
238
262
|
}
|
|
239
263
|
}
|
|
240
|
-
|
|
264
|
+
}
|
|
241
265
|
} }, void 0)] }), void 0), children] }), void 0) }), void 0));
|
|
242
266
|
}
|
|
243
267
|
exports.NodeDefaultView = NodeDefaultView;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/workflow/nodes/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, { useContext } from 'react';\nimport { css, cx } from '@emotion/css';\nimport { Button, Modal, Tag } from 'antd';\nimport { DeleteOutlined, CloseOutlined } from '@ant-design/icons';\nimport { ISchema, useForm } from '@formily/react';\n\nimport { Registry } from '@nocobase/utils';\n\nimport { SchemaComponent, useActionContext, useAPIClient, useCollection, useRequest, useResourceActionContext } from '../..';\nimport { AddButton, useFlowContext } from '../WorkflowCanvas';\n\nimport { nodeClass, nodeCardClass, nodeHeaderClass, nodeTitleClass, nodeBlockClass } from '../style';\n\nimport query from './query';\nimport create from './create';\nimport update from './update';\nimport destroy from './destroy';\nimport condition from './condition';\nimport parallel from './parallel';\nimport calculation from './calculation';\n\n\n\nexport interface Instruction {\n title: string;\n type: string;\n group: string;\n options?: { label: string; value: any; key: string }[];\n fieldset: { [key: string]: ISchema };\n view?: ISchema;\n scope?: { [key: string]: any };\n components?: { [key: string]: any };\n render?(props): React.ReactElement;\n endding?: boolean;\n getter?(node: any): React.ReactElement;\n};\n\nexport const instructions = new Registry<Instruction>();\n\ninstructions.register('query', query);\ninstructions.register('create', create);\ninstructions.register('update', update);\ninstructions.register('destroy', destroy);\ninstructions.register('condition', condition);\ninstructions.register('parallel', parallel);\ninstructions.register('calculation', calculation);\n\nfunction useUpdateConfigAction() {\n const form = useForm();\n const api = useAPIClient();\n const ctx = useActionContext();\n const { refresh } = useResourceActionContext();\n const data = useNodeContext();\n return {\n async run() {\n await api.resource('flow_nodes', data.id).update({\n filterByTk: data.id,\n values: {\n config: {\n ...data.config,\n ...form.values\n }\n },\n });\n ctx.setVisible(false);\n refresh();\n },\n };\n};\n\nconst NodeContext = React.createContext(null);\n\nexport function useNodeContext() {\n return useContext(NodeContext);\n}\n\nexport function Node({ data }) {\n const instruction = instructions.get(data.type);\n\n return (\n <div className={cx(nodeBlockClass)}>\n {instruction.render\n ? instruction.render(data)\n : <NodeDefaultView data={data} />\n }\n {!instruction.endding\n ? <AddButton upstream={data} />\n : (\n <div\n className={css`\n flex-grow: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n width: 1px;\n height: 6em;\n padding: 2em 0;\n background-color: #f0f2f5;\n\n .anticon{\n font-size: 1.5em;\n line-height: 100%;\n }\n `}\n >\n <CloseOutlined />\n </div>\n )\n }\n </div>\n );\n}\n\nexport function RemoveButton() {\n const { resource } = useCollection();\n const current = useNodeContext();\n const { nodes, onNodeRemoved } = useFlowContext();\n\n async function onRemove() {\n async function onOk() {\n const { data: { data: node } } = await resource.destroy({\n filterByTk: current.id\n });\n onNodeRemoved(node);\n }\n\n const hasBranches = !nodes.find(item => item.upstream === current && item.branchIndex != null);\n const message = hasBranches\n ? '确定删除该节点吗?'\n : '节点包含分支,将同时删除其所有分支下的子节点,确定继续?';\n\n Modal.confirm({\n title: '删除节点',\n content: message,\n onOk\n });\n }\n\n return (\n <Button\n type=\"text\"\n shape=\"circle\"\n icon={<DeleteOutlined />}\n onClick={onRemove}\n className=\"workflow-node-remove-button\"\n />\n );\n}\n\nexport function NodeDefaultView(props) {\n const { data, children } = props;\n const instruction = instructions.get(data.type);\n\n return (\n <NodeContext.Provider value={data}>\n <div className={cx(nodeClass, `workflow-node-type-${data.type}`)}>\n <div className={cx(nodeCardClass)}>\n <div className={cx(nodeHeaderClass)}>\n <h4 className={cx(nodeTitleClass)}>\n <Tag>{instruction.title}</Tag>\n <strong>{data.title}</strong>\n <span className=\"workflow-node-id\">#{data.id}</span>\n </h4>\n <RemoveButton />\n </div>\n <SchemaComponent\n scope={instruction.scope}\n components={instruction.components}\n schema={{\n type: 'void',\n properties: {\n view: instruction.view,\n ...(Object.keys(instruction.fieldset).length\n ? {\n config: {\n type: 'void',\n title: '配置节点',\n 'x-component': 'Action.Link',\n 'x-component-props': {\n type: 'primary',\n },\n properties: {\n drawer: {\n type: 'void',\n title: '配置节点',\n 'x-component': 'Action.Drawer',\n 'x-decorator': 'Form',\n 'x-decorator-props': {\n useValues(options) {\n const node = useNodeContext();\n return useRequest(() => {\n return Promise.resolve({ data: node.config });\n }, options);\n }\n },\n properties: {\n ...instruction.fieldset,\n actions: {\n type: 'void',\n 'x-component': 'Action.Drawer.Footer',\n properties: {\n cancel: {\n title: '{{t(\"Cancel\")}}',\n 'x-component': 'Action',\n 'x-component-props': {\n useAction: '{{ cm.useCancelAction }}',\n },\n },\n submit: {\n title: '{{t(\"Submit\")}}',\n 'x-component': 'Action',\n 'x-component-props': {\n type: 'primary',\n useAction: useUpdateConfigAction,\n },\n },\n },\n } as ISchema\n }\n }\n }\n }\n }\n : {})\n }\n }}\n />\n </div>\n {children}\n </div>\n </NodeContext.Provider>\n );\n}\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/workflow/nodes/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import { CloseOutlined, DeleteOutlined } from '@ant-design/icons';\nimport { css, cx } from '@emotion/css';\nimport { Field } from '@formily/core';\nimport { ISchema, RecursionField, useField, useForm } from '@formily/react';\nimport { Registry } from '@nocobase/utils';\nimport { Button, Modal, Tag } from 'antd';\nimport React, { useContext } from 'react';\nimport { SchemaComponent, useActionContext, useAPIClient, useCollection, useRequest, useResourceActionContext } from '../..';\nimport { nodeBlockClass, nodeCardClass, nodeClass, nodeHeaderClass, nodeTitleClass } from '../style';\nimport { AddButton, useFlowContext } from '../WorkflowCanvas';\nimport calculation from './calculation';\nimport condition from './condition';\nimport create from './create';\nimport destroy from './destroy';\nimport parallel from './parallel';\nimport query from './query';\nimport update from './update';\n\n\n\n\n\n\n\nexport interface Instruction {\n title: string;\n type: string;\n group: string;\n options?: { label: string; value: any; key: string }[];\n fieldset: { [key: string]: ISchema };\n view?: ISchema;\n scope?: { [key: string]: any };\n components?: { [key: string]: any };\n render?(props): React.ReactElement;\n endding?: boolean;\n getter?(node: any): React.ReactElement;\n};\n\nexport const instructions = new Registry<Instruction>();\n\ninstructions.register('query', query);\ninstructions.register('create', create);\ninstructions.register('update', update);\ninstructions.register('destroy', destroy);\ninstructions.register('condition', condition);\ninstructions.register('parallel', parallel);\ninstructions.register('calculation', calculation);\n\nfunction useUpdateAction() {\n const form = useForm();\n const api = useAPIClient();\n const ctx = useActionContext();\n const { refresh } = useResourceActionContext();\n const data = useNodeContext();\n return {\n async run() {\n await form.submit();\n await api.resource('flow_nodes', data.id).update({\n filterByTk: data.id,\n values: {\n title: form.values.title,\n config: form.values.config\n }\n });\n ctx.setVisible(false);\n refresh();\n },\n };\n};\n\nconst NodeContext = React.createContext(null);\n\nexport function useNodeContext() {\n return useContext(NodeContext);\n}\n\nexport function Node({ data }) {\n const instruction = instructions.get(data.type);\n\n return (\n <div className={cx(nodeBlockClass)}>\n {instruction.render\n ? instruction.render(data)\n : <NodeDefaultView data={data} />\n }\n {!instruction.endding\n ? <AddButton upstream={data} />\n : (\n <div\n className={css`\n flex-grow: 1;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n width: 1px;\n height: 6em;\n padding: 2em 0;\n background-color: #f0f2f5;\n\n .anticon{\n font-size: 1.5em;\n line-height: 100%;\n }\n `}\n >\n <CloseOutlined />\n </div>\n )\n }\n </div>\n );\n}\n\nexport function RemoveButton() {\n const { resource } = useCollection();\n const current = useNodeContext();\n const { nodes, onNodeRemoved } = useFlowContext();\n\n async function onRemove() {\n async function onOk() {\n const { data: { data: node } } = await resource.destroy({\n filterByTk: current.id\n });\n onNodeRemoved(node);\n }\n\n const hasBranches = !nodes.find(item => item.upstream === current && item.branchIndex != null);\n const message = hasBranches\n ? '确定删除该节点吗?'\n : '节点包含分支,将同时删除其所有分支下的子节点,确定继续?';\n\n Modal.confirm({\n title: '删除节点',\n content: message,\n onOk\n });\n }\n\n return (\n <Button\n type=\"text\"\n shape=\"circle\"\n icon={<DeleteOutlined />}\n onClick={onRemove}\n className=\"workflow-node-remove-button\"\n />\n );\n}\n\nfunction Fieldset({ schema }) {\n const field = useField<Field>();\n\n return (\n <RecursionField basePath={field.address} schema={schema} />\n );\n}\n\nexport function NodeDefaultView(props) {\n const { data, children } = props;\n const instruction = instructions.get(data.type);\n\n return (\n <NodeContext.Provider value={data}>\n <div className={cx(nodeClass, `workflow-node-type-${data.type}`)}>\n <div className={cx(nodeCardClass)}>\n <div className={cx(nodeHeaderClass)}>\n <h4 className={cx(nodeTitleClass)}>\n <Tag>{instruction.title}</Tag>\n <strong>{data.title}</strong>\n <span className=\"workflow-node-id\">#{data.id}</span>\n </h4>\n <RemoveButton />\n </div>\n <SchemaComponent\n scope={instruction.scope}\n components={{\n ...instruction.components,\n Fieldset\n }}\n schema={{\n type: 'void',\n properties: {\n view: instruction.view,\n config: {\n type: 'void',\n title: '配置节点',\n 'x-component': 'Action.Link',\n 'x-component-props': {\n type: 'primary',\n },\n properties: {\n drawer: {\n type: 'void',\n title: '配置节点',\n 'x-component': 'Action.Drawer',\n 'x-decorator': 'Form',\n 'x-decorator-props': {\n useValues(options) {\n const data = useNodeContext();\n return useRequest(() => {\n return Promise.resolve({ data });\n }, options);\n }\n },\n properties: {\n title: {\n type: 'string',\n name: 'title',\n title: '节点名称',\n 'x-decorator': 'FormItem',\n 'x-component': 'Input',\n },\n config: {\n type: 'void',\n name: 'config',\n 'x-component': 'fieldset',\n 'x-component-props': {},\n properties: instruction.fieldset\n },\n actions: {\n type: 'void',\n 'x-component': 'Action.Drawer.Footer',\n properties: {\n cancel: {\n title: '{{t(\"Cancel\")}}',\n 'x-component': 'Action',\n 'x-component-props': {\n useAction: '{{ cm.useCancelAction }}',\n },\n },\n submit: {\n title: '{{t(\"Submit\")}}',\n 'x-component': 'Action',\n 'x-component-props': {\n type: 'primary',\n useAction: useUpdateAction,\n },\n },\n },\n } as ISchema\n }\n }\n }\n }\n }\n }}\n />\n </div>\n {children}\n </div>\n </NodeContext.Provider>\n );\n}\n"]}
|
|
@@ -4,7 +4,7 @@ declare const _default: {
|
|
|
4
4
|
type: string;
|
|
5
5
|
group: string;
|
|
6
6
|
fieldset: {
|
|
7
|
-
mode: {
|
|
7
|
+
'config.mode': {
|
|
8
8
|
type: string;
|
|
9
9
|
name: string;
|
|
10
10
|
title: string;
|
|
@@ -13,7 +13,7 @@ declare const _default: {
|
|
|
13
13
|
'x-component-props': {};
|
|
14
14
|
enum: {
|
|
15
15
|
value: string;
|
|
16
|
-
label:
|
|
16
|
+
label: JSX.Element;
|
|
17
17
|
}[];
|
|
18
18
|
default: string;
|
|
19
19
|
};
|
|
@@ -45,16 +45,22 @@ exports.default = {
|
|
|
45
45
|
type: 'parallel',
|
|
46
46
|
group: 'control',
|
|
47
47
|
fieldset: {
|
|
48
|
-
mode: {
|
|
48
|
+
'config.mode': {
|
|
49
49
|
type: 'string',
|
|
50
|
-
name: 'mode',
|
|
50
|
+
name: 'config.mode',
|
|
51
51
|
title: '模式',
|
|
52
52
|
'x-decorator': 'FormItem',
|
|
53
53
|
'x-component': 'Radio.Group',
|
|
54
54
|
'x-component-props': {},
|
|
55
55
|
enum: [
|
|
56
|
-
{
|
|
57
|
-
|
|
56
|
+
{
|
|
57
|
+
value: 'all',
|
|
58
|
+
label: ((0, jsx_runtime_1.jsxs)(antd_1.Tooltip, __assign({ title: "\u5168\u90E8\u5206\u652F\u90FD\u6210\u529F\u540E\u624D\u80FD\u7EE7\u7EED", placement: "bottom" }, { children: ["\u5168\u90E8\u6210\u529F ", (0, jsx_runtime_1.jsx)(icons_1.QuestionCircleOutlined, { style: { color: '#999' } }, void 0)] }), void 0))
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
value: 'any',
|
|
62
|
+
label: ((0, jsx_runtime_1.jsxs)(antd_1.Tooltip, __assign({ title: "\u4EFB\u610F\u5206\u652F\u6210\u529F\u540E\u5C31\u7EE7\u7EED", placement: "bottom" }, { children: ["\u4EFB\u610F\u6210\u529F ", (0, jsx_runtime_1.jsx)(icons_1.QuestionCircleOutlined, { style: { color: '#999' } }, void 0)] }), void 0))
|
|
63
|
+
},
|
|
58
64
|
// { value: 'race', label: '任意退出' },
|
|
59
65
|
],
|
|
60
66
|
default: 'all'
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parallel.js","sourceRoot":"","sources":["../../../src/workflow/nodes/parallel.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+BAAwC;AACxC,oCAAuC;AACvC,
|
|
1
|
+
{"version":3,"file":"parallel.js","sourceRoot":"","sources":["../../../src/workflow/nodes/parallel.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, { useState } from \"react\";\nimport { css, cx } from \"@emotion/css\";\nimport { PlusOutlined, QuestionCircleOutlined } from '@ant-design/icons';\n\nimport { NodeDefaultView } from \".\";\nimport { Branch, useFlowContext } from \"../WorkflowCanvas\";\nimport { branchBlockClass, nodeSubtreeClass } from \"../style\";\nimport { Button, Tooltip } from \"antd\";\n// import { SchemaComponent } from \"../../schema-component\";\n\nexport default {\n title: '并行',\n type: 'parallel',\n group: 'control',\n fieldset: {\n 'config.mode': {\n type: 'string',\n name: 'config.mode',\n title: '模式',\n 'x-decorator': 'FormItem',\n 'x-component': 'Radio.Group',\n 'x-component-props': {\n },\n enum: [\n {\n value: 'all',\n label: (\n <Tooltip\n title=\"全部分支都成功后才能继续\"\n placement=\"bottom\"\n >\n 全部成功 <QuestionCircleOutlined style={{ color: '#999' }} />\n </Tooltip>\n )\n },\n {\n value: 'any',\n label: (\n <Tooltip\n title=\"任意分支成功后就继续\"\n placement=\"bottom\"\n >\n 任意成功 <QuestionCircleOutlined style={{ color: '#999' }} />\n </Tooltip>\n )\n },\n // { value: 'race', label: '任意退出' },\n ],\n default: 'all'\n }\n },\n view: {\n\n },\n render(data) {\n const { id, config: { mode } } = data;\n const { nodes } = useFlowContext();\n const branches = nodes.reduce((result, node) => {\n if (node.upstreamId === id && node.branchIndex != null) {\n return result.concat(node);\n }\n return result;\n }, []).sort((a, b) => a.branchIndex - b.branchIndex);\n const [branchCount, setBranchCount] = useState(Math.max(2, branches.length));\n\n const tempBranches = Array(Math.max(0, branchCount - branches.length)).fill(null);\n const lastBranchHead = branches[branches.length - 1];\n\n return (\n <NodeDefaultView data={data}>\n <div className={cx(nodeSubtreeClass)}>\n <div className={cx(branchBlockClass)}>\n {branches.map((branch) => (\n <Branch key={branch.id} from={data} entry={branch} branchIndex={branch.branchIndex} />\n ))}\n {tempBranches.map((_, i) => (\n <Branch\n key={`temp_${branches.length + i}`}\n from={data}\n branchIndex={(lastBranchHead ? lastBranchHead.branchIndex : 0) + i + 1}\n controller={\n branches.length + i > 1\n ? (\n <div className={css`\n padding-top: 2em;\n\n > button{\n .anticon{\n transform: rotate(45deg)\n }\n }\n `}>\n <Button\n shape=\"circle\"\n icon={<PlusOutlined />}\n onClick={() => setBranchCount(branchCount - 1)}\n />\n </div>\n )\n : null\n }\n />\n ))}\n </div>\n <div\n className={css`\n position: relative;\n height: 2em;\n `}\n >\n <Tooltip title=\"添加分支\">\n <Button\n icon={<PlusOutlined />}\n className={css`\n position: absolute;\n top: calc(50% - 1px);\n transform: translateX(-50%) rotate(45deg);\n\n .anticon{\n transform: rotate(-45deg);\n }\n `}\n onClick={() => setBranchCount(branchCount + 1)}\n />\n </Tooltip>\n </div>\n </div>\n </NodeDefaultView>\n )\n }\n};\n"]}
|
|
@@ -6,7 +6,7 @@ declare const _default: {
|
|
|
6
6
|
type: string;
|
|
7
7
|
group: string;
|
|
8
8
|
fieldset: {
|
|
9
|
-
collection: {
|
|
9
|
+
'config.collection': {
|
|
10
10
|
type: string;
|
|
11
11
|
title: string;
|
|
12
12
|
name: string;
|
|
@@ -15,7 +15,7 @@ declare const _default: {
|
|
|
15
15
|
'x-decorator': string;
|
|
16
16
|
'x-component': string;
|
|
17
17
|
};
|
|
18
|
-
multiple: {
|
|
18
|
+
'config.multiple': {
|
|
19
19
|
type: string;
|
|
20
20
|
title: string;
|
|
21
21
|
name: string;
|
|
@@ -25,7 +25,7 @@ declare const _default: {
|
|
|
25
25
|
disabled: boolean;
|
|
26
26
|
};
|
|
27
27
|
};
|
|
28
|
-
params: {
|
|
28
|
+
'config.params': {
|
|
29
29
|
type: string;
|
|
30
30
|
name: string;
|
|
31
31
|
title: string;
|
|
@@ -22,20 +22,20 @@ exports.default = {
|
|
|
22
22
|
type: 'query',
|
|
23
23
|
group: 'model',
|
|
24
24
|
fieldset: {
|
|
25
|
-
collection: collection_1.collection,
|
|
26
|
-
multiple: {
|
|
25
|
+
'config.collection': collection_1.collection,
|
|
26
|
+
'config.multiple': {
|
|
27
27
|
type: 'boolean',
|
|
28
28
|
title: '多条数据',
|
|
29
|
-
name: 'multiple',
|
|
29
|
+
name: 'config.multiple',
|
|
30
30
|
'x-decorator': 'FormItem',
|
|
31
31
|
'x-component': 'Checkbox',
|
|
32
32
|
'x-component-props': {
|
|
33
33
|
disabled: true
|
|
34
34
|
}
|
|
35
35
|
},
|
|
36
|
-
params: {
|
|
36
|
+
'config.params': {
|
|
37
37
|
type: 'object',
|
|
38
|
-
name: 'params',
|
|
38
|
+
name: 'config.params',
|
|
39
39
|
title: '',
|
|
40
40
|
'x-decorator': 'FormItem',
|
|
41
41
|
properties: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/workflow/nodes/query.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,6BAA8B;AAE9B,2BAAkF;AAElF,oDAAmD;AACnD,8CAAgE;AAChE,oDAA2D;AAE3D,kBAAe;IACb,KAAK,EAAE,MAAM;IACb,IAAI,EAAE,OAAO;IACb,KAAK,EAAE,OAAO;IACd,QAAQ,EAAE;QACR,
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/workflow/nodes/query.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,6BAA8B;AAE9B,2BAAkF;AAElF,oDAAmD;AACnD,8CAAgE;AAChE,oDAA2D;AAE3D,kBAAe;IACb,KAAK,EAAE,MAAM;IACb,IAAI,EAAE,OAAO;IACb,KAAK,EAAE,OAAO;IACd,QAAQ,EAAE;QACR,mBAAmB,EAAE,uBAAU;QAC/B,iBAAiB,EAAE;YACjB,IAAI,EAAE,SAAS;YACf,KAAK,EAAE,MAAM;YACb,IAAI,EAAE,iBAAiB;YACvB,aAAa,EAAE,UAAU;YACzB,aAAa,EAAE,UAAU;YACzB,mBAAmB,EAAE;gBACnB,QAAQ,EAAE,IAAI;aACf;SACF;QACD,eAAe,EAAE;YACf,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,eAAe;YACrB,KAAK,EAAE,EAAE;YACT,aAAa,EAAE,UAAU;YACzB,UAAU,EAAE;gBACV,MAAM,qBAAA;aACP;SACF;KACF;IACD,IAAI,EAAE,EAEL;IACD,KAAK,EAAE;QACL,uBAAuB,6BAAA;KACxB;IACD,UAAU,EAAE;QACV,iBAAiB,iCAAA;KAClB;IACD,MAAM,YAAC,EAA2B;;YAAzB,IAAI,UAAA,EAAE,OAAO,aAAA,EAAE,QAAQ,cAAA;QAC9B,IAAM,OAAO,GAAG,IAAA,cAAU,GAAE,CAAC;QACrB,IAAA,KAAqB,IAAA,wBAAoB,GAAE,YAA3B,EAAhB,WAAW,mBAAG,EAAE,KAAA,CAA4B;QAC5C,IAAA,KAAK,GAAK,IAAA,+BAAc,GAAE,MAArB,CAAsB;QAC3B,IAAA,MAAM,GAAK,KAAK,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,EAAE,IAAI,OAAO,CAAC,MAAM,EAAtB,CAAsB,CAAC,OAA5C,CAA6C;QAC3D,IAAM,UAAU,GAAG,MAAA,WAAW,CAAC,IAAI,CAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,IAAI,KAAK,MAAM,CAAC,UAAU,EAA/B,CAA+B,CAAC,mCAAI,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;QAE/F,OAAO,CACL,uBAAC,aAAM,aAAC,KAAK,EAAE,OAAO,CAAC,IAAI,EAAE,WAAW,EAAC,0BAAM,EAAC,QAAQ,EAAE,UAAA,IAAI;gBAC5D,QAAQ,CAAC,EAAE,IAAI,MAAA,EAAE,OAAO,wBAAO,OAAO,KAAE,IAAI,MAAA,GAAE,EAAE,CAAC,CAAC;YACpD,CAAC,gBACE,UAAU,CAAC,MAAM;iBACf,MAAM,CAAC,UAAA,KAAK,YAAI,OAAA,yBAAW,CAAC,GAAG,CAAC,MAAA,KAAK,CAAC,QAAQ,0CAAE,IAAI,CAAC,CAAA,EAAA,CAAC;iBACtD,GAAG,CAAC,UAAA,KAAK,IAAI,OAAA,CACd,uBAAC,aAAM,CAAC,MAAM,aAAkB,KAAK,EAAE,KAAK,CAAC,IAAI,gBAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,KAA7D,KAAK,CAAC,IAAI,CAAoE,CACnG,EAFe,CAEf,CAAC,YACK,CACV,CAAC;IACJ,CAAC;CACF,CAAC","sourcesContent":["import React from 'react';\nimport { Select } from 'antd';\n\nimport { useCollectionDataSource, useCollectionManager, useCompile } from '../..';\n\nimport { useFlowContext } from '../WorkflowCanvas';\nimport { BaseTypeSet, VariableComponent } from '../calculators';\nimport { collection, filter } from '../schemas/collection';\n\nexport default {\n title: '查询数据',\n type: 'query',\n group: 'model',\n fieldset: {\n 'config.collection': collection,\n 'config.multiple': {\n type: 'boolean',\n title: '多条数据',\n name: 'config.multiple',\n 'x-decorator': 'FormItem',\n 'x-component': 'Checkbox',\n 'x-component-props': {\n disabled: true\n }\n },\n 'config.params': {\n type: 'object',\n name: 'config.params',\n title: '',\n 'x-decorator': 'FormItem',\n properties: {\n filter\n }\n }\n },\n view: {\n\n },\n scope: {\n useCollectionDataSource\n },\n components: {\n VariableComponent\n },\n getter({ type, options, onChange }) {\n const compile = useCompile();\n const { collections = [] } = useCollectionManager();\n const { nodes } = useFlowContext();\n const { config } = nodes.find(n => n.id == options.nodeId);\n const collection = collections.find(item => item.name === config.collection) ?? { fields: [] };\n\n return (\n <Select value={options.path} placeholder=\"选择字段\" onChange={path => {\n onChange({ type, options: { ...options, path } });\n }}>\n {collection.fields\n .filter(field => BaseTypeSet.has(field.uiSchema?.type))\n .map(field => (\n <Select.Option key={field.name} value={field.name}>{compile(field.uiSchema.title)}</Select.Option>\n ))}\n </Select>\n );\n }\n};\n"]}
|
|
@@ -6,7 +6,7 @@ declare const _default: {
|
|
|
6
6
|
type: string;
|
|
7
7
|
group: string;
|
|
8
8
|
fieldset: {
|
|
9
|
-
collection: {
|
|
9
|
+
'config.collection': {
|
|
10
10
|
type: string;
|
|
11
11
|
title: string;
|
|
12
12
|
name: string;
|
|
@@ -15,7 +15,7 @@ declare const _default: {
|
|
|
15
15
|
'x-decorator': string;
|
|
16
16
|
'x-component': string;
|
|
17
17
|
};
|
|
18
|
-
params: {
|
|
18
|
+
'config.params': {
|
|
19
19
|
type: string;
|
|
20
20
|
name: string;
|
|
21
21
|
title: string;
|
|
@@ -8,10 +8,10 @@ exports.default = {
|
|
|
8
8
|
type: 'update',
|
|
9
9
|
group: 'model',
|
|
10
10
|
fieldset: {
|
|
11
|
-
collection: collection_1.collection,
|
|
12
|
-
params: {
|
|
11
|
+
'config.collection': collection_1.collection,
|
|
12
|
+
'config.params': {
|
|
13
13
|
type: 'object',
|
|
14
|
-
name: 'params',
|
|
14
|
+
name: 'config.params',
|
|
15
15
|
title: '',
|
|
16
16
|
'x-decorator': 'FormItem',
|
|
17
17
|
properties: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update.js","sourceRoot":"","sources":["../../../src/workflow/nodes/update.tsx"],"names":[],"mappings":";;AAAA,2BAAgD;AAChD,8CAAuE;AACvE,oDAAmE;AAEnE,kBAAe;IACb,KAAK,EAAE,MAAM;IACb,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,OAAO;IACd,QAAQ,EAAE;QACR,
|
|
1
|
+
{"version":3,"file":"update.js","sourceRoot":"","sources":["../../../src/workflow/nodes/update.tsx"],"names":[],"mappings":";;AAAA,2BAAgD;AAChD,8CAAuE;AACvE,oDAAmE;AAEnE,kBAAe;IACb,KAAK,EAAE,MAAM;IACb,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,OAAO;IACd,QAAQ,EAAE;QACR,mBAAmB,EAAE,uBAAU;QAC/B,eAAe,EAAE;YACf,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,eAAe;YACrB,KAAK,EAAE,EAAE;YACT,aAAa,EAAE,UAAU;YACzB,UAAU,EAAE;gBACV,MAAM,qBAAA;gBACN,MAAM,qBAAA;aACP;SACF;KACF;IACD,IAAI,EAAE,EAEL;IACD,KAAK,EAAE;QACL,uBAAuB,6BAAA;KACxB;IACD,UAAU,EAAE;QACV,iBAAiB,iCAAA;QACjB,kBAAkB,kCAAA;KACnB;CACF,CAAC","sourcesContent":["import { useCollectionDataSource } from '../..';\nimport { CollectionFieldset, VariableComponent } from '../calculators';\nimport { collection, filter, values } from '../schemas/collection';\n\nexport default {\n title: '更新数据',\n type: 'update',\n group: 'model',\n fieldset: {\n 'config.collection': collection,\n 'config.params': {\n type: 'object',\n name: 'config.params',\n title: '',\n 'x-decorator': 'FormItem',\n properties: {\n filter,\n values\n }\n }\n },\n view: {\n\n },\n scope: {\n useCollectionDataSource\n },\n components: {\n VariableComponent,\n CollectionFieldset\n }\n};\n"]}
|
|
@@ -12,7 +12,7 @@ var action_hooks_1 = require("../../collection-manager/action-hooks");
|
|
|
12
12
|
exports.collection = {
|
|
13
13
|
type: 'string',
|
|
14
14
|
title: '数据表',
|
|
15
|
-
name: 'collection',
|
|
15
|
+
name: 'config.collection',
|
|
16
16
|
required: true,
|
|
17
17
|
'x-reactions': ['{{useCollectionDataSource()}}'],
|
|
18
18
|
'x-decorator': 'FormItem',
|
|
@@ -21,7 +21,7 @@ exports.collection = {
|
|
|
21
21
|
exports.values = {
|
|
22
22
|
type: 'object',
|
|
23
23
|
title: '数据内容',
|
|
24
|
-
name: 'values',
|
|
24
|
+
name: 'config.params.values',
|
|
25
25
|
'x-decorator': 'FormItem',
|
|
26
26
|
'x-decorator-props': {
|
|
27
27
|
labelAlign: 'left',
|
|
@@ -30,9 +30,10 @@ exports.values = {
|
|
|
30
30
|
'x-component': 'CollectionFieldset',
|
|
31
31
|
'x-component-props': {
|
|
32
32
|
useProps: function () {
|
|
33
|
+
var _a;
|
|
33
34
|
var getCollectionFields = (0, collection_manager_1.useCollectionManager)().getCollectionFields;
|
|
34
35
|
var form = (0, react_1.useForm)().values;
|
|
35
|
-
var fields = getCollectionFields(form.collection);
|
|
36
|
+
var fields = getCollectionFields((_a = form === null || form === void 0 ? void 0 : form.config) === null || _a === void 0 ? void 0 : _a.collection);
|
|
36
37
|
return { fields: fields };
|
|
37
38
|
}
|
|
38
39
|
}
|
|
@@ -40,7 +41,7 @@ exports.values = {
|
|
|
40
41
|
exports.filter = {
|
|
41
42
|
type: 'object',
|
|
42
43
|
title: '筛选条件',
|
|
43
|
-
name: 'filter',
|
|
44
|
+
name: 'config.params.filter',
|
|
44
45
|
'x-decorator': 'FormItem',
|
|
45
46
|
'x-decorator-props': {
|
|
46
47
|
labelAlign: 'left',
|
|
@@ -50,10 +51,10 @@ exports.filter = {
|
|
|
50
51
|
'x-component-props': {
|
|
51
52
|
useProps: function () {
|
|
52
53
|
var values = (0, react_1.useForm)().values;
|
|
53
|
-
var options = (0, action_hooks_1.useCollectionFilterOptions)(values.collection);
|
|
54
|
+
var options = (0, action_hooks_1.useCollectionFilterOptions)(values.config.collection);
|
|
54
55
|
return {
|
|
55
56
|
options: options,
|
|
56
|
-
className: (0, css_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n position: relative;\n width: 100%;\n
|
|
57
|
+
className: (0, css_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n position: relative;\n width: 100%;\n "], ["\n position: relative;\n width: 100%;\n "])))
|
|
57
58
|
};
|
|
58
59
|
},
|
|
59
60
|
dynamicComponent: 'VariableComponent'
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collection.js","sourceRoot":"","sources":["../../../src/workflow/schemas/collection.ts"],"names":[],"mappings":";;;;;;;AAAA,oCAAmC;AACnC,wCAAyC;AACzC,+DAAgE;AAChE,sEAAmF;AAEtE,QAAA,UAAU,GAAG;IACxB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,KAAK;IACZ,IAAI,EAAE,
|
|
1
|
+
{"version":3,"file":"collection.js","sourceRoot":"","sources":["../../../src/workflow/schemas/collection.ts"],"names":[],"mappings":";;;;;;;AAAA,oCAAmC;AACnC,wCAAyC;AACzC,+DAAgE;AAChE,sEAAmF;AAEtE,QAAA,UAAU,GAAG;IACxB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,KAAK;IACZ,IAAI,EAAE,mBAAmB;IACzB,QAAQ,EAAE,IAAI;IACd,aAAa,EAAE,CAAC,+BAA+B,CAAC;IAChD,aAAa,EAAE,UAAU;IACzB,aAAa,EAAE,QAAQ;CACxB,CAAC;AAEW,QAAA,MAAM,GAAG;IACpB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,MAAM;IACb,IAAI,EAAE,sBAAsB;IAC5B,aAAa,EAAE,UAAU;IACzB,mBAAmB,EAAE;QACnB,UAAU,EAAE,MAAM;QAClB,SAAS,MAAE,SAAG,2GAAA,uCAEb,IAAA;KACF;IACD,aAAa,EAAE,oBAAoB;IACnC,mBAAmB,EAAE;QACnB,QAAQ;;YACE,IAAA,mBAAmB,GAAK,IAAA,yCAAoB,GAAE,oBAA3B,CAA4B;YAC/C,IAAQ,IAAI,GAAK,IAAA,eAAO,GAAE,OAAd,CAAe;YACnC,IAAM,MAAM,GAAG,mBAAmB,CAAC,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,MAAM,0CAAE,UAAU,CAAC,CAAC;YAC7D,OAAO,EAAE,MAAM,QAAA,EAAE,CAAC;QACpB,CAAC;KACF;CACF,CAAC;AAEW,QAAA,MAAM,GAAG;IACpB,IAAI,EAAE,QAAQ;IACd,KAAK,EAAE,MAAM;IACb,IAAI,EAAE,sBAAsB;IAC5B,aAAa,EAAE,UAAU;IACzB,mBAAmB,EAAE;QACnB,UAAU,EAAE,MAAM;QAClB,SAAS,MAAE,SAAG,2GAAA,uCAEb,IAAA;KACF;IACD,aAAa,EAAE,QAAQ;IACvB,mBAAmB,EAAE;QACnB,QAAQ;YACE,IAAA,MAAM,GAAK,IAAA,eAAO,GAAE,OAAd,CAAe;YAC7B,IAAM,OAAO,GAAG,IAAA,yCAA0B,EAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACrE,OAAO;gBACL,OAAO,SAAA;gBACP,SAAS,MAAE,SAAG,uIAAA,mEAGb,IAAA;aACF,CAAC;QACJ,CAAC;QACD,gBAAgB,EAAE,mBAAmB;KACtC;CACF,CAAC","sourcesContent":["import { css } from \"@emotion/css\";\nimport { useForm } from \"@formily/react\";\nimport { useCollectionManager } from \"../../collection-manager\";\nimport { useCollectionFilterOptions } from \"../../collection-manager/action-hooks\";\n\nexport const collection = {\n type: 'string',\n title: '数据表',\n name: 'config.collection',\n required: true,\n 'x-reactions': ['{{useCollectionDataSource()}}'],\n 'x-decorator': 'FormItem',\n 'x-component': 'Select',\n};\n\nexport const values = {\n type: 'object',\n title: '数据内容',\n name: 'config.params.values',\n 'x-decorator': 'FormItem',\n 'x-decorator-props': {\n labelAlign: 'left',\n className: css`\n flex-direction: column;\n `\n },\n 'x-component': 'CollectionFieldset',\n 'x-component-props': {\n useProps() {\n const { getCollectionFields } = useCollectionManager();\n const { values: form } = useForm();\n const fields = getCollectionFields(form?.config?.collection);\n return { fields };\n }\n }\n};\n\nexport const filter = {\n type: 'object',\n title: '筛选条件',\n name: 'config.params.filter',\n 'x-decorator': 'FormItem',\n 'x-decorator-props': {\n labelAlign: 'left',\n className: css`\n flex-direction: column;\n `\n },\n 'x-component': 'Filter',\n 'x-component-props': {\n useProps() {\n const { values } = useForm();\n const options = useCollectionFilterOptions(values.config.collection);\n return {\n options,\n className: css`\n position: relative;\n width: 100%;\n `\n };\n },\n dynamicComponent: 'VariableComponent'\n }\n};\n"]}
|