@tagplus/components 5.3.2 → 5.3.4
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/demo.html +1 -0
- package/dist/fonts/bevi-bold.7e4dcd11.woff +0 -0
- package/dist/fonts/bevi-bold.873def84.woff2 +0 -0
- package/dist/fonts/bevi-medium.6187e050.woff2 +0 -0
- package/dist/fonts/bevi-medium.65b3056d.woff +0 -0
- package/dist/fonts/bevi-regular.c89f126e.woff +0 -0
- package/dist/fonts/bevi-regular.f81e4b8f.woff2 +0 -0
- package/dist/tp.common.js +2 -0
- package/dist/tp.common.js.map +1 -0
- package/dist/tp.css +167 -0
- package/dist/tp.umd.js +2 -0
- package/dist/tp.umd.js.map +1 -0
- package/dist/tp.umd.min.js +2 -0
- package/dist/tp.umd.min.js.map +1 -0
- package/package.json +61 -74
- package/src/assets/scss/_fonts.scss +27 -0
- package/src/assets/scss/_functions.scss +22 -0
- package/src/assets/scss/_helpers.scss +112 -0
- package/src/assets/scss/_mixins.scss +69 -0
- package/src/assets/scss/_overrides.scss +69 -0
- package/src/assets/scss/_resass.scss +83 -0
- package/src/assets/scss/_variables.scss +27 -0
- package/src/assets/scss/index.scss +11 -0
- package/src/components/Autosuggest/Autosuggest.vue +791 -0
- package/src/components/Autosuggest/index.js +3 -0
- package/src/components/Dialog/Dialog.vue +253 -0
- package/src/components/Dialog/index.js +3 -0
- package/src/components/Inline/Inline.vue +149 -0
- package/src/components/Inline/index.js +3 -0
- package/src/components/InputNumber/InputNumber.vue +430 -0
- package/src/components/InputNumber/index.js +3 -0
- package/src/components/Loader/Loader.vue +317 -0
- package/src/components/Loader/animations.scss +68 -0
- package/src/components/Loader/index.js +3 -0
- package/src/components/Money/Money.vue +82 -0
- package/src/components/Money/index.js +3 -0
- package/src/components/Multisuggest/Multisuggest.vue +858 -0
- package/src/components/Multisuggest/index.js +3 -0
- package/src/components/OptionsList/OptionsList.vue +61 -0
- package/src/components/OptionsList/index.js +3 -0
- package/src/components/OptionsListItem/OptionsListItem.vue +191 -0
- package/src/components/OptionsListItem/index.js +3 -0
- package/src/components/Percent/Percent.vue +81 -0
- package/src/components/Percent/index.js +3 -0
- package/src/components/Skeleton/Skeleton.vue +137 -0
- package/src/components/Skeleton/index.js +3 -0
- package/src/components/Step/Step.vue +230 -0
- package/src/components/Step/index.js +3 -0
- package/src/components/Steps/Steps.vue +18 -0
- package/src/components/Steps/index.js +3 -0
- package/src/components/Tip/Tip.vue +193 -0
- package/src/components/Tip/index.js +3 -0
- package/src/components/index.js +31 -0
- package/src/locale/index.js +78 -0
- package/{dist → src/locale}/lang/en.js +2 -3
- package/{dist → src/locale}/lang/pt-br.js +2 -3
- package/src/main.js +26 -0
- package/src/mixins/floatFormatter.js +53 -0
- package/src/mixins/locale.js +9 -0
- package/src/utils/currency.js +180 -0
- package/src/utils/filters.js +84 -0
- package/dist/es/_virtual/_plugin-vue_export-helper.mjs +0 -10
- package/dist/es/components.css +0 -2391
- package/dist/es/node_modules/@element-plus/icons-vue/dist/index.mjs +0 -148
- package/dist/es/node_modules/@popperjs/core/lib/enums.mjs +0 -22
- package/dist/es/node_modules/@vue/shared/dist/shared.esm-bundler.mjs +0 -28
- package/dist/es/node_modules/@vueuse/core/index.mjs +0 -172
- package/dist/es/node_modules/@vueuse/shared/index.mjs +0 -68
- package/dist/es/node_modules/element-plus/es/constants/size.mjs +0 -4
- package/dist/es/node_modules/element-plus/es/hooks/use-focus-controller/index.mjs +0 -64
- package/dist/es/node_modules/element-plus/es/hooks/use-id/index.mjs +0 -30
- package/dist/es/node_modules/element-plus/es/hooks/use-locale/index.mjs +0 -29
- package/dist/es/node_modules/element-plus/es/hooks/use-namespace/index.mjs +0 -79
- package/dist/es/node_modules/element-plus/es/hooks/use-prop/index.mjs +0 -11
- package/dist/es/node_modules/element-plus/es/hooks/use-size/index.mjs +0 -20
- package/dist/es/node_modules/element-plus/es/locale/lang/en.mjs +0 -182
- package/dist/es/node_modules/element-plus/es/utils/error.mjs +0 -16
- package/dist/es/node_modules/element-plus/es/utils/types.mjs +0 -9
- package/dist/es/node_modules/element-plus/es/utils/vue/props/runtime.mjs +0 -42
- package/dist/es/src/components/Autosuggest/Autosuggest.vue.mjs +0 -446
- package/dist/es/src/components/Autosuggest/Multisuggest.vue.mjs +0 -17
- package/dist/es/src/components/Autosuggest/autosuggest-props.mjs +0 -204
- package/dist/es/src/components/Autosuggest/core.mjs +0 -56
- package/dist/es/src/components/Autosuggest/multisuggest-props.mjs +0 -11
- package/dist/es/src/components/Autosuggest/option.vue.mjs +0 -118
- package/dist/es/src/components/Autosuggest/select-dropdown.vue.mjs +0 -62
- package/dist/es/src/components/Autosuggest/useOption.mjs +0 -93
- package/dist/es/src/components/Autosuggest/useSelect.mjs +0 -803
- package/dist/es/src/components/Inline/Inline.vue.mjs +0 -125
- package/dist/es/src/components/Inline/index.mjs +0 -4
- package/dist/es/src/components/InputNumber/InputNumber.vue.mjs +0 -360
- package/dist/es/src/components/InputNumber/index.mjs +0 -4
- package/dist/es/src/components/InputNumber/input-number.mjs +0 -128
- package/dist/es/src/components/Loader/Loader.vue.mjs +0 -59
- package/dist/es/src/components/Loader/index.mjs +0 -4
- package/dist/es/src/components/Money/Money.vue.mjs +0 -72
- package/dist/es/src/components/Money/index.mjs +0 -4
- package/dist/es/src/components/Multisuggest/index.mjs +0 -4
- package/dist/es/src/components/OptionsList/OptionsList.vue.mjs +0 -28
- package/dist/es/src/components/OptionsList/index.mjs +0 -4
- package/dist/es/src/components/OptionsListItem/OptionsListItem.vue.mjs +0 -96
- package/dist/es/src/components/OptionsListItem/index.mjs +0 -4
- package/dist/es/src/components/Percent/Percent.vue.mjs +0 -73
- package/dist/es/src/components/Percent/index.mjs +0 -4
- package/dist/es/src/components/Skeleton/Skeleton.vue.mjs +0 -79
- package/dist/es/src/components/Skeleton/index.mjs +0 -4
- package/dist/es/src/components/Step/Step.vue.mjs +0 -206
- package/dist/es/src/components/Step/index.mjs +0 -4
- package/dist/es/src/components/Steps/Steps.vue.mjs +0 -15
- package/dist/es/src/components/Steps/index.mjs +0 -4
- package/dist/es/src/components/Tip/Tip.vue.mjs +0 -160
- package/dist/es/src/components/Tip/index.mjs +0 -4
- package/dist/es/src/components/index.mjs +0 -32
- package/dist/es/src/locale/i18nCreator.mjs +0 -93
- package/dist/es/src/locale/lang/pt-br.mjs +0 -21
- package/dist/es/src/main.mjs +0 -17
- package/dist/es/src/mixins/floatFormatter.mjs +0 -42
- package/dist/es/src/plugins/currency.mjs +0 -69
- package/dist/es/src/utils/constants.mjs +0 -6
- package/dist/es/src/utils/error.mjs +0 -22
- package/dist/es/src/utils/i18n.mjs +0 -4
- package/dist/es/src/utils/icon.mjs +0 -9
- package/dist/es/src/utils/index.mjs +0 -11
- package/dist/es/src/utils/runtime.mjs +0 -50
- package/dist/es/src/utils/scroll.mjs +0 -28
- package/dist/es/src/utils/strings.mjs +0 -4
- package/dist/es/src/utils/types.mjs +0 -9
- package/dist/es/src/utils/use-derived-namespace.mjs +0 -15
- package/dist/es/src/utils/use-form-common-props.mjs +0 -25
- package/dist/es/src/utils/use-form-item.mjs +0 -61
- package/dist/es/src/utils/use-id.mjs +0 -35
- package/dist/es/src/utils/use-input.mjs +0 -31
- package/dist/lib/_virtual/_plugin-vue_export-helper.js +0 -10
- package/dist/lib/components.css +0 -2391
- package/dist/lib/node_modules/@element-plus/icons-vue/dist/index.js +0 -148
- package/dist/lib/node_modules/@popperjs/core/lib/enums.js +0 -22
- package/dist/lib/node_modules/@vue/shared/dist/shared.esm-bundler.js +0 -28
- package/dist/lib/node_modules/@vueuse/core/index.js +0 -170
- package/dist/lib/node_modules/@vueuse/shared/index.js +0 -68
- package/dist/lib/node_modules/element-plus/es/constants/size.js +0 -4
- package/dist/lib/node_modules/element-plus/es/hooks/use-focus-controller/index.js +0 -64
- package/dist/lib/node_modules/element-plus/es/hooks/use-id/index.js +0 -30
- package/dist/lib/node_modules/element-plus/es/hooks/use-locale/index.js +0 -29
- package/dist/lib/node_modules/element-plus/es/hooks/use-namespace/index.js +0 -79
- package/dist/lib/node_modules/element-plus/es/hooks/use-prop/index.js +0 -11
- package/dist/lib/node_modules/element-plus/es/hooks/use-size/index.js +0 -20
- package/dist/lib/node_modules/element-plus/es/locale/lang/en.js +0 -182
- package/dist/lib/node_modules/element-plus/es/utils/error.js +0 -16
- package/dist/lib/node_modules/element-plus/es/utils/types.js +0 -9
- package/dist/lib/node_modules/element-plus/es/utils/vue/props/runtime.js +0 -42
- package/dist/lib/src/components/Autosuggest/Autosuggest.vue.js +0 -446
- package/dist/lib/src/components/Autosuggest/Multisuggest.vue.js +0 -17
- package/dist/lib/src/components/Autosuggest/autosuggest-props.js +0 -204
- package/dist/lib/src/components/Autosuggest/core.js +0 -56
- package/dist/lib/src/components/Autosuggest/multisuggest-props.js +0 -11
- package/dist/lib/src/components/Autosuggest/option.vue.js +0 -118
- package/dist/lib/src/components/Autosuggest/select-dropdown.vue.js +0 -62
- package/dist/lib/src/components/Autosuggest/useOption.js +0 -93
- package/dist/lib/src/components/Autosuggest/useSelect.js +0 -803
- package/dist/lib/src/components/Inline/Inline.vue.js +0 -125
- package/dist/lib/src/components/Inline/index.js +0 -4
- package/dist/lib/src/components/InputNumber/InputNumber.vue.js +0 -360
- package/dist/lib/src/components/InputNumber/index.js +0 -4
- package/dist/lib/src/components/InputNumber/input-number.js +0 -128
- package/dist/lib/src/components/Loader/Loader.vue.js +0 -59
- package/dist/lib/src/components/Loader/index.js +0 -4
- package/dist/lib/src/components/Money/Money.vue.js +0 -72
- package/dist/lib/src/components/Money/index.js +0 -4
- package/dist/lib/src/components/Multisuggest/index.js +0 -4
- package/dist/lib/src/components/OptionsList/OptionsList.vue.js +0 -28
- package/dist/lib/src/components/OptionsList/index.js +0 -4
- package/dist/lib/src/components/OptionsListItem/OptionsListItem.vue.js +0 -96
- package/dist/lib/src/components/OptionsListItem/index.js +0 -4
- package/dist/lib/src/components/Percent/Percent.vue.js +0 -73
- package/dist/lib/src/components/Percent/index.js +0 -4
- package/dist/lib/src/components/Skeleton/Skeleton.vue.js +0 -79
- package/dist/lib/src/components/Skeleton/index.js +0 -4
- package/dist/lib/src/components/Step/Step.vue.js +0 -206
- package/dist/lib/src/components/Step/index.js +0 -4
- package/dist/lib/src/components/Steps/Steps.vue.js +0 -15
- package/dist/lib/src/components/Steps/index.js +0 -4
- package/dist/lib/src/components/Tip/Tip.vue.js +0 -160
- package/dist/lib/src/components/Tip/index.js +0 -4
- package/dist/lib/src/components/index.js +0 -32
- package/dist/lib/src/locale/i18nCreator.js +0 -93
- package/dist/lib/src/locale/lang/pt-br.js +0 -21
- package/dist/lib/src/main.js +0 -17
- package/dist/lib/src/mixins/floatFormatter.js +0 -42
- package/dist/lib/src/plugins/currency.js +0 -69
- package/dist/lib/src/utils/constants.js +0 -6
- package/dist/lib/src/utils/error.js +0 -22
- package/dist/lib/src/utils/i18n.js +0 -4
- package/dist/lib/src/utils/icon.js +0 -9
- package/dist/lib/src/utils/index.js +0 -14
- package/dist/lib/src/utils/runtime.js +0 -50
- package/dist/lib/src/utils/scroll.js +0 -28
- package/dist/lib/src/utils/strings.js +0 -4
- package/dist/lib/src/utils/types.js +0 -12
- package/dist/lib/src/utils/use-derived-namespace.js +0 -15
- package/dist/lib/src/utils/use-form-common-props.js +0 -25
- package/dist/lib/src/utils/use-form-item.js +0 -61
- package/dist/lib/src/utils/use-id.js +0 -35
- package/dist/lib/src/utils/use-input.js +0 -31
|
@@ -1,56 +0,0 @@
|
|
|
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;
|
|
@@ -1,11 +0,0 @@
|
|
|
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;
|
|
@@ -1,118 +0,0 @@
|
|
|
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;
|
|
@@ -1,62 +0,0 @@
|
|
|
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;
|
|
@@ -1,93 +0,0 @@
|
|
|
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;
|