@wfrog/vc-ui 1.9.11 → 1.9.13

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 (50) hide show
  1. package/dist/es/components/cdn-tag.vue.d.ts +5 -0
  2. package/dist/es/components/choice/choice.d.ts +3 -0
  3. package/dist/es/components/choice/choice.mjs +14 -4
  4. package/dist/es/components/choice/choice.vue.d.ts +5 -1
  5. package/dist/es/components/daterange-picker/daterange-picker.d.ts +5 -0
  6. package/dist/es/components/daterange-picker/daterange-picker.mjs +12 -3
  7. package/dist/es/components/daterange-picker/daterange-picker.vue.d.ts +2 -0
  8. package/dist/es/components/explorer/explorer.mjs +2 -2
  9. package/dist/es/components/explorer/index.css +2 -2
  10. package/dist/es/components/explorer-column-table/explorer-column-table.mjs +1 -1
  11. package/dist/es/components/explorer-column-table/explorer-column-table.vue.d.ts +1470 -0
  12. package/dist/es/components/explorer-form/explorer-form.mjs +10 -4
  13. package/dist/es/components/explorer-form/explorer-form.vue.d.ts +16 -16
  14. package/dist/es/components/explorer-modal-form/explorer-modal-form.mjs +11 -6
  15. package/dist/es/components/explorer-modal-form/explorer-modal-form.vue.d.ts +16 -16
  16. package/dist/es/components/explorer-modal-form/index.css +4 -3
  17. package/dist/es/components/explorer-query/explorer-query.vue.d.ts +10 -10
  18. package/dist/es/components/explorer-tools/components/column-setter.vue.d.ts +6314 -434
  19. package/dist/es/components/icon-picker/components/collections.vue.d.ts +5 -5
  20. package/dist/es/components/icon-picker/icon-picker.mjs +1 -1
  21. package/dist/es/components/input/index.css +1 -1
  22. package/dist/es/components/input/input.d.ts +4 -0
  23. package/dist/es/components/input/input.mjs +19 -4
  24. package/dist/es/components/input/input.vue.d.ts +7 -1
  25. package/dist/es/components/input-number/index.css +1 -1
  26. package/dist/es/components/input-number/input-number.mjs +7 -2
  27. package/dist/es/components/pca-picker/pca-picker.mjs +16 -3
  28. package/dist/es/components/pca-picker/pca-picker.vue.d.ts +2 -0
  29. package/dist/es/components/scrollbar/index.css +1 -1
  30. package/dist/es/components/scrollbar/scrollbar.mjs +2 -2
  31. package/dist/es/components/scrollbar/scrollbar.vue.d.ts +2 -2
  32. package/dist/es/components/select/index.css +2 -2
  33. package/dist/es/components/select/select.d.ts +4 -0
  34. package/dist/es/components/select/select.mjs +19 -4
  35. package/dist/es/components/select/select.vue.d.ts +7 -1
  36. package/dist/es/components/tags/tags.mjs +6 -1
  37. package/dist/es/components/thousand-input/thousand-input.d.ts +6 -0
  38. package/dist/es/components/thousand-input/thousand-input.mjs +2 -1
  39. package/dist/es/components/thousand-input/thousand-input.vue.d.ts +30 -8
  40. package/dist/es/components/tinymce/index.css +1 -1
  41. package/dist/es/components/tinymce/tinymce.d.ts +5 -0
  42. package/dist/es/components/tinymce/tinymce.mjs +16 -3
  43. package/dist/es/components/tinymce/tinymce.vue.d.ts +7 -3
  44. package/dist/es/components/tree-picker/index.css +2 -2
  45. package/dist/es/components/tree-picker/tree-picker.d.ts +6 -1
  46. package/dist/es/components/tree-picker/tree-picker.mjs +21 -7
  47. package/dist/es/components/tree-picker/tree-picker.vue.d.ts +2 -0
  48. package/dist/es/index.mjs +1 -1
  49. package/dist/index.css +14 -13
  50. package/package.json +1 -1
@@ -1,4 +1,4 @@
1
- import { CascaderOption, CascaderProps } from 'element-plus/es/components/cascader-panel';
1
+ import { CascaderNode, CascaderOption, CascaderProps, CascaderValue } from 'element-plus/es/components/cascader-panel';
2
2
  export interface ITreePickerProps {
3
3
  emptyText?: string;
4
4
  placeholder?: string;
@@ -12,3 +12,8 @@ export interface ITreePickerProps {
12
12
  filterable?: boolean;
13
13
  filterEmptyText?: string;
14
14
  }
15
+ export interface ITreePickerEmits {
16
+ (e: 'update:modelValue', value: string | number | string[] | number[] | undefined): void;
17
+ (e: 'change', value: CascaderValue | null | undefined, node?: CascaderNode[]): void;
18
+ (e: 'blur', event: FocusEvent): void;
19
+ }
@@ -10,7 +10,7 @@ import '../../chunk/DBf73TLo.mjs';
10
10
  import '../../chunk/Do7HIVy5.mjs';
11
11
  import '../../chunk/CqhShW5K.mjs';
12
12
  import { defineComponent, useCssVars, unref, computed, useCssModule, useTemplateRef, ref, createBlock, openBlock, withCtx, createElementVNode, normalizeClass, createVNode, mergeProps, isRef, createTextVNode, toDisplayString, nextTick } from 'vue';
13
- import { useFormDisabled } from 'element-plus';
13
+ import { useFormDisabled, useFormItem } from 'element-plus';
14
14
  import { useVModel, useToggle, useThrottleFn, onClickOutside } from '@vueuse/core';
15
15
  import { E as ElPopover } from '../../chunk/DdY32YAP.mjs';
16
16
  import { _ as _export_sfc } from '../../chunk/pcqpp-6-.mjs';
@@ -30,16 +30,17 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
30
30
  filterable: { type: Boolean },
31
31
  filterEmptyText: { default: "没有匹配到数据" }
32
32
  },
33
- emits: ["update:modelValue", "change"],
33
+ emits: ["update:modelValue", "change", "blur"],
34
34
  setup(__props, { emit: __emit }) {
35
35
  useCssVars((_ctx) => ({
36
- "f8b9a976": unref(myWidth)
36
+ "v07aa23cc": unref(myWidth)
37
37
  }));
38
38
  const props = __props;
39
39
  const emits = __emit;
40
40
  const myValue = useVModel(props, "modelValue", emits);
41
41
  const [popoverVisible, togglePopoverVisible] = useToggle();
42
42
  const formDisabled = useFormDisabled();
43
+ const { formItem } = useFormItem();
43
44
  const handleSelectClick = useThrottleFn(() => !formDisabled.value && togglePopoverVisible(), 300);
44
45
  const cascaderProps = computed(() => ({
45
46
  label: props.props.label || "label",
@@ -80,6 +81,19 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
80
81
  nextTick(() => togglePopoverVisible(false));
81
82
  }, 0);
82
83
  }
84
+ function handleChange(val, node) {
85
+ formItem?.validate?.("change").catch(() => {
86
+ });
87
+ emits("change", val, node);
88
+ }
89
+ function handleBlur(event) {
90
+ formItem?.validate?.("blur").catch(() => {
91
+ });
92
+ setTimeout(() => {
93
+ keyword.value = "";
94
+ }, 300);
95
+ emits("blur", event);
96
+ }
83
97
  return (_ctx, _cache) => {
84
98
  const _component_ElCascader = ElCascader;
85
99
  const _component_ElPopover = ElPopover;
@@ -94,13 +108,13 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
94
108
  reference: withCtx(() => [
95
109
  createElementVNode("div", {
96
110
  class: normalizeClass(unref($style).wrapper),
97
- onClickCapture: _cache[5] || (_cache[5] = //@ts-ignore
111
+ onClickCapture: _cache[3] || (_cache[3] = //@ts-ignore
98
112
  (...args) => unref(handleSelectClick) && unref(handleSelectClick)(...args)),
99
113
  onKeyup: handleKeyup
100
114
  }, [
101
115
  createVNode(_component_ElCascader, mergeProps({
102
116
  modelValue: unref(myValue),
103
- "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => isRef(myValue) ? myValue.value = $event : null),
117
+ "onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => isRef(myValue) ? myValue.value = $event : null),
104
118
  "collapse-tags": "",
105
119
  "collapse-tags-tooltip": "",
106
120
  clearable: "",
@@ -113,7 +127,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
113
127
  disabled: unref(formDisabled)
114
128
  }, _ctx.$attrs, {
115
129
  onClear: clear,
116
- onBlur: _cache[4] || (_cache[4] = ($event) => keyword.value = "")
130
+ onBlur: handleBlur
117
131
  }), {
118
132
  empty: withCtx(() => [
119
133
  createTextVNode(toDisplayString(__props.filterEmptyText), 1)
@@ -137,7 +151,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
137
151
  multiple: __props.multiple,
138
152
  onExpandChange: updatePopper,
139
153
  onChoiced: _cache[1] || (_cache[1] = ($event) => unref(togglePopoverVisible)(false)),
140
- onChange: _cache[2] || (_cache[2] = (val, node) => emits("change", val, node))
154
+ onChange: handleChange
141
155
  }), null, 16, ["modelValue", "options", "props", "multiple"])
142
156
  ], 2)
143
157
  ]),
@@ -1,9 +1,11 @@
1
1
  import { CascaderNode, CascaderValue } from 'element-plus/es/components/cascader-panel';
2
2
  import { ITreePickerProps } from './tree-picker';
3
3
  declare const _default: import('vue').DefineComponent<ITreePickerProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
4
+ blur: (event: FocusEvent) => any;
4
5
  change: (value: CascaderValue | null | undefined, node?: CascaderNode[] | undefined) => any;
5
6
  "update:modelValue": (value: string | number | string[] | number[] | undefined) => any;
6
7
  }, string, import('vue').PublicProps, Readonly<ITreePickerProps> & Readonly<{
8
+ onBlur?: ((event: FocusEvent) => any) | undefined;
7
9
  onChange?: ((value: CascaderValue | null | undefined, node?: CascaderNode[] | undefined) => any) | undefined;
8
10
  "onUpdate:modelValue"?: ((value: string | number | string[] | number[] | undefined) => any) | undefined;
9
11
  }>, {
package/dist/es/index.mjs CHANGED
@@ -156,7 +156,7 @@ const __vite_glob_0_47 = /*#__PURE__*/Object.freeze(/*#__PURE__*/Object.definePr
156
156
  default: _sfc_main$8
157
157
  }, Symbol.toStringTag, { value: 'Module' }));
158
158
 
159
- const version = "1.9.10";
159
+ const version = "1.9.13";
160
160
 
161
161
  const modules = /* #__PURE__ */ Object.assign({"./components/awesome-icon/awesome-icon.vue": __vite_glob_0_0,"./components/backbottom/backbottom.vue": __vite_glob_0_1,"./components/button/button.vue": __vite_glob_0_2,"./components/chat-container/chat-container.vue": __vite_glob_0_3,"./components/choice-boolean/choice-boolean.vue": __vite_glob_0_4,"./components/choice/choice.vue": __vite_glob_0_5,"./components/color-switcher/color-switcher.vue": __vite_glob_0_6,"./components/config-provider/config-provider.vue": __vite_glob_0_7,"./components/cropper/cropper.vue": __vite_glob_0_8,"./components/currency/currency.vue": __vite_glob_0_9,"./components/dark-switcher/dark-switcher.vue": __vite_glob_0_10,"./components/daterange-picker/daterange-picker.vue": __vite_glob_0_11,"./components/dialog-camera-upload/dialog-camera-upload.vue": __vite_glob_0_12,"./components/dialog-map-point/dialog-map-point.vue": __vite_glob_0_13,"./components/dialog-upload-images/dialog-upload-images.vue": __vite_glob_0_14,"./components/dialog/dialog.vue": __vite_glob_0_15,"./components/drag-verify/drag-verify.vue": __vite_glob_0_16,"./components/drawer/drawer.vue": __vite_glob_0_17,"./components/easy-pagination/easy-pagination.vue": __vite_glob_0_18,"./components/el-icon/el-icon.vue": __vite_glob_0_19,"./components/explorer-column-table/explorer-column-table.vue": __vite_glob_0_20,"./components/explorer-container/explorer-container.vue": __vite_glob_0_21,"./components/explorer-filter/explorer-filter.vue": __vite_glob_0_22,"./components/explorer-footer/explorer-footer.vue": __vite_glob_0_23,"./components/explorer-form/explorer-form.vue": __vite_glob_0_24,"./components/explorer-list/explorer-list.vue": __vite_glob_0_25,"./components/explorer-modal-form/explorer-modal-form.vue": __vite_glob_0_26,"./components/explorer-panel/explorer-panel.vue": __vite_glob_0_27,"./components/explorer-query/explorer-query.vue": __vite_glob_0_28,"./components/explorer-table/explorer-table.vue": __vite_glob_0_29,"./components/explorer-tools/explorer-tools.vue": __vite_glob_0_30,"./components/explorer-tree/explorer-tree.vue": __vite_glob_0_31,"./components/explorer/explorer.vue": __vite_glob_0_32,"./components/flag/flag.vue": __vite_glob_0_33,"./components/icon-picker/icon-picker.vue": __vite_glob_0_34,"./components/icon/icon.vue": __vite_glob_0_35,"./components/iconify-icon/iconify-icon.vue": __vite_glob_0_36,"./components/image/image.vue": __vite_glob_0_37,"./components/input-number/input-number.vue": __vite_glob_0_38,"./components/input/input.vue": __vite_glob_0_39,"./components/pca-picker/pca-picker.vue": __vite_glob_0_40,"./components/qr-code/qr-code.vue": __vite_glob_0_41,"./components/screenfull/screenfull.vue": __vite_glob_0_42,"./components/scrollbar/scrollbar.vue": __vite_glob_0_43,"./components/select/select.vue": __vite_glob_0_44,"./components/single-player/single-player.vue": __vite_glob_0_45,"./components/splitter-panel/splitter-panel.vue": __vite_glob_0_46,"./components/splitter/splitter.vue": __vite_glob_0_47,"./components/svg-icon/svg-icon.vue": __vite_glob_0_48,"./components/switch/switch.vue": __vite_glob_0_49,"./components/sync-scroll-container/sync-scroll-container.vue": __vite_glob_0_50,"./components/tags/tags.vue": __vite_glob_0_51,"./components/text-ellipsis/text-ellipsis.vue": __vite_glob_0_52,"./components/thousand-input/thousand-input.vue": __vite_glob_0_53,"./components/tinymce/tinymce.vue": __vite_glob_0_54,"./components/transfer-panel/transfer-panel.vue": __vite_glob_0_55,"./components/transfer/transfer.vue": __vite_glob_0_56,"./components/tree-picker/tree-picker.vue": __vite_glob_0_57,"./components/upload-file/upload-file.vue": __vite_glob_0_58});
162
162
  const upper = (_, letter) => letter.toUpperCase();
package/dist/index.css CHANGED
@@ -752,16 +752,17 @@ div._main_k37nc_1 ._header_k37nc_48 {
752
752
  margin: 0 -8px;
753
753
  }
754
754
  /* source: src/components/explorer-modal-form/explorer-modal-form.vue */
755
- ._icon_1nnr8_1 {
755
+ ._icon_1v6yb_1 {
756
756
  margin-right: 4px;
757
757
  font-size: var(--el-font-size-extra-large);
758
758
  }
759
- ._form_1nnr8_6 {
759
+ ._form_1v6yb_6 {
760
760
  display: flex;
761
761
  flex-grow: 1;
762
762
  align-items: flex-start;
763
+ flex-direction: column;
763
764
  }
764
- ._form_1nnr8_6 > .el-row {
765
+ ._form_1v6yb_6 > .el-row {
765
766
  flex-grow: 1;
766
767
  margin: 0 !important;
767
768
  }
@@ -968,7 +969,7 @@ div._divider_8k9xf_21 {
968
969
  margin: 0 -8px;
969
970
  }
970
971
  /* source: src/components/explorer/explorer.vue */
971
- ._explorer_115yz_1 {
972
+ div._explorer_11uiv_1 {
972
973
  border: 1px solid var(--el-border-color-lighter);
973
974
  border-radius: var(--el-border-radius-base);
974
975
  display: flex;
@@ -977,7 +978,7 @@ div._divider_8k9xf_21 {
977
978
  background-color: var(--el-fill-color-blank);
978
979
  box-sizing: border-box;
979
980
  }
980
- ._explorer_115yz_1 :glbal ._el-splitter__mask_115yz_10 {
981
+ div._explorer_11uiv_1 :glbal ._el-splitter__mask_11uiv_10 {
981
982
  z-index: 10000;
982
983
  transform: translateX(0);
983
984
  }
@@ -1157,11 +1158,11 @@ div._el-input-number_1piks_18 {
1157
1158
  line-height: 10px;
1158
1159
  }
1159
1160
  div._el-input-number_1piks_18 .el-input__inner {
1160
- width: var(--v233f0811);
1161
+ width: var(--e4533d92);
1161
1162
  }
1162
1163
  /* source: src/components/input/input.vue */
1163
1164
  div._input_1vcoq_1 {
1164
- width: var(--v5b821c9b);
1165
+ width: var(--v7a89bfe6);
1165
1166
  display: inline-flex;
1166
1167
  }
1167
1168
  div._input_1vcoq_1._block_1vcoq_5 {
@@ -1326,7 +1327,7 @@ div._input_1vcoq_1._block_1vcoq_5 {
1326
1327
  display: flex;
1327
1328
  flex-direction: column;
1328
1329
  flex-grow: 1;
1329
- margin: var(--v157bc9f4);
1330
+ margin: var(--v21687dc8);
1330
1331
  }
1331
1332
  ._fill-height_edxkl_18 {
1332
1333
  height: 10px;
@@ -1334,11 +1335,11 @@ div._input_1vcoq_1._block_1vcoq_5 {
1334
1335
  /* source: src/components/select/select.vue */
1335
1336
  div._select_1fcv5_1 {
1336
1337
  width: unset;
1337
- min-width: var(--v44193d28);
1338
+ min-width: var(--v393aeef3);
1338
1339
  }
1339
1340
  div._select_1fcv5_1._block_1fcv5_5 {
1340
1341
  display: block;
1341
- width: var(--v44193d28);
1342
+ width: var(--v393aeef3);
1342
1343
  }
1343
1344
  /* source: src/components/single-player/single-player.vue */
1344
1345
  .el-slider{--el-slider-main-bg-color:var(--el-color-primary);--el-slider-runway-bg-color:var(--el-border-color-light);--el-slider-stop-bg-color:var(--el-color-white);--el-slider-disabled-color:var(--el-text-color-placeholder);--el-slider-border-radius:3px;--el-slider-height:6px;--el-slider-button-size:20px;--el-slider-button-wrapper-size:36px;--el-slider-button-wrapper-offset:-15px;align-items:center;display:flex;height:32px;width:100%}.el-slider__runway{background-color:var(--el-slider-runway-bg-color);border-radius:var(--el-slider-border-radius);cursor:pointer;flex:1;height:var(--el-slider-height);position:relative}.el-slider__runway.show-input{margin-right:30px;width:auto}.el-slider__runway.is-disabled{cursor:default}.el-slider__runway.is-disabled .el-slider__bar{background-color:var(--el-slider-disabled-color)}.el-slider__runway.is-disabled .el-slider__button{border-color:var(--el-slider-disabled-color)}.el-slider__runway.is-disabled .el-slider__button-wrapper.dragging,.el-slider__runway.is-disabled .el-slider__button-wrapper.hover,.el-slider__runway.is-disabled .el-slider__button-wrapper:hover{cursor:not-allowed}.el-slider__runway.is-disabled .el-slider__button.dragging,.el-slider__runway.is-disabled .el-slider__button.hover,.el-slider__runway.is-disabled .el-slider__button:hover{transform:scale(1)}.el-slider__runway.is-disabled .el-slider__button.dragging,.el-slider__runway.is-disabled .el-slider__button.hover,.el-slider__runway.is-disabled .el-slider__button:hover{cursor:not-allowed}.el-slider__input{flex-shrink:0;width:130px}.el-slider__bar{background-color:var(--el-slider-main-bg-color);border-bottom-left-radius:var(--el-slider-border-radius);border-top-left-radius:var(--el-slider-border-radius);height:var(--el-slider-height);position:absolute}.el-slider__button-wrapper{background-color:transparent;height:var(--el-slider-button-wrapper-size);line-height:normal;outline:none;position:absolute;text-align:center;top:var(--el-slider-button-wrapper-offset);transform:translateX(-50%);-webkit-user-select:none;-moz-user-select:none;user-select:none;width:var(--el-slider-button-wrapper-size);z-index:1}.el-slider__button-wrapper:after{content:"";display:inline-block;height:100%;vertical-align:middle}.el-slider__button-wrapper.hover,.el-slider__button-wrapper:hover{cursor:grab}.el-slider__button-wrapper.dragging{cursor:grabbing}.el-slider__button{background-color:var(--el-color-white);border:2px solid var(--el-slider-main-bg-color);border-radius:50%;box-sizing:border-box;display:inline-block;height:var(--el-slider-button-size);transition:var(--el-transition-duration-fast);-webkit-user-select:none;-moz-user-select:none;user-select:none;vertical-align:middle;width:var(--el-slider-button-size)}.el-slider__button.dragging,.el-slider__button.hover,.el-slider__button:hover{transform:scale(1.2)}.el-slider__button.hover,.el-slider__button:hover{cursor:grab}.el-slider__button.dragging{cursor:grabbing}.el-slider__stop{background-color:var(--el-slider-stop-bg-color);border-radius:var(--el-border-radius-circle);height:var(--el-slider-height);position:absolute;transform:translateX(-50%);width:var(--el-slider-height)}.el-slider__marks{height:100%;left:12px;top:0;width:18px}.el-slider__marks-text{color:var(--el-color-info);font-size:14px;margin-top:15px;position:absolute;transform:translateX(-50%);white-space:pre}.el-slider.is-vertical{display:inline-flex;flex:0;height:100%;position:relative;width:auto}.el-slider.is-vertical .el-slider__runway{height:100%;margin:0 16px;width:var(--el-slider-height)}.el-slider.is-vertical .el-slider__bar{border-radius:0 0 3px 3px;height:auto;width:var(--el-slider-height)}.el-slider.is-vertical .el-slider__button-wrapper{left:var(--el-slider-button-wrapper-offset);top:auto;transform:translateY(50%)}.el-slider.is-vertical .el-slider__stop{transform:translateY(50%)}.el-slider.is-vertical .el-slider__marks-text{left:15px;margin-top:0;transform:translateY(50%)}.el-slider--large{height:40px}.el-slider--small{height:24px}._main_15lus_1 {
@@ -1536,7 +1537,7 @@ span._draggable_1tp7v_5 > * {
1536
1537
  /* source: src/components/tinymce/tinymce.vue */
1537
1538
  ._tinymce_aa7a3_1 {
1538
1539
  width: 100%;
1539
- height: var(--v6eb7f65f);
1540
+ height: var(--ec3ab54e);
1540
1541
  }
1541
1542
  ._textarea_aa7a3_6 {
1542
1543
  z-index: -1;
@@ -1694,11 +1695,11 @@ span._draggable_1tp7v_5 > * {
1694
1695
  ._wrapper_q784j_13 {
1695
1696
  display: inline-block;
1696
1697
  width: unset;
1697
- min-width: var(--f8b9a976);
1698
+ min-width: var(--v07aa23cc);
1698
1699
  }
1699
1700
  ._wrapper_q784j_13._block_q784j_18 {
1700
1701
  display: block;
1701
- width: var(--f8b9a976);
1702
+ width: var(--v07aa23cc);
1702
1703
  }
1703
1704
  ._wrapper_q784j_13 .el-tag .el-icon {
1704
1705
  display: none;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@wfrog/vc-ui",
3
- "version": "1.9.11",
3
+ "version": "1.9.13",
4
4
  "packageManager": "pnpm@10.20.0",
5
5
  "description": "vue3 组件库 vc-ui",
6
6
  "author": "wellfrog",