cnhis-design-vue 3.1.16-beta.0 → 3.1.16-beta.3
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/es/packages/big-table/index.d.ts +651 -1
- package/es/packages/big-table/src/BigTable.vue.d.ts +672 -28
- package/es/packages/big-table/src/BigTable.vue_vue_type_script_setup_true_lang.js +37 -14
- package/es/packages/big-table/src/bigTableProps.d.ts +4 -0
- package/es/packages/big-table/src/bigTableProps.js +2 -1
- package/es/packages/big-table/src/bigTableState.d.ts +2 -0
- package/es/packages/big-table/src/bigTableState.js +3 -1
- package/es/packages/big-table/src/components/edit-form/edit-time.js +1 -1
- package/es/packages/big-table/src/hooks/index.d.ts +9 -0
- package/es/packages/big-table/src/hooks/index.js +9 -0
- package/es/packages/big-table/src/hooks/useAnchor.d.ts +7 -0
- package/es/packages/big-table/src/hooks/useAnchor.js +41 -0
- package/es/packages/big-table/src/hooks/useColumnConfigAdaptor.js +24 -8
- package/es/packages/big-table/src/hooks/useEdit.js +1 -1
- package/es/packages/big-table/src/hooks/useEvent.d.ts +1 -1
- package/es/packages/big-table/src/hooks/useEvent.js +3 -2
- package/es/packages/button-print/index.d.ts +2 -2
- package/es/packages/button-print/src/ButtonPrint.vue.d.ts +2 -2
- package/es/packages/button-print/src/components/IdentityVerification.vue.d.ts +2 -2
- package/es/packages/drag-layout/index.d.ts +2 -2
- package/es/packages/drag-layout/src/DragLayout.vue.d.ts +2 -2
- package/es/packages/field-set/index.d.ts +1 -1
- package/es/packages/field-set/src/FieldSet.vue.d.ts +1 -1
- package/es/packages/form-config/index.d.ts +14 -32
- package/es/packages/form-config/src/FormConfig.vue.d.ts +14 -32
- package/es/packages/form-config/src/components/FormConfigCreator.vue.d.ts +6 -15
- package/es/packages/form-config/src/components/FormConfigEdit.js +1 -1
- package/es/packages/form-config/src/components/FormConfigEdit.vue.d.ts +8 -17
- package/es/packages/form-config/src/constants/index.d.ts +47 -13
- package/es/packages/form-config/src/constants/index.js +52 -14
- package/es/packages/form-config/src/hooks/index.d.ts +1 -0
- package/es/packages/form-config/src/hooks/index.js +1 -0
- package/es/packages/form-config/src/hooks/useConfigurationField.js +6 -43
- package/es/packages/form-config/src/hooks/usePresetRenderer.js +1 -1
- package/es/packages/form-render/index.d.ts +6 -15
- package/es/packages/form-render/src/FormRender.js +3 -4
- package/es/packages/form-render/src/FormRender.vue.d.ts +7 -16
- package/es/packages/form-render/src/components/renderer/cascader.js +1 -1
- package/es/packages/form-render/src/components/renderer/checkbox.js +1 -1
- package/es/packages/form-render/src/components/renderer/combination/index.js +2 -1
- package/es/packages/form-render/src/components/renderer/complex.js +1 -1
- package/es/packages/form-render/src/components/renderer/input.js +2 -1
- package/es/packages/form-render/src/components/renderer/inputNumber.js +2 -1
- package/es/packages/form-render/src/components/renderer/radio.js +1 -1
- package/es/packages/form-render/src/components/renderer/select.js +1 -1
- package/es/packages/form-render/src/components/renderer/slider.js +1 -1
- package/es/packages/form-render/src/components/renderer/switch.js +1 -1
- package/es/packages/form-render/src/components/renderer/textarea.js +1 -1
- package/es/packages/form-render/src/hooks/useBusinessBinding.d.ts +12 -9
- package/es/packages/form-render/src/hooks/useBusinessBinding.js +58 -58
- package/es/packages/form-render/src/hooks/useFieldListAdaptor.js +9 -2
- package/es/packages/form-render/src/hooks/useFormContext.d.ts +2 -1
- package/es/packages/form-render/src/hooks/useFormContext.js +2 -2
- package/es/packages/form-render/src/hooks/useTypeNormalize.js +1 -1
- package/es/packages/form-render/src/types/index.d.ts +0 -8
- package/es/packages/form-render/src/utils/business.d.ts +12 -0
- package/es/packages/form-render/src/utils/business.js +65 -0
- package/es/packages/form-render/src/utils/dom.d.ts +6 -0
- package/es/packages/form-render/src/utils/dom.js +14 -0
- package/es/packages/form-render/src/utils/index.d.ts +5 -25
- package/es/packages/form-render/src/utils/index.js +5 -137
- package/es/packages/form-render/src/utils/schema.d.ts +15 -0
- package/es/packages/form-render/src/utils/schema.js +83 -0
- package/es/packages/scale-view/src/hooks/scaleview-init.js +35 -35
- package/es/packages/scale-view/src/hooks/use-component.d.ts +7 -7
- package/es/packages/select-label/index.d.ts +10 -10
- package/es/packages/select-label/src/LabelFormContent.vue.d.ts +3 -3
- package/es/packages/select-label/src/SelectLabel.vue.d.ts +7 -7
- package/es/packages/shortcut-setter/index.d.ts +3445 -1
- package/es/packages/shortcut-setter/src/ShortcutSetter.js +5 -2
- package/es/packages/shortcut-setter/src/ShortcutSetter.vue.d.ts +3449 -1
- package/es/packages/time-line/index.d.ts +2 -2
- package/es/packages/time-line/src/TimeLine.vue.d.ts +2 -2
- package/package.json +1 -1
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { differenceInDays, differenceInMonths, differenceInYears, format } from 'date-fns';
|
|
2
|
+
import { FIELD_AGE_UNIT, FIELD_SEX_VALUE } from '../../../../packages/form-render/src/constants';
|
|
3
|
+
|
|
4
|
+
function parseIdCard(idCardNo) {
|
|
5
|
+
const parseInner = (certificateNo, idxSexStart, birthYearSpan) => {
|
|
6
|
+
const res = {};
|
|
7
|
+
const idxSex = 1 - certificateNo.substr(idxSexStart, 1) % 2;
|
|
8
|
+
res.sex = idxSex === 1 ? FIELD_SEX_VALUE.FEMALE : FIELD_SEX_VALUE.MALE;
|
|
9
|
+
const year = (birthYearSpan == 2 ? "19" : "") + certificateNo.substr(6, birthYearSpan);
|
|
10
|
+
const month = certificateNo.substr(6 + birthYearSpan, 2);
|
|
11
|
+
const day = certificateNo.substr(8 + birthYearSpan, 2);
|
|
12
|
+
res.birthday = year + "-" + month + "-" + day;
|
|
13
|
+
const d = new Date();
|
|
14
|
+
const monthFloor = d.getMonth() + 1 < parseInt(month, 10) || d.getMonth() + 1 == parseInt(month, 10) && d.getDate() < parseInt(day, 10) ? 1 : 0;
|
|
15
|
+
Object.assign(res, parseBirthday(res.birthday));
|
|
16
|
+
res.age = res.year = d.getFullYear() - parseInt(year, 10) - monthFloor;
|
|
17
|
+
return res;
|
|
18
|
+
};
|
|
19
|
+
return parseInner(idCardNo, idCardNo.length == 15 ? 14 : 16, idCardNo.length == 15 ? 2 : 4);
|
|
20
|
+
}
|
|
21
|
+
function isMonthType(format2) {
|
|
22
|
+
return format2 && format2.replace(/yyyy-MM/gi, "YYYY-MM") === "YYYY-MM";
|
|
23
|
+
}
|
|
24
|
+
function transformDateFormat(format2 = "") {
|
|
25
|
+
if (isMonthType(format2))
|
|
26
|
+
return "month";
|
|
27
|
+
return format2.includes("HH") ? "datetime" : "date";
|
|
28
|
+
}
|
|
29
|
+
function isIdCard(idCardNo) {
|
|
30
|
+
return /^\d{6}(((19|20)\d{2}(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[0-1])\d{3}(\d|x|X))|(\d{2}(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[0-1])\d{3}))$/.test(idCardNo);
|
|
31
|
+
}
|
|
32
|
+
function isMobile(mobile) {
|
|
33
|
+
return /^1(3\d|4[5-9]|5[0-35-9]|6[2567]|7[0-8]|8\d|9[0-35-9])\d{8}$/.test(mobile);
|
|
34
|
+
}
|
|
35
|
+
function parseBirthday(birthday) {
|
|
36
|
+
const result = {};
|
|
37
|
+
const d = new Date();
|
|
38
|
+
const birthDate = new Date(birthday);
|
|
39
|
+
result.day = differenceInDays(d, birthDate);
|
|
40
|
+
result.month = differenceInMonths(d, birthDate);
|
|
41
|
+
result.age = result.year = differenceInYears(d, birthDate);
|
|
42
|
+
return result;
|
|
43
|
+
}
|
|
44
|
+
function parseAge2Birthday(age, ageUnit, formatter = "yyyy-MM-dd") {
|
|
45
|
+
var _a;
|
|
46
|
+
const result = new Date();
|
|
47
|
+
const handlerMap = {
|
|
48
|
+
[FIELD_AGE_UNIT.MINUTE]: () => decreaseDate(result, "Minute", age),
|
|
49
|
+
[FIELD_AGE_UNIT.HOUR]: () => decreaseDate(result, "Hour", age),
|
|
50
|
+
[FIELD_AGE_UNIT.DAY]: () => decreaseDate(result, "Date", age),
|
|
51
|
+
[FIELD_AGE_UNIT.WEEK]: () => decreaseDate(result, "Date", age * 7),
|
|
52
|
+
[FIELD_AGE_UNIT.MONTH]: () => decreaseDate(result, "Month", age),
|
|
53
|
+
[FIELD_AGE_UNIT.YEAR]: () => decreaseDate(result, "FullYear", age)
|
|
54
|
+
};
|
|
55
|
+
(_a = handlerMap[ageUnit]) == null ? void 0 : _a.call(handlerMap);
|
|
56
|
+
return format(result, formatter);
|
|
57
|
+
function decreaseDate(date, type, num) {
|
|
58
|
+
date[`set${type}`](date[`get${type}`]() - num);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
function parseAge2FromContext(context) {
|
|
62
|
+
return context.day < 30 ? { ageUnit: FIELD_AGE_UNIT.DAY, age: context.day } : context.day < 365 ? { ageUnit: FIELD_AGE_UNIT.MONTH, age: context.month } : { ageUnit: FIELD_AGE_UNIT.YEAR, age: context.year };
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
export { isIdCard, isMobile, parseAge2Birthday, parseAge2FromContext, parseBirthday, parseIdCard, transformDateFormat };
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { WithNull } from '../../../../../es/src/types';
|
|
2
|
+
export declare function queryDecorator(key: string, wrapperElement: HTMLElement, formUUID: string): HTMLElement | null;
|
|
3
|
+
export declare function queryInput(decoratorElement?: WithNull<HTMLElement>): {
|
|
4
|
+
widgetElement: HTMLInputElement | null | undefined;
|
|
5
|
+
widgetElementList: HTMLInputElement[];
|
|
6
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { elementIdEscape } from '../../../../packages/form-render/src/utils/schema';
|
|
2
|
+
|
|
3
|
+
function queryDecorator(key, wrapperElement, formUUID) {
|
|
4
|
+
return wrapperElement.querySelector(elementIdEscape(`#${formUUID}-${key}`));
|
|
5
|
+
}
|
|
6
|
+
function queryInput(decoratorElement) {
|
|
7
|
+
var _a;
|
|
8
|
+
return {
|
|
9
|
+
widgetElement: decoratorElement == null ? void 0 : decoratorElement.querySelector("input"),
|
|
10
|
+
widgetElementList: Array.from((_a = decoratorElement == null ? void 0 : decoratorElement.querySelectorAll("input")) != null ? _a : [])
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export { queryDecorator, queryInput };
|
|
@@ -1,36 +1,16 @@
|
|
|
1
|
-
import { AnyObject, ArrayAble
|
|
2
|
-
import { ISchema } from '@formily/json-schema/esm/types';
|
|
3
|
-
import { GeneralField } from '@formily/core';
|
|
1
|
+
import { AnyObject, ArrayAble } from '../../../../../es/src/types';
|
|
4
2
|
import { FunctionalComponent, InjectionKey, VNode } from 'vue';
|
|
5
|
-
import {
|
|
3
|
+
import { FieldItem } from '../types';
|
|
4
|
+
export * from './business';
|
|
5
|
+
export * from './dom';
|
|
6
|
+
export * from './schema';
|
|
6
7
|
export declare function formRenderLog(message: string, type?: keyof Console): void;
|
|
7
8
|
export declare function arrayed<T>(maybeArray: T): T extends Array<any> ? T : [T];
|
|
8
|
-
export declare function assignUpdateValue(props: AnyObject, field: GeneralField): {
|
|
9
|
-
[x: string]: any;
|
|
10
|
-
};
|
|
11
|
-
export declare function transformDateFormat(format?: string): "date" | "datetime" | "month";
|
|
12
|
-
export declare function isIdCard(idCardNo: string): boolean;
|
|
13
|
-
export declare function isMobile(mobile: string): boolean;
|
|
14
|
-
export declare function parseBirthday(birthday: string): AgeContext;
|
|
15
9
|
export declare function mergeDeepProperties(target: AnyObject, fieldList: FieldItem[], traverseProperties?: string[], property?: string, targetProperty?: string): AnyObject;
|
|
16
|
-
export declare function parseIdCard(idCardNo: string): IdCardParseInfo;
|
|
17
10
|
export declare function injectOrProvide<T>(key: InjectionKey<T>, creator: () => T): T;
|
|
18
11
|
export declare function parseNumberFromMaybeString(value: unknown): unknown;
|
|
19
|
-
export declare function traverseDependKey(dependKeys: DependKeyType, handler: {
|
|
20
|
-
(dependKey: string, valueKey: string, required?: boolean): void;
|
|
21
|
-
}): void;
|
|
22
|
-
export declare function traverseSchema(schema: ISchema, handler: (_s: ISchema) => void): void;
|
|
23
12
|
export declare function uuidGenerator(): string;
|
|
24
13
|
export declare function createSlot(renderer: unknown, props: AnyObject): Record<string, () => ArrayAble<VNode>> | {
|
|
25
14
|
default(): any;
|
|
26
15
|
};
|
|
27
|
-
export declare function queryDecorator(key: string, wrapperElement: HTMLElement, formUUID: string): HTMLElement | null;
|
|
28
|
-
export declare function queryInput(decoratorElement?: WithNull<HTMLElement>): {
|
|
29
|
-
widgetElement: HTMLInputElement | null | undefined;
|
|
30
|
-
widgetElementList: HTMLInputElement[];
|
|
31
|
-
};
|
|
32
|
-
export declare function getParentLinebar(key: string, fieldList: FieldItem[]): WithNull<string>;
|
|
33
|
-
export declare function elementIdEscape(id: string): string;
|
|
34
|
-
export declare function createLinebarId(id: string): string;
|
|
35
|
-
export declare function fieldKeyEscape(fieldList: FieldItem[]): string;
|
|
36
16
|
export declare function createInputSlot(props: AnyObject): import("vue").ComputedRef<Record<string, FunctionalComponent<{}, {}>>>;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { inject, provide, computed, createVNode, Fragment } from 'vue';
|
|
2
2
|
import { isObject } from '@vue/shared';
|
|
3
|
-
import { isNumber, isString,
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
3
|
+
import { isNumber, isString, isFunction } from 'lodash-es';
|
|
4
|
+
export { isIdCard, isMobile, parseAge2Birthday, parseAge2FromContext, parseBirthday, parseIdCard, transformDateFormat } from './business.js';
|
|
5
|
+
export { queryDecorator, queryInput } from './dom.js';
|
|
6
|
+
export { assignUpdateValue, createLinebarId, elementIdEscape, fieldKeyEscape, getParentLinebar, traverseDependKey, traverseSchema } from './schema.js';
|
|
7
7
|
|
|
8
8
|
function formRenderLog(message, type = "log") {
|
|
9
9
|
console[type](`[FormRender]: ${message}`);
|
|
@@ -13,42 +13,6 @@ function arrayed(maybeArray) {
|
|
|
13
13
|
return maybeArray;
|
|
14
14
|
return [maybeArray];
|
|
15
15
|
}
|
|
16
|
-
function assignUpdateValue(props, field) {
|
|
17
|
-
const _props = {
|
|
18
|
-
...props
|
|
19
|
-
};
|
|
20
|
-
if (isField(field)) {
|
|
21
|
-
Object.assign(_props, {
|
|
22
|
-
"onUpdate:value"(value) {
|
|
23
|
-
field.setValue(value);
|
|
24
|
-
}
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
return _props;
|
|
28
|
-
}
|
|
29
|
-
function isMonthType(format) {
|
|
30
|
-
return format && format.replace(/yyyy-MM/gi, "YYYY-MM") === "YYYY-MM";
|
|
31
|
-
}
|
|
32
|
-
function transformDateFormat(format = "") {
|
|
33
|
-
if (isMonthType(format))
|
|
34
|
-
return "month";
|
|
35
|
-
return format.includes("HH") ? "datetime" : "date";
|
|
36
|
-
}
|
|
37
|
-
function isIdCard(idCardNo) {
|
|
38
|
-
return /^\d{6}(((19|20)\d{2}(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[0-1])\d{3}(\d|x|X))|(\d{2}(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[0-1])\d{3}))$/.test(idCardNo);
|
|
39
|
-
}
|
|
40
|
-
function isMobile(mobile) {
|
|
41
|
-
return /^1(3\d|4[5-9]|5[0-35-9]|6[2567]|7[0-8]|8\d|9[0-35-9])\d{8}$/.test(mobile);
|
|
42
|
-
}
|
|
43
|
-
function parseBirthday(birthday) {
|
|
44
|
-
const result = {};
|
|
45
|
-
const d = new Date();
|
|
46
|
-
const birthDate = new Date(birthday);
|
|
47
|
-
result.day = differenceInDays(d, birthDate);
|
|
48
|
-
result.month = differenceInMonths(d, birthDate);
|
|
49
|
-
result.age = result.year = differenceInYears(d, birthDate);
|
|
50
|
-
return result;
|
|
51
|
-
}
|
|
52
16
|
function mergeDeepProperties(target, fieldList, traverseProperties = ["children", "properties", "suffixConfig"], property = "val_key", targetProperty = "default_val") {
|
|
53
17
|
function traverse(_target, _fieldList) {
|
|
54
18
|
_fieldList.forEach((field) => {
|
|
@@ -76,23 +40,6 @@ function mergeDeepProperties(target, fieldList, traverseProperties = ["children"
|
|
|
76
40
|
return field[targetProperty];
|
|
77
41
|
}
|
|
78
42
|
}
|
|
79
|
-
function parseIdCard(idCardNo) {
|
|
80
|
-
const parseInner = (certificateNo, idxSexStart, birthYearSpan) => {
|
|
81
|
-
const res = {};
|
|
82
|
-
const idxSex = 1 - certificateNo.substr(idxSexStart, 1) % 2;
|
|
83
|
-
res.sex = idxSex === 1 ? FIELD_SEX_VALUE.FEMALE : FIELD_SEX_VALUE.MALE;
|
|
84
|
-
const year = (birthYearSpan == 2 ? "19" : "") + certificateNo.substr(6, birthYearSpan);
|
|
85
|
-
const month = certificateNo.substr(6 + birthYearSpan, 2);
|
|
86
|
-
const day = certificateNo.substr(8 + birthYearSpan, 2);
|
|
87
|
-
res.birthday = year + "-" + month + "-" + day;
|
|
88
|
-
const d = new Date();
|
|
89
|
-
const monthFloor = d.getMonth() + 1 < parseInt(month, 10) || d.getMonth() + 1 == parseInt(month, 10) && d.getDate() < parseInt(day, 10) ? 1 : 0;
|
|
90
|
-
Object.assign(res, parseBirthday(res.birthday));
|
|
91
|
-
res.age = res.year = d.getFullYear() - parseInt(year, 10) - monthFloor;
|
|
92
|
-
return res;
|
|
93
|
-
};
|
|
94
|
-
return parseInner(idCardNo, idCardNo.length == 15 ? 14 : 16, idCardNo.length == 15 ? 2 : 4);
|
|
95
|
-
}
|
|
96
43
|
function injectOrProvide(key, creator) {
|
|
97
44
|
let injected = inject(key, null);
|
|
98
45
|
if (!injected) {
|
|
@@ -108,49 +55,6 @@ function parseNumberFromMaybeString(value) {
|
|
|
108
55
|
return +value;
|
|
109
56
|
return value;
|
|
110
57
|
}
|
|
111
|
-
function traverseDependKey(dependKeys, handler) {
|
|
112
|
-
if (!dependKeys)
|
|
113
|
-
return;
|
|
114
|
-
createDependKeyMap().forEach((valueKey, dependKey) => {
|
|
115
|
-
if (isString(valueKey))
|
|
116
|
-
return handler(dependKey, valueKey);
|
|
117
|
-
handler(dependKey, valueKey.key, valueKey.required);
|
|
118
|
-
});
|
|
119
|
-
Object.entries(createDependKeyMap()).forEach(([dependKey, valueKey]) => {
|
|
120
|
-
handler(dependKey, valueKey);
|
|
121
|
-
});
|
|
122
|
-
function createDependKeyMap() {
|
|
123
|
-
const result = /* @__PURE__ */ new Map();
|
|
124
|
-
if (isArray(dependKeys)) {
|
|
125
|
-
dependKeys.forEach((k) => {
|
|
126
|
-
var _a;
|
|
127
|
-
if (isObject(k)) {
|
|
128
|
-
result.set(k.paramName, {
|
|
129
|
-
key: (_a = k.paramName) != null ? _a : k.paramValue,
|
|
130
|
-
required: k.required
|
|
131
|
-
});
|
|
132
|
-
} else {
|
|
133
|
-
result.set(k, k);
|
|
134
|
-
}
|
|
135
|
-
});
|
|
136
|
-
} else if (isObject(dependKeys)) {
|
|
137
|
-
Object.entries(dependKeys).forEach(([k, v]) => {
|
|
138
|
-
result.set(k, v);
|
|
139
|
-
});
|
|
140
|
-
} else if (isString(dependKeys)) {
|
|
141
|
-
result.set(dependKeys, dependKeys);
|
|
142
|
-
}
|
|
143
|
-
return result;
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
function traverseSchema(schema, handler) {
|
|
147
|
-
handler(schema);
|
|
148
|
-
if (isObject(schema.properties)) {
|
|
149
|
-
Object.values(schema.properties).forEach((_s) => {
|
|
150
|
-
traverseSchema(_s, handler);
|
|
151
|
-
});
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
58
|
function uuidGenerator() {
|
|
155
59
|
return "key" + "xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g, function(c) {
|
|
156
60
|
const r = Math.random() * 16 | 0, v = c == "x" ? r : r & 3 | 8;
|
|
@@ -171,42 +75,6 @@ function createSlot(renderer, props) {
|
|
|
171
75
|
}
|
|
172
76
|
};
|
|
173
77
|
}
|
|
174
|
-
function queryDecorator(key, wrapperElement, formUUID) {
|
|
175
|
-
return wrapperElement.querySelector(elementIdEscape(`#${formUUID}-${key}`));
|
|
176
|
-
}
|
|
177
|
-
function queryInput(decoratorElement) {
|
|
178
|
-
var _a;
|
|
179
|
-
return {
|
|
180
|
-
widgetElement: decoratorElement == null ? void 0 : decoratorElement.querySelector("input"),
|
|
181
|
-
widgetElementList: Array.from((_a = decoratorElement == null ? void 0 : decoratorElement.querySelectorAll("input")) != null ? _a : [])
|
|
182
|
-
};
|
|
183
|
-
}
|
|
184
|
-
function getParentLinebar(key, fieldList) {
|
|
185
|
-
let result = null;
|
|
186
|
-
for (const fieldItem of fieldList) {
|
|
187
|
-
if (fieldItem.val_key === key) {
|
|
188
|
-
if (isLinebar(fieldItem))
|
|
189
|
-
result = null;
|
|
190
|
-
break;
|
|
191
|
-
}
|
|
192
|
-
if (isLinebar(fieldItem)) {
|
|
193
|
-
result = fieldItem.val_key;
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
return result;
|
|
197
|
-
function isLinebar(field) {
|
|
198
|
-
return field.html_type === "LINEBAR";
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
function elementIdEscape(id) {
|
|
202
|
-
return id.replace(".", "-");
|
|
203
|
-
}
|
|
204
|
-
function createLinebarId(id) {
|
|
205
|
-
return elementIdEscape(`id-${id}`);
|
|
206
|
-
}
|
|
207
|
-
function fieldKeyEscape(fieldList) {
|
|
208
|
-
return fieldList.map((f) => f.val_key).join("-").replace(/[.]/g, "_");
|
|
209
|
-
}
|
|
210
78
|
function createInputSlot(props) {
|
|
211
79
|
return computed(() => {
|
|
212
80
|
const res = {};
|
|
@@ -220,4 +88,4 @@ function createInputSlot(props) {
|
|
|
220
88
|
});
|
|
221
89
|
}
|
|
222
90
|
|
|
223
|
-
export { arrayed,
|
|
91
|
+
export { arrayed, createInputSlot, createSlot, formRenderLog, injectOrProvide, mergeDeepProperties, parseNumberFromMaybeString, uuidGenerator };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { AnyObject, WithNull } from '../../../../../es/src/types';
|
|
2
|
+
import { GeneralField } from '@formily/core';
|
|
3
|
+
import { ISchema } from '@formily/json-schema/esm/types';
|
|
4
|
+
import { DependKeyType, FieldItem } from '../../../../../es/packages/form-render';
|
|
5
|
+
export declare function traverseSchema(schema: ISchema, handler: (_s: ISchema) => void): void;
|
|
6
|
+
export declare function fieldKeyEscape(fieldList: FieldItem[]): string;
|
|
7
|
+
export declare function elementIdEscape(id: string): string;
|
|
8
|
+
export declare function createLinebarId(id: string): string;
|
|
9
|
+
export declare function traverseDependKey(dependKeys: DependKeyType, handler: {
|
|
10
|
+
(dependKey: string, valueKey: string, required?: boolean): void;
|
|
11
|
+
}): void;
|
|
12
|
+
export declare function getParentLinebar(key: string, fieldList: FieldItem[]): WithNull<string>;
|
|
13
|
+
export declare function assignUpdateValue(props: AnyObject, field: GeneralField): {
|
|
14
|
+
[x: string]: any;
|
|
15
|
+
};
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { isField } from '@formily/core';
|
|
2
|
+
import { isObject } from '@vue/shared';
|
|
3
|
+
import { isString, isArray } from 'lodash-es';
|
|
4
|
+
|
|
5
|
+
function traverseSchema(schema, handler) {
|
|
6
|
+
handler(schema);
|
|
7
|
+
if (isObject(schema.properties)) {
|
|
8
|
+
Object.values(schema.properties).forEach((_s) => {
|
|
9
|
+
traverseSchema(_s, handler);
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
function fieldKeyEscape(fieldList) {
|
|
14
|
+
return fieldList.map((f) => f.val_key).join("-").replace(/[.]/g, "_");
|
|
15
|
+
}
|
|
16
|
+
function elementIdEscape(id) {
|
|
17
|
+
return id.replace(".", "-");
|
|
18
|
+
}
|
|
19
|
+
function createLinebarId(id) {
|
|
20
|
+
return elementIdEscape(`id-${id}`);
|
|
21
|
+
}
|
|
22
|
+
function traverseDependKey(dependKeys, handler) {
|
|
23
|
+
if (!dependKeys)
|
|
24
|
+
return;
|
|
25
|
+
createDependKeyMap().forEach((valueKey, dependKey) => {
|
|
26
|
+
if (isString(valueKey))
|
|
27
|
+
return handler(dependKey, valueKey);
|
|
28
|
+
handler(dependKey, valueKey.key, valueKey.required);
|
|
29
|
+
});
|
|
30
|
+
Object.entries(createDependKeyMap()).forEach(([dependKey, valueKey]) => {
|
|
31
|
+
handler(dependKey, valueKey);
|
|
32
|
+
});
|
|
33
|
+
function createDependKeyMap() {
|
|
34
|
+
const result = /* @__PURE__ */ new Map();
|
|
35
|
+
if (isArray(dependKeys)) {
|
|
36
|
+
dependKeys.forEach((k) => {
|
|
37
|
+
var _a;
|
|
38
|
+
if (isObject(k)) {
|
|
39
|
+
result.set(k.paramName, { key: (_a = k.paramName) != null ? _a : k.paramValue, required: k.required });
|
|
40
|
+
} else {
|
|
41
|
+
result.set(k, k);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
} else if (isObject(dependKeys)) {
|
|
45
|
+
Object.entries(dependKeys).forEach(([k, v]) => {
|
|
46
|
+
result.set(k, v);
|
|
47
|
+
});
|
|
48
|
+
} else if (isString(dependKeys)) {
|
|
49
|
+
result.set(dependKeys, dependKeys);
|
|
50
|
+
}
|
|
51
|
+
return result;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
function getParentLinebar(key, fieldList) {
|
|
55
|
+
let result = null;
|
|
56
|
+
for (const fieldItem of fieldList) {
|
|
57
|
+
if (fieldItem.val_key === key) {
|
|
58
|
+
if (isLinebar(fieldItem))
|
|
59
|
+
result = null;
|
|
60
|
+
break;
|
|
61
|
+
}
|
|
62
|
+
if (isLinebar(fieldItem)) {
|
|
63
|
+
result = fieldItem.val_key;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return result;
|
|
67
|
+
function isLinebar(field) {
|
|
68
|
+
return field.html_type === "LINEBAR";
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
function assignUpdateValue(props, field) {
|
|
72
|
+
const _props = { ...props };
|
|
73
|
+
if (isField(field)) {
|
|
74
|
+
Object.assign(_props, {
|
|
75
|
+
"onUpdate:value"(value) {
|
|
76
|
+
field.setValue(value);
|
|
77
|
+
}
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
return _props;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
export { assignUpdateValue, createLinebarId, elementIdEscape, fieldKeyEscape, getParentLinebar, traverseDependKey, traverseSchema };
|
|
@@ -14,7 +14,7 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
14
14
|
const { formatRules } = ScaleViewValidate(props, state, config);
|
|
15
15
|
const { nextLogicEvent } = useEvent(props, state);
|
|
16
16
|
const setEvaluateStartTime = (evaluateResultSetting) => {
|
|
17
|
-
|
|
17
|
+
const evaluateStartTime = evaluateResultSetting == null ? void 0 : evaluateResultSetting.evaluateStartTime;
|
|
18
18
|
if (!evaluateStartTime)
|
|
19
19
|
return;
|
|
20
20
|
if (!vexutils.isValidDate(new Date(evaluateStartTime)) && vexutils.isValidDate(new Date(Number(evaluateStartTime)))) {
|
|
@@ -57,12 +57,12 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
57
57
|
state.showEvaluateCountdownWrap = true;
|
|
58
58
|
return;
|
|
59
59
|
}
|
|
60
|
-
|
|
60
|
+
const { evaluateResultSetting = {} } = state.config;
|
|
61
61
|
if (!evaluateResultSetting || !Object.keys(evaluateResultSetting).length)
|
|
62
62
|
return;
|
|
63
63
|
state.showEvaluateCountdownWrap = true;
|
|
64
|
-
|
|
65
|
-
|
|
64
|
+
const { evaluateStartTime } = evaluateResultSetting;
|
|
65
|
+
const { evaluateName } = ((_a = state.originConfig) == null ? void 0 : _a.evaluateResultSetting) || {};
|
|
66
66
|
if (!evaluateStartTime) {
|
|
67
67
|
state.showEvaluatePage = true;
|
|
68
68
|
return;
|
|
@@ -76,7 +76,7 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
76
76
|
const initForm = (data) => {
|
|
77
77
|
var _a;
|
|
78
78
|
let { list = [], map = {}, isFinished = false } = data;
|
|
79
|
-
|
|
79
|
+
const curUrl = handleFrontAddress(list);
|
|
80
80
|
if (curUrl) {
|
|
81
81
|
window.location.href = curUrl;
|
|
82
82
|
return;
|
|
@@ -112,13 +112,13 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
112
112
|
}
|
|
113
113
|
state.originConfig = JSON.parse(JSON.stringify(state.config));
|
|
114
114
|
if (props.params && Object.keys(props.params).length) {
|
|
115
|
-
|
|
115
|
+
const res = handleBtnParamsEvaluate(props.params);
|
|
116
116
|
res && Object.keys(res).length && (state.paramsEvaluate = res);
|
|
117
117
|
}
|
|
118
118
|
handleEvaluateParams(state.config.evaluateResultSetting);
|
|
119
119
|
handleShowEvaluate();
|
|
120
120
|
state.defaultFormArray = JSON.parse(JSON.stringify(list));
|
|
121
|
-
|
|
121
|
+
const filterArr = state.filterArr;
|
|
122
122
|
list = list.filter((v) => !filterArr.includes(v.type));
|
|
123
123
|
state.formArray = formatArray(list || []);
|
|
124
124
|
state.form = defaultFormValue(state.formArray);
|
|
@@ -128,13 +128,13 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
128
128
|
state.hasFrontAddress = false;
|
|
129
129
|
};
|
|
130
130
|
const replaceConditionItem = (options, value) => {
|
|
131
|
-
|
|
131
|
+
const matchOption = options.find((v) => value === v.value);
|
|
132
132
|
if (!matchOption)
|
|
133
133
|
return value;
|
|
134
134
|
return matchOption.key;
|
|
135
135
|
};
|
|
136
136
|
const isRadioOrCheckBox = (options, type) => {
|
|
137
|
-
|
|
137
|
+
const typeArr = ["RADIO_BLOCK", "CHECKBOX_BLOCK"];
|
|
138
138
|
if (!typeArr.includes(type))
|
|
139
139
|
return;
|
|
140
140
|
if (!options)
|
|
@@ -147,10 +147,10 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
147
147
|
return true;
|
|
148
148
|
};
|
|
149
149
|
const handLenextLogic = (item) => {
|
|
150
|
-
|
|
150
|
+
const { nextLogic, options, type } = item || {};
|
|
151
151
|
if (!nextLogic || !isRadioOrCheckBox(options, type))
|
|
152
152
|
return;
|
|
153
|
-
|
|
153
|
+
const { condition } = nextLogic || {};
|
|
154
154
|
if (!condition || !condition.length)
|
|
155
155
|
return;
|
|
156
156
|
condition.forEach((c) => {
|
|
@@ -166,12 +166,12 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
166
166
|
});
|
|
167
167
|
};
|
|
168
168
|
const handleRelationLogic = (list, item) => {
|
|
169
|
-
|
|
170
|
-
|
|
169
|
+
const relationLogicObj = vexutils.isString(item.relationLogic) ? JSON.parse(item.relationLogic) : item.relationLogic;
|
|
170
|
+
const { condition } = relationLogicObj || {};
|
|
171
171
|
if (!condition || !condition.length)
|
|
172
172
|
return;
|
|
173
173
|
condition.forEach((c) => {
|
|
174
|
-
|
|
174
|
+
const matchItem = list.find((f) => f.seq == c.subject_seq);
|
|
175
175
|
if (!matchItem)
|
|
176
176
|
return;
|
|
177
177
|
if (!isRadioOrCheckBox(matchItem.options, matchItem.type))
|
|
@@ -192,10 +192,10 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
192
192
|
var _a, _b;
|
|
193
193
|
if (!list || !list.length)
|
|
194
194
|
return;
|
|
195
|
-
|
|
195
|
+
const query = handleQueryParams();
|
|
196
196
|
if ((props == null ? void 0 : props.noBtn) || (query == null ? void 0 : query.noBtn))
|
|
197
197
|
return;
|
|
198
|
-
|
|
198
|
+
const matchItem = list.find((item) => item.type === "FRONT_ADDRESS");
|
|
199
199
|
if (!matchItem || !Object.keys(matchItem).length)
|
|
200
200
|
return;
|
|
201
201
|
let setting;
|
|
@@ -206,22 +206,22 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
206
206
|
return;
|
|
207
207
|
if ((query == null ? void 0 : query.redirect) == 1 || ((_a = props.params) == null ? void 0 : _a.redirect) == 1 || query.isEdit == 3 || ((_b = props.params) == null ? void 0 : _b.isEdit) == 3)
|
|
208
208
|
return;
|
|
209
|
-
|
|
209
|
+
const { frontAddress } = setting;
|
|
210
210
|
if (frontAddress) {
|
|
211
|
-
|
|
211
|
+
const urlHref = window.location.href;
|
|
212
212
|
let preStr = "?";
|
|
213
213
|
if (frontAddress.includes("?")) {
|
|
214
214
|
preStr = "&";
|
|
215
215
|
}
|
|
216
|
-
|
|
216
|
+
const curUrl = `${frontAddress}${preStr}redirect_url=${encodeURIComponent(urlHref)}`;
|
|
217
217
|
return curUrl;
|
|
218
218
|
}
|
|
219
219
|
};
|
|
220
220
|
const handleBtnParamsEvaluate = (params) => {
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
for (
|
|
224
|
-
|
|
221
|
+
const defaultVariable = ["evaname", "evadesc", "evast", "evadur", "evaan"];
|
|
222
|
+
const res = {};
|
|
223
|
+
for (const key in params) {
|
|
224
|
+
const value = params[key];
|
|
225
225
|
if (defaultVariable.includes(key) && value) {
|
|
226
226
|
res[key] = value;
|
|
227
227
|
}
|
|
@@ -235,18 +235,18 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
235
235
|
if (hasparamsEvaluate.value) {
|
|
236
236
|
query = state.paramsEvaluate;
|
|
237
237
|
}
|
|
238
|
-
|
|
238
|
+
const obj = {
|
|
239
239
|
evaluateName: "evaname",
|
|
240
240
|
evaluateExplain: "evadesc",
|
|
241
241
|
evaluateStartTime: "evast",
|
|
242
242
|
evaluateTime: "evadur",
|
|
243
243
|
evaluateAnswer: "evaan"
|
|
244
244
|
};
|
|
245
|
-
for (
|
|
246
|
-
|
|
247
|
-
|
|
245
|
+
for (const key in evaluateResultSetting) {
|
|
246
|
+
const value = evaluateResultSetting[key];
|
|
247
|
+
const isParseKey = value && key != "evaluateAnswer" && typeof value === "string" && value.includes("${");
|
|
248
248
|
if (isParseKey) {
|
|
249
|
-
|
|
249
|
+
const parseValue = value.replace(/\$\{([^}]+)\}/g, (_v, $1) => {
|
|
250
250
|
let param;
|
|
251
251
|
if ($1.startsWith("form.")) {
|
|
252
252
|
param = query[$1.split(".")[1]];
|
|
@@ -263,8 +263,8 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
263
263
|
}
|
|
264
264
|
}
|
|
265
265
|
if (hasDefault.value) {
|
|
266
|
-
|
|
267
|
-
|
|
266
|
+
const defaultVariable = ["evaname", "evadesc", "evast", "evadur", "evaan"];
|
|
267
|
+
const defObj = {
|
|
268
268
|
evaname: "evaluateName",
|
|
269
269
|
evadesc: "evaluateExplain",
|
|
270
270
|
evast: "evaluateStartTime",
|
|
@@ -272,7 +272,7 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
272
272
|
evaan: "evaluateAnswer"
|
|
273
273
|
};
|
|
274
274
|
defaultVariable.forEach((item) => {
|
|
275
|
-
|
|
275
|
+
const key = defObj[item];
|
|
276
276
|
if (!evaluateResultSetting[key]) {
|
|
277
277
|
let val = query[item];
|
|
278
278
|
if (item == "evaan") {
|
|
@@ -354,12 +354,12 @@ const ScaleViewInit = (props, state, emit, config) => {
|
|
|
354
354
|
defValue = item.dbValue;
|
|
355
355
|
} else {
|
|
356
356
|
if (((_a = item.setting) == null ? void 0 : _a.defValType) == 3) {
|
|
357
|
-
|
|
357
|
+
const urlKey = (_c = (_b = item.setting) == null ? void 0 : _b.outDefaultValue) == null ? void 0 : _c.urlKey;
|
|
358
358
|
if (urlKey) {
|
|
359
|
-
|
|
359
|
+
const list = urlKey.split(",");
|
|
360
360
|
if (list.length > 1) {
|
|
361
|
-
|
|
362
|
-
|
|
361
|
+
const val2 = list.map((l) => {
|
|
362
|
+
const tempV = getQueryVariable(l, state, props.params);
|
|
363
363
|
if (tempV)
|
|
364
364
|
return decodeURIComponent(tempV);
|
|
365
365
|
return null;
|
|
@@ -1471,7 +1471,7 @@ export declare const componentMap: {
|
|
|
1471
1471
|
type: BooleanConstructor;
|
|
1472
1472
|
default: boolean;
|
|
1473
1473
|
};
|
|
1474
|
-
preset: import("vue").PropType<"dialog" | "
|
|
1474
|
+
preset: import("vue").PropType<"dialog" | "card" | "confirm">;
|
|
1475
1475
|
to: import("vue").PropType<string | HTMLElement>;
|
|
1476
1476
|
displayDirective: {
|
|
1477
1477
|
type: import("vue").PropType<"show" | "if">;
|
|
@@ -2433,7 +2433,7 @@ export declare const componentMap: {
|
|
|
2433
2433
|
type: BooleanConstructor;
|
|
2434
2434
|
default: boolean;
|
|
2435
2435
|
};
|
|
2436
|
-
preset: import("vue").PropType<"dialog" | "
|
|
2436
|
+
preset: import("vue").PropType<"dialog" | "card" | "confirm">;
|
|
2437
2437
|
to: import("vue").PropType<string | HTMLElement>;
|
|
2438
2438
|
displayDirective: {
|
|
2439
2439
|
type: import("vue").PropType<"show" | "if">;
|
|
@@ -3329,7 +3329,7 @@ export declare const componentMap: {
|
|
|
3329
3329
|
closeOnEsc: boolean;
|
|
3330
3330
|
}>;
|
|
3331
3331
|
NSpace: import("vue").DefineComponent<{
|
|
3332
|
-
readonly align: import("vue").PropType<"
|
|
3332
|
+
readonly align: import("vue").PropType<"start" | "end" | "center" | "stretch" | "baseline" | "flex-end" | "flex-start">;
|
|
3333
3333
|
readonly justify: {
|
|
3334
3334
|
readonly type: import("vue").PropType<import("naive-ui/es/space/src/Space").Justify>;
|
|
3335
3335
|
readonly default: "start";
|
|
@@ -3377,7 +3377,7 @@ export declare const componentMap: {
|
|
|
3377
3377
|
vertical: number;
|
|
3378
3378
|
}>;
|
|
3379
3379
|
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, Record<string, any>, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
3380
|
-
readonly align: import("vue").PropType<"
|
|
3380
|
+
readonly align: import("vue").PropType<"start" | "end" | "center" | "stretch" | "baseline" | "flex-end" | "flex-start">;
|
|
3381
3381
|
readonly justify: {
|
|
3382
3382
|
readonly type: import("vue").PropType<import("naive-ui/es/space/src/Space").Justify>;
|
|
3383
3383
|
readonly default: "start";
|
|
@@ -3548,7 +3548,7 @@ export declare const componentMap: {
|
|
|
3548
3548
|
readonly default: "bar";
|
|
3549
3549
|
};
|
|
3550
3550
|
readonly closable: BooleanConstructor;
|
|
3551
|
-
readonly justifyContent: import("vue").PropType<"
|
|
3551
|
+
readonly justifyContent: import("vue").PropType<"start" | "end" | "space-around" | "space-between" | "space-evenly" | "center">;
|
|
3552
3552
|
readonly size: {
|
|
3553
3553
|
readonly type: import("vue").PropType<"small" | "medium" | "large">;
|
|
3554
3554
|
readonly default: "medium";
|
|
@@ -3824,7 +3824,7 @@ export declare const componentMap: {
|
|
|
3824
3824
|
addTabFixed: import("vue").Ref<boolean>;
|
|
3825
3825
|
tabWrapperStyle: import("vue").ComputedRef<{
|
|
3826
3826
|
display: string;
|
|
3827
|
-
justifyContent: "
|
|
3827
|
+
justifyContent: "start" | "end" | "space-around" | "space-between" | "space-evenly" | "center";
|
|
3828
3828
|
} | undefined>;
|
|
3829
3829
|
handleNavResize: import("lodash").DebouncedFunc<(entry: ResizeObserverEntry) => void>;
|
|
3830
3830
|
mergedSize: import("vue").ComputedRef<"small" | "medium" | "large">;
|
|
@@ -3880,7 +3880,7 @@ export declare const componentMap: {
|
|
|
3880
3880
|
readonly default: "bar";
|
|
3881
3881
|
};
|
|
3882
3882
|
readonly closable: BooleanConstructor;
|
|
3883
|
-
readonly justifyContent: import("vue").PropType<"
|
|
3883
|
+
readonly justifyContent: import("vue").PropType<"start" | "end" | "space-around" | "space-between" | "space-evenly" | "center">;
|
|
3884
3884
|
readonly size: {
|
|
3885
3885
|
readonly type: import("vue").PropType<"small" | "medium" | "large">;
|
|
3886
3886
|
readonly default: "medium";
|