hzzt-plus 2.0.5 → 2.0.7

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 (104) hide show
  1. package/dist/index.full.js +77 -74
  2. package/dist/index.full.min.js +10 -10
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +10 -10
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +77 -74
  7. package/dist/locale/en.js +1 -1
  8. package/dist/locale/en.min.js +1 -1
  9. package/dist/locale/en.min.mjs +1 -1
  10. package/dist/locale/en.mjs +1 -1
  11. package/dist/locale/zh-cn.js +1 -1
  12. package/dist/locale/zh-cn.min.js +1 -1
  13. package/dist/locale/zh-cn.min.mjs +1 -1
  14. package/dist/locale/zh-cn.mjs +1 -1
  15. package/es/components/cascader/index.mjs +2 -2
  16. package/es/components/cascader/src/cascader.mjs +36 -122
  17. package/es/components/cascader/src/cascader.mjs.map +1 -1
  18. package/es/components/cascader/src/cascader2.mjs +122 -36
  19. package/es/components/cascader/src/cascader2.mjs.map +1 -1
  20. package/es/components/click-input/index.mjs +2 -2
  21. package/es/components/click-input/src/click-input.mjs +84 -21
  22. package/es/components/click-input/src/click-input.mjs.map +1 -1
  23. package/es/components/click-input/src/click-input2.mjs +21 -84
  24. package/es/components/click-input/src/click-input2.mjs.map +1 -1
  25. package/es/components/collapse/index.mjs +2 -2
  26. package/es/components/collapse/src/collapse.mjs +0 -88
  27. package/es/components/collapse/src/collapse.mjs.map +1 -1
  28. package/es/components/collapse/src/collapse2.mjs +88 -0
  29. package/es/components/collapse/src/collapse2.mjs.map +1 -1
  30. package/es/components/icon/index.d.ts +432 -3
  31. package/es/components/icon/index.mjs +12 -11
  32. package/es/components/icon/index.mjs.map +1 -1
  33. package/es/components/icon/src/index.mjs +4 -1
  34. package/es/components/icon/src/index.mjs.map +1 -1
  35. package/es/components/index.mjs +5 -5
  36. package/es/components/input-range/index.mjs +2 -2
  37. package/es/components/input-range/src/input-range.mjs +26 -76
  38. package/es/components/input-range/src/input-range.mjs.map +1 -1
  39. package/es/components/input-range/src/input-range2.mjs +76 -26
  40. package/es/components/input-range/src/input-range2.mjs.map +1 -1
  41. package/es/components/lazy-list/index.mjs +2 -2
  42. package/es/components/lazy-list/src/lazy-list.mjs +22 -80
  43. package/es/components/lazy-list/src/lazy-list.mjs.map +1 -1
  44. package/es/components/lazy-list/src/lazy-list2.mjs +80 -22
  45. package/es/components/lazy-list/src/lazy-list2.mjs.map +1 -1
  46. package/es/components/select-input/index.mjs +2 -2
  47. package/es/components/select-input/src/select-input.mjs +45 -124
  48. package/es/components/select-input/src/select-input.mjs.map +1 -1
  49. package/es/components/select-input/src/select-input2.mjs +124 -45
  50. package/es/components/select-input/src/select-input2.mjs.map +1 -1
  51. package/es/components/tab/index.d.ts +2 -0
  52. package/es/components/tab/src/index.mjs +10 -9
  53. package/es/components/tab/src/index.mjs.map +1 -1
  54. package/es/components/tab/src/index.vue.d.ts +2 -0
  55. package/es/index.mjs +5 -5
  56. package/es/version.d.ts +1 -1
  57. package/es/version.mjs +1 -1
  58. package/es/version.mjs.map +1 -1
  59. package/lib/components/cascader/index.js +2 -2
  60. package/lib/components/cascader/src/cascader.js +36 -121
  61. package/lib/components/cascader/src/cascader.js.map +1 -1
  62. package/lib/components/cascader/src/cascader2.js +121 -36
  63. package/lib/components/cascader/src/cascader2.js.map +1 -1
  64. package/lib/components/click-input/index.js +2 -2
  65. package/lib/components/click-input/src/click-input.js +84 -22
  66. package/lib/components/click-input/src/click-input.js.map +1 -1
  67. package/lib/components/click-input/src/click-input2.js +22 -84
  68. package/lib/components/click-input/src/click-input2.js.map +1 -1
  69. package/lib/components/collapse/index.js +2 -2
  70. package/lib/components/collapse/src/collapse.js +0 -91
  71. package/lib/components/collapse/src/collapse.js.map +1 -1
  72. package/lib/components/collapse/src/collapse2.js +91 -0
  73. package/lib/components/collapse/src/collapse2.js.map +1 -1
  74. package/lib/components/icon/index.d.ts +432 -3
  75. package/lib/components/icon/index.js +14 -13
  76. package/lib/components/icon/index.js.map +1 -1
  77. package/lib/components/icon/src/index.js +4 -1
  78. package/lib/components/icon/src/index.js.map +1 -1
  79. package/lib/components/index.js +5 -5
  80. package/lib/components/input-range/index.js +2 -2
  81. package/lib/components/input-range/src/input-range.js +27 -76
  82. package/lib/components/input-range/src/input-range.js.map +1 -1
  83. package/lib/components/input-range/src/input-range2.js +76 -27
  84. package/lib/components/input-range/src/input-range2.js.map +1 -1
  85. package/lib/components/lazy-list/index.js +2 -2
  86. package/lib/components/lazy-list/src/lazy-list.js +23 -80
  87. package/lib/components/lazy-list/src/lazy-list.js.map +1 -1
  88. package/lib/components/lazy-list/src/lazy-list2.js +80 -23
  89. package/lib/components/lazy-list/src/lazy-list2.js.map +1 -1
  90. package/lib/components/select-input/index.js +2 -2
  91. package/lib/components/select-input/src/select-input.js +46 -124
  92. package/lib/components/select-input/src/select-input.js.map +1 -1
  93. package/lib/components/select-input/src/select-input2.js +124 -46
  94. package/lib/components/select-input/src/select-input2.js.map +1 -1
  95. package/lib/components/tab/index.d.ts +2 -0
  96. package/lib/components/tab/src/index.js +9 -8
  97. package/lib/components/tab/src/index.js.map +1 -1
  98. package/lib/components/tab/src/index.vue.d.ts +2 -0
  99. package/lib/index.js +5 -5
  100. package/lib/version.d.ts +1 -1
  101. package/lib/version.js +1 -1
  102. package/lib/version.js.map +1 -1
  103. package/package.json +1 -1
  104. package/web-types.json +1 -1
@@ -1,50 +1,129 @@
1
- import '../../../utils/index.mjs';
1
+ import { defineComponent, ref, computed, watch, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, renderSlot, createVNode, mergeProps, withCtx, Fragment, renderList, createBlock, createTextVNode, toDisplayString, createCommentVNode } from 'vue';
2
+ import { selectInputProps, selectInputEmits } from './select-input.mjs';
2
3
  import '../../../hooks/index.mjs';
3
- import '../../../constants/index.mjs';
4
- import { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';
5
- import { useSizeProp } from '../../../hooks/use-size/index.mjs';
6
- import { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';
7
- import { isString } from '@vue/shared';
4
+ import { useFormSize, useFormDisabled, ElInput, ElLink } from 'element-plus';
5
+ import HzztTitle from '../../title/src/title2.mjs';
6
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
7
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
8
+ import { useGlobalSize } from '../../../hooks/use-size/index.mjs';
9
+ import { numberToLetter } from '../../../hooks/use-letter/index.mjs';
8
10
 
9
- const selectInputProps = buildProps({
10
- modelValue: {
11
- type: definePropType([
12
- String,
13
- Number
14
- ]),
15
- default: ""
16
- },
17
- indexType: {
18
- type: String,
19
- default: "number"
20
- },
21
- disabled: Boolean,
22
- replace: Boolean,
23
- label: String,
24
- options: {
25
- type: definePropType(Array),
26
- default: () => []
27
- },
28
- inputProps: Object,
29
- customProps: Object,
30
- position: {
31
- type: String,
32
- default: "left"
33
- },
34
- formatLabel: {
35
- type: Function
36
- },
37
- split: {
38
- type: String,
39
- default: ""
40
- },
41
- size: useSizeProp
11
+ const _hoisted_1 = { slot: "append" };
12
+ const _hoisted_2 = { key: 0 };
13
+ const __default__ = defineComponent({
14
+ name: "HzztSelectInput"
42
15
  });
43
- const selectInputEmits = {
44
- [UPDATE_MODEL_EVENT]: (value) => isString(value),
45
- input: (value) => isString(value),
46
- change: (value) => isString(value)
47
- };
16
+ const _sfc_main = /* @__PURE__ */ defineComponent({
17
+ ...__default__,
18
+ props: selectInputProps,
19
+ emits: selectInputEmits,
20
+ setup(__props, { emit }) {
21
+ const props = __props;
22
+ const inputVal = ref(props.modelValue);
23
+ const nsInput = useNamespace("select-input");
24
+ const formSize = useFormSize();
25
+ const formDisabled = useFormDisabled();
26
+ const trueSize = computed(() => props.size || formSize.value || useGlobalSize().value);
27
+ const trueDisabled = computed(() => props.disabled || formDisabled.value);
28
+ const containerCls = computed(() => [
29
+ nsInput.b(),
30
+ nsInput.m(trueSize.value)
31
+ ]);
32
+ const inputContainerCls = computed(() => [
33
+ "flex",
34
+ props.position === "top" ? "column" : "row align-items-center"
35
+ ]);
36
+ const inputCls = computed(() => [
37
+ "flex-1",
38
+ props.label ? props.position === "top" ? "margin-b-1" : "margin-l-1" : ""
39
+ ]);
40
+ const _inputProps = computed(() => ({
41
+ disabled: trueDisabled.value,
42
+ clearable: true,
43
+ ...props.inputProps
44
+ }));
45
+ watch(() => props.modelValue, (v) => {
46
+ inputVal.value = v;
47
+ });
48
+ function input(val) {
49
+ emit("update:modelValue", val);
50
+ emit("input", val);
51
+ }
52
+ function change(val) {
53
+ emit("change", val);
54
+ }
55
+ function getLinkName(item, index) {
56
+ let prefix = "";
57
+ if (props.indexType == "number") {
58
+ prefix = `\uFF08${index + 1}\uFF09`;
59
+ } else if (props.indexType == "letter") {
60
+ prefix = `\uFF08${numberToLetter(index)}\uFF09`;
61
+ }
62
+ return prefix + (item.label || item.value);
63
+ }
64
+ function select(item) {
65
+ const value = item.value || item.label;
66
+ let content = "";
67
+ if (!inputVal.value)
68
+ inputVal.value = "";
69
+ if (props.formatLabel) {
70
+ content = props.formatLabel(value);
71
+ } else if (props.replace) {
72
+ content = value;
73
+ } else {
74
+ content = inputVal.value ? `${inputVal.value}${props.split}${value}` : value;
75
+ }
76
+ inputVal.value = content;
77
+ input(content);
78
+ change(content);
79
+ }
80
+ return (_ctx, _cache) => {
81
+ return openBlock(), createElementBlock("div", {
82
+ class: normalizeClass(unref(containerCls))
83
+ }, [
84
+ createElementVNode("div", {
85
+ class: normalizeClass(unref(inputContainerCls))
86
+ }, [
87
+ renderSlot(_ctx.$slots, "title", {}, () => [
88
+ createVNode(HzztTitle, { label: _ctx.label }, null, 8, ["label"])
89
+ ]),
90
+ createVNode(unref(ElInput), mergeProps({
91
+ ref: "inputRef",
92
+ class: unref(inputCls),
93
+ modelValue: inputVal.value,
94
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => inputVal.value = $event)
95
+ }, unref(_inputProps), {
96
+ onInput: input,
97
+ onChange: change
98
+ }), {
99
+ default: withCtx(() => [
100
+ createElementVNode("template", _hoisted_1, [
101
+ renderSlot(_ctx.$slots, "append")
102
+ ])
103
+ ]),
104
+ _: 3
105
+ }, 16, ["class", "modelValue"])
106
+ ], 2),
107
+ _ctx.options.length && !unref(trueDisabled) ? (openBlock(), createElementBlock("div", _hoisted_2, [
108
+ (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.options, (item, index) => {
109
+ return openBlock(), createBlock(unref(ElLink), mergeProps({
110
+ key: index,
111
+ class: "margin-r-4"
112
+ }, _ctx.customProps, {
113
+ onClick: ($event) => select(item)
114
+ }), {
115
+ default: withCtx(() => [
116
+ createTextVNode(toDisplayString(getLinkName(item, index)), 1)
117
+ ]),
118
+ _: 2
119
+ }, 1040, ["onClick"]);
120
+ }), 128))
121
+ ])) : createCommentVNode("v-if", true)
122
+ ], 2);
123
+ };
124
+ }
125
+ });
126
+ var SelectInput = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "select-input.vue"]]);
48
127
 
49
- export { selectInputEmits, selectInputProps };
128
+ export { SelectInput as default };
50
129
  //# sourceMappingURL=select-input2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"select-input2.mjs","sources":["../../../../../../packages/components/select-input/src/select-input.ts"],"sourcesContent":["import {buildProps, definePropType, isString} from '@hzzt-plus/utils'\nimport {useSizeProp} from \"@hzzt-plus/hooks\";\n\nimport type { ExtractPropTypes } from 'vue'\nimport type SelectInput from './select-input.vue'\nimport {UPDATE_MODEL_EVENT} from \"@hzzt-plus/constants\";\nimport {OptionType} from \"@hzzt-plus/components/select/src/select\";\n\nexport const selectInputProps = buildProps({\n modelValue: {\n type: definePropType<string | number | null | undefined>([\n String,\n Number,\n ]),\n default: '',\n },\n indexType: {\n type: String,\n default: 'number',\n },\n disabled: Boolean,\n replace: Boolean,\n label: String,\n options: {\n type: definePropType<OptionType[]>(Array),\n default: () => [],\n },\n inputProps: Object,\n customProps: Object,\n position: {\n type: String,\n default: 'left',\n },\n formatLabel: {\n type: Function,\n },\n split: {\n type: String,\n default: '',\n },\n size: useSizeProp,\n})\n\nexport type SelectInputProps = ExtractPropTypes<typeof selectInputProps>\n\nexport const selectInputEmits = {\n [UPDATE_MODEL_EVENT]: (value: string | undefined) => isString(value),\n input: (value: string | undefined) => isString(value),\n change: (value: string | undefined) => isString(value),\n}\nexport type SelectInputEmits = typeof selectInputEmits\n\nexport type SelectInputInstance = InstanceType<typeof SelectInput>\n"],"names":[],"mappings":";;;;;;;;AAGY,MAAC,gBAAgB,GAAG,UAAU,CAAC;AAC3C,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,cAAc,CAAC;AACzB,MAAM,MAAM;AACZ,MAAM,MAAM;AACZ,KAAK,CAAC;AACN,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,QAAQ;AACrB,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,MAAM,EAAE;AACrB,GAAG;AACH,EAAE,UAAU,EAAE,MAAM;AACpB,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,MAAM;AACnB,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,QAAQ;AAClB,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,IAAI,EAAE,WAAW;AACnB,CAAC,EAAE;AACS,MAAC,gBAAgB,GAAG;AAChC,EAAE,CAAC,kBAAkB,GAAG,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,KAAK,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AACnC,EAAE,MAAM,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AACpC;;;;"}
1
+ {"version":3,"file":"select-input2.mjs","sources":["../../../../../../packages/components/select-input/src/select-input.vue"],"sourcesContent":["<template>\n <div :class=\"containerCls\">\n <div :class=\"inputContainerCls\">\n <slot name=\"title\">\n <hzzt-title :label=\"label\"></hzzt-title>\n </slot>\n <el-input ref=\"inputRef\"\n :class=\"inputCls\"\n v-model=\"inputVal\"\n v-bind=\"_inputProps\"\n @input=\"input\"\n @change=\"change\"\n >\n <template slot=\"append\">\n <slot name=\"append\"></slot>\n </template>\n </el-input>\n </div>\n <div v-if=\"options.length&&!trueDisabled\">\n <el-link v-for=\"(item, index) in options\" :key=\"index\" class=\"margin-r-4\" v-bind=\"customProps\" @click=\"select(item)\">\n {{ getLinkName(item, index) }}\n </el-link>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\n import {computed, ref, watch} from 'vue'\n import {selectInputEmits, selectInputProps} from './select-input'\n import {useGlobalSize, useNamespace, numberToLetter} from \"@hzzt-plus/hooks\";\n import {useFormDisabled, useFormSize} from \"element-plus\";\n import HzztTitle from \"@hzzt-plus/components/title/src/title.vue\";\n import {ElInput, ElLink} from 'element-plus'\n import {OptionType} from \"@hzzt-plus/components/select/src/select\";\n\n defineOptions({\n name: 'HzztSelectInput',\n })\n\n const props = defineProps(selectInputProps)\n const emit = defineEmits(selectInputEmits)\n\n const inputVal = ref(props.modelValue);\n\n const nsInput = useNamespace('select-input')\n const formSize = useFormSize()\n const formDisabled = useFormDisabled()\n\n const trueSize = computed(\n () => props.size || formSize.value || useGlobalSize().value\n )\n\n const trueDisabled = computed(() => props.disabled || formDisabled.value)\n\n const containerCls = computed(() => [\n nsInput.b(),\n nsInput.m(trueSize.value),\n ])\n\n const inputContainerCls = computed(() => [\n 'flex',\n props.position === 'top' ? 'column' : 'row align-items-center'\n ])\n\n const inputCls = computed(() => [\n 'flex-1',\n props.label ? props.position === 'top' ? 'margin-b-1' : 'margin-l-1' : ''\n ])\n\n const _inputProps = computed(() => ({\n disabled: trueDisabled.value,\n clearable: true,\n ...props.inputProps,\n }))\n\n watch(() => props.modelValue, (v) => {\n inputVal.value = v;\n })\n\n function input(val: string) {\n emit('update:modelValue', val);\n emit('input', val);\n }\n\n function change(val: string) {\n emit('change', val);\n }\n\n function getLinkName(item: OptionType, index: number) {\n let prefix = '';\n if (props.indexType == 'number') {\n prefix = `(${index + 1})`\n } else if (props.indexType == 'letter') {\n prefix = `(${numberToLetter(index)})`\n }\n return prefix + (item.label || item.value);\n }\n\n function select(item: OptionType) {\n const value = item.value||item.label;\n let content = '';\n if (!inputVal.value) inputVal.value = '';\n if (props.formatLabel) {\n content = props.formatLabel(value);\n } else if (props.replace) {\n content = value;\n } else {\n content = inputVal.value ? `${inputVal.value}${props.split}${value}` : value;\n }\n inputVal.value = content;\n input(content);\n change(content);\n }\n\n</script>\n"],"names":["_openBlock","_createElementBlock"],"mappings":"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"}
@@ -32,6 +32,7 @@ export declare const HzztTab: import("hzzt-plus/es/utils").SFCWithInstall<import
32
32
  customTabList: import("vue").ComputedRef<{
33
33
  number: number;
34
34
  hide: boolean;
35
+ bgColor: string;
35
36
  name: string;
36
37
  label: string;
37
38
  key: string;
@@ -41,6 +42,7 @@ export declare const HzztTab: import("hzzt-plus/es/utils").SFCWithInstall<import
41
42
  label: string;
42
43
  number: number;
43
44
  hide: boolean;
45
+ bgColor: string;
44
46
  }, event: Event) => void;
45
47
  close: (index: number, event: Event) => void;
46
48
  HzztIcon: import("vue").DefineComponent<{
@@ -1,4 +1,4 @@
1
- import { defineComponent, computed, openBlock, createElementBlock, createElementVNode, Fragment, renderList, unref, normalizeClass, toDisplayString, createCommentVNode, createBlock, renderSlot } from 'vue';
1
+ import { defineComponent, computed, openBlock, createElementBlock, createElementVNode, Fragment, renderList, unref, normalizeClass, toDisplayString, normalizeStyle, createCommentVNode, createBlock, renderSlot } from 'vue';
2
2
  import HzztIcon from '../../icon/src/index.mjs';
3
3
  import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
4
4
 
@@ -7,11 +7,7 @@ const _hoisted_2 = { class: "flex align-items-center" };
7
7
  const _hoisted_3 = { class: "flex" };
8
8
  const _hoisted_4 = ["onClick"];
9
9
  const _hoisted_5 = { class: "hzzt-tab-badge" };
10
- const _hoisted_6 = {
11
- key: 0,
12
- class: "hzzt-tab-badge-count"
13
- };
14
- const _hoisted_7 = { class: "flex wrap" };
10
+ const _hoisted_6 = { class: "flex wrap" };
15
11
  const __default__ = defineComponent({
16
12
  name: "HzztTab"
17
13
  });
@@ -39,7 +35,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
39
35
  key: `${tab.name}-${tab.number}`,
40
36
  ...tab,
41
37
  number: Number(tab.number || 0),
42
- hide: tab.hide
38
+ hide: tab.hide,
39
+ bgColor: tab.bgColor || ""
43
40
  };
44
41
  }).filter((tab) => !tab.hide));
45
42
  function tabClick(tab, event) {
@@ -66,7 +63,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
66
63
  createElementVNode("p", {
67
64
  class: normalizeClass([{ active: __props.modelValue === tab.name }, "hzzt-tab-badge-text"])
68
65
  }, toDisplayString(tab.label), 3),
69
- tab.number && tab.number !== 0 ? (openBlock(), createElementBlock("p", _hoisted_6, toDisplayString(tab.number > 999 ? "999+" : tab.number), 1)) : createCommentVNode("v-if", true),
66
+ tab.number && tab.number !== 0 ? (openBlock(), createElementBlock("p", {
67
+ key: 0,
68
+ class: "hzzt-tab-badge-count",
69
+ style: normalizeStyle({ backgroundColor: tab.bgColor })
70
+ }, toDisplayString(tab.number > 999 ? "999+" : tab.number), 5)) : createCommentVNode("v-if", true),
70
71
  __props.closable ? (openBlock(), createBlock(HzztIcon, {
71
72
  key: 1,
72
73
  class: "is-icon-close",
@@ -80,7 +81,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
80
81
  renderSlot(_ctx.$slots, "filter"),
81
82
  renderSlot(_ctx.$slots, "extra")
82
83
  ]),
83
- createElementVNode("div", _hoisted_7, [
84
+ createElementVNode("div", _hoisted_6, [
84
85
  renderSlot(_ctx.$slots, "right")
85
86
  ])
86
87
  ]);
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../../../../packages/components/tab/src/index.vue"],"sourcesContent":["<template>\n <div class=\"hzzt-tab flex align-items-center justify-content-between wrap\">\n <div class=\"flex align-items-center\">\n <div class=\"flex\">\n <div\n v-for=\"(tab, index) in customTabList\"\n :key=\"tab.key\"\n class=\"hzzt-tab-pane\"\n @click=\"tabClick(tab, $event)\"\n >\n <div class=\"hzzt-tab-badge\">\n <p\n :class=\"{ active: modelValue === tab.name }\"\n class=\"hzzt-tab-badge-text\"\n >\n {{ tab.label }}\n </p>\n <p\n v-if=\"tab.number && tab.number !== 0\"\n class=\"hzzt-tab-badge-count\"\n >\n {{ tab.number > 999 ? '999+' : tab.number }}\n </p>\n <hzzt-icon\n v-if=\"closable\"\n class=\"is-icon-close\"\n name=\"close\"\n @click=\"close(index, $event)\"\n />\n </div>\n </div>\n </div>\n <slot name=\"filter\" />\n <slot name=\"extra\" />\n </div>\n <div class=\"flex wrap\">\n <slot name=\"right\" />\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport HzztIcon from '@hzzt-plus/components/icon/src/index.vue'\n\ndefineOptions({\n name: 'HzztTab',\n})\n\ndeclare type Tab = {\n name: string\n label: string\n number: number\n hide: boolean\n}\n\nconst props = defineProps({\n tabList: {\n type: Array,\n default: () => [],\n },\n modelValue: {\n type: [Number, String, Array],\n },\n closable: {\n type: Boolean,\n default: () => false,\n },\n})\n\nconst emit = defineEmits(['update:modelValue', 'tab-click', 'tab-close'])\n\nconst customTabList = computed(() =>\n props.tabList\n .map((value) => {\n const tab = value as Tab\n return {\n key: `${tab.name}-${tab.number}` as string,\n ...tab,\n number: Number(tab.number || 0),\n hide: tab.hide,\n }\n })\n .filter((tab) => !tab.hide)\n)\n\nfunction tabClick(tab: Tab, event: Event) {\n if (tab.name === props.modelValue) return\n emit('update:modelValue', tab.name)\n emit('tab-click', tab, event)\n}\n\nfunction close(index: number, event: Event) {\n event.stopPropagation()\n emit('tab-close', index)\n}\n</script>\n"],"names":["_openBlock","_createElementBlock"],"mappings":";;;;;;;;;;;;;;mCA6Cc,CAAA;AAAA,EACZ,IAAM,EAAA,SAAA;AACR,CAAA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;AAyBA,IAAA,MAAM,aAAgB,GAAA,QAAA,CAAA,MAAA,KAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,KAAA,KAAA;AAAA,MAAS,MAC7B,GAAA,GAAM,KACH,CAAA;AACC,MAAA,OAAA;AACA,QAAO,GAAA,EAAA,CAAA,EAAA,GAAA,CAAA,IAAA,CAAA,CAAA,EAAA,GAAA,CAAA,MAAA,CAAA,CAAA;AAAA,QAAA;AACyB,QAAA,MAC3B,EAAA,MAAA,CAAA,GAAA,CAAA,MAAA,IAAA,CAAA,CAAA;AAAA,QAAA,IACK,EAAA,GAAA,CAAA,IAAA;AAAsB,OAAA,CAAA;AACpB,KACZ,CAAA,CAAA,MAAA,CAAA,CAAA,GAAA,KAAA,CAAA,GAAA,CAAA,IAAA,CAAA,CAAA,CAAA;AAAA,IAAA,SAED,QAAgB,CAAA,GAAA,OAAS,EAAA;AAAA,MAC9B,IAAA,GAAA,CAAA,IAAA,KAAA,KAAA,CAAA,UAAA;AAEA,QAAS,OAAA;AACP,MAAI,IAAA,CAAA,mBAAmB,EAAA,GAAA,CAAA,IAAA,CAAA,CAAA;AAAY,MAAA,IAAA,CAAA,WAAA,EAAA,GAAA,EAAA,KAAA,CAAA,CAAA;AACnC,KAAK;AACL,IAAK,SAAA,KAAA,CAAA,KAAa,OAAU,EAAA;AAAA,MAC9B,KAAA,CAAA,eAAA,EAAA,CAAA;AAEA,MAAS,IAAA,CAAA,kBAAmC,CAAA,CAAA;AAC1C,KAAA;AACA,IAAA,OAAK,aAAa,KAAK;AAAA,MACzB,OAAAA,SAAA,EAAA,EAAAC,kBAAA,CAAA,KAAA,EAAA,UAAA,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index.mjs","sources":["../../../../../../packages/components/tab/src/index.vue"],"sourcesContent":["<template>\n <div class=\"hzzt-tab flex align-items-center justify-content-between wrap\">\n <div class=\"flex align-items-center\">\n <div class=\"flex\">\n <div\n v-for=\"(tab, index) in customTabList\"\n :key=\"tab.key\"\n class=\"hzzt-tab-pane\"\n @click=\"tabClick(tab, $event)\"\n >\n <div class=\"hzzt-tab-badge\">\n <p\n :class=\"{ active: modelValue === tab.name }\"\n class=\"hzzt-tab-badge-text\"\n >\n {{ tab.label }}\n </p>\n <p\n v-if=\"tab.number && tab.number !== 0\"\n class=\"hzzt-tab-badge-count\"\n :style=\"{ backgroundColor: tab.bgColor }\"\n >\n {{ tab.number > 999 ? '999+' : tab.number }}\n </p>\n <hzzt-icon\n v-if=\"closable\"\n class=\"is-icon-close\"\n name=\"close\"\n @click=\"close(index, $event)\"\n />\n </div>\n </div>\n </div>\n <slot name=\"filter\" />\n <slot name=\"extra\" />\n </div>\n <div class=\"flex wrap\">\n <slot name=\"right\" />\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport HzztIcon from '@hzzt-plus/components/icon/src/index.vue'\n\ndefineOptions({\n name: 'HzztTab',\n})\n\ndeclare type Tab = {\n name: string\n label: string\n number: number\n hide: boolean\n bgColor: string\n}\n\nconst props = defineProps({\n tabList: {\n type: Array,\n default: () => [],\n },\n modelValue: {\n type: [Number, String, Array],\n },\n closable: {\n type: Boolean,\n default: () => false,\n },\n})\n\nconst emit = defineEmits(['update:modelValue', 'tab-click', 'tab-close'])\n\nconst customTabList = computed(() =>\n props.tabList\n .map((value) => {\n const tab = value as Tab\n return {\n key: `${tab.name}-${tab.number}` as string,\n ...tab,\n number: Number(tab.number || 0),\n hide: tab.hide,\n bgColor: tab.bgColor || '',\n }\n })\n .filter((tab) => !tab.hide)\n)\n\nfunction tabClick(tab: Tab, event: Event) {\n if (tab.name === props.modelValue) return\n emit('update:modelValue', tab.name)\n emit('tab-click', tab, event)\n}\n\nfunction close(index: number, event: Event) {\n event.stopPropagation()\n emit('tab-close', index)\n}\n</script>\n"],"names":["_openBlock","_createElementBlock"],"mappings":";;;;;;;;;;mCA8Cc,CAAA;AAAA,EACZ,IAAM,EAAA,SAAA;AACR,CAAA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;AA0BA,IAAA,MAAM,aAAgB,GAAA,QAAA,CAAA,MAAA,KAAA,CAAA,OAAA,CAAA,GAAA,CAAA,CAAA,KAAA,KAAA;AAAA,MAAS,MAC7B,GAAA,GAAM,KACH,CAAA;AACC,MAAA,OAAA;AACA,QAAO,GAAA,EAAA,CAAA,EAAA,GAAA,CAAA,IAAA,CAAA,CAAA,EAAA,GAAA,CAAA,MAAA,CAAA,CAAA;AAAA,QAAA;AACyB,QAAA,MAC3B,EAAA,MAAA,CAAA,GAAA,CAAA,MAAA,IAAA,CAAA,CAAA;AAAA,QAAA,IACK,EAAA,GAAA,CAAA,IAAA;AAAsB,QAAA,SACpB,GAAA,CAAA,OAAA,IAAA,EAAA;AAAA,OACV,CAAA;AAAwB,KAC1B,CAAA,CAAA,MAAA,CAAA,CAAA,GAAA,KAAA,CAAA,GAAA,CAAA,IAAA,CAAA,CAAA,CAAA;AAAA,IAAA,SAED,QAAgB,CAAA,GAAA,OAAS,EAAA;AAAA,MAC9B,IAAA,GAAA,CAAA,IAAA,KAAA,KAAA,CAAA,UAAA;AAEA,QAAS,OAAA;AACP,MAAI,IAAA,CAAA,mBAAmB,EAAA,GAAA,CAAA,IAAA,CAAA,CAAA;AAAY,MAAA,IAAA,CAAA,WAAA,EAAA,GAAA,EAAA,KAAA,CAAA,CAAA;AACnC,KAAK;AACL,IAAK,SAAA,KAAA,CAAA,KAAa,OAAU,EAAA;AAAA,MAC9B,KAAA,CAAA,eAAA,EAAA,CAAA;AAEA,MAAS,IAAA,CAAA,kBAAmC,CAAA,CAAA;AAC1C,KAAA;AACA,IAAA,OAAK,aAAa,KAAK;AAAA,MACzB,OAAAA,SAAA,EAAA,EAAAC,kBAAA,CAAA,KAAA,EAAA,UAAA,EAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -3,6 +3,7 @@ declare type Tab = {
3
3
  label: string;
4
4
  number: number;
5
5
  hide: boolean;
6
+ bgColor: string;
6
7
  };
7
8
  declare const _default: import("vue").DefineComponent<{
8
9
  tabList: {
@@ -38,6 +39,7 @@ declare const _default: import("vue").DefineComponent<{
38
39
  customTabList: import("vue").ComputedRef<{
39
40
  number: number;
40
41
  hide: boolean;
42
+ bgColor: string;
41
43
  name: string;
42
44
  label: string;
43
45
  key: string;
package/es/index.mjs CHANGED
@@ -23,20 +23,20 @@ export { HzztCheckButton } from './components/check-button/index.mjs';
23
23
  export { HzztQuarterPicker } from './components/quarter-picker/index.mjs';
24
24
  export { scanEmits, scanProps } from './components/scan/src/scan.mjs';
25
25
  export { HzztScan } from './components/scan/index.mjs';
26
- export { selectInputEmits, selectInputProps } from './components/select-input/src/select-input2.mjs';
26
+ export { selectInputEmits, selectInputProps } from './components/select-input/src/select-input.mjs';
27
27
  export { HzztSelectInput } from './components/select-input/index.mjs';
28
28
  export { selectTextareaEmits, selectTextareaProps } from './components/select-textarea/src/select-textarea.mjs';
29
29
  export { HzztSelectTextarea } from './components/select-textarea/index.mjs';
30
- export { inputRangeEmits, inputRangeProps } from './components/input-range/src/input-range2.mjs';
30
+ export { inputRangeEmits, inputRangeProps } from './components/input-range/src/input-range.mjs';
31
31
  export { HzztInputRange } from './components/input-range/index.mjs';
32
- export { cascaderEmits, cascaderProps } from './components/cascader/src/cascader2.mjs';
32
+ export { cascaderEmits, cascaderProps } from './components/cascader/src/cascader.mjs';
33
33
  export { HzztCascader } from './components/cascader/index.mjs';
34
34
  export { selectEmits, selectProps } from './components/select/src/select.mjs';
35
35
  export { HzztSelect } from './components/select/index.mjs';
36
- export { clickInputEmits, clickInputProps } from './components/click-input/src/click-input.mjs';
36
+ export { clickInputEmits, clickInputProps } from './components/click-input/src/click-input2.mjs';
37
37
  export { HzztClickInput } from './components/click-input/index.mjs';
38
38
  export { HzztScroll } from './components/scroll/index.mjs';
39
- export { lazyListEmits, lazyListProps } from './components/lazy-list/src/lazy-list2.mjs';
39
+ export { lazyListEmits, lazyListProps } from './components/lazy-list/src/lazy-list.mjs';
40
40
  export { HzztLazyList } from './components/lazy-list/index.mjs';
41
41
  export { INSTALLED_KEY } from './constants/key.mjs';
42
42
  export { componentSizeMap, componentSizes } from './constants/size.mjs';
package/es/version.d.ts CHANGED
@@ -1 +1 @@
1
- export declare const version = "2.0.5";
1
+ export declare const version = "2.0.7";
package/es/version.mjs CHANGED
@@ -1,4 +1,4 @@
1
- const version = "2.0.5";
1
+ const version = "2.0.7";
2
2
 
3
3
  export { version };
4
4
  //# sourceMappingURL=version.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.mjs","sources":["../../../packages/hzzt-plus/version.ts"],"sourcesContent":["export const version = '2.0.5'\n"],"names":[],"mappings":"AAAY,MAAC,OAAO,GAAG;;;;"}
1
+ {"version":3,"file":"version.mjs","sources":["../../../packages/hzzt-plus/version.ts"],"sourcesContent":["export const version = '2.0.7'\n"],"names":[],"mappings":"AAAY,MAAC,OAAO,GAAG;;;;"}
@@ -3,8 +3,8 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  require('../../utils/index.js');
6
- var cascader$1 = require('./src/cascader.js');
7
- var cascader = require('./src/cascader2.js');
6
+ var cascader$1 = require('./src/cascader2.js');
7
+ var cascader = require('./src/cascader.js');
8
8
  var install = require('../../utils/vue/install.js');
9
9
 
10
10
  const HzztCascader = install.withInstall(cascader$1["default"]);
@@ -2,131 +2,46 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var vue = require('vue');
6
- var cascader = require('./cascader2.js');
7
- var elementPlus = require('element-plus');
8
- require('../../../hooks/index.js');
9
5
  require('../../../utils/index.js');
10
- var utils = require('./hooks/utils.js');
11
- var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
12
- var index = require('../../../hooks/use-namespace/index.js');
13
- var index$1 = require('../../../hooks/use-size/index.js');
6
+ require('../../../hooks/index.js');
7
+ require('../../../constants/index.js');
8
+ var runtime = require('../../../utils/vue/props/runtime.js');
9
+ var index = require('../../../hooks/use-size/index.js');
10
+ var event = require('../../../constants/event.js');
14
11
  var shared = require('@vue/shared');
15
12
 
16
- const __default__ = vue.defineComponent({
17
- name: "HzztCascader"
18
- });
19
- const _sfc_main = /* @__PURE__ */ vue.defineComponent({
20
- ...__default__,
21
- props: cascader.cascaderProps,
22
- emits: cascader.cascaderEmits,
23
- setup(__props, { emit }) {
24
- const props = __props;
25
- const attrs = vue.useAttrs();
26
- const inputVal = vue.ref(props.modelValue);
27
- const cascaderVal = vue.ref();
28
- const inputRef = vue.ref();
29
- const cascaderRef = vue.ref();
30
- const nsCascader = index.useNamespace("cascader");
31
- const formSize = elementPlus.useFormSize();
32
- const formDisabled = elementPlus.useFormDisabled();
33
- const trueSize = vue.computed(() => props.size || formSize.value || index$1.useGlobalSize().value);
34
- const trueDisabled = vue.computed(() => props.disabled || formDisabled.value);
35
- const containerCls = vue.computed(() => [
36
- "relative",
37
- nsCascader.b(),
38
- nsCascader.m(trueSize.value)
39
- ]);
40
- const inputCls = vue.computed(() => [
41
- nsCascader.e("input")
42
- ]);
43
- const cascaderCls = vue.computed(() => [
44
- nsCascader.e("cascader")
45
- ]);
46
- const _inputProps = vue.computed(() => ({
47
- disabled: trueDisabled.value,
48
- size: trueSize.value,
49
- clearable: props.clearable,
50
- placeholder: props.placeholder,
51
- readonly: props.readonly,
52
- ...attrs
53
- }));
54
- const _cascaderProps = vue.computed(() => ({
55
- options: props.options,
56
- disabled: trueDisabled.value,
57
- size: trueSize.value,
58
- clearable: props.clearable,
59
- placeholder: props.placeholder,
60
- props: { checkStrictly: true, expandTrigger: "hover" },
61
- filterable: true,
62
- separator: "/",
63
- showAllLevels: true,
64
- ...props.cascaderProps
65
- }));
66
- vue.watch(() => props.modelValue, (v) => {
67
- inputVal.value = v;
68
- getCascaderVal();
69
- });
70
- vue.watch(() => props.options, (v) => {
71
- if (!v)
72
- return;
73
- getCascaderVal();
74
- });
75
- getCascaderVal();
76
- function input(str) {
77
- emit("update:modelValue", str);
78
- emit("input", str);
79
- }
80
- function change(str) {
81
- emit("change", str);
82
- }
83
- function click(e) {
84
- cascaderRef.value.togglePopperVisible();
85
- const target = e.target;
86
- target.focus();
87
- }
88
- function cascaderChange(val) {
89
- const separator = _cascaderProps.value.separator || "/";
90
- inputVal.value = val ? shared.isArray(val) ? val.join(separator) : [val].join(separator) : "";
91
- input(inputVal.value);
92
- change(inputVal.value);
93
- }
94
- function getCascaderVal() {
95
- const separator = _cascaderProps.value.separator || "/";
96
- if (_cascaderProps.value.showAllLevels === false) {
97
- const list = utils.getCascaderId(props.modelValue, props.options);
98
- cascaderVal.value = list.join(separator);
99
- } else {
100
- cascaderVal.value = (props.modelValue || "").split(separator);
101
- }
102
- }
103
- return (_ctx, _cache) => {
104
- return vue.openBlock(), vue.createElementBlock("div", {
105
- class: vue.normalizeClass(vue.unref(containerCls))
106
- }, [
107
- vue.createVNode(vue.unref(elementPlus.ElInput), vue.mergeProps({
108
- class: vue.unref(inputCls),
109
- modelValue: inputVal.value,
110
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => inputVal.value = $event),
111
- ref_key: "inputRef",
112
- ref: inputRef
113
- }, vue.unref(_inputProps), {
114
- onInput: input,
115
- onClick: click,
116
- onChange: change
117
- }), null, 16, ["class", "modelValue"]),
118
- vue.createVNode(vue.unref(elementPlus.ElCascader), vue.mergeProps({
119
- class: vue.unref(cascaderCls),
120
- modelValue: cascaderVal.value,
121
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => cascaderVal.value = $event),
122
- ref_key: "cascaderRef",
123
- ref: cascaderRef
124
- }, vue.unref(_cascaderProps), { onChange: cascaderChange }), null, 16, ["class", "modelValue"])
125
- ], 2);
126
- };
13
+ const cascaderProps = runtime.buildProps({
14
+ cascaderProps: {
15
+ type: Object,
16
+ default: () => ({
17
+ showAllLevels: true
18
+ })
19
+ },
20
+ disabled: Boolean,
21
+ readonly: Boolean,
22
+ clearable: Boolean,
23
+ size: index.useSizeProp,
24
+ options: {
25
+ type: runtime.definePropType(Array),
26
+ default: () => []
27
+ },
28
+ placeholder: {
29
+ type: String,
30
+ default: ""
31
+ },
32
+ modelValue: {
33
+ type: runtime.definePropType([
34
+ String
35
+ ]),
36
+ default: ""
127
37
  }
128
38
  });
129
- var Cascader = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "cascader.vue"]]);
39
+ const cascaderEmits = {
40
+ [event.UPDATE_MODEL_EVENT]: (value) => shared.isString(value),
41
+ input: (value) => shared.isString(value),
42
+ change: (value) => shared.isString(value)
43
+ };
130
44
 
131
- exports["default"] = Cascader;
45
+ exports.cascaderEmits = cascaderEmits;
46
+ exports.cascaderProps = cascaderProps;
132
47
  //# sourceMappingURL=cascader.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"cascader.js","sources":["../../../../../../packages/components/cascader/src/cascader.vue"],"sourcesContent":["<template>\n <div :class=\"containerCls\">\n <el-input\n :class=\"inputCls\"\n v-model=\"inputVal\"\n ref=\"inputRef\"\n v-bind=\"_inputProps\"\n @input=\"input\"\n @click=\"click\"\n @change=\"change\"\n >\n </el-input>\n <el-cascader :class=\"cascaderCls\" v-model=\"cascaderVal\" ref=\"cascaderRef\" v-bind=\"_cascaderProps\"\n @change=\"cascaderChange\">\n </el-cascader>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\n import {cascaderEmits, cascaderProps} from './cascader'\n import {computed, ref, useAttrs, watch} from \"vue\";\n import {CascaderProps, useFormDisabled, useFormSize, CascaderValue} from \"element-plus\";\n import {useGlobalSize, useNamespace} from \"@hzzt-plus/hooks\";\n import {isArray} from '@hzzt-plus/utils'\n import {ElInput, ElCascader} from 'element-plus'\n import {getCascaderId} from \"./hooks/utils\";\n\n defineOptions({\n name: 'HzztCascader',\n })\n\n const props = defineProps(cascaderProps)\n const emit = defineEmits(cascaderEmits)\n\n const attrs = useAttrs();\n\n const inputVal = ref(props.modelValue);\n const cascaderVal = ref();\n const inputRef = ref();\n const cascaderRef = ref();\n\n const nsCascader = useNamespace('cascader');\n\n const formSize = useFormSize()\n const formDisabled = useFormDisabled()\n\n const trueSize = computed(\n () => props.size || formSize.value || useGlobalSize().value\n )\n\n const trueDisabled = computed(() => props.disabled || formDisabled.value)\n\n const containerCls = computed(() => [\n 'relative',\n nsCascader.b(),\n nsCascader.m(trueSize.value),\n ])\n\n const inputCls = computed(() => [\n nsCascader.e('input'),\n ])\n\n const cascaderCls = computed(() => [\n nsCascader.e('cascader'),\n ])\n\n const _inputProps = computed(() => ({\n disabled: trueDisabled.value,\n size: trueSize.value,\n clearable: props.clearable,\n placeholder: props.placeholder,\n readonly: props.readonly,\n ...attrs,\n }))\n\n const _cascaderProps = computed(() => ({\n options: props.options,\n disabled: trueDisabled.value,\n size: trueSize.value,\n clearable: props.clearable,\n placeholder: props.placeholder,\n props: {checkStrictly: true, expandTrigger: 'hover'} as CascaderProps,\n filterable: true,\n separator: '/',\n showAllLevels: true,\n ...props.cascaderProps,\n }))\n\n watch(() => props.modelValue, (v) => {\n inputVal.value = v;\n getCascaderVal();\n })\n\n watch(() => props.options, (v) => {\n if (!v) return;\n getCascaderVal();\n })\n\n getCascaderVal();\n\n function input(str: string) {\n emit('update:modelValue', str)\n emit('input', str)\n }\n\n function change(str: string) {\n emit('change', str)\n }\n\n function click(e: MouseEvent) {\n cascaderRef.value.togglePopperVisible();\n const target = e.target as HTMLInputElement;\n target.focus();\n }\n\n function cascaderChange(val: CascaderValue) {\n const separator = _cascaderProps.value.separator || '/';\n inputVal.value = val ? isArray(val) ? val.join(separator) : [val].join(separator) : '';\n input(inputVal.value);\n change(inputVal.value);\n }\n\n function getCascaderVal() {\n const separator = _cascaderProps.value.separator || '/';\n if (_cascaderProps.value.showAllLevels === false) {\n const list = getCascaderId(props.modelValue, props.options);\n cascaderVal.value = list.join(separator);\n } else {\n cascaderVal.value = (props.modelValue || '').split(separator);\n }\n }\n\n\n</script>\n"],"names":["useAttrs","ref","useNamespace","useFormSize","useFormDisabled","computed","useGlobalSize","watch","isArray","getCascaderId","_openBlock","_createElementBlock"],"mappings":"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"}
1
+ {"version":3,"file":"cascader.js","sources":["../../../../../../packages/components/cascader/src/cascader.ts"],"sourcesContent":["import {buildProps, definePropType, isString} from '@hzzt-plus/utils'\nimport {useSizeProp} from \"@hzzt-plus/hooks\";\nimport type {ExtractPropTypes} from 'vue'\nimport type Cascader from './cascader.vue'\nimport {UPDATE_MODEL_EVENT} from \"@hzzt-plus/constants\";\n\nexport type CascaderNodeValue = string | number\n\nexport interface CascaderOption extends Record<string, unknown> {\n label?: string\n value?: CascaderNodeValue\n children?: CascaderOption[]\n disabled?: boolean\n leaf?: boolean\n}\n\nexport const cascaderProps = buildProps({\n cascaderProps: {\n type: Object,\n default: () => ({\n showAllLevels: true,\n }),\n },\n disabled: Boolean,\n readonly: Boolean,\n clearable: Boolean,\n size: useSizeProp,\n options: {\n type: definePropType<CascaderOption[]>(Array),\n default: () => [] as CascaderOption[],\n },\n placeholder: {\n type: String,\n default: '',\n },\n modelValue: {\n type: definePropType<string | undefined>([\n String,\n ]),\n default: '',\n },\n})\n\nexport type CascaderProps = ExtractPropTypes<typeof cascaderProps>\n\nexport const cascaderEmits = {\n [UPDATE_MODEL_EVENT]: (value: string | undefined) => isString(value),\n input: (value: string | undefined) => isString(value),\n change: (value: string | undefined) => isString(value),\n}\nexport type CascaderEmits = typeof cascaderEmits\n\n\nexport type CascaderInstance = InstanceType<typeof Cascader>\n"],"names":["buildProps","useSizeProp","definePropType","UPDATE_MODEL_EVENT","isString"],"mappings":";;;;;;;;;;;;AAGY,MAAC,aAAa,GAAGA,kBAAU,CAAC;AACxC,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,OAAO;AACpB,MAAM,aAAa,EAAE,IAAI;AACzB,KAAK,CAAC;AACN,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,SAAS,EAAE,OAAO;AACpB,EAAE,IAAI,EAAEC,iBAAW;AACnB,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAEC,sBAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,MAAM,EAAE;AACrB,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAEA,sBAAc,CAAC;AACzB,MAAM,MAAM;AACZ,KAAK,CAAC;AACN,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,CAAC,EAAE;AACS,MAAC,aAAa,GAAG;AAC7B,EAAE,CAACC,wBAAkB,GAAG,CAAC,KAAK,KAAKC,eAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,KAAK,EAAE,CAAC,KAAK,KAAKA,eAAQ,CAAC,KAAK,CAAC;AACnC,EAAE,MAAM,EAAE,CAAC,KAAK,KAAKA,eAAQ,CAAC,KAAK,CAAC;AACpC;;;;;"}