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.
Files changed (74) hide show
  1. package/es/packages/big-table/index.d.ts +651 -1
  2. package/es/packages/big-table/src/BigTable.vue.d.ts +672 -28
  3. package/es/packages/big-table/src/BigTable.vue_vue_type_script_setup_true_lang.js +37 -14
  4. package/es/packages/big-table/src/bigTableProps.d.ts +4 -0
  5. package/es/packages/big-table/src/bigTableProps.js +2 -1
  6. package/es/packages/big-table/src/bigTableState.d.ts +2 -0
  7. package/es/packages/big-table/src/bigTableState.js +3 -1
  8. package/es/packages/big-table/src/components/edit-form/edit-time.js +1 -1
  9. package/es/packages/big-table/src/hooks/index.d.ts +9 -0
  10. package/es/packages/big-table/src/hooks/index.js +9 -0
  11. package/es/packages/big-table/src/hooks/useAnchor.d.ts +7 -0
  12. package/es/packages/big-table/src/hooks/useAnchor.js +41 -0
  13. package/es/packages/big-table/src/hooks/useColumnConfigAdaptor.js +24 -8
  14. package/es/packages/big-table/src/hooks/useEdit.js +1 -1
  15. package/es/packages/big-table/src/hooks/useEvent.d.ts +1 -1
  16. package/es/packages/big-table/src/hooks/useEvent.js +3 -2
  17. package/es/packages/button-print/index.d.ts +2 -2
  18. package/es/packages/button-print/src/ButtonPrint.vue.d.ts +2 -2
  19. package/es/packages/button-print/src/components/IdentityVerification.vue.d.ts +2 -2
  20. package/es/packages/drag-layout/index.d.ts +2 -2
  21. package/es/packages/drag-layout/src/DragLayout.vue.d.ts +2 -2
  22. package/es/packages/field-set/index.d.ts +1 -1
  23. package/es/packages/field-set/src/FieldSet.vue.d.ts +1 -1
  24. package/es/packages/form-config/index.d.ts +14 -32
  25. package/es/packages/form-config/src/FormConfig.vue.d.ts +14 -32
  26. package/es/packages/form-config/src/components/FormConfigCreator.vue.d.ts +6 -15
  27. package/es/packages/form-config/src/components/FormConfigEdit.js +1 -1
  28. package/es/packages/form-config/src/components/FormConfigEdit.vue.d.ts +8 -17
  29. package/es/packages/form-config/src/constants/index.d.ts +47 -13
  30. package/es/packages/form-config/src/constants/index.js +52 -14
  31. package/es/packages/form-config/src/hooks/index.d.ts +1 -0
  32. package/es/packages/form-config/src/hooks/index.js +1 -0
  33. package/es/packages/form-config/src/hooks/useConfigurationField.js +6 -43
  34. package/es/packages/form-config/src/hooks/usePresetRenderer.js +1 -1
  35. package/es/packages/form-render/index.d.ts +6 -15
  36. package/es/packages/form-render/src/FormRender.js +3 -4
  37. package/es/packages/form-render/src/FormRender.vue.d.ts +7 -16
  38. package/es/packages/form-render/src/components/renderer/cascader.js +1 -1
  39. package/es/packages/form-render/src/components/renderer/checkbox.js +1 -1
  40. package/es/packages/form-render/src/components/renderer/combination/index.js +2 -1
  41. package/es/packages/form-render/src/components/renderer/complex.js +1 -1
  42. package/es/packages/form-render/src/components/renderer/input.js +2 -1
  43. package/es/packages/form-render/src/components/renderer/inputNumber.js +2 -1
  44. package/es/packages/form-render/src/components/renderer/radio.js +1 -1
  45. package/es/packages/form-render/src/components/renderer/select.js +1 -1
  46. package/es/packages/form-render/src/components/renderer/slider.js +1 -1
  47. package/es/packages/form-render/src/components/renderer/switch.js +1 -1
  48. package/es/packages/form-render/src/components/renderer/textarea.js +1 -1
  49. package/es/packages/form-render/src/hooks/useBusinessBinding.d.ts +12 -9
  50. package/es/packages/form-render/src/hooks/useBusinessBinding.js +58 -58
  51. package/es/packages/form-render/src/hooks/useFieldListAdaptor.js +9 -2
  52. package/es/packages/form-render/src/hooks/useFormContext.d.ts +2 -1
  53. package/es/packages/form-render/src/hooks/useFormContext.js +2 -2
  54. package/es/packages/form-render/src/hooks/useTypeNormalize.js +1 -1
  55. package/es/packages/form-render/src/types/index.d.ts +0 -8
  56. package/es/packages/form-render/src/utils/business.d.ts +12 -0
  57. package/es/packages/form-render/src/utils/business.js +65 -0
  58. package/es/packages/form-render/src/utils/dom.d.ts +6 -0
  59. package/es/packages/form-render/src/utils/dom.js +14 -0
  60. package/es/packages/form-render/src/utils/index.d.ts +5 -25
  61. package/es/packages/form-render/src/utils/index.js +5 -137
  62. package/es/packages/form-render/src/utils/schema.d.ts +15 -0
  63. package/es/packages/form-render/src/utils/schema.js +83 -0
  64. package/es/packages/scale-view/src/hooks/scaleview-init.js +35 -35
  65. package/es/packages/scale-view/src/hooks/use-component.d.ts +7 -7
  66. package/es/packages/select-label/index.d.ts +10 -10
  67. package/es/packages/select-label/src/LabelFormContent.vue.d.ts +3 -3
  68. package/es/packages/select-label/src/SelectLabel.vue.d.ts +7 -7
  69. package/es/packages/shortcut-setter/index.d.ts +3445 -1
  70. package/es/packages/shortcut-setter/src/ShortcutSetter.js +5 -2
  71. package/es/packages/shortcut-setter/src/ShortcutSetter.vue.d.ts +3449 -1
  72. package/es/packages/time-line/index.d.ts +2 -2
  73. package/es/packages/time-line/src/TimeLine.vue.d.ts +2 -2
  74. 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, WithNull } from '../../../../../es/src/types';
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 { AgeContext, DependKeyType, FieldItem, IdCardParseInfo } from '../types';
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, isArray, isFunction } from 'lodash-es';
4
- import { FIELD_SEX_VALUE } from '../constants/index.js';
5
- import { isField } from '@formily/core';
6
- import { differenceInDays, differenceInMonths, differenceInYears } from 'date-fns';
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, assignUpdateValue, createInputSlot, createLinebarId, createSlot, elementIdEscape, fieldKeyEscape, formRenderLog, getParentLinebar, injectOrProvide, isIdCard, isMobile, mergeDeepProperties, parseBirthday, parseIdCard, parseNumberFromMaybeString, queryDecorator, queryInput, transformDateFormat, traverseDependKey, traverseSchema, uuidGenerator };
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
- let evaluateStartTime = evaluateResultSetting == null ? void 0 : evaluateResultSetting.evaluateStartTime;
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
- let { evaluateResultSetting = {} } = state.config;
60
+ const { evaluateResultSetting = {} } = state.config;
61
61
  if (!evaluateResultSetting || !Object.keys(evaluateResultSetting).length)
62
62
  return;
63
63
  state.showEvaluateCountdownWrap = true;
64
- let { evaluateStartTime } = evaluateResultSetting;
65
- let { evaluateName } = ((_a = state.originConfig) == null ? void 0 : _a.evaluateResultSetting) || {};
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
- let curUrl = handleFrontAddress(list);
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
- let res = handleBtnParamsEvaluate(props.params);
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
- let filterArr = state.filterArr;
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
- let matchOption = options.find((v) => value === v.value);
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
- let typeArr = ["RADIO_BLOCK", "CHECKBOX_BLOCK"];
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
- let { nextLogic, options, type } = item || {};
150
+ const { nextLogic, options, type } = item || {};
151
151
  if (!nextLogic || !isRadioOrCheckBox(options, type))
152
152
  return;
153
- let { condition } = nextLogic || {};
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
- let relationLogicObj = vexutils.isString(item.relationLogic) ? JSON.parse(item.relationLogic) : item.relationLogic;
170
- let { condition } = relationLogicObj || {};
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
- let matchItem = list.find((f) => f.seq == c.subject_seq);
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
- let query = handleQueryParams();
195
+ const query = handleQueryParams();
196
196
  if ((props == null ? void 0 : props.noBtn) || (query == null ? void 0 : query.noBtn))
197
197
  return;
198
- let matchItem = list.find((item) => item.type === "FRONT_ADDRESS");
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
- let { frontAddress } = setting;
209
+ const { frontAddress } = setting;
210
210
  if (frontAddress) {
211
- let urlHref = window.location.href;
211
+ const urlHref = window.location.href;
212
212
  let preStr = "?";
213
213
  if (frontAddress.includes("?")) {
214
214
  preStr = "&";
215
215
  }
216
- let curUrl = `${frontAddress}${preStr}redirect_url=${encodeURIComponent(urlHref)}`;
216
+ const curUrl = `${frontAddress}${preStr}redirect_url=${encodeURIComponent(urlHref)}`;
217
217
  return curUrl;
218
218
  }
219
219
  };
220
220
  const handleBtnParamsEvaluate = (params) => {
221
- let defaultVariable = ["evaname", "evadesc", "evast", "evadur", "evaan"];
222
- let res = {};
223
- for (let key in params) {
224
- let value = params[key];
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
- let obj = {
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 (let key in evaluateResultSetting) {
246
- let value = evaluateResultSetting[key];
247
- let isParseKey = value && key != "evaluateAnswer" && typeof value === "string" && value.includes("${");
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
- let parseValue = value.replace(/\$\{([^}]+)\}/g, (_v, $1) => {
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
- let defaultVariable = ["evaname", "evadesc", "evast", "evadur", "evaan"];
267
- let defObj = {
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
- let key = defObj[item];
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
- let urlKey = (_c = (_b = item.setting) == null ? void 0 : _b.outDefaultValue) == null ? void 0 : _c.urlKey;
357
+ const urlKey = (_c = (_b = item.setting) == null ? void 0 : _b.outDefaultValue) == null ? void 0 : _c.urlKey;
358
358
  if (urlKey) {
359
- let list = urlKey.split(",");
359
+ const list = urlKey.split(",");
360
360
  if (list.length > 1) {
361
- let val2 = list.map((l) => {
362
- let tempV = getQueryVariable(l, state, props.params);
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" | "confirm" | "card">;
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" | "confirm" | "card">;
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<"center" | "stretch" | "baseline" | "start" | "end" | "flex-end" | "flex-start">;
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<"center" | "stretch" | "baseline" | "start" | "end" | "flex-end" | "flex-start">;
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<"center" | "start" | "end" | "space-around" | "space-between" | "space-evenly">;
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: "center" | "start" | "end" | "space-around" | "space-between" | "space-evenly";
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<"center" | "start" | "end" | "space-around" | "space-between" | "space-evenly">;
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";