@tagplus/components 5.2.19 → 5.3.0
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/es/_virtual/_plugin-vue_export-helper.mjs +10 -0
- package/dist/es/components.css +2391 -0
- package/dist/es/node_modules/@element-plus/icons-vue/dist/index.mjs +148 -0
- package/dist/es/node_modules/@popperjs/core/lib/enums.mjs +22 -0
- package/dist/es/node_modules/@vue/shared/dist/shared.esm-bundler.mjs +28 -0
- package/dist/es/node_modules/@vueuse/core/index.mjs +172 -0
- package/dist/es/node_modules/@vueuse/shared/index.mjs +68 -0
- package/dist/es/node_modules/element-plus/es/constants/size.mjs +4 -0
- package/dist/es/node_modules/element-plus/es/hooks/use-focus-controller/index.mjs +64 -0
- package/dist/es/node_modules/element-plus/es/hooks/use-id/index.mjs +30 -0
- package/dist/es/node_modules/element-plus/es/hooks/use-locale/index.mjs +29 -0
- package/dist/es/node_modules/element-plus/es/hooks/use-namespace/index.mjs +79 -0
- package/dist/es/node_modules/element-plus/es/hooks/use-prop/index.mjs +11 -0
- package/dist/es/node_modules/element-plus/es/hooks/use-size/index.mjs +20 -0
- package/dist/es/node_modules/element-plus/es/locale/lang/en.mjs +182 -0
- package/dist/es/node_modules/element-plus/es/utils/error.mjs +16 -0
- package/dist/es/node_modules/element-plus/es/utils/types.mjs +9 -0
- package/dist/es/node_modules/element-plus/es/utils/vue/props/runtime.mjs +42 -0
- package/dist/es/src/components/Autosuggest/Autosuggest.vue.mjs +446 -0
- package/dist/es/src/components/Autosuggest/Multisuggest.vue.mjs +17 -0
- package/dist/es/src/components/Autosuggest/autosuggest-props.mjs +204 -0
- package/dist/es/src/components/Autosuggest/core.mjs +56 -0
- package/dist/es/src/components/Autosuggest/multisuggest-props.mjs +11 -0
- package/dist/es/src/components/Autosuggest/option.vue.mjs +118 -0
- package/dist/es/src/components/Autosuggest/select-dropdown.vue.mjs +62 -0
- package/dist/es/src/components/Autosuggest/useOption.mjs +93 -0
- package/dist/es/src/components/Autosuggest/useSelect.mjs +803 -0
- package/dist/es/src/components/Inline/Inline.vue.mjs +125 -0
- package/dist/es/src/components/Inline/index.mjs +4 -0
- package/dist/es/src/components/InputNumber/InputNumber.vue.mjs +360 -0
- package/dist/es/src/components/InputNumber/index.mjs +4 -0
- package/dist/es/src/components/InputNumber/input-number.mjs +128 -0
- package/dist/es/src/components/Loader/Loader.vue.mjs +59 -0
- package/dist/es/src/components/Loader/index.mjs +4 -0
- package/dist/es/src/components/Money/Money.vue.mjs +72 -0
- package/dist/es/src/components/Money/index.mjs +4 -0
- package/dist/es/src/components/Multisuggest/index.mjs +4 -0
- package/dist/es/src/components/OptionsList/OptionsList.vue.mjs +28 -0
- package/dist/es/src/components/OptionsList/index.mjs +4 -0
- package/dist/es/src/components/OptionsListItem/OptionsListItem.vue.mjs +96 -0
- package/dist/es/src/components/OptionsListItem/index.mjs +4 -0
- package/dist/es/src/components/Percent/Percent.vue.mjs +73 -0
- package/dist/es/src/components/Percent/index.mjs +4 -0
- package/dist/es/src/components/Skeleton/Skeleton.vue.mjs +79 -0
- package/dist/es/src/components/Skeleton/index.mjs +4 -0
- package/dist/es/src/components/Step/Step.vue.mjs +206 -0
- package/dist/es/src/components/Step/index.mjs +4 -0
- package/dist/es/src/components/Steps/Steps.vue.mjs +15 -0
- package/dist/es/src/components/Steps/index.mjs +4 -0
- package/dist/es/src/components/Tip/Tip.vue.mjs +160 -0
- package/dist/es/src/components/Tip/index.mjs +4 -0
- package/dist/es/src/components/index.mjs +32 -0
- package/dist/es/src/locale/i18nCreator.mjs +93 -0
- package/dist/es/src/locale/lang/pt-br.mjs +21 -0
- package/dist/es/src/main.mjs +17 -0
- package/dist/es/src/mixins/floatFormatter.mjs +42 -0
- package/dist/es/src/plugins/currency.mjs +69 -0
- package/dist/es/src/utils/constants.mjs +6 -0
- package/dist/es/src/utils/error.mjs +22 -0
- package/dist/es/src/utils/i18n.mjs +4 -0
- package/dist/es/src/utils/icon.mjs +9 -0
- package/dist/es/src/utils/index.mjs +11 -0
- package/dist/es/src/utils/runtime.mjs +50 -0
- package/dist/es/src/utils/scroll.mjs +28 -0
- package/dist/es/src/utils/strings.mjs +4 -0
- package/dist/es/src/utils/types.mjs +9 -0
- package/dist/es/src/utils/use-derived-namespace.mjs +15 -0
- package/dist/es/src/utils/use-form-common-props.mjs +25 -0
- package/dist/es/src/utils/use-form-item.mjs +61 -0
- package/dist/es/src/utils/use-id.mjs +35 -0
- package/dist/es/src/utils/use-input.mjs +31 -0
- package/dist/lib/_virtual/_plugin-vue_export-helper.js +10 -0
- package/dist/lib/components.css +2391 -0
- package/dist/lib/node_modules/@element-plus/icons-vue/dist/index.js +148 -0
- package/dist/lib/node_modules/@popperjs/core/lib/enums.js +22 -0
- package/dist/lib/node_modules/@vue/shared/dist/shared.esm-bundler.js +28 -0
- package/dist/lib/node_modules/@vueuse/core/index.js +170 -0
- package/dist/lib/node_modules/@vueuse/shared/index.js +68 -0
- package/dist/lib/node_modules/element-plus/es/constants/size.js +4 -0
- package/dist/lib/node_modules/element-plus/es/hooks/use-focus-controller/index.js +64 -0
- package/dist/lib/node_modules/element-plus/es/hooks/use-id/index.js +30 -0
- package/dist/lib/node_modules/element-plus/es/hooks/use-locale/index.js +29 -0
- package/dist/lib/node_modules/element-plus/es/hooks/use-namespace/index.js +79 -0
- package/dist/lib/node_modules/element-plus/es/hooks/use-prop/index.js +11 -0
- package/dist/lib/node_modules/element-plus/es/hooks/use-size/index.js +20 -0
- package/dist/lib/node_modules/element-plus/es/locale/lang/en.js +182 -0
- package/dist/lib/node_modules/element-plus/es/utils/error.js +16 -0
- package/dist/lib/node_modules/element-plus/es/utils/types.js +9 -0
- package/dist/lib/node_modules/element-plus/es/utils/vue/props/runtime.js +42 -0
- package/dist/lib/src/components/Autosuggest/Autosuggest.vue.js +446 -0
- package/dist/lib/src/components/Autosuggest/Multisuggest.vue.js +17 -0
- package/dist/lib/src/components/Autosuggest/autosuggest-props.js +204 -0
- package/dist/lib/src/components/Autosuggest/core.js +56 -0
- package/dist/lib/src/components/Autosuggest/multisuggest-props.js +11 -0
- package/dist/lib/src/components/Autosuggest/option.vue.js +118 -0
- package/dist/lib/src/components/Autosuggest/select-dropdown.vue.js +62 -0
- package/dist/lib/src/components/Autosuggest/useOption.js +93 -0
- package/dist/lib/src/components/Autosuggest/useSelect.js +803 -0
- package/dist/lib/src/components/Inline/Inline.vue.js +125 -0
- package/dist/lib/src/components/Inline/index.js +4 -0
- package/dist/lib/src/components/InputNumber/InputNumber.vue.js +360 -0
- package/dist/lib/src/components/InputNumber/index.js +4 -0
- package/dist/lib/src/components/InputNumber/input-number.js +128 -0
- package/dist/lib/src/components/Loader/Loader.vue.js +59 -0
- package/dist/lib/src/components/Loader/index.js +4 -0
- package/dist/lib/src/components/Money/Money.vue.js +72 -0
- package/dist/lib/src/components/Money/index.js +4 -0
- package/dist/lib/src/components/Multisuggest/index.js +4 -0
- package/dist/lib/src/components/OptionsList/OptionsList.vue.js +28 -0
- package/dist/lib/src/components/OptionsList/index.js +4 -0
- package/dist/lib/src/components/OptionsListItem/OptionsListItem.vue.js +96 -0
- package/dist/lib/src/components/OptionsListItem/index.js +4 -0
- package/dist/lib/src/components/Percent/Percent.vue.js +73 -0
- package/dist/lib/src/components/Percent/index.js +4 -0
- package/dist/lib/src/components/Skeleton/Skeleton.vue.js +79 -0
- package/dist/lib/src/components/Skeleton/index.js +4 -0
- package/dist/lib/src/components/Step/Step.vue.js +206 -0
- package/dist/lib/src/components/Step/index.js +4 -0
- package/dist/lib/src/components/Steps/Steps.vue.js +15 -0
- package/dist/lib/src/components/Steps/index.js +4 -0
- package/dist/lib/src/components/Tip/Tip.vue.js +160 -0
- package/dist/lib/src/components/Tip/index.js +4 -0
- package/dist/lib/src/components/index.js +32 -0
- package/dist/lib/src/locale/i18nCreator.js +93 -0
- package/dist/lib/src/locale/lang/pt-br.js +21 -0
- package/dist/lib/src/main.js +17 -0
- package/dist/lib/src/mixins/floatFormatter.js +42 -0
- package/dist/lib/src/plugins/currency.js +69 -0
- package/dist/lib/src/utils/constants.js +6 -0
- package/dist/lib/src/utils/error.js +22 -0
- package/dist/lib/src/utils/i18n.js +4 -0
- package/dist/lib/src/utils/icon.js +9 -0
- package/dist/lib/src/utils/index.js +14 -0
- package/dist/lib/src/utils/runtime.js +50 -0
- package/dist/lib/src/utils/scroll.js +28 -0
- package/dist/lib/src/utils/strings.js +4 -0
- package/dist/lib/src/utils/types.js +12 -0
- package/dist/lib/src/utils/use-derived-namespace.js +15 -0
- package/dist/lib/src/utils/use-form-common-props.js +25 -0
- package/dist/lib/src/utils/use-form-item.js +61 -0
- package/dist/lib/src/utils/use-id.js +35 -0
- package/dist/lib/src/utils/use-input.js +31 -0
- package/package.json +19 -17
- package/dist/main.bundle.js +0 -2
- package/dist/main.bundle.js.LICENSE.txt +0 -15
- package/dist/main.css +0 -11
- package/src/locale/i18nCreator.js +0 -170
- package/src/locale/lang/en.js +0 -35
- package/src/locale/lang/pt-br.js +0 -35
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const vue = require("vue");
|
|
4
|
+
const elementPlus = require("element-plus");
|
|
5
|
+
const index = require("../../../node_modules/@element-plus/icons-vue/dist/index.js");
|
|
6
|
+
const selectDropdown = require("./select-dropdown.vue.js");
|
|
7
|
+
const option = require("./option.vue.js");
|
|
8
|
+
const useSelect = require("./useSelect.js");
|
|
9
|
+
function autosuggestCore(component_name, propsDefinition) {
|
|
10
|
+
return {
|
|
11
|
+
name: component_name,
|
|
12
|
+
componentName: component_name,
|
|
13
|
+
directives: {
|
|
14
|
+
ClickOutside: elementPlus.ClickOutside
|
|
15
|
+
},
|
|
16
|
+
components: {
|
|
17
|
+
ArrowDown: index.ArrowDown,
|
|
18
|
+
ElOption: option.default,
|
|
19
|
+
ElSelectMenu: selectDropdown.default
|
|
20
|
+
},
|
|
21
|
+
props: propsDefinition,
|
|
22
|
+
emits: [
|
|
23
|
+
"update:modelValue",
|
|
24
|
+
"change",
|
|
25
|
+
"remove-tag",
|
|
26
|
+
"clear",
|
|
27
|
+
"visible-change",
|
|
28
|
+
"focus",
|
|
29
|
+
"blur"
|
|
30
|
+
],
|
|
31
|
+
setup(props, context) {
|
|
32
|
+
const API = useSelect.useSelect(props, context);
|
|
33
|
+
vue.provide(
|
|
34
|
+
"select",
|
|
35
|
+
vue.reactive({
|
|
36
|
+
props,
|
|
37
|
+
states: API.states,
|
|
38
|
+
optionsArray: API.optionsArray,
|
|
39
|
+
handleOptionSelect: API.handleOptionSelect,
|
|
40
|
+
onOptionCreate: API.onOptionCreate,
|
|
41
|
+
onOptionDestroy: API.onOptionDestroy,
|
|
42
|
+
selectRef: API.selectRef,
|
|
43
|
+
setSelected: API.setSelected
|
|
44
|
+
})
|
|
45
|
+
);
|
|
46
|
+
return API;
|
|
47
|
+
},
|
|
48
|
+
data() {
|
|
49
|
+
return {
|
|
50
|
+
visible: false,
|
|
51
|
+
tooltipVisible: false
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
exports.default = autosuggestCore;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const autosuggestProps = require("./autosuggest-props.js");
|
|
4
|
+
const multisuggestProps = {
|
|
5
|
+
...autosuggestProps.default,
|
|
6
|
+
multiple: {
|
|
7
|
+
type: Boolean,
|
|
8
|
+
default: true
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
exports.default = multisuggestProps;
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const vue = require("vue");
|
|
4
|
+
const useOption = require("./useOption.js");
|
|
5
|
+
const _pluginVue_exportHelper = require("../../../_virtual/_plugin-vue_export-helper.js");
|
|
6
|
+
const index = require("../../../node_modules/element-plus/es/hooks/use-namespace/index.js");
|
|
7
|
+
const index$1 = require("../../../node_modules/element-plus/es/hooks/use-id/index.js");
|
|
8
|
+
const _sfc_main = vue.defineComponent({
|
|
9
|
+
name: "ElOption",
|
|
10
|
+
componentName: "ElOption",
|
|
11
|
+
props: {
|
|
12
|
+
/**
|
|
13
|
+
* @description value of option
|
|
14
|
+
*/
|
|
15
|
+
value: {
|
|
16
|
+
required: true,
|
|
17
|
+
type: [String, Number, Boolean, Object, null]
|
|
18
|
+
},
|
|
19
|
+
/**
|
|
20
|
+
* @description label of option, same as `value` if omitted
|
|
21
|
+
*/
|
|
22
|
+
label: [String, Number],
|
|
23
|
+
created: Boolean,
|
|
24
|
+
/**
|
|
25
|
+
* @description whether option is disabled
|
|
26
|
+
*/
|
|
27
|
+
disabled: Boolean,
|
|
28
|
+
/**
|
|
29
|
+
* @tagplus
|
|
30
|
+
* @description recebe o item inteiro para ser emitido, ao inves de somente key/value
|
|
31
|
+
*/
|
|
32
|
+
item: {
|
|
33
|
+
type: [String, Number, Boolean, Object],
|
|
34
|
+
required: true
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
setup(props) {
|
|
38
|
+
const ns = index.useNamespace("select");
|
|
39
|
+
const id = index$1.useId();
|
|
40
|
+
const containerKls = vue.computed(() => [
|
|
41
|
+
ns.be("dropdown", "item"),
|
|
42
|
+
ns.is("disabled", vue.unref(isDisabled)),
|
|
43
|
+
ns.is("selected", vue.unref(itemSelected)),
|
|
44
|
+
ns.is("hovering", vue.unref(hover))
|
|
45
|
+
]);
|
|
46
|
+
const states = vue.reactive({
|
|
47
|
+
index: -1,
|
|
48
|
+
groupDisabled: false,
|
|
49
|
+
visible: true,
|
|
50
|
+
hover: false
|
|
51
|
+
});
|
|
52
|
+
const {
|
|
53
|
+
currentLabel,
|
|
54
|
+
itemSelected,
|
|
55
|
+
isDisabled,
|
|
56
|
+
select,
|
|
57
|
+
hoverItem,
|
|
58
|
+
updateOption
|
|
59
|
+
} = useOption.useOption(props, states);
|
|
60
|
+
const { visible, hover } = vue.toRefs(states);
|
|
61
|
+
const vm = vue.getCurrentInstance().proxy;
|
|
62
|
+
select.onOptionCreate(vm);
|
|
63
|
+
vue.onBeforeUnmount(() => {
|
|
64
|
+
const key = vm.value;
|
|
65
|
+
const { selected } = select.states;
|
|
66
|
+
const selectedOptions = select.props.multiple ? selected : [selected];
|
|
67
|
+
const doesSelected = selectedOptions.some((item) => {
|
|
68
|
+
return item.value === vm.value;
|
|
69
|
+
});
|
|
70
|
+
vue.nextTick(() => {
|
|
71
|
+
if (select.states.cachedOptions.get(key) === vm && !doesSelected) {
|
|
72
|
+
select.states.cachedOptions.delete(key);
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
select.onOptionDestroy(key, vm);
|
|
76
|
+
});
|
|
77
|
+
function selectOptionClick() {
|
|
78
|
+
if (props.disabled !== true && states.groupDisabled !== true) {
|
|
79
|
+
select.handleOptionSelect(vm);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return {
|
|
83
|
+
ns,
|
|
84
|
+
id,
|
|
85
|
+
containerKls,
|
|
86
|
+
currentLabel,
|
|
87
|
+
itemSelected,
|
|
88
|
+
isDisabled,
|
|
89
|
+
select,
|
|
90
|
+
hoverItem,
|
|
91
|
+
updateOption,
|
|
92
|
+
visible,
|
|
93
|
+
hover,
|
|
94
|
+
selectOptionClick,
|
|
95
|
+
states
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
const _hoisted_1 = ["id", "aria-disabled", "aria-selected"];
|
|
100
|
+
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
101
|
+
return vue.withDirectives((vue.openBlock(), vue.createElementBlock("li", {
|
|
102
|
+
id: _ctx.id,
|
|
103
|
+
class: vue.normalizeClass(_ctx.containerKls),
|
|
104
|
+
role: "option",
|
|
105
|
+
"aria-disabled": _ctx.isDisabled || void 0,
|
|
106
|
+
"aria-selected": _ctx.itemSelected,
|
|
107
|
+
onMouseenter: _cache[0] || (_cache[0] = (...args) => _ctx.hoverItem && _ctx.hoverItem(...args)),
|
|
108
|
+
onClick: _cache[1] || (_cache[1] = vue.withModifiers((...args) => _ctx.selectOptionClick && _ctx.selectOptionClick(...args), ["stop"]))
|
|
109
|
+
}, [
|
|
110
|
+
vue.renderSlot(_ctx.$slots, "default", {}, () => [
|
|
111
|
+
vue.createElementVNode("span", null, vue.toDisplayString(_ctx.currentLabel), 1)
|
|
112
|
+
])
|
|
113
|
+
], 42, _hoisted_1)), [
|
|
114
|
+
[vue.vShow, _ctx.visible]
|
|
115
|
+
]);
|
|
116
|
+
}
|
|
117
|
+
const ElOption = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["render", _sfc_render]]);
|
|
118
|
+
exports.default = ElOption;
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const vue = require("vue");
|
|
4
|
+
const index = require("../../../node_modules/@vueuse/core/index.js");
|
|
5
|
+
const _pluginVue_exportHelper = require("../../../_virtual/_plugin-vue_export-helper.js");
|
|
6
|
+
const index$1 = require("../../../node_modules/element-plus/es/hooks/use-namespace/index.js");
|
|
7
|
+
const _sfc_main = vue.defineComponent({
|
|
8
|
+
name: "ElSelectDropdown",
|
|
9
|
+
componentName: "ElSelectDropdown",
|
|
10
|
+
inject: ["select"],
|
|
11
|
+
setup() {
|
|
12
|
+
const ns = index$1.useNamespace("select");
|
|
13
|
+
const minWidth = vue.ref("");
|
|
14
|
+
return {
|
|
15
|
+
ns,
|
|
16
|
+
minWidth
|
|
17
|
+
};
|
|
18
|
+
},
|
|
19
|
+
computed: {
|
|
20
|
+
popperClass() {
|
|
21
|
+
return this.select.popperClass;
|
|
22
|
+
},
|
|
23
|
+
isMultiple() {
|
|
24
|
+
return this.select.multiple;
|
|
25
|
+
},
|
|
26
|
+
isFitInputWidth() {
|
|
27
|
+
return this.select.fitInputWidth;
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
mounted() {
|
|
31
|
+
this.updateMinWidth();
|
|
32
|
+
index.useResizeObserver(this.select.selectRef, this.updateMinWidth);
|
|
33
|
+
},
|
|
34
|
+
methods: {
|
|
35
|
+
updateMinWidth() {
|
|
36
|
+
var _a;
|
|
37
|
+
this.minWidth = `${(_a = this.select.selectRef) == null ? void 0 : _a.offsetWidth}px`;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
42
|
+
return vue.openBlock(), vue.createElementBlock("div", {
|
|
43
|
+
class: vue.normalizeClass([_ctx.ns.b("dropdown"), _ctx.ns.is("multiple", _ctx.isMultiple), _ctx.popperClass]),
|
|
44
|
+
style: vue.normalizeStyle({ [_ctx.isFitInputWidth ? "width" : "minWidth"]: _ctx.minWidth })
|
|
45
|
+
}, [
|
|
46
|
+
_ctx.$slots.header ? (vue.openBlock(), vue.createElementBlock("div", {
|
|
47
|
+
key: 0,
|
|
48
|
+
class: vue.normalizeClass(_ctx.ns.be("dropdown", "header"))
|
|
49
|
+
}, [
|
|
50
|
+
vue.renderSlot(_ctx.$slots, "header")
|
|
51
|
+
], 2)) : vue.createCommentVNode("", true),
|
|
52
|
+
vue.renderSlot(_ctx.$slots, "default"),
|
|
53
|
+
_ctx.$slots.footer ? (vue.openBlock(), vue.createElementBlock("div", {
|
|
54
|
+
key: 1,
|
|
55
|
+
class: vue.normalizeClass(_ctx.ns.be("dropdown", "footer"))
|
|
56
|
+
}, [
|
|
57
|
+
vue.renderSlot(_ctx.$slots, "footer")
|
|
58
|
+
], 2)) : vue.createCommentVNode("", true)
|
|
59
|
+
], 6);
|
|
60
|
+
}
|
|
61
|
+
const ElSelectMenu = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["render", _sfc_render]]);
|
|
62
|
+
exports.default = ElSelectMenu;
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const vue = require("vue");
|
|
4
|
+
const lodashEs = require("lodash-es");
|
|
5
|
+
const shared_esmBundler = require("../../../node_modules/@vue/shared/dist/shared.esm-bundler.js");
|
|
6
|
+
const strings = require("../../utils/strings.js");
|
|
7
|
+
function useOption(props, states) {
|
|
8
|
+
const select = vue.inject("select");
|
|
9
|
+
const selectGroup = vue.inject("ElSelectGroup", { disabled: false });
|
|
10
|
+
const itemSelected = vue.computed(() => {
|
|
11
|
+
if (select.props.multiple) {
|
|
12
|
+
return contains(select.props.modelValue, props.value);
|
|
13
|
+
} else {
|
|
14
|
+
return contains([select.props.modelValue], props.value);
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
const limitReached = vue.computed(() => {
|
|
18
|
+
if (select.props.multiple) {
|
|
19
|
+
const modelValue = select.props.modelValue || [];
|
|
20
|
+
return !itemSelected.value && modelValue.length >= select.props.multipleLimit && select.props.multipleLimit > 0;
|
|
21
|
+
} else {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
const currentLabel = vue.computed(() => {
|
|
26
|
+
return props.label || (shared_esmBundler.isObject(props.value) ? "" : props.value);
|
|
27
|
+
});
|
|
28
|
+
const currentValue = vue.computed(() => {
|
|
29
|
+
return props.value || props.label || "";
|
|
30
|
+
});
|
|
31
|
+
const isDisabled = vue.computed(() => {
|
|
32
|
+
return props.disabled || states.groupDisabled || limitReached.value;
|
|
33
|
+
});
|
|
34
|
+
const instance = vue.getCurrentInstance();
|
|
35
|
+
const contains = (arr = [], target) => {
|
|
36
|
+
if (!shared_esmBundler.isObject(props.value)) {
|
|
37
|
+
return arr && arr.includes(target);
|
|
38
|
+
} else {
|
|
39
|
+
const valueKey = select.props.valueKey;
|
|
40
|
+
return arr && arr.some((item) => {
|
|
41
|
+
return vue.toRaw(lodashEs.get(item, valueKey)) === lodashEs.get(target, valueKey);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
const hoverItem = () => {
|
|
46
|
+
if (!props.disabled && !selectGroup.disabled) {
|
|
47
|
+
select.states.hoveringIndex = select.optionsArray.indexOf(instance.proxy);
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
const updateOption = (query) => {
|
|
51
|
+
const regexp = new RegExp(strings.escapeStringRegexp(query), "i");
|
|
52
|
+
states.visible = regexp.test(currentLabel.value) || props.created;
|
|
53
|
+
};
|
|
54
|
+
vue.watch(
|
|
55
|
+
() => currentLabel.value,
|
|
56
|
+
() => {
|
|
57
|
+
if (!props.created && !select.props.remote) select.setSelected();
|
|
58
|
+
}
|
|
59
|
+
);
|
|
60
|
+
vue.watch(
|
|
61
|
+
() => props.value,
|
|
62
|
+
(val, oldVal) => {
|
|
63
|
+
const { remote, valueKey } = select.props;
|
|
64
|
+
if (!lodashEs.isEqual(val, oldVal)) {
|
|
65
|
+
select.onOptionDestroy(oldVal, instance.proxy);
|
|
66
|
+
select.onOptionCreate(instance.proxy);
|
|
67
|
+
}
|
|
68
|
+
if (!props.created && !remote) {
|
|
69
|
+
if (valueKey && shared_esmBundler.isObject(val) && shared_esmBundler.isObject(oldVal) && val[valueKey] === oldVal[valueKey]) {
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
select.setSelected();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
);
|
|
76
|
+
vue.watch(
|
|
77
|
+
() => selectGroup.disabled,
|
|
78
|
+
() => {
|
|
79
|
+
states.groupDisabled = selectGroup.disabled;
|
|
80
|
+
},
|
|
81
|
+
{ immediate: true }
|
|
82
|
+
);
|
|
83
|
+
return {
|
|
84
|
+
select,
|
|
85
|
+
currentLabel,
|
|
86
|
+
currentValue,
|
|
87
|
+
itemSelected,
|
|
88
|
+
isDisabled,
|
|
89
|
+
hoverItem,
|
|
90
|
+
updateOption
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
exports.useOption = useOption;
|