@byteluck-fe/model-driven-engine 2.7.0-alpha.15a → 2.7.0-alpha.15c
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/dist/esm/common/ActionManager.js +173 -56
- package/dist/esm/common/DataManager.js +134 -25
- package/dist/esm/common/Engine.js +407 -273
- package/dist/esm/common/OkWorker.js +31 -17
- package/dist/esm/common/Plugin.js +2 -2
- package/dist/esm/common/Runtime.js +54 -39
- package/dist/esm/common/Store.js +61 -59
- package/dist/esm/common/checkerValue.js +112 -110
- package/dist/esm/common/index.js +2 -2
- package/dist/esm/common/proxyState.js +61 -60
- package/dist/esm/index.js +3 -3
- package/dist/esm/plugins/CalcPlugin.js +86 -77
- package/dist/esm/plugins/ControlsEventPlugin.js +196 -73
- package/dist/esm/plugins/ES6ModulePlugin.js +37 -21
- package/dist/esm/plugins/LifecycleEventPlugin.js +198 -79
- package/dist/esm/plugins/StylePlugin.js +26 -11
- package/dist/esm/plugins/index.js +5 -5
- package/dist/esm/utils/index.js +1 -1
- package/dist/esm/utils/runtimeUtils.js +7 -7
- package/dist/index.umd.js +9 -9
- package/dist/types/common/Engine.d.ts +6 -6
- package/dist/types/common/Runtime.d.ts +1 -1
- package/dist/types/common/Store.d.ts +5 -5
- package/dist/types/common/proxyState.d.ts +3 -3
- package/dist/types/plugins/ControlsEventPlugin.d.ts +1 -1
- package/dist/types/plugins/ES6ModulePlugin.d.ts +4 -4
- package/dist/types/plugins/LifecycleEventPlugin.d.ts +1 -1
- package/dist/types/plugins/StylePlugin.d.ts +1 -1
- package/package.json +2 -2
|
@@ -1,44 +1,44 @@
|
|
|
1
|
-
function
|
|
1
|
+
function _array_like_to_array(arr, len) {
|
|
2
2
|
if (len == null || len > arr.length) len = arr.length;
|
|
3
3
|
for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
|
|
4
4
|
return arr2;
|
|
5
5
|
}
|
|
6
|
-
function
|
|
7
|
-
if (Array.isArray(arr)) return
|
|
6
|
+
function _array_without_holes(arr) {
|
|
7
|
+
if (Array.isArray(arr)) return _array_like_to_array(arr);
|
|
8
8
|
}
|
|
9
|
-
function
|
|
9
|
+
function _iterable_to_array(iter) {
|
|
10
10
|
if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
|
|
11
11
|
}
|
|
12
|
-
function
|
|
12
|
+
function _non_iterable_spread() {
|
|
13
13
|
throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
14
14
|
}
|
|
15
|
-
function
|
|
16
|
-
return
|
|
15
|
+
function _to_consumable_array(arr) {
|
|
16
|
+
return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
|
|
17
17
|
}
|
|
18
|
-
function
|
|
18
|
+
function _unsupported_iterable_to_array(o, minLen) {
|
|
19
19
|
if (!o) return;
|
|
20
|
-
if (typeof o === "string") return
|
|
20
|
+
if (typeof o === "string") return _array_like_to_array(o, minLen);
|
|
21
21
|
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
22
22
|
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
23
23
|
if (n === "Map" || n === "Set") return Array.from(n);
|
|
24
|
-
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return
|
|
24
|
+
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
|
25
25
|
}
|
|
26
|
-
import { CONTROL_BASE_TYPE, error, logerror } from '@byteluck-fe/model-driven-shared';
|
|
27
26
|
var cc = console;
|
|
27
|
+
import { CONTROL_BASE_TYPE, error, logerror } from "@byteluck-fe/model-driven-shared";
|
|
28
28
|
var proxyArrayApi = [
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
29
|
+
"splice",
|
|
30
|
+
"push",
|
|
31
|
+
"shift",
|
|
32
|
+
"pop",
|
|
33
|
+
"unshift",
|
|
34
|
+
"reverse"
|
|
35
35
|
];
|
|
36
|
-
export var engineProxyFlag = Symbol(
|
|
37
|
-
export var engineTargetKey = Symbol(
|
|
38
|
-
export var engineArrayBeforeSetCallbackFlag = Symbol(
|
|
39
|
-
export var engineProxyThisKey = Symbol(
|
|
36
|
+
export var engineProxyFlag = Symbol("__engineProxy__");
|
|
37
|
+
export var engineTargetKey = Symbol("__engineTarget__");
|
|
38
|
+
export var engineArrayBeforeSetCallbackFlag = Symbol("__engineArrayBeforeSetCallbackFlag__");
|
|
39
|
+
export var engineProxyThisKey = Symbol("__engineProxyThisKey__");
|
|
40
40
|
var currentHandlerState = {
|
|
41
|
-
type:
|
|
41
|
+
type: "",
|
|
42
42
|
args: [],
|
|
43
43
|
callback: emptyFn
|
|
44
44
|
};
|
|
@@ -55,16 +55,16 @@ function ArrayHandler(target, propertyKey, value, thisKey, callback) {
|
|
|
55
55
|
// 操作下标
|
|
56
56
|
// Number(propertyKey) > target.length 说明当前操作的下标已经超过了安全范围(数组的运行长度,比如[1,2,3],它的长度为3,可操作的下标为0,1,2,3,如果操作4将会产生一个empty index)
|
|
57
57
|
if (index > target.length) {
|
|
58
|
-
error("Wrong array operations may cause unknown errors. It is recommended to use APIs such as ".concat(proxyArrayApi.join(
|
|
58
|
+
error("Wrong array operations may cause unknown errors. It is recommended to use APIs such as ".concat(proxyArrayApi.join(","), " for array operations"));
|
|
59
59
|
return;
|
|
60
60
|
}
|
|
61
61
|
// 不是操作下标,而是直接操作length或者自定义属性等
|
|
62
62
|
var isNotHandlerIndex = Number.isNaN(index);
|
|
63
|
-
if (isNotHandlerIndex && propertyKey !==
|
|
63
|
+
if (isNotHandlerIndex && propertyKey !== "length") {
|
|
64
64
|
return;
|
|
65
65
|
}
|
|
66
66
|
// 直接操作length
|
|
67
|
-
if (propertyKey ===
|
|
67
|
+
if (propertyKey === "length") {
|
|
68
68
|
var newLength = value;
|
|
69
69
|
var oldLength = target.length;
|
|
70
70
|
if (newLength > target.length) {
|
|
@@ -76,9 +76,9 @@ function ArrayHandler(target, propertyKey, value, thisKey, callback) {
|
|
|
76
76
|
}
|
|
77
77
|
// 通过操作length删除旧的行
|
|
78
78
|
return function() {
|
|
79
|
-
return callback.call(null, target, thisKey,
|
|
79
|
+
return callback.call(null, target, thisKey, "splice", [
|
|
80
80
|
newLength,
|
|
81
|
-
oldLength - newLength
|
|
81
|
+
oldLength - newLength
|
|
82
82
|
]);
|
|
83
83
|
};
|
|
84
84
|
// 直接操作下标
|
|
@@ -86,13 +86,13 @@ function ArrayHandler(target, propertyKey, value, thisKey, callback) {
|
|
|
86
86
|
// 正常操作
|
|
87
87
|
if (index === target.length) {
|
|
88
88
|
return function() {
|
|
89
|
-
return callback.call(null, target, thisKey,
|
|
89
|
+
return callback.call(null, target, thisKey, "push", [
|
|
90
90
|
value
|
|
91
91
|
]);
|
|
92
92
|
};
|
|
93
93
|
} else {
|
|
94
94
|
return function() {
|
|
95
|
-
return callback.call(null, target, thisKey,
|
|
95
|
+
return callback.call(null, target, thisKey, "splice", [
|
|
96
96
|
index,
|
|
97
97
|
1,
|
|
98
98
|
value
|
|
@@ -124,9 +124,9 @@ function ArrayHandler(target, propertyKey, value, thisKey, callback) {
|
|
|
124
124
|
}
|
|
125
125
|
return Reflect.get(target, propertyKey, receiver);
|
|
126
126
|
},
|
|
127
|
-
set: function set(target, propertyKey,
|
|
127
|
+
set: function set(target, propertyKey, value, receiver) {
|
|
128
128
|
var reProxyState = function reProxyState(value) {
|
|
129
|
-
if (typeof value ===
|
|
129
|
+
if (typeof value === "object" && value !== null) {
|
|
130
130
|
// @ts-ignore
|
|
131
131
|
if (value[engineProxyFlag] !== true) {
|
|
132
132
|
return proxyState(value, callback, beforeSetCallback, concatKey);
|
|
@@ -137,19 +137,19 @@ function ArrayHandler(target, propertyKey, value, thisKey, callback) {
|
|
|
137
137
|
}
|
|
138
138
|
}
|
|
139
139
|
};
|
|
140
|
-
var newValue =
|
|
140
|
+
var newValue = value;
|
|
141
141
|
// @ts-ignore
|
|
142
142
|
var oldValue = target[propertyKey];
|
|
143
|
-
var concatKey = thisKey ===
|
|
144
|
-
var
|
|
145
|
-
newValue = (
|
|
143
|
+
var concatKey = thisKey === "" ? propertyKey : thisKey + "." + propertyKey;
|
|
144
|
+
var _reProxyState;
|
|
145
|
+
newValue = (_reProxyState = reProxyState(value)) !== null && _reProxyState !== void 0 ? _reProxyState : newValue;
|
|
146
146
|
// 先设置值,然后再进行触发回调,确保回调内拿到的是最新的值
|
|
147
147
|
var setResult;
|
|
148
148
|
// TODO 数组拦截操作需要重构,优化现有逻辑
|
|
149
149
|
// TODO 直接操作下标改动明细表时,没有对行数据进行checker
|
|
150
150
|
if (Array.isArray(target)) {
|
|
151
151
|
// 操作数组的时候,不需要使用拼接的thisKey,先判断执行的是否是违规操作,违规操作的话会报错,不允许继续执行,正常操作的话,返回一个回调函数,用于在值修改完之后触发
|
|
152
|
-
var nextHandler = ArrayHandler(target, propertyKey,
|
|
152
|
+
var nextHandler = ArrayHandler(target, propertyKey, value, thisKey, callback);
|
|
153
153
|
setResult = Reflect.set(target, propertyKey, newValue, receiver);
|
|
154
154
|
if (nextHandler) {
|
|
155
155
|
nextHandler();
|
|
@@ -171,7 +171,7 @@ function ArrayHandler(target, propertyKey, value, thisKey, callback) {
|
|
|
171
171
|
return true;
|
|
172
172
|
}
|
|
173
173
|
setResult = Reflect.set(target, propertyKey, newValue, receiver);
|
|
174
|
-
callback.call(null, target, concatKey,
|
|
174
|
+
callback.call(null, target, concatKey, value, oldValue);
|
|
175
175
|
}
|
|
176
176
|
return setResult;
|
|
177
177
|
}
|
|
@@ -184,15 +184,15 @@ function ArrayHandler(target, propertyKey, value, thisKey, callback) {
|
|
|
184
184
|
* @param beforeSetCallback
|
|
185
185
|
* @param prevKey 递归对象的key
|
|
186
186
|
* */ export function proxyState(state, callback, beforeSetCallback) {
|
|
187
|
-
var prevKey = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] :
|
|
187
|
+
var prevKey = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : "";
|
|
188
188
|
// 冻结的对象不需要再执行proxy,否则会报错
|
|
189
189
|
if (Object.isFrozen(state)) {
|
|
190
190
|
return state;
|
|
191
191
|
}
|
|
192
192
|
for(var key in state){
|
|
193
|
-
var concatKey = prevKey ===
|
|
193
|
+
var concatKey = prevKey === "" ? key : prevKey + "." + key;
|
|
194
194
|
var obj = state[key];
|
|
195
|
-
if (typeof obj ===
|
|
195
|
+
if (typeof obj === "object" && obj !== null) {
|
|
196
196
|
// @ts-ignore
|
|
197
197
|
state[key] = proxyState(obj, callback, beforeSetCallback, concatKey);
|
|
198
198
|
}
|
|
@@ -203,9 +203,9 @@ function flatInstanceForChildren(controls) {
|
|
|
203
203
|
var result = [];
|
|
204
204
|
controls.forEach(function(item) {
|
|
205
205
|
result.push(item);
|
|
206
|
-
if (item.controlType ===
|
|
206
|
+
if (item.controlType === "layout" || item.controlType === "wrap") {
|
|
207
207
|
var _result;
|
|
208
|
-
(_result = result).push.apply(_result,
|
|
208
|
+
(_result = result).push.apply(_result, _to_consumable_array(flatInstanceForChildren(item.children)));
|
|
209
209
|
}
|
|
210
210
|
});
|
|
211
211
|
return result;
|
|
@@ -214,9 +214,9 @@ function flatInstanceForChildren(controls) {
|
|
|
214
214
|
* 在flatInstance中通过key查找出对应的instance
|
|
215
215
|
* @param flatInstance 拍平的instance数组
|
|
216
216
|
* @param key 操作的数据在state的key - 可以是深层次的 subtable.0.input等
|
|
217
|
-
* */ export function findItem(flatInstance,
|
|
218
|
-
if (
|
|
219
|
-
var keys =
|
|
217
|
+
* */ export function findItem(flatInstance, key, instanceMap) {
|
|
218
|
+
if (key === "") return undefined;
|
|
219
|
+
var keys = key.split(".");
|
|
220
220
|
if (keys.length === 0) return undefined;
|
|
221
221
|
var oneKey = keys[0];
|
|
222
222
|
var otherKeys = keys.slice(1);
|
|
@@ -235,38 +235,39 @@ function flatInstanceForChildren(controls) {
|
|
|
235
235
|
var index = Number(key);
|
|
236
236
|
var isNotIndex = Number.isNaN(index);
|
|
237
237
|
if (isNotIndex && prevItem) {
|
|
238
|
-
var
|
|
239
|
-
var
|
|
238
|
+
var _prevItem, _flatChildren;
|
|
239
|
+
var flatChildren = ((_prevItem = prevItem) === null || _prevItem === void 0 ? void 0 : _prevItem.children) ? flatInstanceForChildren(prevItem.children) : undefined;
|
|
240
|
+
var findEndItem = (_flatChildren = flatChildren) === null || _flatChildren === void 0 ? void 0 : _flatChildren.find(function(item) {
|
|
240
241
|
return item.id === key;
|
|
241
242
|
});
|
|
242
243
|
// 最后一个key可能是值对象上边的key,比如金额的amount和currency,计算公式的result和unit,所以需要判断前一个控件是不是一个表单控件,是的话就返回最后一个表单控件
|
|
243
244
|
return findEndItem ? findEndItem : prevItem.controlType === CONTROL_BASE_TYPE.FORM ? prevItem : undefined;
|
|
244
245
|
} else {
|
|
245
|
-
var
|
|
246
|
-
var
|
|
246
|
+
var _prevItem_children, _prevItem1;
|
|
247
|
+
var _prevItem_children_index;
|
|
247
248
|
// 如果有children,则取children中对应的下标,没有的话一直返回prevItem
|
|
248
|
-
return (
|
|
249
|
+
return (_prevItem_children_index = (_prevItem1 = prevItem) === null || _prevItem1 === void 0 ? void 0 : (_prevItem_children = _prevItem1.children) === null || _prevItem_children === void 0 ? void 0 : _prevItem_children[index]) !== null && _prevItem_children_index !== void 0 ? _prevItem_children_index : prevItem;
|
|
249
250
|
}
|
|
250
251
|
}, initInstance);
|
|
251
252
|
}
|
|
252
253
|
function getArrayNewValue(type, args) {
|
|
253
254
|
if ([
|
|
254
|
-
|
|
255
|
-
|
|
255
|
+
"push",
|
|
256
|
+
"unshift"
|
|
256
257
|
].includes(type)) {
|
|
257
258
|
return args;
|
|
258
|
-
} else if (type ===
|
|
259
|
+
} else if (type === "splice") {
|
|
259
260
|
return args.slice(2);
|
|
260
261
|
}
|
|
261
262
|
return [];
|
|
262
263
|
}
|
|
263
264
|
function getArrayNewArgs(type, args, value) {
|
|
264
265
|
if ([
|
|
265
|
-
|
|
266
|
-
|
|
266
|
+
"push",
|
|
267
|
+
"unshift"
|
|
267
268
|
].includes(type)) {
|
|
268
269
|
return value;
|
|
269
|
-
} else if (type ===
|
|
270
|
+
} else if (type === "splice") {
|
|
270
271
|
return args.slice(0, 2).concat(value);
|
|
271
272
|
}
|
|
272
273
|
}
|
|
@@ -285,9 +286,9 @@ function getArrayNewArgs(type, args, value) {
|
|
|
285
286
|
var result;
|
|
286
287
|
var addValue = getArrayNewValue(key, args);
|
|
287
288
|
if (addValue.length) {
|
|
288
|
-
var
|
|
289
|
+
var _this_engineArrayBeforeSetCallbackFlag, _this;
|
|
289
290
|
// @ts-ignore
|
|
290
|
-
var newValue = (
|
|
291
|
+
var newValue = (_this_engineArrayBeforeSetCallbackFlag = (_this = this)[engineArrayBeforeSetCallbackFlag]) === null || _this_engineArrayBeforeSetCallbackFlag === void 0 ? void 0 : _this_engineArrayBeforeSetCallbackFlag.call(_this, // @ts-ignore
|
|
291
292
|
this[engineTargetKey], // @ts-ignore
|
|
292
293
|
this[engineProxyThisKey], addValue);
|
|
293
294
|
var newArgs = getArrayNewArgs(key, args, newValue);
|
|
@@ -301,8 +302,8 @@ function getArrayNewArgs(type, args, value) {
|
|
|
301
302
|
// @ts-ignore
|
|
302
303
|
result = oldApiHandler.apply(this, args);
|
|
303
304
|
}
|
|
304
|
-
typeof currentHandlerState.callback ===
|
|
305
|
-
currentHandlerState.type =
|
|
305
|
+
typeof currentHandlerState.callback === "function" && currentHandlerState.callback(key, args, result);
|
|
306
|
+
currentHandlerState.type = "";
|
|
306
307
|
currentHandlerState.args = [];
|
|
307
308
|
currentHandlerState.callback = emptyFn;
|
|
308
309
|
return result;
|
package/dist/esm/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from
|
|
2
|
-
export * from
|
|
3
|
-
export * from
|
|
1
|
+
export * from "./common";
|
|
2
|
+
export * from "./plugins";
|
|
3
|
+
export * from "./utils";
|