hzzt-plus 2.0.9 → 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 (56) hide show
  1. package/dist/index.full.js +45 -25
  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 +5 -5
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +45 -25
  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 +156 -40
  17. package/es/components/cascader/src/cascader.mjs.map +1 -1
  18. package/es/components/cascader/src/cascader2.mjs +40 -156
  19. package/es/components/cascader/src/cascader2.mjs.map +1 -1
  20. package/es/components/index.mjs +3 -3
  21. package/es/components/lazy-list/index.mjs +2 -2
  22. package/es/components/lazy-list/src/lazy-list.mjs +22 -80
  23. package/es/components/lazy-list/src/lazy-list.mjs.map +1 -1
  24. package/es/components/lazy-list/src/lazy-list2.mjs +80 -22
  25. package/es/components/lazy-list/src/lazy-list2.mjs.map +1 -1
  26. package/es/components/select/index.mjs +2 -2
  27. package/es/components/select/src/select.mjs +213 -42
  28. package/es/components/select/src/select.mjs.map +1 -1
  29. package/es/components/select/src/select2.mjs +42 -193
  30. package/es/components/select/src/select2.mjs.map +1 -1
  31. package/es/index.mjs +3 -3
  32. package/es/version.d.ts +1 -1
  33. package/es/version.mjs +1 -1
  34. package/es/version.mjs.map +1 -1
  35. package/lib/components/cascader/index.js +2 -2
  36. package/lib/components/cascader/src/cascader.js +155 -40
  37. package/lib/components/cascader/src/cascader.js.map +1 -1
  38. package/lib/components/cascader/src/cascader2.js +40 -155
  39. package/lib/components/cascader/src/cascader2.js.map +1 -1
  40. package/lib/components/index.js +3 -3
  41. package/lib/components/lazy-list/index.js +2 -2
  42. package/lib/components/lazy-list/src/lazy-list.js +23 -80
  43. package/lib/components/lazy-list/src/lazy-list.js.map +1 -1
  44. package/lib/components/lazy-list/src/lazy-list2.js +80 -23
  45. package/lib/components/lazy-list/src/lazy-list2.js.map +1 -1
  46. package/lib/components/select/index.js +2 -2
  47. package/lib/components/select/src/select.js +213 -43
  48. package/lib/components/select/src/select.js.map +1 -1
  49. package/lib/components/select/src/select2.js +43 -193
  50. package/lib/components/select/src/select2.js.map +1 -1
  51. package/lib/index.js +3 -3
  52. package/lib/version.d.ts +1 -1
  53. package/lib/version.js +1 -1
  54. package/lib/version.js.map +1 -1
  55. package/package.json +1 -1
  56. package/web-types.json +1 -1
@@ -2,51 +2,221 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- require('../../../utils/index.js');
6
- require('../../../constants/index.js');
5
+ var vue = require('vue');
6
+ var select = require('./select2.js');
7
+ var elementPlus = require('element-plus');
7
8
  require('../../../hooks/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');
11
- var shared = require('@vue/shared');
9
+ var index$2 = require('../../icon/src/index.js');
10
+ var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
11
+ var index = require('../../../hooks/use-namespace/index.js');
12
+ var index$1 = require('../../../hooks/use-size/index.js');
12
13
 
13
- const selectProps = runtime.buildProps({
14
- selectProps: Object,
15
- options: {
16
- type: runtime.definePropType(Array),
17
- default: () => []
18
- },
19
- modelValue: {
20
- type: runtime.definePropType([
21
- String
22
- ]),
23
- default: ""
24
- },
25
- disabled: Boolean,
26
- readonly: Boolean,
27
- clearable: Boolean,
28
- replace: {
29
- type: Boolean,
30
- default: true
31
- },
32
- autoPullDown: {
33
- type: Boolean,
34
- default: true
35
- },
36
- placeholder: String,
37
- size: index.useSizeProp
14
+ const __default__ = vue.defineComponent({
15
+ name: "HzztSelect",
16
+ inheritAttrs: false
38
17
  });
39
- const selectEmits = {
40
- [event.UPDATE_MODEL_EVENT]: (value) => shared.isString(value),
41
- "input": (value) => shared.isString(value),
42
- "change": (value) => shared.isString(value),
43
- "arrow-down": (e) => e,
44
- "arrow-up": (e) => e,
45
- "arrow-left": (e) => e,
46
- "arrow-right": (e) => e,
47
- "enter": (e) => e
48
- };
18
+ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
19
+ ...__default__,
20
+ props: select.selectProps,
21
+ emits: select.selectEmits,
22
+ setup(__props, { emit }) {
23
+ const props = __props;
24
+ const attrs = vue.useAttrs();
25
+ const inputVal = vue.ref(props.modelValue);
26
+ const selectVal = vue.ref();
27
+ const inputRef = vue.ref();
28
+ const selectRef = vue.ref();
29
+ const arrowName = vue.ref("arrow-down");
30
+ const nsSelect = index.useNamespace("select");
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 trueReadonly = vue.computed(() => props.readonly || trueDisabled.value);
36
+ const containerCls = vue.computed(() => [
37
+ "relative",
38
+ "line-height-1",
39
+ attrs.class,
40
+ nsSelect.b(),
41
+ nsSelect.m(trueSize.value)
42
+ ]);
43
+ const containerStyle = vue.computed(() => attrs.style);
44
+ const inputCls = vue.computed(() => [nsSelect.e("input"), "width-100%"]);
45
+ const selectCls = vue.computed(() => [nsSelect.e("select"), "width-100%"]);
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
+ class: "",
54
+ style: {
55
+ position: trueReadonly.value ? "static" : "absolute",
56
+ left: 0,
57
+ top: 0,
58
+ right: 0,
59
+ zIndex: 2
60
+ }
61
+ }));
62
+ const _selectProps = vue.computed(() => ({
63
+ options: props.options,
64
+ size: trueSize.value,
65
+ filterable: true,
66
+ popperClass: "select-v2-popper-min-width-100",
67
+ ...props.selectProps
68
+ }));
69
+ vue.watch(() => props.modelValue, (v) => {
70
+ inputVal.value = v;
71
+ });
72
+ vue.watch(() => inputVal.value, (v) => {
73
+ selectVal.value = v;
74
+ });
75
+ function input(str) {
76
+ var _a, _b;
77
+ if ((_a = selectRef.value) == null ? void 0 : _a.dropdownMenuVisible) {
78
+ selectRef.value.states.inputValue = (_b = inputVal.value) != null ? _b : "";
79
+ selectRef.value.debouncedOnInputChange();
80
+ } else if (selectRef.value) {
81
+ selectRef.value.dropdownMenuVisible = true;
82
+ setTimeout(() => {
83
+ var _a2;
84
+ if (selectRef.value) {
85
+ selectRef.value.states.inputValue = (_a2 = inputVal.value) != null ? _a2 : "";
86
+ selectRef.value.debouncedOnInputChange();
87
+ }
88
+ }, 200);
89
+ }
90
+ emit("update:modelValue", str);
91
+ emit("input", str);
92
+ }
93
+ function change(str) {
94
+ emit("change", str);
95
+ }
96
+ function focus() {
97
+ if (selectRef.value && props.autoPullDown) {
98
+ setTimeout(() => {
99
+ if (selectRef.value) {
100
+ selectRef.value.dropdownMenuVisible = true;
101
+ }
102
+ }, 200);
103
+ }
104
+ }
105
+ function keydown(e) {
106
+ var _a, _b, _c, _d, _e, _f, _g;
107
+ const key = "key" in e && e.key;
108
+ const dropdownVisible = (_a = selectRef.value) == null ? void 0 : _a.dropdownMenuVisible;
109
+ if (dropdownVisible && (key === "ArrowDown" || key === "ArrowUp" || key === "Enter")) {
110
+ (_b = e.preventDefault) == null ? void 0 : _b.call(e);
111
+ if (key === "ArrowDown") {
112
+ (_c = selectRef.value) == null ? void 0 : _c.onKeyboardNavigate("forward");
113
+ } else if (key === "ArrowUp") {
114
+ (_d = selectRef.value) == null ? void 0 : _d.onKeyboardNavigate("backward");
115
+ } else if (key === "Enter") {
116
+ (_e = selectRef.value) == null ? void 0 : _e.onKeyboardSelect();
117
+ }
118
+ return;
119
+ }
120
+ if (!dropdownVisible) {
121
+ if (key === "ArrowDown") {
122
+ emit("arrow-down", e);
123
+ } else if (key === "ArrowUp") {
124
+ emit("arrow-up", e);
125
+ }
126
+ }
127
+ if (key === "ArrowLeft") {
128
+ const index = inputRef.value.input.selectionStart;
129
+ if (index === 0 && selectRef.value) {
130
+ emit("arrow-left", e);
131
+ selectRef.value.dropdownMenuVisible = false;
132
+ }
133
+ } else if (key === "ArrowRight") {
134
+ const index = inputRef.value.input.selectionStart;
135
+ if (((_g = (_f = inputVal.value) == null ? void 0 : _f.length) != null ? _g : 0) === index && selectRef.value) {
136
+ emit("arrow-right", e);
137
+ selectRef.value.dropdownMenuVisible = false;
138
+ }
139
+ } else if (key === "Enter") {
140
+ emit("enter", e);
141
+ selectRef.value && (selectRef.value.dropdownMenuVisible = false);
142
+ }
143
+ }
144
+ function showSelect() {
145
+ if (selectRef.value) {
146
+ selectRef.value.dropdownMenuVisible = !selectRef.value.dropdownMenuVisible;
147
+ }
148
+ }
149
+ function selectChange(v) {
150
+ let str = inputVal.value || "";
151
+ if (props.replace) {
152
+ str = v;
153
+ } else {
154
+ str += v;
155
+ }
156
+ emit("update:modelValue", str);
157
+ emit("input", str);
158
+ inputVal.value = str;
159
+ setTimeout(() => {
160
+ inputRef.value.focus();
161
+ setTimeout(() => {
162
+ if (selectRef.value) {
163
+ selectRef.value.dropdownMenuVisible = false;
164
+ }
165
+ }, 250);
166
+ emit("change", str);
167
+ });
168
+ }
169
+ function selectVisibleChange(v) {
170
+ arrowName.value = v ? "arrow-up" : "arrow-down";
171
+ }
172
+ return (_ctx, _cache) => {
173
+ return vue.openBlock(), vue.createElementBlock("div", {
174
+ class: vue.normalizeClass(vue.unref(containerCls)),
175
+ style: vue.normalizeStyle(vue.unref(containerStyle))
176
+ }, [
177
+ vue.createVNode(vue.unref(elementPlus.ElInput), vue.mergeProps({
178
+ class: vue.unref(inputCls),
179
+ modelValue: inputVal.value,
180
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => inputVal.value = $event),
181
+ ref_key: "inputRef",
182
+ ref: inputRef
183
+ }, vue.unref(_inputProps), {
184
+ onInput: input,
185
+ onChange: change,
186
+ onFocus: focus,
187
+ onKeydown: keydown
188
+ }), {
189
+ suffix: vue.withCtx(() => [
190
+ !vue.unref(trueReadonly) ? (vue.openBlock(), vue.createBlock(index$2["default"], {
191
+ key: 0,
192
+ class: "pointer",
193
+ name: arrowName.value,
194
+ onClick: showSelect
195
+ }, null, 8, ["name"])) : vue.createCommentVNode("v-if", true)
196
+ ]),
197
+ _: 1
198
+ }, 16, ["class", "modelValue"]),
199
+ !vue.unref(trueReadonly) ? (vue.openBlock(), vue.createBlock(vue.unref(elementPlus.ElSelectV2), vue.mergeProps({
200
+ key: 0,
201
+ class: vue.unref(selectCls),
202
+ modelValue: selectVal.value,
203
+ "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => selectVal.value = $event),
204
+ ref_key: "selectRef",
205
+ ref: selectRef
206
+ }, vue.unref(_selectProps), {
207
+ onChange: selectChange,
208
+ onVisibleChange: selectVisibleChange
209
+ }), {
210
+ default: vue.withCtx(({ item }) => [
211
+ vue.renderSlot(_ctx.$slots, "default", { item })
212
+ ]),
213
+ _: 3
214
+ }, 16, ["class", "modelValue"])) : vue.createCommentVNode("v-if", true)
215
+ ], 6);
216
+ };
217
+ }
218
+ });
219
+ var Select = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "select.vue"]]);
49
220
 
50
- exports.selectEmits = selectEmits;
51
- exports.selectProps = selectProps;
221
+ exports["default"] = Select;
52
222
  //# sourceMappingURL=select.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"select.js","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":["buildProps","definePropType","useSizeProp","UPDATE_MODEL_EVENT","isString"],"mappings":";;;;;;;;;;;;AAGY,MAAC,WAAW,GAAGA,kBAAU,CAAC;AACtC,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAEC,sBAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,MAAM,EAAE;AACrB,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,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,EAAEC,iBAAW;AACnB,CAAC,EAAE;AACS,MAAC,WAAW,GAAG;AAC3B,EAAE,CAACC,wBAAkB,GAAG,CAAC,KAAK,KAAKC,eAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,OAAO,EAAE,CAAC,KAAK,KAAKA,eAAQ,CAAC,KAAK,CAAC;AACrC,EAAE,QAAQ,EAAE,CAAC,KAAK,KAAKA,eAAQ,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.js","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":["useAttrs","ref","useNamespace","useFormSize","useFormDisabled","computed","useGlobalSize","watch","_openBlock","_createElementBlock","_normalizeStyle","_unref"],"mappings":"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"}
@@ -2,201 +2,51 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var vue = require('vue');
6
- var select = require('./select.js');
7
- var elementPlus = require('element-plus');
5
+ require('../../../utils/index.js');
6
+ require('../../../constants/index.js');
8
7
  require('../../../hooks/index.js');
9
- var index$2 = require('../../icon/src/index.js');
10
- var pluginVue_exportHelper = require('../../../_virtual/plugin-vue_export-helper.js');
11
- var index = require('../../../hooks/use-namespace/index.js');
12
- var index$1 = require('../../../hooks/use-size/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');
11
+ var shared = require('@vue/shared');
13
12
 
14
- const __default__ = vue.defineComponent({
15
- name: "HzztSelect",
16
- inheritAttrs: false
13
+ const selectProps = runtime.buildProps({
14
+ selectProps: Object,
15
+ options: {
16
+ type: runtime.definePropType(Array),
17
+ default: () => []
18
+ },
19
+ modelValue: {
20
+ type: runtime.definePropType([
21
+ String
22
+ ]),
23
+ default: ""
24
+ },
25
+ disabled: Boolean,
26
+ readonly: Boolean,
27
+ clearable: Boolean,
28
+ replace: {
29
+ type: Boolean,
30
+ default: true
31
+ },
32
+ autoPullDown: {
33
+ type: Boolean,
34
+ default: true
35
+ },
36
+ placeholder: String,
37
+ size: index.useSizeProp
17
38
  });
18
- const _sfc_main = /* @__PURE__ */ vue.defineComponent({
19
- ...__default__,
20
- props: select.selectProps,
21
- emits: select.selectEmits,
22
- setup(__props, { emit }) {
23
- const props = __props;
24
- const attrs = vue.useAttrs();
25
- const inputVal = vue.ref(props.modelValue);
26
- const selectVal = vue.ref();
27
- const inputRef = vue.ref();
28
- const selectRef = vue.ref();
29
- const arrowName = vue.ref("arrow-down");
30
- const nsSelect = index.useNamespace("select");
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 trueReadonly = vue.computed(() => props.readonly || trueDisabled.value);
36
- const containerCls = vue.computed(() => [
37
- "relative",
38
- "line-height-1",
39
- attrs.class,
40
- nsSelect.b(),
41
- nsSelect.m(trueSize.value)
42
- ]);
43
- const containerStyle = vue.computed(() => attrs.style);
44
- const inputCls = vue.computed(() => [
45
- nsSelect.e("input"),
46
- "width-100%"
47
- ]);
48
- const selectCls = vue.computed(() => [
49
- nsSelect.e("select"),
50
- "width-100%"
51
- ]);
52
- const _inputProps = vue.computed(() => ({
53
- disabled: trueDisabled.value,
54
- size: trueSize.value,
55
- clearable: props.clearable,
56
- placeholder: props.placeholder,
57
- readonly: props.readonly,
58
- ...attrs,
59
- class: "",
60
- style: {
61
- position: trueReadonly.value ? "static" : "absolute",
62
- left: 0,
63
- top: 0,
64
- right: 0,
65
- zIndex: 2
66
- }
67
- }));
68
- const _selectProps = vue.computed(() => ({
69
- options: props.options,
70
- size: trueSize.value,
71
- filterable: true,
72
- popperClass: "select-v2-popper-min-width-100",
73
- ...props.selectProps
74
- }));
75
- vue.watch(() => props.modelValue, (v) => {
76
- inputVal.value = v;
77
- });
78
- vue.watch(() => inputVal.value, (v) => {
79
- selectVal.value = v;
80
- });
81
- function input(str) {
82
- var _a;
83
- if ((_a = selectRef.value) == null ? void 0 : _a.dropdownMenuVisible) {
84
- selectRef.value.states.inputValue = inputVal.value;
85
- selectRef.value.debouncedOnInputChange();
86
- }
87
- emit("update:modelValue", str);
88
- emit("input", str);
89
- }
90
- function change(str) {
91
- emit("change", str);
92
- }
93
- function focus() {
94
- if (selectRef.value && props.autoPullDown) {
95
- setTimeout(() => {
96
- selectRef.value.dropdownMenuVisible = true;
97
- }, 200);
98
- }
99
- }
100
- function keydown(e) {
101
- var _a, _b;
102
- const key = "key" in e && e.key;
103
- if (key === "ArrowDown") {
104
- emit("arrow-down", e);
105
- selectRef.value.dropdownMenuVisible = false;
106
- } else if (key === "ArrowUp") {
107
- emit("arrow-up", e);
108
- selectRef.value.dropdownMenuVisible = false;
109
- } else if (key === "ArrowLeft") {
110
- const index = inputRef.value.input.selectionStart;
111
- if (index === 0) {
112
- emit("arrow-left", e);
113
- selectRef.value.dropdownMenuVisible = false;
114
- }
115
- } else if (key === "ArrowRight") {
116
- const index = inputRef.value.input.selectionStart;
117
- if (((_b = (_a = inputVal.value) == null ? void 0 : _a.length) != null ? _b : 0) === index) {
118
- emit("arrow-right", e);
119
- selectRef.value.dropdownMenuVisible = false;
120
- }
121
- } else if (key === "Enter") {
122
- emit("enter", e);
123
- selectRef.value.dropdownMenuVisible = false;
124
- }
125
- }
126
- function showSelect() {
127
- if (selectRef.value) {
128
- selectRef.value.dropdownMenuVisible = !selectRef.value.dropdownMenuVisible;
129
- }
130
- }
131
- function selectChange(v) {
132
- let str = inputVal.value || "";
133
- if (props.replace) {
134
- str = v;
135
- } else {
136
- str += v;
137
- }
138
- emit("update:modelValue", str);
139
- emit("input", str);
140
- inputVal.value = str;
141
- setTimeout(() => {
142
- inputRef.value.focus();
143
- setTimeout(() => {
144
- selectRef.value.dropdownMenuVisible = false;
145
- }, 250);
146
- emit("change", str);
147
- });
148
- }
149
- function selectVisibleChange(v) {
150
- arrowName.value = v ? "arrow-up" : "arrow-down";
151
- }
152
- return (_ctx, _cache) => {
153
- return vue.openBlock(), vue.createElementBlock("div", {
154
- class: vue.normalizeClass(vue.unref(containerCls)),
155
- style: vue.normalizeStyle(vue.unref(containerStyle))
156
- }, [
157
- vue.createVNode(vue.unref(elementPlus.ElInput), vue.mergeProps({
158
- class: vue.unref(inputCls),
159
- modelValue: inputVal.value,
160
- "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => inputVal.value = $event),
161
- ref_key: "inputRef",
162
- ref: inputRef
163
- }, vue.unref(_inputProps), {
164
- onInput: input,
165
- onChange: change,
166
- onFocus: focus,
167
- onKeydown: keydown
168
- }), {
169
- suffix: vue.withCtx(() => [
170
- !vue.unref(trueReadonly) ? (vue.openBlock(), vue.createBlock(index$2["default"], {
171
- key: 0,
172
- class: "pointer",
173
- name: arrowName.value,
174
- onClick: showSelect
175
- }, null, 8, ["name"])) : vue.createCommentVNode("v-if", true)
176
- ]),
177
- _: 1
178
- }, 16, ["class", "modelValue"]),
179
- !vue.unref(trueReadonly) ? (vue.openBlock(), vue.createBlock(vue.unref(elementPlus.ElSelectV2), vue.mergeProps({
180
- key: 0,
181
- class: vue.unref(selectCls),
182
- modelValue: selectVal.value,
183
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => selectVal.value = $event),
184
- ref_key: "selectRef",
185
- ref: selectRef
186
- }, vue.unref(_selectProps), {
187
- onChange: selectChange,
188
- onVisibleChange: selectVisibleChange
189
- }), {
190
- default: vue.withCtx(({ item }) => [
191
- vue.renderSlot(_ctx.$slots, "default", { item })
192
- ]),
193
- _: 3
194
- }, 16, ["class", "modelValue"])) : vue.createCommentVNode("v-if", true)
195
- ], 6);
196
- };
197
- }
198
- });
199
- var Select = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "select.vue"]]);
39
+ const selectEmits = {
40
+ [event.UPDATE_MODEL_EVENT]: (value) => shared.isString(value),
41
+ "input": (value) => shared.isString(value),
42
+ "change": (value) => shared.isString(value),
43
+ "arrow-down": (e) => e,
44
+ "arrow-up": (e) => e,
45
+ "arrow-left": (e) => e,
46
+ "arrow-right": (e) => e,
47
+ "enter": (e) => e
48
+ };
200
49
 
201
- exports["default"] = Select;
50
+ exports.selectEmits = selectEmits;
51
+ exports.selectProps = selectProps;
202
52
  //# sourceMappingURL=select2.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"select2.js","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 v-if=\"!trueReadonly\" class=\"pointer\" :name=\"arrowName\"\n @click=\"showSelect\"></hzzt-icon>\n </template>\n </el-input>\n <el-select-v2 v-if=\"!trueReadonly\" :class=\"selectCls\" v-model=\"selectVal\" ref=\"selectRef\" v-bind=\"_selectProps\"\n @change=\"selectChange\" @visible-change=\"selectVisibleChange\">\n <template #default=\"{ item }\">\n <slot :item=\"item\" />\n </template>\n </el-select-v2>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\n import {selectEmits, selectProps} from './select'\n import {computed, ref, useAttrs, watch} from \"vue\";\n import {useFormDisabled, useFormSize} from \"element-plus\";\n import {useGlobalSize, useNamespace} from \"@hzzt-plus/hooks\";\n import {ElInput, ElSelectV2} from 'element-plus'\n import type {CSSProperties} from 'vue'\n import HzztIcon from \"@hzzt-plus/components/icon/src/index.vue\";\n\n\n defineOptions({\n name: 'HzztSelect',\n inheritAttrs: false,\n })\n\n const props = defineProps(selectProps)\n const emit = defineEmits(selectEmits)\n\n const attrs = useAttrs();\n\n const inputVal = ref(props.modelValue);\n const selectVal = ref();\n const inputRef = ref();\n const selectRef = ref();\n const arrowName = ref('arrow-down');\n\n const nsSelect = useNamespace('select');\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 trueReadonly = computed(() => props.readonly || trueDisabled.value)\n\n const containerCls = computed(() => [\n 'relative',\n 'line-height-1',\n attrs.class,\n nsSelect.b(),\n nsSelect.m(trueSize.value),\n ])\n\n const containerStyle = computed(() => attrs.style as CSSProperties)\n\n const inputCls = computed(() => [\n nsSelect.e('input'),\n 'width-100%'\n ])\n\n const selectCls = computed(() => [\n nsSelect.e('select'),\n 'width-100%'\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 class: '',\n style: {\n position: trueReadonly.value ? 'static' : 'absolute',\n left: 0,\n top: 0,\n right: 0,\n zIndex: 2,\n },\n }))\n\n const _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\n watch(() => props.modelValue, (v) => {\n inputVal.value = v;\n })\n\n watch(() => inputVal.value, (v) => {\n selectVal.value = v;\n })\n\n function input(str: string) {\n if (selectRef.value?.dropdownMenuVisible) {\n selectRef.value.states.inputValue = inputVal.value;\n selectRef.value.debouncedOnInputChange();\n }\n emit('update:modelValue', str)\n emit('input', str)\n }\n\n function change(str: string) {\n emit('change', str)\n }\n\n function focus() {\n if (selectRef.value && props.autoPullDown) {\n setTimeout(() => {\n selectRef.value.dropdownMenuVisible = true;\n }, 200)\n }\n }\n\n function 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\n function showSelect() {\n if (selectRef.value) {\n selectRef.value.dropdownMenuVisible = !selectRef.value.dropdownMenuVisible;\n }\n }\n\n function 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\n function selectVisibleChange(v: boolean) {\n arrowName.value = v ? 'arrow-up' : 'arrow-down'\n }\n\n\n</script>\n"],"names":["useAttrs","ref","useNamespace","useFormSize","useFormDisabled","computed","useGlobalSize","watch"],"mappings":"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"}
1
+ {"version":3,"file":"select2.js","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":["buildProps","definePropType","useSizeProp","UPDATE_MODEL_EVENT","isString"],"mappings":";;;;;;;;;;;;AAGY,MAAC,WAAW,GAAGA,kBAAU,CAAC;AACtC,EAAE,WAAW,EAAE,MAAM;AACrB,EAAE,OAAO,EAAE;AACX,IAAI,IAAI,EAAEC,sBAAc,CAAC,KAAK,CAAC;AAC/B,IAAI,OAAO,EAAE,MAAM,EAAE;AACrB,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,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,EAAEC,iBAAW;AACnB,CAAC,EAAE;AACS,MAAC,WAAW,GAAG;AAC3B,EAAE,CAACC,wBAAkB,GAAG,CAAC,KAAK,KAAKC,eAAQ,CAAC,KAAK,CAAC;AAClD,EAAE,OAAO,EAAE,CAAC,KAAK,KAAKA,eAAQ,CAAC,KAAK,CAAC;AACrC,EAAE,QAAQ,EAAE,CAAC,KAAK,KAAKA,eAAQ,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;;;;;"}
package/lib/index.js CHANGED
@@ -32,14 +32,14 @@ var selectTextarea = require('./components/select-textarea/src/select-textarea.j
32
32
  var index$e = require('./components/select-textarea/index.js');
33
33
  var inputRange = require('./components/input-range/src/input-range.js');
34
34
  var index$f = require('./components/input-range/index.js');
35
- var cascader = require('./components/cascader/src/cascader.js');
35
+ var cascader = require('./components/cascader/src/cascader2.js');
36
36
  var index$g = require('./components/cascader/index.js');
37
- var select = require('./components/select/src/select.js');
37
+ var select = require('./components/select/src/select2.js');
38
38
  var index$h = require('./components/select/index.js');
39
39
  var clickInput = require('./components/click-input/src/click-input.js');
40
40
  var index$i = require('./components/click-input/index.js');
41
41
  var index$j = require('./components/scroll/index.js');
42
- var lazyList = require('./components/lazy-list/src/lazy-list2.js');
42
+ var lazyList = require('./components/lazy-list/src/lazy-list.js');
43
43
  var index$k = require('./components/lazy-list/index.js');
44
44
  var key = require('./constants/key.js');
45
45
  var size = require('./constants/size.js');
package/lib/version.d.ts CHANGED
@@ -1 +1 @@
1
- export declare const version = "2.0.8";
1
+ export declare const version = "2.0.9";
package/lib/version.js CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const version = "2.0.8";
5
+ const version = "2.0.9";
6
6
 
7
7
  exports.version = version;
8
8
  //# sourceMappingURL=version.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.js","sources":["../../../packages/hzzt-plus/version.ts"],"sourcesContent":["export const version = '2.0.8'\n"],"names":[],"mappings":";;;;AAAY,MAAC,OAAO,GAAG;;;;"}
1
+ {"version":3,"file":"version.js","sources":["../../../packages/hzzt-plus/version.ts"],"sourcesContent":["export const version = '2.0.9'\n"],"names":[],"mappings":";;;;AAAY,MAAC,OAAO,GAAG;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hzzt-plus",
3
- "version": "2.0.9",
3
+ "version": "2.0.11",
4
4
  "description": "A Component Library for Vue 3",
5
5
  "keywords": [
6
6
  "hzzt-plus",