hzzt-plus 2.0.2 → 2.0.3
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.
- package/dist/index.full.js +6 -2
- package/dist/index.full.min.js +5 -5
- package/dist/index.full.min.js.map +1 -1
- package/dist/index.full.min.mjs +5 -5
- package/dist/index.full.min.mjs.map +1 -1
- package/dist/index.full.mjs +6 -2
- package/dist/locale/en.js +1 -1
- package/dist/locale/en.min.js +1 -1
- package/dist/locale/en.min.mjs +1 -1
- package/dist/locale/en.mjs +1 -1
- package/dist/locale/zh-cn.js +1 -1
- package/dist/locale/zh-cn.min.js +1 -1
- package/dist/locale/zh-cn.min.mjs +1 -1
- package/dist/locale/zh-cn.mjs +1 -1
- package/es/components/index.mjs +2 -2
- package/es/components/input-range/index.mjs +2 -2
- package/es/components/input-range/src/input-range.mjs +26 -76
- package/es/components/input-range/src/input-range.mjs.map +1 -1
- package/es/components/input-range/src/input-range2.mjs +76 -26
- package/es/components/input-range/src/input-range2.mjs.map +1 -1
- package/es/components/scroll/index.mjs +2 -2
- package/es/components/scroll/src/scroll.mjs +90 -0
- package/es/components/scroll/src/scroll.mjs.map +1 -1
- package/es/components/scroll/src/scroll.vue.d.ts +1 -0
- package/es/components/scroll/src/scroll2.mjs +0 -86
- package/es/components/scroll/src/scroll2.mjs.map +1 -1
- package/es/components/select-input/index.mjs +2 -2
- package/es/components/select-input/src/select-input.mjs +124 -45
- package/es/components/select-input/src/select-input.mjs.map +1 -1
- package/es/components/select-input/src/select-input2.mjs +45 -124
- package/es/components/select-input/src/select-input2.mjs.map +1 -1
- package/es/index.mjs +2 -2
- package/es/version.d.ts +1 -1
- package/es/version.mjs +1 -1
- package/es/version.mjs.map +1 -1
- package/lib/components/index.js +2 -2
- package/lib/components/input-range/index.js +2 -2
- package/lib/components/input-range/src/input-range.js +27 -76
- package/lib/components/input-range/src/input-range.js.map +1 -1
- package/lib/components/input-range/src/input-range2.js +76 -27
- package/lib/components/input-range/src/input-range2.js.map +1 -1
- package/lib/components/scroll/index.js +2 -2
- package/lib/components/scroll/src/scroll.js +93 -0
- package/lib/components/scroll/src/scroll.js.map +1 -1
- package/lib/components/scroll/src/scroll.vue.d.ts +1 -0
- package/lib/components/scroll/src/scroll2.js +0 -89
- package/lib/components/scroll/src/scroll2.js.map +1 -1
- package/lib/components/select-input/index.js +2 -2
- package/lib/components/select-input/src/select-input.js +124 -46
- package/lib/components/select-input/src/select-input.js.map +1 -1
- package/lib/components/select-input/src/select-input2.js +46 -124
- package/lib/components/select-input/src/select-input2.js.map +1 -1
- package/lib/index.js +2 -2
- package/lib/version.d.ts +1 -1
- package/lib/version.js +1 -1
- package/lib/version.js.map +1 -1
- package/package.json +1 -1
- package/web-types.json +1 -1
|
@@ -1,50 +1,129 @@
|
|
|
1
|
-
import '
|
|
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-input2.mjs';
|
|
2
3
|
import '../../../hooks/index.mjs';
|
|
3
|
-
import '
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
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
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
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 {
|
|
128
|
+
export { SelectInput as default };
|
|
50
129
|
//# sourceMappingURL=select-input.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"select-input.mjs","sources":["../../../../../../packages/components/select-input/src/select-input.
|
|
1
|
+
{"version":3,"file":"select-input.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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"}
|
|
@@ -1,129 +1,50 @@
|
|
|
1
|
-
import
|
|
2
|
-
import { selectInputProps, selectInputEmits } from './select-input.mjs';
|
|
1
|
+
import '../../../utils/index.mjs';
|
|
3
2
|
import '../../../hooks/index.mjs';
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import { numberToLetter } from '../../../hooks/use-letter/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';
|
|
10
8
|
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
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
|
|
15
42
|
});
|
|
16
|
-
const
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
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"]]);
|
|
43
|
+
const selectInputEmits = {
|
|
44
|
+
[UPDATE_MODEL_EVENT]: (value) => isString(value),
|
|
45
|
+
input: (value) => isString(value),
|
|
46
|
+
change: (value) => isString(value)
|
|
47
|
+
};
|
|
127
48
|
|
|
128
|
-
export {
|
|
49
|
+
export { selectInputEmits, selectInputProps };
|
|
129
50
|
//# sourceMappingURL=select-input2.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"select-input2.mjs","sources":["../../../../../../packages/components/select-input/src/select-input.
|
|
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;;;;"}
|
package/es/index.mjs
CHANGED
|
@@ -23,11 +23,11 @@ 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-
|
|
26
|
+
export { selectInputEmits, selectInputProps } from './components/select-input/src/select-input2.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-
|
|
30
|
+
export { inputRangeEmits, inputRangeProps } from './components/input-range/src/input-range.mjs';
|
|
31
31
|
export { HzztInputRange } from './components/input-range/index.mjs';
|
|
32
32
|
export { cascaderEmits, cascaderProps } from './components/cascader/src/cascader.mjs';
|
|
33
33
|
export { HzztCascader } from './components/cascader/index.mjs';
|
package/es/version.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const version = "2.0.
|
|
1
|
+
export declare const version = "2.0.3";
|
package/es/version.mjs
CHANGED
package/es/version.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"version.mjs","sources":["../../../packages/hzzt-plus/version.ts"],"sourcesContent":["export const version = '2.0.
|
|
1
|
+
{"version":3,"file":"version.mjs","sources":["../../../packages/hzzt-plus/version.ts"],"sourcesContent":["export const version = '2.0.3'\n"],"names":[],"mappings":"AAAY,MAAC,OAAO,GAAG;;;;"}
|
package/lib/components/index.js
CHANGED
|
@@ -28,9 +28,9 @@ var configProviderProps = require('./config-provider/src/config-provider-props.j
|
|
|
28
28
|
var constants = require('./config-provider/src/constants.js');
|
|
29
29
|
var useGlobalConfig = require('./config-provider/src/hooks/use-global-config.js');
|
|
30
30
|
var scan = require('./scan/src/scan.js');
|
|
31
|
-
var selectInput = require('./select-input/src/select-
|
|
31
|
+
var selectInput = require('./select-input/src/select-input2.js');
|
|
32
32
|
var selectTextarea = require('./select-textarea/src/select-textarea.js');
|
|
33
|
-
var inputRange = require('./input-range/src/input-
|
|
33
|
+
var inputRange = require('./input-range/src/input-range.js');
|
|
34
34
|
var cascader = require('./cascader/src/cascader.js');
|
|
35
35
|
var select = require('./select/src/select.js');
|
|
36
36
|
var clickInput = require('./click-input/src/click-input.js');
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
5
|
require('../../utils/index.js');
|
|
6
|
-
var inputRange$1 = require('./src/input-
|
|
7
|
-
var inputRange = require('./src/input-
|
|
6
|
+
var inputRange$1 = require('./src/input-range2.js');
|
|
7
|
+
var inputRange = require('./src/input-range.js');
|
|
8
8
|
var install = require('../../utils/vue/install.js');
|
|
9
9
|
|
|
10
10
|
const HzztInputRange = install.withInstall(inputRange$1["default"]);
|
|
@@ -2,84 +2,35 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
var inputRange = require('./input-range2.js');
|
|
7
|
-
var elementPlus = require('element-plus');
|
|
5
|
+
require('../../../utils/index.js');
|
|
8
6
|
require('../../../hooks/index.js');
|
|
9
|
-
|
|
10
|
-
var
|
|
11
|
-
var index
|
|
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');
|
|
11
|
+
var shared = require('@vue/shared');
|
|
12
12
|
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
|
|
13
|
+
const inputRangeProps = runtime.buildProps({
|
|
14
|
+
modelValue: {
|
|
15
|
+
type: Array,
|
|
16
|
+
default: () => []
|
|
17
|
+
},
|
|
18
|
+
size: index.useSizeProp,
|
|
19
|
+
disabled: Boolean,
|
|
20
|
+
clearable: {
|
|
21
|
+
type: Boolean,
|
|
22
|
+
default: false
|
|
23
|
+
},
|
|
24
|
+
startPlaceholder: String,
|
|
25
|
+
endPlaceholder: String,
|
|
26
|
+
startProps: Object,
|
|
27
|
+
endProps: Object
|
|
16
28
|
});
|
|
17
|
-
const
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
setup(__props, { emit }) {
|
|
22
|
-
const props = __props;
|
|
23
|
-
const startValue = vue.ref(props.modelValue[0]);
|
|
24
|
-
const endValue = vue.ref(props.modelValue[1]);
|
|
25
|
-
const nsInput = index.useNamespace("input-range");
|
|
26
|
-
const formSize = elementPlus.useFormSize();
|
|
27
|
-
const formDisabled = elementPlus.useFormDisabled();
|
|
28
|
-
const trueSize = vue.computed(() => props.size || formSize.value || index$1.useGlobalSize().value);
|
|
29
|
-
const trueDisabled = vue.computed(() => props.disabled || formDisabled.value);
|
|
30
|
-
const containerCls = vue.computed(() => [
|
|
31
|
-
nsInput.b(),
|
|
32
|
-
nsInput.m(trueSize.value)
|
|
33
|
-
]);
|
|
34
|
-
vue.watch(() => props.modelValue, (v) => {
|
|
35
|
-
startValue.value = v[0];
|
|
36
|
-
endValue.value = v[1];
|
|
37
|
-
}, {
|
|
38
|
-
deep: true
|
|
39
|
-
});
|
|
40
|
-
function change() {
|
|
41
|
-
if (startValue.value || endValue.value) {
|
|
42
|
-
const modelValue = [startValue.value, endValue.value];
|
|
43
|
-
emit("update:modelValue", modelValue);
|
|
44
|
-
emit("change", modelValue);
|
|
45
|
-
} else if (!startValue.value && !endValue.value) {
|
|
46
|
-
emit("update:modelValue", []);
|
|
47
|
-
emit("change", []);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
return (_ctx, _cache) => {
|
|
51
|
-
const _component_el_input = vue.resolveComponent("el-input");
|
|
52
|
-
return vue.openBlock(), vue.createElementBlock("div", {
|
|
53
|
-
class: vue.normalizeClass(["flex align-items-center", vue.unref(containerCls)])
|
|
54
|
-
}, [
|
|
55
|
-
vue.createVNode(_component_el_input, vue.mergeProps({
|
|
56
|
-
modelValue: startValue.value,
|
|
57
|
-
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => startValue.value = $event)
|
|
58
|
-
}, _ctx.startProps, {
|
|
59
|
-
clearable: _ctx.clearable,
|
|
60
|
-
placeholder: _ctx.startPlaceholder,
|
|
61
|
-
size: vue.unref(trueSize),
|
|
62
|
-
disabled: vue.unref(trueDisabled),
|
|
63
|
-
class: "flex-1",
|
|
64
|
-
onChange: change
|
|
65
|
-
}), null, 16, ["modelValue", "clearable", "placeholder", "size", "disabled"]),
|
|
66
|
-
_hoisted_1,
|
|
67
|
-
vue.createVNode(_component_el_input, vue.mergeProps({
|
|
68
|
-
modelValue: endValue.value,
|
|
69
|
-
"onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => endValue.value = $event)
|
|
70
|
-
}, _ctx.endProps, {
|
|
71
|
-
clearable: _ctx.clearable,
|
|
72
|
-
placeholder: _ctx.endPlaceholder,
|
|
73
|
-
size: vue.unref(trueSize),
|
|
74
|
-
disabled: vue.unref(trueDisabled),
|
|
75
|
-
class: "flex-1",
|
|
76
|
-
onChange: change
|
|
77
|
-
}), null, 16, ["modelValue", "clearable", "placeholder", "size", "disabled"])
|
|
78
|
-
], 2);
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
});
|
|
82
|
-
var InputRange = /* @__PURE__ */ pluginVue_exportHelper["default"](_sfc_main, [["__file", "input-range.vue"]]);
|
|
29
|
+
const inputRangeEmits = {
|
|
30
|
+
[event.UPDATE_MODEL_EVENT]: (val) => shared.isArray(val),
|
|
31
|
+
[event.CHANGE_EVENT]: (val) => shared.isArray(val)
|
|
32
|
+
};
|
|
83
33
|
|
|
84
|
-
exports
|
|
34
|
+
exports.inputRangeEmits = inputRangeEmits;
|
|
35
|
+
exports.inputRangeProps = inputRangeProps;
|
|
85
36
|
//# sourceMappingURL=input-range.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"input-range.js","sources":["../../../../../../packages/components/input-range/src/input-range.
|
|
1
|
+
{"version":3,"file":"input-range.js","sources":["../../../../../../packages/components/input-range/src/input-range.ts"],"sourcesContent":["import {buildProps, isArray} from '@hzzt-plus/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type InputRange from './input-range.vue'\nimport {useSizeProp} from \"@hzzt-plus/hooks\";\nimport {CHANGE_EVENT, UPDATE_MODEL_EVENT} from \"@hzzt-plus/constants\";\n\nexport const inputRangeProps = buildProps({\n modelValue: {\n type: Array,\n default: () => [],\n },\n size: useSizeProp,\n disabled: Boolean,\n clearable: {\n type: Boolean,\n default: false,\n },\n startPlaceholder: String,\n endPlaceholder: String,\n startProps: Object,\n endProps: Object,\n})\n\nexport type InputRangeProps = ExtractPropTypes<typeof inputRangeProps>\n\nexport const inputRangeEmits = {\n [UPDATE_MODEL_EVENT]: (val: Array<string>) => isArray(val),\n [CHANGE_EVENT]: (val: Array<string>) => isArray(val),\n}\nexport type InputRangeEmits = typeof inputRangeEmits\n\nexport type InputRangeInstance = InstanceType<typeof InputRange>\n"],"names":["buildProps","useSizeProp","UPDATE_MODEL_EVENT","isArray","CHANGE_EVENT"],"mappings":";;;;;;;;;;;;AAGY,MAAC,eAAe,GAAGA,kBAAU,CAAC;AAC1C,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,KAAK;AACf,IAAI,OAAO,EAAE,MAAM,EAAE;AACrB,GAAG;AACH,EAAE,IAAI,EAAEC,iBAAW;AACnB,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,SAAS,EAAE;AACb,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,gBAAgB,EAAE,MAAM;AAC1B,EAAE,cAAc,EAAE,MAAM;AACxB,EAAE,UAAU,EAAE,MAAM;AACpB,EAAE,QAAQ,EAAE,MAAM;AAClB,CAAC,EAAE;AACS,MAAC,eAAe,GAAG;AAC/B,EAAE,CAACC,wBAAkB,GAAG,CAAC,GAAG,KAAKC,cAAO,CAAC,GAAG,CAAC;AAC7C,EAAE,CAACC,kBAAY,GAAG,CAAC,GAAG,KAAKD,cAAO,CAAC,GAAG,CAAC;AACvC;;;;;"}
|