cnhis-design-vue 3.1.9-beta.1 → 3.1.9-beta.4

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 (61) hide show
  1. package/README.md +22 -22
  2. package/es/packages/big-table/index.d.ts +1 -1
  3. package/es/packages/big-table/src/BigTable.vue.d.ts +1 -1
  4. package/es/packages/big-table/src/BigTable.vue_vue_type_script_setup_true_lang.mjs +3 -1
  5. package/es/packages/big-table/style/index.less +557 -557
  6. package/es/packages/bpmn-workflow/style/index.less +29 -29
  7. package/es/packages/button-print/style/index.less +30 -30
  8. package/es/packages/chunk-upload/src/chunk-upload-new.vue.d.ts +4 -6
  9. package/es/packages/chunk-upload/src/vod-chunk-upload/vod-chunk-upload.vue.d.ts +0 -3
  10. package/es/packages/chunk-upload/style/index.less +394 -394
  11. package/es/packages/drag-layout/src/DragLayout.vue.d.ts +5 -8
  12. package/es/packages/drag-layout/style/index.less +208 -208
  13. package/es/packages/field-set/style/index.less +157 -157
  14. package/es/packages/form-render/index.d.ts +267 -3
  15. package/es/packages/form-render/index.mjs +2 -0
  16. package/es/packages/form-render/src/FormRender.vue.d.ts +267 -3
  17. package/es/packages/form-render/src/FormRender.vue_vue_type_script_setup_true_lang.mjs +39 -25
  18. package/es/packages/form-render/src/components/cascader.d.ts +6 -2
  19. package/es/packages/form-render/src/components/cascader.mjs +12 -6
  20. package/es/packages/form-render/src/components/select.d.ts +12 -2
  21. package/es/packages/form-render/src/components/select.mjs +65 -29
  22. package/es/packages/form-render/src/constants/index.d.ts +4 -1
  23. package/es/packages/form-render/src/constants/index.mjs +3 -1
  24. package/es/packages/form-render/src/hooks/index.d.ts +11 -9
  25. package/es/packages/form-render/src/hooks/index.mjs +2 -0
  26. package/es/packages/form-render/src/hooks/useAsyncQueue.d.ts +13 -33
  27. package/es/packages/form-render/src/hooks/useBusinessBinding.d.ts +5 -3
  28. package/es/packages/form-render/src/hooks/useBusinessBinding.mjs +15 -15
  29. package/es/packages/form-render/src/hooks/useChangeContext.d.ts +11 -0
  30. package/es/packages/form-render/src/hooks/useChangeContext.mjs +21 -0
  31. package/es/packages/form-render/src/hooks/useFormField.d.ts +1 -0
  32. package/es/packages/form-render/src/hooks/useFormField.mjs +7 -1
  33. package/es/packages/form-render/src/hooks/useFormItemDeps.d.ts +8 -0
  34. package/es/packages/form-render/src/hooks/useFormItemDeps.mjs +29 -0
  35. package/es/packages/form-render/src/types/index.d.ts +16 -6
  36. package/es/packages/form-render/src/utils/index.d.ts +5 -3
  37. package/es/packages/form-render/src/utils/index.mjs +13 -1
  38. package/es/packages/form-table/style/index.less +301 -301
  39. package/es/packages/grid/style/index.less +12 -12
  40. package/es/packages/index.css +0 -3
  41. package/es/packages/index.less +2941 -2945
  42. package/es/packages/index.mjs +2 -0
  43. package/es/packages/info-header/index.d.ts +18 -2
  44. package/es/packages/info-header/src/HiddenContent.vue.d.ts +29 -13
  45. package/es/packages/info-header/src/HiddenContent.vue_vue_type_script_setup_true_lang.mjs +6 -4
  46. package/es/packages/info-header/src/InfoHeader.vue.d.ts +18 -2
  47. package/es/packages/info-header/src/InfoHeader.vue_vue_type_script_setup_true_lang.mjs +10 -5
  48. package/es/packages/info-header/style/index.css +0 -3
  49. package/es/packages/info-header/style/index.less +149 -153
  50. package/es/packages/map/style/index.less +59 -59
  51. package/es/packages/scale-view/style/index.less +748 -748
  52. package/es/packages/select-label/src/LabelFormContent.vue.d.ts +0 -3
  53. package/es/packages/select-label/style/index.less +151 -151
  54. package/es/packages/select-person/src/SelectPerson.vue_vue_type_script_setup_true_lang.mjs +1 -1
  55. package/es/packages/select-person/style/index.less +229 -229
  56. package/es/packages/time-line/style/index.less +34 -34
  57. package/es/src/types/index.d.ts +1 -0
  58. package/es/src/utils/anime.mjs +1 -1
  59. package/global.d.ts +8 -8
  60. package/package.json +1 -1
  61. package/yarn-error.log +8659 -103
@@ -1,6 +1,8 @@
1
1
  const InjectAsyncQueue = Symbol("InjectAsyncQueue");
2
2
  const InjectionSchemaField = Symbol("InjectionSchemaField");
3
3
  const InjectionBusinessCollector = Symbol("InjectionBusinessCollector");
4
+ const InjectionChangeContextCollector = Symbol("InjectionChangeContextCollector");
5
+ const InjectionFormItemDepsCollector = Symbol("InjectionFormItemDepsCollector");
4
6
  var FIELD_BUSINESS_TYPE = /* @__PURE__ */ ((FIELD_BUSINESS_TYPE2) => {
5
7
  FIELD_BUSINESS_TYPE2["PASSWORD"] = "password";
6
8
  FIELD_BUSINESS_TYPE2["ID_CARD"] = "id_card";
@@ -23,4 +25,4 @@ var FIELD_SEX_VALUE = /* @__PURE__ */ ((FIELD_SEX_VALUE2) => {
23
25
  return FIELD_SEX_VALUE2;
24
26
  })(FIELD_SEX_VALUE || {});
25
27
 
26
- export { FIELD_BUSINESS_TYPE, FIELD_SEX_VALUE, InjectAsyncQueue, InjectionBusinessCollector, InjectionSchemaField };
28
+ export { FIELD_BUSINESS_TYPE, FIELD_SEX_VALUE, InjectAsyncQueue, InjectionBusinessCollector, InjectionChangeContextCollector, InjectionFormItemDepsCollector, InjectionSchemaField };
@@ -1,9 +1,11 @@
1
- export * from "./useFieldList2Schema";
2
- export * from "./useFormRequest";
3
- export * from "./useCommonLog";
4
- export * from "./useFormField";
5
- export * from "./useAsyncQueue";
6
- export * from "./useFieldVisitor";
7
- export * from "./useTypeNormalize";
8
- export * from "./useFormValidator";
9
- export * from "./useBusinessBinding";
1
+ export * from './useFieldList2Schema';
2
+ export * from './useFormRequest';
3
+ export * from './useCommonLog';
4
+ export * from './useFormField';
5
+ export * from './useAsyncQueue';
6
+ export * from './useFieldVisitor';
7
+ export * from './useTypeNormalize';
8
+ export * from './useFormValidator';
9
+ export * from './useBusinessBinding';
10
+ export * from './useChangeContext';
11
+ export * from './useFormItemDeps';
@@ -7,3 +7,5 @@ export { useFieldVisitor } from './useFieldVisitor.mjs';
7
7
  export { useTypeNormalize } from './useTypeNormalize.mjs';
8
8
  export { useFormValidator } from './useFormValidator.mjs';
9
9
  export { BusinessCollector, useBusinessBinding } from './useBusinessBinding.mjs';
10
+ export { ContextCollector, useChangeContext } from './useChangeContext.mjs';
11
+ export { FormItemDepsCollector, useFormItemDeps } from './useFormItemDeps.mjs';
@@ -1,27 +1,7 @@
1
- import { FormAsyncQueueItem } from "../types";
2
- declare enum ENTRY_STATE {
3
- PENDING = 0,
4
- DONE = 1
5
- }
1
+ import { FormAsyncQueueItem } from '../types';
6
2
  interface EntryCallback {
7
3
  (err?: any, result?: any): void;
8
4
  }
9
- declare class AsyncQueueEntry<K = any> {
10
- key: K;
11
- item: any;
12
- state: ENTRY_STATE;
13
- callback?: EntryCallback;
14
- callbacks?: EntryCallback[];
15
- result?: any;
16
- error?: any;
17
- constructor(item: any, key: K, callback: EntryCallback);
18
- }
19
- declare class ArrayQueue<K = any> {
20
- _list: AsyncQueueEntry<K>[];
21
- constructor(items?: AsyncQueueEntry<K>[]);
22
- enqueue(item: AsyncQueueEntry<K>): void;
23
- dequeue(): AsyncQueueEntry<K> | undefined;
24
- }
25
5
  interface Processor<T, R = any> {
26
6
  (item: T, cb: (err?: any, result?: R) => void, removeCache: () => void): void;
27
7
  }
@@ -35,21 +15,21 @@ interface AsyncQueueOptions<T = any, K = any> {
35
15
  * @constructor 并发控制器
36
16
  */
37
17
  export declare class AsyncQueue<T = any, K = any, R = any> {
38
- name: string;
39
- processor: Processor<T, R>;
40
- getKey: AsyncQueueOptions<T, K>["getKey"];
41
- parallelism: number;
42
- _queued: ArrayQueue<K>;
43
- _entries: Map<K, AsyncQueueEntry<K>>;
44
- _activeTasks: number;
45
- _processingLock: boolean;
46
- _stopped: boolean;
18
+ readonly name: string;
19
+ private readonly processor;
20
+ private readonly getKey;
21
+ private readonly parallelism;
22
+ private readonly _queued;
23
+ private readonly _entries;
24
+ private _activeTasks;
25
+ private _processingLock;
26
+ private _stopped;
47
27
  constructor({ name, processor, getKey, parallelism }: AsyncQueueOptions<T>);
48
28
  add(item: T, callback: EntryCallback): void;
49
29
  addAsync(item: T): Promise<R>;
50
- _ensureProcessing(): void;
51
- _startProcess(entry: AsyncQueueEntry): void;
52
- _handlerResult(entry: AsyncQueueEntry, e?: any, r?: any): void;
30
+ private _ensureProcessing;
31
+ private _startProcess;
32
+ private _handlerResult;
53
33
  }
54
34
  export declare function useAsyncQueue(): {
55
35
  create: (parallelism?: number) => AsyncQueue<FormAsyncQueueItem, any, {
@@ -1,13 +1,15 @@
1
1
  import { Form } from '@formily/core';
2
2
  import { FIELD_BUSINESS_TYPE } from '../constants';
3
3
  export declare class BusinessCollector {
4
- typeCollector: Map<FIELD_BUSINESS_TYPE, Set<string>>;
5
- fieldNameCollector: Map<string, FIELD_BUSINESS_TYPE>;
4
+ private readonly typeCollector;
5
+ private readonly fieldNameCollector;
6
6
  collect(type: FIELD_BUSINESS_TYPE, fieldName: string): void;
7
7
  getField(type: FIELD_BUSINESS_TYPE): string[];
8
8
  getType(fieldName: string): FIELD_BUSINESS_TYPE | undefined;
9
+ handlerIdCardType(formModel: Form, value: unknown): void;
10
+ handlerMap: Map<FIELD_BUSINESS_TYPE, (formModel: Form, value: unknown) => void>;
11
+ trigger(formModel: Form, fieldName: string, value: unknown): void;
9
12
  }
10
13
  export declare function useBusinessBinding(): {
11
14
  create: () => BusinessCollector;
12
- trigger: (collector: BusinessCollector, formModel: Form, fieldName: string, value: unknown) => void;
13
15
  };
@@ -6,6 +6,7 @@ class BusinessCollector {
6
6
  constructor() {
7
7
  this.typeCollector = /* @__PURE__ */ new Map();
8
8
  this.fieldNameCollector = /* @__PURE__ */ new Map();
9
+ this.handlerMap = /* @__PURE__ */ new Map([[FIELD_BUSINESS_TYPE.ID_CARD, this.handlerIdCardType.bind(this)]]);
9
10
  }
10
11
  collect(type, fieldName) {
11
12
  const set = this.typeCollector.get(type) || /* @__PURE__ */ new Set();
@@ -19,42 +20,41 @@ class BusinessCollector {
19
20
  getType(fieldName) {
20
21
  return this.fieldNameCollector.get(fieldName);
21
22
  }
22
- }
23
- function useBusinessBinding() {
24
- function create() {
25
- return new BusinessCollector();
26
- }
27
- function handlerIdCardType(formModel, collector, value) {
23
+ handlerIdCardType(formModel, value) {
28
24
  if (!value || !isString(value) || !isIdCard(value))
29
25
  return;
30
26
  const info = parseIdCard(value);
31
- const ageFields = collector.getField(FIELD_BUSINESS_TYPE.AGE);
27
+ const ageFields = this.getField(FIELD_BUSINESS_TYPE.AGE);
32
28
  ageFields.forEach((field) => {
33
29
  formModel.setFieldState(field, (state) => {
34
30
  state.value = info.age;
35
31
  });
36
32
  });
37
- const sexFields = collector.getField(FIELD_BUSINESS_TYPE.SEX);
33
+ const sexFields = this.getField(FIELD_BUSINESS_TYPE.SEX);
38
34
  sexFields.forEach((field) => {
39
35
  formModel.setFieldState(field, (state) => {
40
36
  state.value = info.sex;
41
37
  });
42
38
  });
43
- const birthdayFields = collector.getField(FIELD_BUSINESS_TYPE.BIRTHDAY);
39
+ const birthdayFields = this.getField(FIELD_BUSINESS_TYPE.BIRTHDAY);
44
40
  birthdayFields.forEach((field) => {
45
41
  formModel.setFieldState(field, (state) => {
46
42
  state.value = info.birthday;
47
43
  });
48
44
  });
49
45
  }
50
- const handlerMap = /* @__PURE__ */ new Map([[FIELD_BUSINESS_TYPE.ID_CARD, handlerIdCardType]]);
51
- function trigger(collector, formModel, fieldName, value) {
52
- const type = collector.fieldNameCollector.get(fieldName);
53
- if (!type || !handlerMap.has(type))
46
+ trigger(formModel, fieldName, value) {
47
+ const type = this.getType(fieldName);
48
+ if (!type || !this.handlerMap.has(type))
54
49
  return;
55
- handlerMap.get(type)(formModel, collector, value);
50
+ this.handlerMap.get(type)(formModel, value);
51
+ }
52
+ }
53
+ function useBusinessBinding() {
54
+ function create() {
55
+ return new BusinessCollector();
56
56
  }
57
- return { create, trigger };
57
+ return { create };
58
58
  }
59
59
 
60
60
  export { BusinessCollector, useBusinessBinding };
@@ -0,0 +1,11 @@
1
+ import { FormChangeContext } from 'cnhis-design-vue/es/packages/form-render';
2
+ export declare class ContextCollector {
3
+ private readonly contextMap;
4
+ setContext(key: string, prop: keyof FormChangeContext, value: any): void;
5
+ getContext(key: string): Partial<{
6
+ currentOption: import("../../../../src/types").AnyObject;
7
+ }>;
8
+ }
9
+ export declare function useChangeContext(): {
10
+ create: () => ContextCollector;
11
+ };
@@ -0,0 +1,21 @@
1
+ class ContextCollector {
2
+ constructor() {
3
+ this.contextMap = /* @__PURE__ */ new Map();
4
+ }
5
+ setContext(key, prop, value) {
6
+ const context = this.contextMap.get(key) || {};
7
+ Reflect.set(context, prop, value);
8
+ this.contextMap.set(key, context);
9
+ }
10
+ getContext(key) {
11
+ return this.contextMap.get(key) || {};
12
+ }
13
+ }
14
+ function useChangeContext() {
15
+ function create() {
16
+ return new ContextCollector();
17
+ }
18
+ return { create };
19
+ }
20
+
21
+ export { ContextCollector, useChangeContext };
@@ -1,4 +1,5 @@
1
1
  export declare function useFormField(): {
2
2
  field: import("vue").Ref<import("@formily/core").GeneralField>;
3
3
  title: import("vue").ComputedRef<any>;
4
+ fieldKey: import("vue").ComputedRef<string>;
4
5
  };
@@ -3,7 +3,13 @@ import { computed } from 'vue';
3
3
 
4
4
  function useFormField() {
5
5
  const field = useField();
6
- return { field, title: computed(() => field.value.title) };
6
+ return {
7
+ field,
8
+ title: computed(() => field.value.title),
9
+ fieldKey: computed(() => {
10
+ return field.value.props.name.toString();
11
+ })
12
+ };
7
13
  }
8
14
 
9
15
  export { useFormField };
@@ -0,0 +1,8 @@
1
+ export declare class FormItemDepsCollector {
2
+ private readonly collector;
3
+ setDeps(key: string, dependKey: string | string[], callback: Function): void;
4
+ trigger(dependKey: string): void;
5
+ }
6
+ export declare function useFormItemDeps(): {
7
+ create: () => FormItemDepsCollector;
8
+ };
@@ -0,0 +1,29 @@
1
+ import { arrayed } from 'cnhis-design-vue/es/packages/form-render/src/utils';
2
+
3
+ class FormItemDepsCollector {
4
+ constructor() {
5
+ this.collector = /* @__PURE__ */ new Map();
6
+ }
7
+ setDeps(key, dependKey, callback) {
8
+ dependKey = arrayed(dependKey);
9
+ dependKey.forEach((dependKey2) => {
10
+ const map = this.collector.get(dependKey2) || /* @__PURE__ */ new Map();
11
+ map.set(key, callback);
12
+ this.collector.set(dependKey2, map);
13
+ });
14
+ }
15
+ trigger(dependKey) {
16
+ const map = this.collector.get(dependKey);
17
+ map && map.forEach((cb) => {
18
+ typeof cb === "function" && cb();
19
+ });
20
+ }
21
+ }
22
+ function useFormItemDeps() {
23
+ function create() {
24
+ return new FormItemDepsCollector();
25
+ }
26
+ return { create };
27
+ }
28
+
29
+ export { FormItemDepsCollector, useFormItemDeps };
@@ -1,8 +1,8 @@
1
1
  import { AnyObject } from 'cnhis-design-vue/es/src/types';
2
- import { Field } from "@formily/core";
3
- import { FieldItem } from "../types";
4
- import { AsyncQueue } from "../hooks";
5
- export * from "./fieldItem";
2
+ import { DataField, Field } from '@formily/core';
3
+ import { FieldItem } from '../types';
4
+ import { AsyncQueue } from '../hooks';
5
+ export * from './fieldItem';
6
6
  export interface FieldVisitorContext {
7
7
  field: FieldItem;
8
8
  replace(f: FieldItem): void;
@@ -10,7 +10,7 @@ export interface FieldVisitorContext {
10
10
  insertAfter(f: FieldItem | FieldItem[]): void;
11
11
  }
12
12
  export declare type FieldVisitor = Record<string, (context: FieldVisitorContext) => void>;
13
- export declare type FormRequestType = "post" | "get" | "patch" | "delete" | "put";
13
+ export declare type FormRequestType = 'post' | 'get' | 'patch' | 'delete' | 'put';
14
14
  export interface FormAsyncQueueItem {
15
15
  key: any;
16
16
  url: string;
@@ -18,9 +18,19 @@ export interface FormAsyncQueueItem {
18
18
  params?: AnyObject;
19
19
  }
20
20
  export declare type FormAsyncQueue = AsyncQueue<FormAsyncQueueItem, any, AnyObject[]>;
21
- export declare type IdCardParseInfo = Record<"sex" | "birthday", string> & Record<"age" | "day" | "month" | "year", number>;
21
+ export declare type IdCardParseInfo = Record<'sex' | 'birthday', string> & Record<'age' | 'day' | 'month' | 'year', number>;
22
22
  export declare type FormRenderExpose = {
23
23
  validate(): Promise<unknown>;
24
24
  getFormValues(): AnyObject;
25
25
  setFieldState(path: string, setter: (field: Field) => void): void;
26
26
  };
27
+ export declare type FormChangeContext = Partial<{
28
+ currentOption: AnyObject;
29
+ }>;
30
+ export declare type FormChangePayload = {
31
+ value: any;
32
+ fieldKey: string;
33
+ fieldName: string;
34
+ fieldInstance: DataField;
35
+ context: FormChangeContext;
36
+ };
@@ -1,6 +1,7 @@
1
- import { GeneralField } from "@formily/core";
2
- import { InjectionKey } from "vue";
3
- import { IdCardParseInfo } from "../types";
1
+ import { AnyObject } from 'cnhis-design-vue/es/src/types';
2
+ import { GeneralField } from '@formily/core';
3
+ import { InjectionKey } from 'vue';
4
+ import { IdCardParseInfo } from '../types';
4
5
  export declare function formRenderLog(message: string, type?: keyof Console): void;
5
6
  export declare function arrayed<T>(maybeArray: T): T extends Array<any> ? T : [T];
6
7
  export declare function assignUpdateValue(props: any, field: GeneralField): any;
@@ -8,3 +9,4 @@ export declare function transformDateFormat(format: string): "date" | "datetime"
8
9
  export declare function isIdCard(idCardNo: string): boolean;
9
10
  export declare function parseIdCard(idCardNo: string): IdCardParseInfo;
10
11
  export declare function injectOrProvide<T>(key: InjectionKey<T>, creator: () => T): T;
12
+ export declare function generateUrlParams(field: GeneralField, dependKeys?: string | string[]): AnyObject;
@@ -55,5 +55,17 @@ function injectOrProvide(key, creator) {
55
55
  }
56
56
  return injected;
57
57
  }
58
+ function generateUrlParams(field, dependKeys) {
59
+ const result = {};
60
+ if (dependKeys) {
61
+ arrayed(dependKeys).forEach((dependKey) => {
62
+ const _field = field.query(dependKey).take();
63
+ if (isField(_field)) {
64
+ result[dependKey] = _field.value;
65
+ }
66
+ });
67
+ }
68
+ return result;
69
+ }
58
70
 
59
- export { arrayed, assignUpdateValue, formRenderLog, injectOrProvide, isIdCard, parseIdCard, transformDateFormat };
71
+ export { arrayed, assignUpdateValue, formRenderLog, generateUrlParams, injectOrProvide, isIdCard, parseIdCard, transformDateFormat };