hzzt-plus 2.0.10 → 2.0.11

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 (42) hide show
  1. package/dist/index.full.js +38 -18
  2. package/dist/index.full.min.js +6 -6
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +3 -3
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +38 -18
  7. package/es/components/cascader/index.mjs +2 -2
  8. package/es/components/cascader/src/cascader.mjs +156 -40
  9. package/es/components/cascader/src/cascader.mjs.map +1 -1
  10. package/es/components/cascader/src/cascader2.mjs +40 -156
  11. package/es/components/cascader/src/cascader2.mjs.map +1 -1
  12. package/es/components/index.mjs +3 -3
  13. package/es/components/select/index.mjs +2 -2
  14. package/es/components/select/src/select.mjs +213 -42
  15. package/es/components/select/src/select.mjs.map +1 -1
  16. package/es/components/select/src/select2.mjs +42 -193
  17. package/es/components/select/src/select2.mjs.map +1 -1
  18. package/es/components/select-input/index.mjs +2 -2
  19. package/es/components/select-input/src/select-input.mjs +45 -124
  20. package/es/components/select-input/src/select-input.mjs.map +1 -1
  21. package/es/components/select-input/src/select-input2.mjs +124 -45
  22. package/es/components/select-input/src/select-input2.mjs.map +1 -1
  23. package/es/index.mjs +3 -3
  24. package/lib/components/cascader/index.js +2 -2
  25. package/lib/components/cascader/src/cascader.js +155 -40
  26. package/lib/components/cascader/src/cascader.js.map +1 -1
  27. package/lib/components/cascader/src/cascader2.js +40 -155
  28. package/lib/components/cascader/src/cascader2.js.map +1 -1
  29. package/lib/components/index.js +3 -3
  30. package/lib/components/select/index.js +2 -2
  31. package/lib/components/select/src/select.js +213 -43
  32. package/lib/components/select/src/select.js.map +1 -1
  33. package/lib/components/select/src/select2.js +43 -193
  34. package/lib/components/select/src/select2.js.map +1 -1
  35. package/lib/components/select-input/index.js +2 -2
  36. package/lib/components/select-input/src/select-input.js +46 -124
  37. package/lib/components/select-input/src/select-input.js.map +1 -1
  38. package/lib/components/select-input/src/select-input2.js +124 -46
  39. package/lib/components/select-input/src/select-input2.js.map +1 -1
  40. package/lib/index.js +3 -3
  41. package/package.json +1 -1
  42. package/web-types.json +1 -1
@@ -1,47 +1,218 @@
1
- import '../../../utils/index.mjs';
2
- import '../../../constants/index.mjs';
1
+ import { defineComponent, useAttrs, ref, computed, watch, openBlock, createElementBlock, normalizeClass, unref, normalizeStyle, createVNode, mergeProps, withCtx, createBlock, createCommentVNode, renderSlot } from 'vue';
2
+ import { selectProps, selectEmits } from './select2.mjs';
3
+ import { useFormSize, useFormDisabled, ElInput, ElSelectV2 } from 'element-plus';
3
4
  import '../../../hooks/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';
5
+ import HzztIcon from '../../icon/src/index.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';
8
9
 
9
- const selectProps = buildProps({
10
- selectProps: Object,
11
- options: {
12
- type: definePropType(Array),
13
- default: () => []
14
- },
15
- modelValue: {
16
- type: definePropType([
17
- String
18
- ]),
19
- default: ""
20
- },
21
- disabled: Boolean,
22
- readonly: Boolean,
23
- clearable: Boolean,
24
- replace: {
25
- type: Boolean,
26
- default: true
27
- },
28
- autoPullDown: {
29
- type: Boolean,
30
- default: true
31
- },
32
- placeholder: String,
33
- size: useSizeProp
10
+ const __default__ = defineComponent({
11
+ name: "HzztSelect",
12
+ inheritAttrs: false
34
13
  });
35
- const selectEmits = {
36
- [UPDATE_MODEL_EVENT]: (value) => isString(value),
37
- "input": (value) => isString(value),
38
- "change": (value) => isString(value),
39
- "arrow-down": (e) => e,
40
- "arrow-up": (e) => e,
41
- "arrow-left": (e) => e,
42
- "arrow-right": (e) => e,
43
- "enter": (e) => e
44
- };
14
+ const _sfc_main = /* @__PURE__ */ defineComponent({
15
+ ...__default__,
16
+ props: selectProps,
17
+ emits: selectEmits,
18
+ setup(__props, { emit }) {
19
+ const props = __props;
20
+ const attrs = useAttrs();
21
+ const inputVal = ref(props.modelValue);
22
+ const selectVal = ref();
23
+ const inputRef = ref();
24
+ const selectRef = ref();
25
+ const arrowName = ref("arrow-down");
26
+ const nsSelect = useNamespace("select");
27
+ const formSize = useFormSize();
28
+ const formDisabled = useFormDisabled();
29
+ const trueSize = computed(() => props.size || formSize.value || useGlobalSize().value);
30
+ const trueDisabled = computed(() => props.disabled || formDisabled.value);
31
+ const trueReadonly = computed(() => props.readonly || trueDisabled.value);
32
+ const containerCls = computed(() => [
33
+ "relative",
34
+ "line-height-1",
35
+ attrs.class,
36
+ nsSelect.b(),
37
+ nsSelect.m(trueSize.value)
38
+ ]);
39
+ const containerStyle = computed(() => attrs.style);
40
+ const inputCls = computed(() => [nsSelect.e("input"), "width-100%"]);
41
+ const selectCls = computed(() => [nsSelect.e("select"), "width-100%"]);
42
+ const _inputProps = computed(() => ({
43
+ disabled: trueDisabled.value,
44
+ size: trueSize.value,
45
+ clearable: props.clearable,
46
+ placeholder: props.placeholder,
47
+ readonly: props.readonly,
48
+ ...attrs,
49
+ class: "",
50
+ style: {
51
+ position: trueReadonly.value ? "static" : "absolute",
52
+ left: 0,
53
+ top: 0,
54
+ right: 0,
55
+ zIndex: 2
56
+ }
57
+ }));
58
+ const _selectProps = computed(() => ({
59
+ options: props.options,
60
+ size: trueSize.value,
61
+ filterable: true,
62
+ popperClass: "select-v2-popper-min-width-100",
63
+ ...props.selectProps
64
+ }));
65
+ watch(() => props.modelValue, (v) => {
66
+ inputVal.value = v;
67
+ });
68
+ watch(() => inputVal.value, (v) => {
69
+ selectVal.value = v;
70
+ });
71
+ function input(str) {
72
+ var _a, _b;
73
+ if ((_a = selectRef.value) == null ? void 0 : _a.dropdownMenuVisible) {
74
+ selectRef.value.states.inputValue = (_b = inputVal.value) != null ? _b : "";
75
+ selectRef.value.debouncedOnInputChange();
76
+ } else if (selectRef.value) {
77
+ selectRef.value.dropdownMenuVisible = true;
78
+ setTimeout(() => {
79
+ var _a2;
80
+ if (selectRef.value) {
81
+ selectRef.value.states.inputValue = (_a2 = inputVal.value) != null ? _a2 : "";
82
+ selectRef.value.debouncedOnInputChange();
83
+ }
84
+ }, 200);
85
+ }
86
+ emit("update:modelValue", str);
87
+ emit("input", str);
88
+ }
89
+ function change(str) {
90
+ emit("change", str);
91
+ }
92
+ function focus() {
93
+ if (selectRef.value && props.autoPullDown) {
94
+ setTimeout(() => {
95
+ if (selectRef.value) {
96
+ selectRef.value.dropdownMenuVisible = true;
97
+ }
98
+ }, 200);
99
+ }
100
+ }
101
+ function keydown(e) {
102
+ var _a, _b, _c, _d, _e, _f, _g;
103
+ const key = "key" in e && e.key;
104
+ const dropdownVisible = (_a = selectRef.value) == null ? void 0 : _a.dropdownMenuVisible;
105
+ if (dropdownVisible && (key === "ArrowDown" || key === "ArrowUp" || key === "Enter")) {
106
+ (_b = e.preventDefault) == null ? void 0 : _b.call(e);
107
+ if (key === "ArrowDown") {
108
+ (_c = selectRef.value) == null ? void 0 : _c.onKeyboardNavigate("forward");
109
+ } else if (key === "ArrowUp") {
110
+ (_d = selectRef.value) == null ? void 0 : _d.onKeyboardNavigate("backward");
111
+ } else if (key === "Enter") {
112
+ (_e = selectRef.value) == null ? void 0 : _e.onKeyboardSelect();
113
+ }
114
+ return;
115
+ }
116
+ if (!dropdownVisible) {
117
+ if (key === "ArrowDown") {
118
+ emit("arrow-down", e);
119
+ } else if (key === "ArrowUp") {
120
+ emit("arrow-up", e);
121
+ }
122
+ }
123
+ if (key === "ArrowLeft") {
124
+ const index = inputRef.value.input.selectionStart;
125
+ if (index === 0 && selectRef.value) {
126
+ emit("arrow-left", e);
127
+ selectRef.value.dropdownMenuVisible = false;
128
+ }
129
+ } else if (key === "ArrowRight") {
130
+ const index = inputRef.value.input.selectionStart;
131
+ if (((_g = (_f = inputVal.value) == null ? void 0 : _f.length) != null ? _g : 0) === index && selectRef.value) {
132
+ emit("arrow-right", e);
133
+ selectRef.value.dropdownMenuVisible = false;
134
+ }
135
+ } else if (key === "Enter") {
136
+ emit("enter", e);
137
+ selectRef.value && (selectRef.value.dropdownMenuVisible = false);
138
+ }
139
+ }
140
+ function showSelect() {
141
+ if (selectRef.value) {
142
+ selectRef.value.dropdownMenuVisible = !selectRef.value.dropdownMenuVisible;
143
+ }
144
+ }
145
+ function selectChange(v) {
146
+ let str = inputVal.value || "";
147
+ if (props.replace) {
148
+ str = v;
149
+ } else {
150
+ str += v;
151
+ }
152
+ emit("update:modelValue", str);
153
+ emit("input", str);
154
+ inputVal.value = str;
155
+ setTimeout(() => {
156
+ inputRef.value.focus();
157
+ setTimeout(() => {
158
+ if (selectRef.value) {
159
+ selectRef.value.dropdownMenuVisible = false;
160
+ }
161
+ }, 250);
162
+ emit("change", str);
163
+ });
164
+ }
165
+ function selectVisibleChange(v) {
166
+ arrowName.value = v ? "arrow-up" : "arrow-down";
167
+ }
168
+ return (_ctx, _cache) => {
169
+ return openBlock(), createElementBlock("div", {
170
+ class: normalizeClass(unref(containerCls)),
171
+ style: normalizeStyle(unref(containerStyle))
172
+ }, [
173
+ createVNode(unref(ElInput), mergeProps({
174
+ class: unref(inputCls),
175
+ modelValue: inputVal.value,
176
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => inputVal.value = $event),
177
+ ref_key: "inputRef",
178
+ ref: inputRef
179
+ }, unref(_inputProps), {
180
+ onInput: input,
181
+ onChange: change,
182
+ onFocus: focus,
183
+ onKeydown: keydown
184
+ }), {
185
+ suffix: withCtx(() => [
186
+ !unref(trueReadonly) ? (openBlock(), createBlock(HzztIcon, {
187
+ key: 0,
188
+ class: "pointer",
189
+ name: arrowName.value,
190
+ onClick: showSelect
191
+ }, null, 8, ["name"])) : createCommentVNode("v-if", true)
192
+ ]),
193
+ _: 1
194
+ }, 16, ["class", "modelValue"]),
195
+ !unref(trueReadonly) ? (openBlock(), createBlock(unref(ElSelectV2), mergeProps({
196
+ key: 0,
197
+ class: unref(selectCls),
198
+ modelValue: selectVal.value,
199
+ "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => selectVal.value = $event),
200
+ ref_key: "selectRef",
201
+ ref: selectRef
202
+ }, unref(_selectProps), {
203
+ onChange: selectChange,
204
+ onVisibleChange: selectVisibleChange
205
+ }), {
206
+ default: withCtx(({ item }) => [
207
+ renderSlot(_ctx.$slots, "default", { item })
208
+ ]),
209
+ _: 3
210
+ }, 16, ["class", "modelValue"])) : createCommentVNode("v-if", true)
211
+ ], 6);
212
+ };
213
+ }
214
+ });
215
+ var Select = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "select.vue"]]);
45
216
 
46
- export { selectEmits, selectProps };
217
+ export { Select as default };
47
218
  //# sourceMappingURL=select.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"select.mjs","sources":["../../../../../../packages/components/select/src/select.ts"],"sourcesContent":["import {buildProps, definePropType, isString} from '@hzzt-plus/utils'\nimport type {ExtractPropTypes} from 'vue'\nimport type Select from './select.vue'\nimport {UPDATE_MODEL_EVENT} from \"@hzzt-plus/constants\";\nimport {useSizeProp} from \"@hzzt-plus/hooks\";\n\n\ntype OptionCommon = Record<string, any>\n\nexport type Option = OptionCommon & {\n created?: boolean\n}\n\nexport type OptionGroup = OptionCommon\n\nexport type OptionType = Option | OptionGroup\n\nexport const selectProps = buildProps({\n selectProps: Object,\n options: {\n type: definePropType<OptionType[]>(Array),\n default: () => [],\n },\n modelValue: {\n type: definePropType<string | null | undefined>([\n String,\n ]),\n default: '',\n },\n disabled: Boolean,\n readonly: Boolean,\n clearable: Boolean,\n replace: {\n type: Boolean,\n default: true,\n },\n autoPullDown: {\n type: Boolean,\n default: true,\n },\n placeholder: String,\n size: useSizeProp,\n})\n\nexport type SelectProps = ExtractPropTypes<typeof selectProps>\n\nexport const selectEmits = {\n [UPDATE_MODEL_EVENT]: (value: string | undefined) => isString(value),\n 'input': (value: string | undefined) => isString(value),\n 'change': (value: string | undefined) => isString(value),\n 'arrow-down': (e: KeyboardEvent | Event) => e,\n 'arrow-up': (e: KeyboardEvent | Event) => e,\n 'arrow-left': (e: KeyboardEvent | Event) => e,\n 'arrow-right': (e: KeyboardEvent | Event) => e,\n 'enter': (e: KeyboardEvent | Event) => e,\n}\nexport type SelectEmits = typeof selectEmits\n\n\nexport type SelectInstance = InstanceType<typeof Select>\n"],"names":[],"mappings":";;;;;;;;AAGY,MAAC,WAAW,GAAG,UAAU,CAAC;AACtC,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,MAAM,EAAE;AACrB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,cAAc,CAAC;AACzB,MAAM,MAAM;AACZ,KAAK,CAAC;AACN,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,SAAS,EAAE,OAAO;AACpB,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,IAAI,EAAE,WAAW;AACnB,CAAC,EAAE;AACS,MAAC,WAAW,GAAG;AAC3B,EAAE,CAAC,kBAAkB,GAAG,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,OAAO,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AACrC,EAAE,QAAQ,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AACtC,EAAE,YAAY,EAAE,CAAC,CAAC,KAAK,CAAC;AACxB,EAAE,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC;AACtB,EAAE,YAAY,EAAE,CAAC,CAAC,KAAK,CAAC;AACxB,EAAE,aAAa,EAAE,CAAC,CAAC,KAAK,CAAC;AACzB,EAAE,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC;AACnB;;;;"}
1
+ {"version":3,"file":"select.mjs","sources":["../../../../../../packages/components/select/src/select.vue"],"sourcesContent":["<template>\n <div :class=\"containerCls\" :style=\"containerStyle\">\n <el-input\n :class=\"inputCls\"\n v-model=\"inputVal\"\n ref=\"inputRef\"\n v-bind=\"_inputProps\"\n @input=\"input\"\n @change=\"change\"\n @focus=\"focus\"\n @keydown=\"keydown\"\n >\n <template #suffix>\n <hzzt-icon\n v-if=\"!trueReadonly\"\n class=\"pointer\"\n :name=\"arrowName\"\n @click=\"showSelect\"\n ></hzzt-icon>\n </template>\n </el-input>\n <el-select-v2\n v-if=\"!trueReadonly\"\n :class=\"selectCls\"\n v-model=\"selectVal\"\n ref=\"selectRef\"\n v-bind=\"_selectProps\"\n @change=\"selectChange\"\n @visible-change=\"selectVisibleChange\"\n >\n <template #default=\"{ item }\">\n <slot :item=\"item\" />\n </template>\n </el-select-v2>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { selectEmits, selectProps } from './select'\nimport { computed, ref, useAttrs, watch } from 'vue'\nimport { useFormDisabled, useFormSize } from 'element-plus'\nimport { useGlobalSize, useNamespace } from '@hzzt-plus/hooks'\nimport { ElInput, ElSelectV2 } from 'element-plus'\nimport type { CSSProperties } from 'vue'\nimport HzztIcon from '@hzzt-plus/components/icon/src/index.vue'\n\ndefineOptions({\n name: 'HzztSelect',\n inheritAttrs: false,\n})\n\nconst props = defineProps(selectProps)\nconst emit = defineEmits(selectEmits)\n\nconst attrs = useAttrs()\n\nconst inputVal = ref(props.modelValue)\nconst selectVal = ref()\nconst inputRef = ref()\nconst selectRef = ref()\nconst arrowName = ref('arrow-down')\n\nconst nsSelect = useNamespace('select')\n\nconst formSize = useFormSize()\nconst formDisabled = useFormDisabled()\n\nconst trueSize = computed(\n () => props.size || formSize.value || useGlobalSize().value\n)\n\nconst trueDisabled = computed(() => props.disabled || formDisabled.value)\n\nconst trueReadonly = computed(() => props.readonly || trueDisabled.value)\n\nconst containerCls = computed(() => [\n 'relative',\n 'line-height-1',\n attrs.class,\n nsSelect.b(),\n nsSelect.m(trueSize.value),\n])\n\nconst containerStyle = computed(() => attrs.style as CSSProperties)\n\nconst inputCls = computed(() => [nsSelect.e('input'), 'width-100%'])\n\nconst selectCls = computed(() => [nsSelect.e('select'), 'width-100%'])\n\nconst _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 class: '',\n style: {\n position: trueReadonly.value ? 'static' : 'absolute',\n left: 0,\n top: 0,\n right: 0,\n zIndex: 2,\n },\n}))\n\nconst _selectProps = computed(() => ({\n options: props.options,\n size: trueSize.value,\n filterable: true,\n popperClass: 'select-v2-popper-min-width-100',\n ...props.selectProps,\n}))\n\nwatch(\n () => props.modelValue,\n (v) => {\n inputVal.value = v\n }\n)\n\nwatch(\n () => inputVal.value,\n (v) => {\n selectVal.value = v\n }\n)\n\nfunction input(str: string) {\n if (selectRef.value?.dropdownMenuVisible) {\n selectRef.value.states.inputValue = inputVal.value ?? ''\n selectRef.value.debouncedOnInputChange()\n } else if (selectRef.value) {\n selectRef.value.dropdownMenuVisible = true\n setTimeout(() => {\n if (selectRef.value) {\n selectRef.value.states.inputValue = inputVal.value ?? ''\n selectRef.value.debouncedOnInputChange()\n }\n }, 200)\n }\n emit('update:modelValue', str)\n emit('input', str)\n}\n\nfunction change(str: string) {\n emit('change', str)\n}\n\nfunction focus() {\n if (selectRef.value && props.autoPullDown) {\n setTimeout(() => {\n if (selectRef.value) {\n selectRef.value.dropdownMenuVisible = true\n }\n }, 200)\n }\n}\n\nfunction keydown(e: KeyboardEvent | Event) {\n const key = 'key' in e && e.key\n const dropdownVisible = selectRef.value?.dropdownMenuVisible\n\n // 下拉面板展开时,上下箭头切换选项,回车选中当前高亮项\n if (\n dropdownVisible &&\n (key === 'ArrowDown' || key === 'ArrowUp' || key === 'Enter')\n ) {\n e.preventDefault?.()\n if (key === 'ArrowDown') {\n selectRef.value?.onKeyboardNavigate('forward')\n } else if (key === 'ArrowUp') {\n selectRef.value?.onKeyboardNavigate('backward')\n } else if (key === 'Enter') {\n selectRef.value?.onKeyboardSelect()\n }\n return\n }\n\n if (!dropdownVisible) {\n if (key === 'ArrowDown') {\n emit('arrow-down', e)\n } else if (key === 'ArrowUp') {\n emit('arrow-up', e)\n }\n }\n if (key === 'ArrowLeft') {\n const index = inputRef.value.input.selectionStart\n if (index === 0 && selectRef.value) {\n emit('arrow-left', e)\n selectRef.value.dropdownMenuVisible = false\n }\n } else if (key === 'ArrowRight') {\n const index = inputRef.value.input.selectionStart\n if ((inputVal.value?.length ?? 0) === index && selectRef.value) {\n emit('arrow-right', e)\n selectRef.value.dropdownMenuVisible = false\n }\n } else if (key === 'Enter') {\n emit('enter', e)\n selectRef.value && (selectRef.value.dropdownMenuVisible = false)\n }\n}\n\nfunction showSelect() {\n if (selectRef.value) {\n selectRef.value.dropdownMenuVisible = !selectRef.value.dropdownMenuVisible\n }\n}\n\nfunction selectChange(v: string) {\n let str = inputVal.value || ''\n if (props.replace) {\n str = v\n } else {\n str += v\n }\n emit('update:modelValue', str)\n emit('input', str)\n inputVal.value = str\n setTimeout(() => {\n inputRef.value.focus()\n setTimeout(() => {\n if (selectRef.value) {\n selectRef.value.dropdownMenuVisible = false\n }\n }, 250)\n emit('change', str)\n })\n}\n\nfunction selectVisibleChange(v: boolean) {\n arrowName.value = v ? 'arrow-up' : 'arrow-down'\n}\n</script>\n"],"names":["_openBlock","_createElementBlock","_normalizeStyle","_unref"],"mappings":"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"}
@@ -1,198 +1,47 @@
1
- import { defineComponent, useAttrs, ref, computed, watch, openBlock, createElementBlock, normalizeClass, unref, normalizeStyle, createVNode, mergeProps, withCtx, createBlock, createCommentVNode, renderSlot } from 'vue';
2
- import { selectProps, selectEmits } from './select.mjs';
3
- import { useFormSize, useFormDisabled, ElInput, ElSelectV2 } from 'element-plus';
1
+ import '../../../utils/index.mjs';
2
+ import '../../../constants/index.mjs';
4
3
  import '../../../hooks/index.mjs';
5
- import HzztIcon from '../../icon/src/index.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';
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';
9
8
 
10
- const __default__ = defineComponent({
11
- name: "HzztSelect",
12
- inheritAttrs: false
9
+ const selectProps = buildProps({
10
+ selectProps: Object,
11
+ options: {
12
+ type: definePropType(Array),
13
+ default: () => []
14
+ },
15
+ modelValue: {
16
+ type: definePropType([
17
+ String
18
+ ]),
19
+ default: ""
20
+ },
21
+ disabled: Boolean,
22
+ readonly: Boolean,
23
+ clearable: Boolean,
24
+ replace: {
25
+ type: Boolean,
26
+ default: true
27
+ },
28
+ autoPullDown: {
29
+ type: Boolean,
30
+ default: true
31
+ },
32
+ placeholder: String,
33
+ size: useSizeProp
13
34
  });
14
- const _sfc_main = /* @__PURE__ */ defineComponent({
15
- ...__default__,
16
- props: selectProps,
17
- emits: selectEmits,
18
- setup(__props, { emit }) {
19
- const props = __props;
20
- const attrs = useAttrs();
21
- const inputVal = ref(props.modelValue);
22
- const selectVal = ref();
23
- const inputRef = ref();
24
- const selectRef = ref();
25
- const arrowName = ref("arrow-down");
26
- const nsSelect = useNamespace("select");
27
- const formSize = useFormSize();
28
- const formDisabled = useFormDisabled();
29
- const trueSize = computed(() => props.size || formSize.value || useGlobalSize().value);
30
- const trueDisabled = computed(() => props.disabled || formDisabled.value);
31
- const trueReadonly = computed(() => props.readonly || trueDisabled.value);
32
- const containerCls = computed(() => [
33
- "relative",
34
- "line-height-1",
35
- attrs.class,
36
- nsSelect.b(),
37
- nsSelect.m(trueSize.value)
38
- ]);
39
- const containerStyle = computed(() => attrs.style);
40
- const inputCls = computed(() => [nsSelect.e("input"), "width-100%"]);
41
- const selectCls = computed(() => [nsSelect.e("select"), "width-100%"]);
42
- const _inputProps = computed(() => ({
43
- disabled: trueDisabled.value,
44
- size: trueSize.value,
45
- clearable: props.clearable,
46
- placeholder: props.placeholder,
47
- readonly: props.readonly,
48
- ...attrs,
49
- class: "",
50
- style: {
51
- position: trueReadonly.value ? "static" : "absolute",
52
- left: 0,
53
- top: 0,
54
- right: 0,
55
- zIndex: 2
56
- }
57
- }));
58
- const _selectProps = computed(() => ({
59
- options: props.options,
60
- size: trueSize.value,
61
- filterable: true,
62
- popperClass: "select-v2-popper-min-width-100",
63
- ...props.selectProps
64
- }));
65
- watch(() => props.modelValue, (v) => {
66
- inputVal.value = v;
67
- });
68
- watch(() => inputVal.value, (v) => {
69
- selectVal.value = v;
70
- });
71
- function input(str) {
72
- var _a;
73
- if ((_a = selectRef.value) == null ? void 0 : _a.dropdownMenuVisible) {
74
- selectRef.value.states.inputValue = inputVal.value;
75
- selectRef.value.debouncedOnInputChange();
76
- } else {
77
- selectRef.value.dropdownMenuVisible = true;
78
- setTimeout(() => {
79
- selectRef.value.states.inputValue = inputVal.value;
80
- selectRef.value.debouncedOnInputChange();
81
- }, 200);
82
- }
83
- emit("update:modelValue", str);
84
- emit("input", str);
85
- }
86
- function change(str) {
87
- emit("change", str);
88
- }
89
- function focus() {
90
- if (selectRef.value && props.autoPullDown) {
91
- setTimeout(() => {
92
- selectRef.value.dropdownMenuVisible = true;
93
- }, 200);
94
- }
95
- }
96
- function keydown(e) {
97
- var _a, _b;
98
- const key = "key" in e && e.key;
99
- if (key === "ArrowDown") {
100
- emit("arrow-down", e);
101
- selectRef.value.dropdownMenuVisible = false;
102
- } else if (key === "ArrowUp") {
103
- emit("arrow-up", e);
104
- selectRef.value.dropdownMenuVisible = false;
105
- } else if (key === "ArrowLeft") {
106
- const index = inputRef.value.input.selectionStart;
107
- if (index === 0) {
108
- emit("arrow-left", e);
109
- selectRef.value.dropdownMenuVisible = false;
110
- }
111
- } else if (key === "ArrowRight") {
112
- const index = inputRef.value.input.selectionStart;
113
- if (((_b = (_a = inputVal.value) == null ? void 0 : _a.length) != null ? _b : 0) === index) {
114
- emit("arrow-right", e);
115
- selectRef.value.dropdownMenuVisible = false;
116
- }
117
- } else if (key === "Enter") {
118
- emit("enter", e);
119
- selectRef.value.dropdownMenuVisible = false;
120
- }
121
- }
122
- function showSelect() {
123
- if (selectRef.value) {
124
- selectRef.value.dropdownMenuVisible = !selectRef.value.dropdownMenuVisible;
125
- }
126
- }
127
- function selectChange(v) {
128
- let str = inputVal.value || "";
129
- if (props.replace) {
130
- str = v;
131
- } else {
132
- str += v;
133
- }
134
- emit("update:modelValue", str);
135
- emit("input", str);
136
- inputVal.value = str;
137
- setTimeout(() => {
138
- inputRef.value.focus();
139
- setTimeout(() => {
140
- selectRef.value.dropdownMenuVisible = false;
141
- }, 250);
142
- emit("change", str);
143
- });
144
- }
145
- function selectVisibleChange(v) {
146
- arrowName.value = v ? "arrow-up" : "arrow-down";
147
- }
148
- return (_ctx, _cache) => {
149
- return openBlock(), createElementBlock("div", {
150
- class: normalizeClass(unref(containerCls)),
151
- style: normalizeStyle(unref(containerStyle))
152
- }, [
153
- createVNode(unref(ElInput), mergeProps({
154
- class: unref(inputCls),
155
- modelValue: inputVal.value,
156
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => inputVal.value = $event),
157
- ref_key: "inputRef",
158
- ref: inputRef
159
- }, unref(_inputProps), {
160
- onInput: input,
161
- onChange: change,
162
- onFocus: focus,
163
- onKeydown: keydown
164
- }), {
165
- suffix: withCtx(() => [
166
- !unref(trueReadonly) ? (openBlock(), createBlock(HzztIcon, {
167
- key: 0,
168
- class: "pointer",
169
- name: arrowName.value,
170
- onClick: showSelect
171
- }, null, 8, ["name"])) : createCommentVNode("v-if", true)
172
- ]),
173
- _: 1
174
- }, 16, ["class", "modelValue"]),
175
- !unref(trueReadonly) ? (openBlock(), createBlock(unref(ElSelectV2), mergeProps({
176
- key: 0,
177
- class: unref(selectCls),
178
- modelValue: selectVal.value,
179
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => selectVal.value = $event),
180
- ref_key: "selectRef",
181
- ref: selectRef
182
- }, unref(_selectProps), {
183
- onChange: selectChange,
184
- onVisibleChange: selectVisibleChange
185
- }), {
186
- default: withCtx(({ item }) => [
187
- renderSlot(_ctx.$slots, "default", { item })
188
- ]),
189
- _: 3
190
- }, 16, ["class", "modelValue"])) : createCommentVNode("v-if", true)
191
- ], 6);
192
- };
193
- }
194
- });
195
- var Select = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "select.vue"]]);
35
+ const selectEmits = {
36
+ [UPDATE_MODEL_EVENT]: (value) => isString(value),
37
+ "input": (value) => isString(value),
38
+ "change": (value) => isString(value),
39
+ "arrow-down": (e) => e,
40
+ "arrow-up": (e) => e,
41
+ "arrow-left": (e) => e,
42
+ "arrow-right": (e) => e,
43
+ "enter": (e) => e
44
+ };
196
45
 
197
- export { Select as default };
46
+ export { selectEmits, selectProps };
198
47
  //# sourceMappingURL=select2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"select2.mjs","sources":["../../../../../../packages/components/select/src/select.vue"],"sourcesContent":["<template>\n <div :class=\"containerCls\" :style=\"containerStyle\">\n <el-input\n :class=\"inputCls\"\n v-model=\"inputVal\"\n ref=\"inputRef\"\n v-bind=\"_inputProps\"\n @input=\"input\"\n @change=\"change\"\n @focus=\"focus\"\n @keydown=\"keydown\"\n >\n <template #suffix>\n <hzzt-icon\n v-if=\"!trueReadonly\"\n class=\"pointer\"\n :name=\"arrowName\"\n @click=\"showSelect\"\n ></hzzt-icon>\n </template>\n </el-input>\n <el-select-v2\n v-if=\"!trueReadonly\"\n :class=\"selectCls\"\n v-model=\"selectVal\"\n ref=\"selectRef\"\n v-bind=\"_selectProps\"\n @change=\"selectChange\"\n @visible-change=\"selectVisibleChange\"\n >\n <template #default=\"{ item }\">\n <slot :item=\"item\" />\n </template>\n </el-select-v2>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport { selectEmits, selectProps } from './select'\nimport { computed, ref, useAttrs, watch } from 'vue'\nimport { useFormDisabled, useFormSize } from 'element-plus'\nimport { useGlobalSize, useNamespace } from '@hzzt-plus/hooks'\nimport { ElInput, ElSelectV2 } from 'element-plus'\nimport type { CSSProperties } from 'vue'\nimport HzztIcon from '@hzzt-plus/components/icon/src/index.vue'\n\ndefineOptions({\n name: 'HzztSelect',\n inheritAttrs: false,\n})\n\nconst props = defineProps(selectProps)\nconst emit = defineEmits(selectEmits)\n\nconst attrs = useAttrs()\n\nconst inputVal = ref(props.modelValue)\nconst selectVal = ref()\nconst inputRef = ref()\nconst selectRef = ref()\nconst arrowName = ref('arrow-down')\n\nconst nsSelect = useNamespace('select')\n\nconst formSize = useFormSize()\nconst formDisabled = useFormDisabled()\n\nconst trueSize = computed(\n () => props.size || formSize.value || useGlobalSize().value\n)\n\nconst trueDisabled = computed(() => props.disabled || formDisabled.value)\n\nconst trueReadonly = computed(() => props.readonly || trueDisabled.value)\n\nconst containerCls = computed(() => [\n 'relative',\n 'line-height-1',\n attrs.class,\n nsSelect.b(),\n nsSelect.m(trueSize.value),\n])\n\nconst containerStyle = computed(() => attrs.style as CSSProperties)\n\nconst inputCls = computed(() => [nsSelect.e('input'), 'width-100%'])\n\nconst selectCls = computed(() => [nsSelect.e('select'), 'width-100%'])\n\nconst _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 class: '',\n style: {\n position: trueReadonly.value ? 'static' : 'absolute',\n left: 0,\n top: 0,\n right: 0,\n zIndex: 2,\n },\n}))\n\nconst _selectProps = computed(() => ({\n options: props.options,\n size: trueSize.value,\n filterable: true,\n popperClass: 'select-v2-popper-min-width-100',\n ...props.selectProps,\n}))\n\nwatch(\n () => props.modelValue,\n (v) => {\n inputVal.value = v\n }\n)\n\nwatch(\n () => inputVal.value,\n (v) => {\n selectVal.value = v\n }\n)\n\nfunction input(str: string) {\n if (selectRef.value?.dropdownMenuVisible) {\n selectRef.value.states.inputValue = inputVal.value\n selectRef.value.debouncedOnInputChange()\n } else {\n selectRef.value.dropdownMenuVisible = true\n setTimeout(() => {\n selectRef.value.states.inputValue = inputVal.value\n selectRef.value.debouncedOnInputChange()\n }, 200)\n }\n emit('update:modelValue', str)\n emit('input', str)\n}\n\nfunction change(str: string) {\n emit('change', str)\n}\n\nfunction focus() {\n if (selectRef.value && props.autoPullDown) {\n setTimeout(() => {\n selectRef.value.dropdownMenuVisible = true\n }, 200)\n }\n}\n\nfunction keydown(e: KeyboardEvent | Event) {\n const key = 'key' in e && e.key\n if (key === 'ArrowDown') {\n emit('arrow-down', e)\n selectRef.value.dropdownMenuVisible = false\n } else if (key === 'ArrowUp') {\n emit('arrow-up', e)\n selectRef.value.dropdownMenuVisible = false\n } else if (key === 'ArrowLeft') {\n const index = inputRef.value.input.selectionStart\n if (index === 0) {\n emit('arrow-left', e)\n selectRef.value.dropdownMenuVisible = false\n }\n } else if (key === 'ArrowRight') {\n const index = inputRef.value.input.selectionStart\n if ((inputVal.value?.length ?? 0) === index) {\n emit('arrow-right', e)\n selectRef.value.dropdownMenuVisible = false\n }\n } else if (key === 'Enter') {\n emit('enter', e)\n selectRef.value.dropdownMenuVisible = false\n }\n}\n\nfunction showSelect() {\n if (selectRef.value) {\n selectRef.value.dropdownMenuVisible = !selectRef.value.dropdownMenuVisible\n }\n}\n\nfunction selectChange(v: string) {\n let str = inputVal.value || ''\n if (props.replace) {\n str = v\n } else {\n str += v\n }\n emit('update:modelValue', str)\n emit('input', str)\n inputVal.value = str\n setTimeout(() => {\n inputRef.value.focus()\n setTimeout(() => {\n selectRef.value.dropdownMenuVisible = false\n }, 250)\n emit('change', str)\n })\n}\n\nfunction selectVisibleChange(v: boolean) {\n arrowName.value = v ? 'arrow-up' : 'arrow-down'\n}\n</script>\n"],"names":["_openBlock","_createElementBlock","_normalizeClass","_unref","_createVNode","_mergeProps"],"mappings":"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"}
1
+ {"version":3,"file":"select2.mjs","sources":["../../../../../../packages/components/select/src/select.ts"],"sourcesContent":["import {buildProps, definePropType, isString} from '@hzzt-plus/utils'\nimport type {ExtractPropTypes} from 'vue'\nimport type Select from './select.vue'\nimport {UPDATE_MODEL_EVENT} from \"@hzzt-plus/constants\";\nimport {useSizeProp} from \"@hzzt-plus/hooks\";\n\n\ntype OptionCommon = Record<string, any>\n\nexport type Option = OptionCommon & {\n created?: boolean\n}\n\nexport type OptionGroup = OptionCommon\n\nexport type OptionType = Option | OptionGroup\n\nexport const selectProps = buildProps({\n selectProps: Object,\n options: {\n type: definePropType<OptionType[]>(Array),\n default: () => [],\n },\n modelValue: {\n type: definePropType<string | null | undefined>([\n String,\n ]),\n default: '',\n },\n disabled: Boolean,\n readonly: Boolean,\n clearable: Boolean,\n replace: {\n type: Boolean,\n default: true,\n },\n autoPullDown: {\n type: Boolean,\n default: true,\n },\n placeholder: String,\n size: useSizeProp,\n})\n\nexport type SelectProps = ExtractPropTypes<typeof selectProps>\n\nexport const selectEmits = {\n [UPDATE_MODEL_EVENT]: (value: string | undefined) => isString(value),\n 'input': (value: string | undefined) => isString(value),\n 'change': (value: string | undefined) => isString(value),\n 'arrow-down': (e: KeyboardEvent | Event) => e,\n 'arrow-up': (e: KeyboardEvent | Event) => e,\n 'arrow-left': (e: KeyboardEvent | Event) => e,\n 'arrow-right': (e: KeyboardEvent | Event) => e,\n 'enter': (e: KeyboardEvent | Event) => e,\n}\nexport type SelectEmits = typeof selectEmits\n\n\nexport type SelectInstance = InstanceType<typeof Select>\n"],"names":[],"mappings":";;;;;;;;AAGY,MAAC,WAAW,GAAG,UAAU,CAAC;AACtC,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,cAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,MAAM,EAAE;AACrB,GAAG;AACH,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,cAAc,CAAC;AACzB,MAAM,MAAM;AACZ,KAAK,CAAC;AACN,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,SAAS,EAAE,OAAO;AACpB,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,YAAY,EAAE;AAChB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,IAAI,EAAE,WAAW;AACnB,CAAC,EAAE;AACS,MAAC,WAAW,GAAG;AAC3B,EAAE,CAAC,kBAAkB,GAAG,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,OAAO,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AACrC,EAAE,QAAQ,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC;AACtC,EAAE,YAAY,EAAE,CAAC,CAAC,KAAK,CAAC;AACxB,EAAE,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC;AACtB,EAAE,YAAY,EAAE,CAAC,CAAC,KAAK,CAAC;AACxB,EAAE,aAAa,EAAE,CAAC,CAAC,KAAK,CAAC;AACzB,EAAE,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC;AACnB;;;;"}
@@ -1,6 +1,6 @@
1
1
  import '../../utils/index.mjs';
2
- import SelectInput from './src/select-input.mjs';
3
- export { selectInputEmits, selectInputProps } from './src/select-input2.mjs';
2
+ import SelectInput from './src/select-input2.mjs';
3
+ export { selectInputEmits, selectInputProps } from './src/select-input.mjs';
4
4
  import { withInstall } from '../../utils/vue/install.mjs';
5
5
 
6
6
  const HzztSelectInput = withInstall(SelectInput);