ele-admin-plus 1.4.0-beta.1 → 1.4.1-beta.1
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/es/ele-admin-layout/components/layout-skeleton.d.ts +9 -3
- package/es/ele-admin-layout/components/layout-skeleton.js +11 -5
- package/es/ele-admin-layout/components/layout-tabs.d.ts +7 -2
- package/es/ele-admin-layout/components/layout-tabs.js +9 -4
- package/es/ele-admin-layout/index.js +23 -18
- package/es/ele-alert/index.js +7 -8
- package/es/ele-app/el.d.ts +3 -1
- package/es/ele-app/plus.d.ts +12 -41
- package/es/ele-app/plusx.d.ts +40 -0
- package/es/ele-app/style/overwrite/date-picker/index.scss +1 -1
- package/es/ele-autocomplete/index.d.ts +265 -47
- package/es/ele-autocomplete/props.d.ts +124 -22
- package/es/ele-avatar-group/types.d.ts +1 -1
- package/es/ele-backtop/index.js +7 -8
- package/es/ele-basic-select/components/select-view.d.ts +129 -0
- package/es/ele-basic-select/components/select-view.js +272 -0
- package/es/ele-basic-select/index.d.ts +13 -23
- package/es/ele-basic-select/index.js +109 -248
- package/es/ele-basic-select/props.d.ts +8 -2
- package/es/ele-basic-select/props.js +7 -1
- package/es/ele-basic-select/types.d.ts +21 -0
- package/es/ele-basic-select/util.js +6 -1
- package/es/ele-bottom-bar/index.js +6 -6
- package/es/ele-breadcrumb/types.d.ts +1 -1
- package/es/ele-cascader/index.d.ts +14 -16
- package/es/ele-cascader/props.d.ts +3 -4
- package/es/ele-check-card/types.d.ts +1 -1
- package/es/ele-checkbox-group/index.d.ts +1 -1
- package/es/ele-config-provider/components/receiver-view.d.ts +2 -13
- package/es/ele-config-provider/components/receiver-view.js +111 -116
- package/es/ele-config-provider/receiver.d.ts +2 -0
- package/es/ele-config-provider/receiver.js +8 -1
- package/es/ele-cropper/index.d.ts +1 -3
- package/es/ele-cropper-modal/index.d.ts +1 -1
- package/es/ele-crud/components/page-side.js +1 -4
- package/es/ele-crud/types.d.ts +1 -1
- package/es/ele-crud/util.d.ts +1 -1
- package/es/ele-crud-builder/components/body-header.d.ts +1 -1
- package/es/ele-crud-builder/components/code-generator.d.ts +1 -1
- package/es/ele-crud-builder/components/code-preview.d.ts +1 -1
- package/es/ele-crud-builder/components/form-design-modal.d.ts +1 -1
- package/es/ele-crud-builder/components/import-modal.d.ts +1 -1
- package/es/ele-crud-builder/components/page-config.d.ts +1 -1
- package/es/ele-crud-builder/components/template-list.d.ts +1 -1
- package/es/ele-crud-builder/index.d.ts +3 -3
- package/es/ele-crud-builder/index.js +3 -3
- package/es/ele-crud-builder/props.d.ts +2 -1
- package/es/ele-crud-builder/types.d.ts +1 -1
- package/es/ele-crud-builder/util.js +2 -2
- package/es/ele-data-table/index.d.ts +38 -44
- package/es/ele-data-table/index.js +6 -3
- package/es/ele-data-table/props.d.ts +39 -45
- package/es/ele-drawer/index.d.ts +2 -2
- package/es/ele-drawer/index.js +5 -4
- package/es/ele-drawer/props.d.ts +6 -0
- package/es/ele-drawer/props.js +5 -1
- package/es/ele-dropdown/components/pro-dropdown.d.ts +26 -26
- package/es/ele-dropdown/index.d.ts +30 -30
- package/es/ele-dropdown/props.d.ts +12 -12
- package/es/ele-dropdown/types.d.ts +1 -1
- package/es/ele-edit-tag/index.d.ts +1 -1
- package/es/ele-ellipsis/props.d.ts +1 -1
- package/es/ele-file-list/components/file-grid.d.ts +1 -1
- package/es/ele-file-list/components/file-grid.js +2 -2
- package/es/ele-file-list/components/file-table.d.ts +1 -1
- package/es/ele-file-list/components/file-table.js +2 -2
- package/es/ele-file-list/icons.js +10 -1
- package/es/ele-file-list/types.d.ts +1 -1
- package/es/ele-icon-select/index.d.ts +5 -1
- package/es/ele-icon-select/index.js +3 -1
- package/es/ele-icon-select/props.d.ts +7 -2
- package/es/ele-icon-select/props.js +4 -0
- package/es/ele-image-viewer/index.d.ts +2 -16
- package/es/ele-image-viewer/index.js +13 -15
- package/es/ele-image-viewer/props.d.ts +1 -8
- package/es/ele-loading/index.js +6 -6
- package/es/ele-map-picker/index.d.ts +2 -4
- package/es/ele-mention/index.d.ts +29 -8
- package/es/ele-mention/props.d.ts +9 -0
- package/es/ele-menus/types.d.ts +2 -0
- package/es/ele-menus/util.js +1 -1
- package/es/ele-modal/index.d.ts +4 -4
- package/es/ele-modal/index.js +4 -3
- package/es/ele-popconfirm/index.d.ts +95 -96
- package/es/ele-popconfirm/index.js +6 -21
- package/es/ele-popconfirm/props.d.ts +32 -32
- package/es/ele-popover/index.d.ts +72 -72
- package/es/ele-printer/index.d.ts +2 -2
- package/es/ele-printer/index.js +8 -8
- package/es/ele-pro-form/components/render-util.d.ts +2 -2
- package/es/ele-pro-form/index.d.ts +2 -2
- package/es/ele-pro-form/props.d.ts +1 -1
- package/es/ele-pro-form-builder/components/body-form.d.ts +1 -1
- package/es/ele-pro-form-builder/components/body-header.d.ts +1 -1
- package/es/ele-pro-form-builder/components/code-generator.d.ts +1 -1
- package/es/ele-pro-form-builder/components/code-preview.d.ts +1 -1
- package/es/ele-pro-form-builder/components/config-form.d.ts +1 -1
- package/es/ele-pro-form-builder/components/import-modal.d.ts +1 -1
- package/es/ele-pro-form-builder/components/preview-modal.d.ts +1 -1
- package/es/ele-pro-form-builder/components/props-form.d.ts +1 -1
- package/es/ele-pro-form-builder/components/table-util.js +3 -0
- package/es/ele-pro-form-builder/components/template-list.d.ts +1 -1
- package/es/ele-pro-form-builder/index.d.ts +1 -1
- package/es/ele-pro-form-builder/props.d.ts +2 -1
- package/es/ele-pro-form-builder/types.d.ts +1 -1
- package/es/ele-pro-layout/index.d.ts +29 -29
- package/es/ele-pro-layout/props.d.ts +12 -12
- package/es/ele-pro-layout/style/index.scss +0 -2
- package/es/ele-pro-layout/types.d.ts +2 -0
- package/es/ele-pro-table/components/table-tools.d.ts +1 -1
- package/es/ele-pro-table/components/tool-export.d.ts +2 -2
- package/es/ele-pro-table/components/tool-print.d.ts +1 -1
- package/es/ele-pro-table/index.d.ts +40 -46
- package/es/ele-pro-table/index.js +11 -16
- package/es/ele-pro-table/props.d.ts +18 -21
- package/es/ele-pro-table/style/css-var.scss +4 -0
- package/es/ele-pro-table/style/index.scss +2 -2
- package/es/ele-radio-group/index.d.ts +2 -2
- package/es/ele-segmented/index.d.ts +2 -2
- package/es/ele-segmented/props.d.ts +1 -1
- package/es/ele-segmented/style/index.scss +1 -0
- package/es/ele-select/index.d.ts +9 -9
- package/es/ele-select/props.d.ts +1 -1
- package/es/ele-select/props.js +2 -2
- package/es/ele-select-tree/index.d.ts +7 -7
- package/es/ele-select-tree/props.d.ts +1 -1
- package/es/ele-select-tree/props.js +2 -2
- package/es/ele-split-panel/index.js +2 -2
- package/es/ele-steps/types.d.ts +1 -1
- package/es/ele-tab-bar/index.d.ts +4 -2
- package/es/ele-tab-bar/index.js +1 -0
- package/es/ele-tab-bar/props.d.ts +3 -1
- package/es/ele-tab-bar/props.js +4 -2
- package/es/ele-tab-bar/style/index.scss +1 -0
- package/es/ele-table-select/props.d.ts +2 -2
- package/es/ele-table-select/props.js +1 -1
- package/es/ele-tabs/index.d.ts +16 -12
- package/es/ele-tabs/style/index.scss +1 -0
- package/es/ele-tabs/types.d.ts +1 -1
- package/es/ele-timeline/types.d.ts +3 -3
- package/es/ele-tooltip/index.d.ts +53 -53
- package/es/ele-tour/index.js +8 -8
- package/es/ele-transfer/index.d.ts +1 -1
- package/es/ele-tree-select/index.d.ts +1 -1
- package/es/ele-tree-select/props.d.ts +1 -1
- package/es/ele-upload-list/components/list-item.d.ts +3 -0
- package/es/ele-upload-list/components/list-item.js +1 -0
- package/es/ele-upload-list/types.d.ts +1 -1
- package/es/ele-virtual-table/index.d.ts +38 -44
- package/es/ele-virtual-table/props.d.ts +19 -22
- package/es/ele-watermark/index.js +9 -6
- package/es/ele-watermark/util.d.ts +2 -0
- package/es/ele-watermark/util.js +10 -3
- package/es/style/themes/default.scss +6 -0
- package/es/style/themes/rounded.scss +3 -0
- package/es/style/themes/transparent.scss +3 -0
- package/es/utils/common.d.ts +10 -0
- package/es/utils/common.js +10 -0
- package/es/utils/core.d.ts +6 -0
- package/es/utils/core.js +10 -1
- package/es/utils/menu-util.js +1 -0
- package/lib/ele-admin-layout/components/layout-skeleton.cjs +10 -4
- package/lib/ele-admin-layout/components/layout-skeleton.d.ts +9 -3
- package/lib/ele-admin-layout/components/layout-tabs.cjs +9 -4
- package/lib/ele-admin-layout/components/layout-tabs.d.ts +7 -2
- package/lib/ele-admin-layout/index.cjs +23 -18
- package/lib/ele-alert/index.cjs +6 -7
- package/lib/ele-app/el.d.ts +3 -1
- package/lib/ele-app/plus.d.ts +12 -41
- package/lib/ele-app/plusx.d.ts +40 -0
- package/lib/ele-app/style/overwrite/date-picker/index.scss +1 -1
- package/lib/ele-autocomplete/index.d.ts +265 -47
- package/lib/ele-autocomplete/props.d.ts +124 -22
- package/lib/ele-avatar-group/types.d.ts +1 -1
- package/lib/ele-backtop/index.cjs +6 -7
- package/lib/ele-basic-select/components/select-view.cjs +271 -0
- package/lib/ele-basic-select/components/select-view.d.ts +129 -0
- package/lib/ele-basic-select/index.cjs +108 -247
- package/lib/ele-basic-select/index.d.ts +13 -23
- package/lib/ele-basic-select/props.cjs +7 -1
- package/lib/ele-basic-select/props.d.ts +8 -2
- package/lib/ele-basic-select/types.d.ts +21 -0
- package/lib/ele-basic-select/util.cjs +6 -1
- package/lib/ele-bottom-bar/index.cjs +5 -5
- package/lib/ele-breadcrumb/types.d.ts +1 -1
- package/lib/ele-cascader/index.d.ts +14 -16
- package/lib/ele-cascader/props.d.ts +3 -4
- package/lib/ele-check-card/types.d.ts +1 -1
- package/lib/ele-checkbox-group/index.d.ts +1 -1
- package/lib/ele-config-provider/components/receiver-view.cjs +2 -2
- package/lib/ele-config-provider/components/receiver-view.d.ts +2 -13
- package/lib/ele-config-provider/receiver.cjs +10 -1
- package/lib/ele-config-provider/receiver.d.ts +2 -0
- package/lib/ele-cropper/index.d.ts +1 -3
- package/lib/ele-cropper-modal/index.d.ts +1 -1
- package/lib/ele-crud/components/page-side.cjs +1 -4
- package/lib/ele-crud/types.d.ts +1 -1
- package/lib/ele-crud/util.d.ts +1 -1
- package/lib/ele-crud-builder/components/body-header.d.ts +1 -1
- package/lib/ele-crud-builder/components/code-generator.d.ts +1 -1
- package/lib/ele-crud-builder/components/code-preview.d.ts +1 -1
- package/lib/ele-crud-builder/components/form-design-modal.d.ts +1 -1
- package/lib/ele-crud-builder/components/import-modal.d.ts +1 -1
- package/lib/ele-crud-builder/components/page-config.d.ts +1 -1
- package/lib/ele-crud-builder/components/template-list.d.ts +1 -1
- package/lib/ele-crud-builder/index.cjs +3 -3
- package/lib/ele-crud-builder/index.d.ts +3 -3
- package/lib/ele-crud-builder/props.d.ts +2 -1
- package/lib/ele-crud-builder/types.d.ts +1 -1
- package/lib/ele-crud-builder/util.cjs +2 -2
- package/lib/ele-data-table/index.cjs +6 -3
- package/lib/ele-data-table/index.d.ts +38 -44
- package/lib/ele-data-table/props.d.ts +39 -45
- package/lib/ele-drawer/index.cjs +15 -14
- package/lib/ele-drawer/index.d.ts +2 -2
- package/lib/ele-drawer/props.cjs +4 -0
- package/lib/ele-drawer/props.d.ts +6 -0
- package/lib/ele-dropdown/components/pro-dropdown.d.ts +26 -26
- package/lib/ele-dropdown/index.d.ts +30 -30
- package/lib/ele-dropdown/props.d.ts +12 -12
- package/lib/ele-dropdown/types.d.ts +1 -1
- package/lib/ele-edit-tag/index.d.ts +1 -1
- package/lib/ele-ellipsis/props.d.ts +1 -1
- package/lib/ele-file-list/components/file-grid.cjs +1 -1
- package/lib/ele-file-list/components/file-grid.d.ts +1 -1
- package/lib/ele-file-list/components/file-table.cjs +1 -1
- package/lib/ele-file-list/components/file-table.d.ts +1 -1
- package/lib/ele-file-list/icons.cjs +10 -1
- package/lib/ele-file-list/types.d.ts +1 -1
- package/lib/ele-icon-select/index.cjs +3 -1
- package/lib/ele-icon-select/index.d.ts +5 -1
- package/lib/ele-icon-select/props.cjs +4 -0
- package/lib/ele-icon-select/props.d.ts +7 -2
- package/lib/ele-image-viewer/index.cjs +12 -14
- package/lib/ele-image-viewer/index.d.ts +2 -16
- package/lib/ele-image-viewer/props.d.ts +1 -8
- package/lib/ele-loading/index.cjs +5 -5
- package/lib/ele-map-picker/index.d.ts +2 -4
- package/lib/ele-mention/index.d.ts +29 -8
- package/lib/ele-mention/props.d.ts +9 -0
- package/lib/ele-menus/types.d.ts +2 -0
- package/lib/ele-menus/util.cjs +1 -1
- package/lib/ele-modal/index.cjs +36 -35
- package/lib/ele-modal/index.d.ts +4 -4
- package/lib/ele-popconfirm/index.cjs +5 -20
- package/lib/ele-popconfirm/index.d.ts +95 -96
- package/lib/ele-popconfirm/props.d.ts +32 -32
- package/lib/ele-popover/index.d.ts +72 -72
- package/lib/ele-printer/index.cjs +7 -7
- package/lib/ele-printer/index.d.ts +2 -2
- package/lib/ele-pro-form/components/render-util.d.ts +2 -2
- package/lib/ele-pro-form/index.d.ts +2 -2
- package/lib/ele-pro-form/props.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/body-form.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/body-header.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/code-generator.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/code-preview.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/config-form.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/import-modal.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/preview-modal.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/props-form.d.ts +1 -1
- package/lib/ele-pro-form-builder/components/table-util.cjs +3 -0
- package/lib/ele-pro-form-builder/components/template-list.d.ts +1 -1
- package/lib/ele-pro-form-builder/index.d.ts +1 -1
- package/lib/ele-pro-form-builder/props.d.ts +2 -1
- package/lib/ele-pro-form-builder/types.d.ts +1 -1
- package/lib/ele-pro-layout/index.d.ts +29 -29
- package/lib/ele-pro-layout/props.d.ts +12 -12
- package/lib/ele-pro-layout/style/index.scss +0 -2
- package/lib/ele-pro-layout/types.d.ts +2 -0
- package/lib/ele-pro-table/components/table-tools.d.ts +1 -1
- package/lib/ele-pro-table/components/tool-export.d.ts +2 -2
- package/lib/ele-pro-table/components/tool-print.d.ts +1 -1
- package/lib/ele-pro-table/index.cjs +10 -15
- package/lib/ele-pro-table/index.d.ts +40 -46
- package/lib/ele-pro-table/props.d.ts +18 -21
- package/lib/ele-pro-table/style/css-var.scss +4 -0
- package/lib/ele-pro-table/style/index.scss +2 -2
- package/lib/ele-radio-group/index.d.ts +2 -2
- package/lib/ele-segmented/index.d.ts +2 -2
- package/lib/ele-segmented/props.d.ts +1 -1
- package/lib/ele-segmented/style/index.scss +1 -0
- package/lib/ele-select/index.d.ts +9 -9
- package/lib/ele-select/props.cjs +1 -1
- package/lib/ele-select/props.d.ts +1 -1
- package/lib/ele-select-tree/index.d.ts +7 -7
- package/lib/ele-select-tree/props.cjs +1 -1
- package/lib/ele-select-tree/props.d.ts +1 -1
- package/lib/ele-split-panel/index.cjs +1 -1
- package/lib/ele-steps/types.d.ts +1 -1
- package/lib/ele-tab-bar/index.cjs +1 -0
- package/lib/ele-tab-bar/index.d.ts +4 -2
- package/lib/ele-tab-bar/props.cjs +4 -2
- package/lib/ele-tab-bar/props.d.ts +3 -1
- package/lib/ele-tab-bar/style/index.scss +1 -0
- package/lib/ele-table-select/props.cjs +1 -1
- package/lib/ele-table-select/props.d.ts +2 -2
- package/lib/ele-tabs/index.d.ts +16 -12
- package/lib/ele-tabs/style/index.scss +1 -0
- package/lib/ele-tabs/types.d.ts +1 -1
- package/lib/ele-timeline/types.d.ts +3 -3
- package/lib/ele-tooltip/index.d.ts +53 -53
- package/lib/ele-tour/index.cjs +7 -7
- package/lib/ele-transfer/index.d.ts +1 -1
- package/lib/ele-tree-select/index.d.ts +1 -1
- package/lib/ele-tree-select/props.d.ts +1 -1
- package/lib/ele-upload-list/components/list-item.cjs +1 -0
- package/lib/ele-upload-list/components/list-item.d.ts +3 -0
- package/lib/ele-upload-list/types.d.ts +1 -1
- package/lib/ele-virtual-table/index.d.ts +38 -44
- package/lib/ele-virtual-table/props.d.ts +19 -22
- package/lib/ele-watermark/index.cjs +7 -4
- package/lib/ele-watermark/util.cjs +12 -3
- package/lib/ele-watermark/util.d.ts +2 -0
- package/lib/style/themes/default.scss +6 -0
- package/lib/style/themes/rounded.scss +3 -0
- package/lib/style/themes/transparent.scss +3 -0
- package/lib/utils/common.cjs +10 -0
- package/lib/utils/common.d.ts +10 -0
- package/lib/utils/core.cjs +10 -1
- package/lib/utils/core.d.ts +6 -0
- package/lib/utils/menu-util.cjs +1 -0
- package/package.json +3 -2
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
const vue = require("vue");
|
|
3
|
-
const elementPlus = require("element-plus");
|
|
4
|
-
const index = require("../icons/index");
|
|
5
3
|
const EleTooltip = require("../ele-tooltip/index");
|
|
6
4
|
const ReceiverView = require("../ele-config-provider/components/receiver-view");
|
|
5
|
+
const SelectView = require("./components/select-view");
|
|
7
6
|
const props = require("./props");
|
|
8
7
|
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
9
8
|
...{ name: "EleBasicSelect" },
|
|
@@ -13,48 +12,15 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
13
12
|
setup(__props, { expose: __expose, emit: __emit }) {
|
|
14
13
|
const props2 = __props;
|
|
15
14
|
const emit = __emit;
|
|
15
|
+
const selectViewRef = vue.ref(null);
|
|
16
16
|
const tooltipRef = vue.ref(null);
|
|
17
|
-
const
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
props2.
|
|
21
|
-
|
|
22
|
-
const searchValue = vue.ref("");
|
|
23
|
-
const isEmpty = vue.computed(() => {
|
|
24
|
-
if (!props2.multiple) {
|
|
25
|
-
return props2.value == null || props2.value === "";
|
|
26
|
-
}
|
|
27
|
-
return !Array.isArray(props2.value) || !props2.value.length;
|
|
28
|
-
});
|
|
29
|
-
const inputPlaceholder = vue.computed(() => {
|
|
30
|
-
const str = isEmpty.value && props2.placeholder ? props2.placeholder : "";
|
|
31
|
-
if (!props2.filterable || !props2.visible || props2.multiple) {
|
|
32
|
-
return str;
|
|
33
|
-
}
|
|
34
|
-
return props2.selectedLabel || str;
|
|
35
|
-
});
|
|
36
|
-
const isCollapse = vue.computed(() => {
|
|
37
|
-
return typeof props2.maxTagCount === "number" && props2.selected != null && props2.selected.length > props2.maxTagCount;
|
|
38
|
-
});
|
|
39
|
-
const currentTags = vue.computed(() => {
|
|
40
|
-
if (!isCollapse.value || isEmpty.value || props2.selected == null) {
|
|
41
|
-
return props2.selected || [];
|
|
42
|
-
}
|
|
43
|
-
return props2.selected.slice(0, props2.maxTagCount);
|
|
44
|
-
});
|
|
45
|
-
const omittedTags = vue.computed(() => {
|
|
46
|
-
if (!isCollapse.value || isEmpty.value || props2.selected == null) {
|
|
47
|
-
return [];
|
|
48
|
-
}
|
|
49
|
-
return props2.selected.slice(props2.maxTagCount);
|
|
50
|
-
});
|
|
51
|
-
const omittedSize = vue.computed(() => {
|
|
52
|
-
if (isEmpty.value || props2.maxTagCount == null || props2.maxTagCount < 0) {
|
|
53
|
-
return 0;
|
|
17
|
+
const isSelectInputClick = vue.ref(false);
|
|
18
|
+
const updateVisible = (visible) => {
|
|
19
|
+
isSelectInputClick.value = false;
|
|
20
|
+
if (!props2.disabled || !visible) {
|
|
21
|
+
emit("update:visible", visible);
|
|
54
22
|
}
|
|
55
|
-
|
|
56
|
-
});
|
|
57
|
-
let isSelectInputClick = false;
|
|
23
|
+
};
|
|
58
24
|
const updatePopper = () => {
|
|
59
25
|
tooltipRef.value && tooltipRef.value.updatePopper();
|
|
60
26
|
};
|
|
@@ -66,115 +32,113 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
66
32
|
return;
|
|
67
33
|
}
|
|
68
34
|
}
|
|
69
|
-
|
|
70
|
-
input && input.focus();
|
|
71
|
-
vue.nextTick(() => {
|
|
72
|
-
input && input.focus();
|
|
73
|
-
});
|
|
74
|
-
}
|
|
75
|
-
};
|
|
76
|
-
const updateSearchValue = (modelValue) => {
|
|
77
|
-
if (props2.filterable && props2.visible && props2.multiple) {
|
|
78
|
-
searchValue.value = modelValue;
|
|
79
|
-
emit("filterChange", modelValue);
|
|
80
|
-
}
|
|
81
|
-
};
|
|
82
|
-
const updateInputValue = (modelValue) => {
|
|
83
|
-
if (props2.filterable && props2.visible && !props2.multiple) {
|
|
84
|
-
inputValue.value = modelValue;
|
|
85
|
-
emit("filterChange", modelValue);
|
|
86
|
-
}
|
|
87
|
-
};
|
|
88
|
-
const updateVisible = (visible) => {
|
|
89
|
-
isSelectInputClick = false;
|
|
90
|
-
if (!props2.disabled || !visible) {
|
|
91
|
-
emit("update:visible", visible);
|
|
35
|
+
selectViewRef.value && selectViewRef.value.focusSearchInput();
|
|
92
36
|
}
|
|
93
37
|
};
|
|
94
38
|
const handleUpdatePopoverVisible = (visible) => {
|
|
95
|
-
if (!visible && props2.filterable && isSelectInputClick) {
|
|
96
|
-
isSelectInputClick = false;
|
|
39
|
+
if (!visible && props2.filterable && isSelectInputClick.value) {
|
|
40
|
+
isSelectInputClick.value = false;
|
|
97
41
|
return;
|
|
98
42
|
}
|
|
99
43
|
updateVisible(visible);
|
|
100
44
|
};
|
|
101
45
|
const handleSelectInputClick = () => {
|
|
102
|
-
isSelectInputClick = true;
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
if (!props2.disabled) {
|
|
106
|
-
emit("removeTag", item);
|
|
46
|
+
isSelectInputClick.value = true;
|
|
47
|
+
if (props2.popperType === "modal") {
|
|
48
|
+
updateVisible(true);
|
|
107
49
|
}
|
|
108
50
|
};
|
|
109
|
-
const handleClear = () => {
|
|
110
|
-
isSelectInputClick = false;
|
|
111
|
-
emit("clear");
|
|
112
|
-
};
|
|
113
51
|
const handleInputClick = (e) => {
|
|
114
52
|
if (props2.automaticDropdown && props2.visible) {
|
|
115
|
-
isSelectInputClick = true;
|
|
53
|
+
isSelectInputClick.value = true;
|
|
116
54
|
e.stopPropagation();
|
|
117
55
|
}
|
|
118
56
|
};
|
|
119
|
-
const
|
|
57
|
+
const handleRemoveTag = (item) => {
|
|
58
|
+
emit("removeTag", item);
|
|
59
|
+
};
|
|
60
|
+
const handleClear = () => {
|
|
61
|
+
isSelectInputClick.value = false;
|
|
62
|
+
emit("clear");
|
|
63
|
+
};
|
|
64
|
+
const handleFocus = (e) => {
|
|
120
65
|
if (props2.automaticDropdown && !props2.visible) {
|
|
121
66
|
updateVisible(true);
|
|
122
67
|
}
|
|
123
68
|
emit("focus", e);
|
|
124
69
|
};
|
|
125
|
-
const
|
|
70
|
+
const handleBlur = (e) => {
|
|
126
71
|
emit("blur", e);
|
|
127
72
|
};
|
|
128
|
-
const
|
|
129
|
-
|
|
130
|
-
e.stopPropagation();
|
|
131
|
-
e.preventDefault();
|
|
132
|
-
updateVisible(false);
|
|
133
|
-
}
|
|
73
|
+
const handleFilterChange = (value) => {
|
|
74
|
+
emit("filterChange", value);
|
|
134
75
|
};
|
|
135
|
-
vue.watch(
|
|
136
|
-
() => props2.selectedLabel,
|
|
137
|
-
(label) => {
|
|
138
|
-
if (!props2.filterable || !props2.visible) {
|
|
139
|
-
inputValue.value = props2.multiple || !label ? "" : label;
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
);
|
|
143
|
-
vue.watch(
|
|
144
|
-
() => props2.visible,
|
|
145
|
-
(visible) => {
|
|
146
|
-
if (props2.filterable) {
|
|
147
|
-
if (props2.multiple) {
|
|
148
|
-
searchValue.value = "";
|
|
149
|
-
if (visible) {
|
|
150
|
-
focusSearchInput();
|
|
151
|
-
}
|
|
152
|
-
} else {
|
|
153
|
-
const label = props2.selectedLabel;
|
|
154
|
-
inputValue.value = visible || !label ? "" : label;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
);
|
|
159
76
|
__expose({
|
|
160
77
|
tooltipRef,
|
|
161
|
-
|
|
162
|
-
searchRef,
|
|
163
|
-
currentTags,
|
|
164
|
-
omittedTags,
|
|
165
|
-
omittedSize,
|
|
78
|
+
selectViewRef,
|
|
166
79
|
updatePopper,
|
|
167
80
|
focusSearchInput,
|
|
168
|
-
updateSearchValue,
|
|
169
|
-
updateInputValue,
|
|
170
81
|
updateVisible
|
|
171
82
|
});
|
|
172
83
|
return (_ctx, _cache) => {
|
|
173
|
-
|
|
84
|
+
const _component_EleModal = vue.resolveComponent("EleModal");
|
|
85
|
+
return _ctx.popperType === "modal" ? (vue.openBlock(), vue.createBlock(SelectView, vue.mergeProps({ key: 0 }, _ctx.$props, {
|
|
86
|
+
ref_key: "selectViewRef",
|
|
87
|
+
ref: selectViewRef,
|
|
88
|
+
"onUpdate:visible": updateVisible,
|
|
89
|
+
onRemoveTag: handleRemoveTag,
|
|
90
|
+
onClear: handleClear,
|
|
91
|
+
onFocus: handleFocus,
|
|
92
|
+
onBlur: handleBlur,
|
|
93
|
+
onFilterChange: handleFilterChange,
|
|
94
|
+
onInputClick: handleInputClick,
|
|
95
|
+
onClick: handleSelectInputClick
|
|
96
|
+
}), vue.createSlots({
|
|
97
|
+
default: vue.withCtx(() => [
|
|
98
|
+
vue.createVNode(_component_EleModal, vue.mergeProps({
|
|
99
|
+
position: "center",
|
|
100
|
+
width: _ctx.popperWidth,
|
|
101
|
+
destroyOnClose: !_ctx.persistent,
|
|
102
|
+
class: _ctx.popperClass
|
|
103
|
+
}, _ctx.popperProps || {}, {
|
|
104
|
+
modelValue: _ctx.visible,
|
|
105
|
+
"onUpdate:modelValue": handleUpdatePopoverVisible
|
|
106
|
+
}), vue.createSlots({
|
|
107
|
+
default: vue.withCtx(() => [
|
|
108
|
+
vue.renderSlot(_ctx.$slots, "default")
|
|
109
|
+
]),
|
|
110
|
+
_: 2
|
|
111
|
+
}, [
|
|
112
|
+
vue.renderList(Object.keys(_ctx.popperSlots || {}).filter(
|
|
113
|
+
(k) => k !== "default" && _ctx.popperSlots && _ctx.popperSlots[k] && _ctx.popperSlots[k] !== "default" && _ctx.$slots[_ctx.popperSlots[k]]
|
|
114
|
+
), (name) => {
|
|
115
|
+
return {
|
|
116
|
+
name,
|
|
117
|
+
fn: vue.withCtx((slotProps) => {
|
|
118
|
+
var _a;
|
|
119
|
+
return [
|
|
120
|
+
vue.renderSlot(_ctx.$slots, (_a = _ctx.popperSlots) == null ? void 0 : _a[name], vue.normalizeProps(vue.guardReactiveProps(slotProps || {})))
|
|
121
|
+
];
|
|
122
|
+
})
|
|
123
|
+
};
|
|
124
|
+
})
|
|
125
|
+
]), 1040, ["width", "destroyOnClose", "class", "modelValue"])
|
|
126
|
+
]),
|
|
127
|
+
_: 2
|
|
128
|
+
}, [
|
|
129
|
+
vue.renderList(Object.keys(_ctx.$slots).filter((k) => k !== "default"), (name) => {
|
|
130
|
+
return {
|
|
131
|
+
name,
|
|
132
|
+
fn: vue.withCtx((slotProps) => [
|
|
133
|
+
vue.renderSlot(_ctx.$slots, name, vue.normalizeProps(vue.guardReactiveProps(slotProps || {})))
|
|
134
|
+
])
|
|
135
|
+
};
|
|
136
|
+
})
|
|
137
|
+
]), 1040)) : (vue.openBlock(), vue.createBlock(EleTooltip, vue.mergeProps({
|
|
138
|
+
key: 1,
|
|
174
139
|
ref_key: "tooltipRef",
|
|
175
140
|
ref: tooltipRef,
|
|
176
141
|
trigger: "click",
|
|
177
|
-
visible: _ctx.visible,
|
|
178
142
|
disabled: _ctx.disabled,
|
|
179
143
|
placement: _ctx.placement,
|
|
180
144
|
teleported: _ctx.teleported,
|
|
@@ -186,11 +150,13 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
186
150
|
effect: "light",
|
|
187
151
|
persistent: true,
|
|
188
152
|
isPopover: true,
|
|
189
|
-
triggerKeys: []
|
|
153
|
+
triggerKeys: []
|
|
154
|
+
}, _ctx.popperProps || {}, {
|
|
155
|
+
visible: _ctx.visible,
|
|
190
156
|
"onUpdate:visible": handleUpdatePopoverVisible
|
|
191
|
-
}, {
|
|
157
|
+
}), {
|
|
192
158
|
body: vue.withCtx(() => [
|
|
193
|
-
_ctx.persistent || _ctx.visible ? (vue.openBlock(), vue.createBlock(ReceiverView, {
|
|
159
|
+
_ctx.persistent || _ctx.visible ? (vue.openBlock(), vue.createBlock(vue.unref(ReceiverView), {
|
|
194
160
|
key: 0,
|
|
195
161
|
class: "ele-popover-body",
|
|
196
162
|
onClick: focusSearchInput,
|
|
@@ -203,135 +169,30 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
203
169
|
})) : vue.createCommentVNode("", true)
|
|
204
170
|
]),
|
|
205
171
|
default: vue.withCtx(() => [
|
|
206
|
-
vue.
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
{ "is-opened": _ctx.visible }
|
|
217
|
-
]),
|
|
218
|
-
style: vue.normalizeStyle(_ctx.selectStyle),
|
|
172
|
+
vue.createVNode(SelectView, vue.mergeProps(_ctx.$props, {
|
|
173
|
+
ref_key: "selectViewRef",
|
|
174
|
+
ref: selectViewRef,
|
|
175
|
+
"onUpdate:visible": updateVisible,
|
|
176
|
+
onRemoveTag: handleRemoveTag,
|
|
177
|
+
onClear: handleClear,
|
|
178
|
+
onFocus: handleFocus,
|
|
179
|
+
onBlur: handleBlur,
|
|
180
|
+
onFilterChange: handleFilterChange,
|
|
181
|
+
onInputClick: handleInputClick,
|
|
219
182
|
onClick: handleSelectInputClick
|
|
220
|
-
}, [
|
|
221
|
-
vue.
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
style: vue.normalizeStyle(_ctx.inputStyle),
|
|
231
|
-
"onUpdate:modelValue": updateInputValue,
|
|
232
|
-
onClick: handleInputClick,
|
|
233
|
-
onFocus: handleInputFocus,
|
|
234
|
-
onBlur: handleInputBlur,
|
|
235
|
-
onKeydown: vue.withKeys(handleInputEsc, ["esc"])
|
|
236
|
-
}, vue.createSlots({
|
|
237
|
-
suffix: vue.withCtx(() => [
|
|
238
|
-
_ctx.clearable && !_ctx.disabled && !isEmpty.value ? (vue.openBlock(), vue.createBlock(vue.unref(elementPlus.ElIcon), {
|
|
239
|
-
key: 0,
|
|
240
|
-
class: "ele-select-clear el-input__icon",
|
|
241
|
-
onClick: vue.withModifiers(handleClear, ["stop"])
|
|
242
|
-
}, {
|
|
243
|
-
default: vue.withCtx(() => [
|
|
244
|
-
vue.renderSlot(_ctx.$slots, "clearIcon", {}, () => [
|
|
245
|
-
vue.createVNode(vue.unref(index.CloseCircleFilled))
|
|
246
|
-
])
|
|
247
|
-
]),
|
|
248
|
-
_: 3
|
|
249
|
-
})) : vue.createCommentVNode("", true),
|
|
250
|
-
vue.createVNode(vue.unref(elementPlus.ElIcon), { class: "ele-select-arrow el-input__icon" }, {
|
|
251
|
-
default: vue.withCtx(() => [
|
|
252
|
-
vue.renderSlot(_ctx.$slots, "suffixIcon", { visible: _ctx.visible }, () => [
|
|
253
|
-
vue.createVNode(vue.unref(index.ArrowDown))
|
|
254
|
-
])
|
|
255
|
-
]),
|
|
256
|
-
_: 3
|
|
257
|
-
})
|
|
258
|
-
]),
|
|
259
|
-
_: 2
|
|
260
|
-
}, [
|
|
261
|
-
_ctx.$slots.prefix ? {
|
|
262
|
-
name: "prefix",
|
|
263
|
-
fn: vue.withCtx(() => [
|
|
264
|
-
vue.renderSlot(_ctx.$slots, "prefix")
|
|
265
|
-
]),
|
|
266
|
-
key: "0"
|
|
267
|
-
} : void 0
|
|
268
|
-
]), 1032, ["size", "disabled", "modelValue", "placeholder", "readonly", "style"]),
|
|
269
|
-
_ctx.multiple ? (vue.openBlock(), vue.createElementBlock("div", {
|
|
270
|
-
key: 0,
|
|
271
|
-
class: "ele-select-tags",
|
|
272
|
-
style: vue.normalizeStyle(_ctx.selectTagsStyle)
|
|
273
|
-
}, [
|
|
274
|
-
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(currentTags.value, (item, index2) => {
|
|
275
|
-
return vue.openBlock(), vue.createBlock(vue.unref(elementPlus.ElTag), {
|
|
276
|
-
key: index2 + "-" + item.value,
|
|
277
|
-
size: _ctx.size,
|
|
278
|
-
type: _ctx.tagType,
|
|
279
|
-
closable: !_ctx.disabled,
|
|
280
|
-
disableTransitions: true,
|
|
281
|
-
title: item.label,
|
|
282
|
-
onClose: ($event) => handleTagClose(item)
|
|
283
|
-
}, {
|
|
284
|
-
default: vue.withCtx(() => [
|
|
285
|
-
item.label && _ctx.maxTagTextLength && item.label.length > _ctx.maxTagTextLength ? (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 0 }, [
|
|
286
|
-
vue.createTextVNode(vue.toDisplayString(item.label.slice(0, _ctx.maxTagTextLength)) + "... ", 1)
|
|
287
|
-
], 64)) : (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 1 }, [
|
|
288
|
-
vue.createTextVNode(vue.toDisplayString(item.label), 1)
|
|
289
|
-
], 64))
|
|
290
|
-
]),
|
|
291
|
-
_: 2
|
|
292
|
-
}, 1032, ["size", "type", "closable", "title", "onClose"]);
|
|
293
|
-
}), 128)),
|
|
294
|
-
isCollapse.value ? (vue.openBlock(), vue.createBlock(vue.unref(elementPlus.ElTag), {
|
|
295
|
-
key: 0,
|
|
296
|
-
size: _ctx.size,
|
|
297
|
-
type: _ctx.tagType,
|
|
298
|
-
disableTransitions: true
|
|
299
|
-
}, {
|
|
300
|
-
default: vue.withCtx(() => [
|
|
301
|
-
vue.renderSlot(_ctx.$slots, "maxTagPlaceholder", {
|
|
302
|
-
omittedValues: omittedTags.value,
|
|
303
|
-
omittedSize: omittedSize.value
|
|
304
|
-
}, () => [
|
|
305
|
-
vue.createTextVNode(" +" + vue.toDisplayString(omittedSize.value), 1)
|
|
306
|
-
])
|
|
307
|
-
]),
|
|
308
|
-
_: 3
|
|
309
|
-
}, 8, ["size", "type"])) : vue.createCommentVNode("", true),
|
|
310
|
-
!_ctx.disabled && _ctx.filterable ? (vue.openBlock(), vue.createBlock(vue.unref(elementPlus.ElTag), {
|
|
311
|
-
key: 1,
|
|
312
|
-
size: _ctx.size,
|
|
313
|
-
disableTransitions: true,
|
|
314
|
-
class: "ele-select-search"
|
|
315
|
-
}, {
|
|
316
|
-
default: vue.withCtx(() => [
|
|
317
|
-
vue.createVNode(vue.unref(elementPlus.ElInput), {
|
|
318
|
-
ref_key: "searchRef",
|
|
319
|
-
ref: searchRef,
|
|
320
|
-
size: _ctx.size,
|
|
321
|
-
validateEvent: false,
|
|
322
|
-
modelValue: searchValue.value,
|
|
323
|
-
placeholder: inputPlaceholder.value,
|
|
324
|
-
"onUpdate:modelValue": updateSearchValue,
|
|
325
|
-
onKeydown: vue.withKeys(handleInputEsc, ["esc"])
|
|
326
|
-
}, null, 8, ["size", "modelValue", "placeholder"])
|
|
327
|
-
]),
|
|
328
|
-
_: 1
|
|
329
|
-
}, 8, ["size"])) : vue.createCommentVNode("", true)
|
|
330
|
-
], 4)) : vue.createCommentVNode("", true)
|
|
331
|
-
], 6)
|
|
183
|
+
}), vue.createSlots({ _: 2 }, [
|
|
184
|
+
vue.renderList(Object.keys(_ctx.$slots).filter((k) => k !== "default"), (name) => {
|
|
185
|
+
return {
|
|
186
|
+
name,
|
|
187
|
+
fn: vue.withCtx((slotProps) => [
|
|
188
|
+
vue.renderSlot(_ctx.$slots, name, vue.normalizeProps(vue.guardReactiveProps(slotProps || {})))
|
|
189
|
+
])
|
|
190
|
+
};
|
|
191
|
+
})
|
|
192
|
+
]), 1040)
|
|
332
193
|
]),
|
|
333
194
|
_: 3
|
|
334
|
-
},
|
|
195
|
+
}, 16, ["disabled", "placement", "teleported", "width", "popperClass", "popperOptions", "transition", "gpuAcceleration", "visible"]));
|
|
335
196
|
};
|
|
336
197
|
}
|
|
337
198
|
});
|
|
@@ -1,17 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { EleTooltipInstance } from '../ele-app/plus';
|
|
1
|
+
import { EleTooltipInstance, EleBasicSelectViewInstance } from '../ele-app/plus';
|
|
3
2
|
import { SelectedItem } from './types';
|
|
4
3
|
|
|
5
|
-
declare function __VLS_template(): {
|
|
6
|
-
prefix?(_: {}): any;
|
|
7
|
-
clearIcon?(_: {}): any;
|
|
8
|
-
suffixIcon?(_: {
|
|
9
|
-
visible: boolean;
|
|
10
|
-
}): any;
|
|
11
|
-
maxTagPlaceholder?(_: {
|
|
12
|
-
omittedValues: SelectedItem[];
|
|
13
|
-
omittedSize: number;
|
|
14
|
-
}): any;
|
|
4
|
+
declare function __VLS_template(): Partial<Record<string, (_: any) => any>> & Partial<Record<any, (_: any) => any>> & Partial<Record<string, (_: any) => any>> & {
|
|
15
5
|
default?(_: {}): any;
|
|
16
6
|
};
|
|
17
7
|
declare const __VLS_component: import('vue').DefineComponent<import('vue').ExtractPropTypes<{
|
|
@@ -46,21 +36,18 @@ declare const __VLS_component: import('vue').DefineComponent<import('vue').Extra
|
|
|
46
36
|
selectStyle: import('vue').PropType<import('../ele-app/types').StyleValue>;
|
|
47
37
|
inputStyle: import('vue').PropType<import('../ele-app/types').StyleValue>;
|
|
48
38
|
selectTagsStyle: import('vue').PropType<import('../ele-app/types').StyleValue>;
|
|
39
|
+
popperType: import('vue').PropType<import('./types').PopperType>;
|
|
40
|
+
popperProps: import('vue').PropType<import('./types').PopperProps>;
|
|
41
|
+
popperSlots: ObjectConstructor;
|
|
49
42
|
}>, {
|
|
50
43
|
tooltipRef: import('vue').Ref<EleTooltipInstance, EleTooltipInstance>;
|
|
51
|
-
|
|
52
|
-
searchRef: import('vue').Ref<ElInputInstance, ElInputInstance>;
|
|
53
|
-
currentTags: import('vue').ComputedRef<SelectedItem[]>;
|
|
54
|
-
omittedTags: import('vue').ComputedRef<SelectedItem[]>;
|
|
55
|
-
omittedSize: import('vue').ComputedRef<number>;
|
|
44
|
+
selectViewRef: import('vue').Ref<EleBasicSelectViewInstance, EleBasicSelectViewInstance>;
|
|
56
45
|
updatePopper: () => void;
|
|
57
46
|
focusSearchInput: (e?: MouseEvent) => void;
|
|
58
|
-
updateSearchValue: (modelValue: string) => void;
|
|
59
|
-
updateInputValue: (modelValue: string) => void;
|
|
60
47
|
updateVisible: (visible: boolean) => void;
|
|
61
48
|
}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
|
|
62
|
-
focus: (_e: FocusEvent) => void;
|
|
63
49
|
blur: (_e: FocusEvent) => void;
|
|
50
|
+
focus: (_e: FocusEvent) => void;
|
|
64
51
|
clear: () => void;
|
|
65
52
|
"update:visible": (_visible: boolean) => void;
|
|
66
53
|
filterChange: (_value: string) => void;
|
|
@@ -97,18 +84,21 @@ declare const __VLS_component: import('vue').DefineComponent<import('vue').Extra
|
|
|
97
84
|
selectStyle: import('vue').PropType<import('../ele-app/types').StyleValue>;
|
|
98
85
|
inputStyle: import('vue').PropType<import('../ele-app/types').StyleValue>;
|
|
99
86
|
selectTagsStyle: import('vue').PropType<import('../ele-app/types').StyleValue>;
|
|
87
|
+
popperType: import('vue').PropType<import('./types').PopperType>;
|
|
88
|
+
popperProps: import('vue').PropType<import('./types').PopperProps>;
|
|
89
|
+
popperSlots: ObjectConstructor;
|
|
100
90
|
}>> & Readonly<{
|
|
101
|
-
onFocus?: ((_e: FocusEvent) => any) | undefined;
|
|
102
91
|
onBlur?: ((_e: FocusEvent) => any) | undefined;
|
|
92
|
+
onFocus?: ((_e: FocusEvent) => any) | undefined;
|
|
103
93
|
onClear?: (() => any) | undefined;
|
|
104
94
|
"onUpdate:visible"?: ((_visible: boolean) => any) | undefined;
|
|
105
95
|
onFilterChange?: ((_value: string) => any) | undefined;
|
|
106
96
|
onRemoveTag?: ((_item: SelectedItem) => any) | undefined;
|
|
107
97
|
}>, {
|
|
108
|
-
value: import('./types').SelectValue;
|
|
109
98
|
teleported: boolean;
|
|
110
|
-
clearable: boolean;
|
|
111
99
|
disabled: boolean;
|
|
100
|
+
clearable: boolean;
|
|
101
|
+
value: import('./types').SelectValue;
|
|
112
102
|
filterable: boolean;
|
|
113
103
|
persistent: boolean;
|
|
114
104
|
visible: boolean;
|
|
@@ -58,7 +58,13 @@ const basicSelectProps = {
|
|
|
58
58
|
/** 自定义输入框样式 */
|
|
59
59
|
inputStyle: Object,
|
|
60
60
|
/** 自定义多选标签容器样式 */
|
|
61
|
-
selectTagsStyle: Object
|
|
61
|
+
selectTagsStyle: Object,
|
|
62
|
+
/** 下拉类型 */
|
|
63
|
+
popperType: String,
|
|
64
|
+
/** 下拉组件属性 */
|
|
65
|
+
popperProps: Object,
|
|
66
|
+
/** 下拉组件插槽 */
|
|
67
|
+
popperSlots: Object
|
|
62
68
|
};
|
|
63
69
|
const basicSelectEmits = {
|
|
64
70
|
/** 更新下拉框显示状态 */
|
|
@@ -2,7 +2,7 @@ import { PropType, ExtractPropTypes } from 'vue';
|
|
|
2
2
|
import { StyleValue } from '../ele-app/types';
|
|
3
3
|
import { ElInputProps, ElTagProps } from '../ele-app/el';
|
|
4
4
|
import { EleTooltipProps } from '../ele-app/plus';
|
|
5
|
-
import { SelectValue, SelectedItem } from './types';
|
|
5
|
+
import { SelectValue, SelectedItem, PopperType, PopperProps } from './types';
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* 属性
|
|
@@ -55,7 +55,7 @@ export declare const basicSelectProps: {
|
|
|
55
55
|
/** 下拉框类名 */
|
|
56
56
|
popperClass: StringConstructor;
|
|
57
57
|
/** 下拉框宽度 */
|
|
58
|
-
popperWidth: (
|
|
58
|
+
popperWidth: (NumberConstructor | StringConstructor)[];
|
|
59
59
|
/** 自定义类名 */
|
|
60
60
|
selectClass: StringConstructor;
|
|
61
61
|
/** 自定义样式 */
|
|
@@ -64,6 +64,12 @@ export declare const basicSelectProps: {
|
|
|
64
64
|
inputStyle: PropType<StyleValue>;
|
|
65
65
|
/** 自定义多选标签容器样式 */
|
|
66
66
|
selectTagsStyle: PropType<StyleValue>;
|
|
67
|
+
/** 下拉类型 */
|
|
68
|
+
popperType: PropType<PopperType>;
|
|
69
|
+
/** 下拉组件属性 */
|
|
70
|
+
popperProps: PropType<PopperProps>;
|
|
71
|
+
/** 下拉组件插槽 */
|
|
72
|
+
popperSlots: ObjectConstructor;
|
|
67
73
|
};
|
|
68
74
|
export type BasicSelectProps = ExtractPropTypes<typeof basicSelectProps>;
|
|
69
75
|
/**
|
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
import type { ComponentProps } from '../ele-app/types';
|
|
2
|
+
import type {
|
|
3
|
+
EleModalProps,
|
|
4
|
+
EleDrawerProps,
|
|
5
|
+
EleTooltipProps
|
|
6
|
+
} from '../ele-app/plus';
|
|
7
|
+
|
|
1
8
|
/**
|
|
2
9
|
* 单选值
|
|
3
10
|
*/
|
|
@@ -26,3 +33,17 @@ export interface SelectedItem {
|
|
|
26
33
|
/** 排序号 */
|
|
27
34
|
index?: number;
|
|
28
35
|
}
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* 下拉类型
|
|
39
|
+
*/
|
|
40
|
+
export type PopperType = 'popper' | 'modal' | 'drawer' | 'default';
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* 下拉组件属性
|
|
44
|
+
*/
|
|
45
|
+
export type PopperProps =
|
|
46
|
+
| EleModalProps
|
|
47
|
+
| EleDrawerProps
|
|
48
|
+
| EleTooltipProps
|
|
49
|
+
| ComponentProps<{}>;
|
|
@@ -27,7 +27,12 @@ function valueIsChanged(value1, value2, multiple) {
|
|
|
27
27
|
if (value1.length !== value2.length) {
|
|
28
28
|
return true;
|
|
29
29
|
}
|
|
30
|
-
|
|
30
|
+
for (let i = 0; i < value1.length; i++) {
|
|
31
|
+
if (value1[i] !== value2[i]) {
|
|
32
|
+
return true;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return false;
|
|
31
36
|
}
|
|
32
37
|
function useFormValidate() {
|
|
33
38
|
const formItem = vue.inject(elementPlus.formItemContextKey, null);
|
|
@@ -3,7 +3,7 @@ const vue = require("vue");
|
|
|
3
3
|
const util = require("../ele-pro-layout/util");
|
|
4
4
|
const props = require("./props");
|
|
5
5
|
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
6
|
-
...{ name: "EleBottomBar" },
|
|
6
|
+
...{ name: "EleBottomBar", inheritAttrs: false },
|
|
7
7
|
__name: "index",
|
|
8
8
|
props: props.bottomBarProps,
|
|
9
9
|
setup(__props) {
|
|
@@ -24,9 +24,9 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
24
24
|
to: teleportTo.value,
|
|
25
25
|
disabled: !_ctx.teleported || !teleportTo.value
|
|
26
26
|
}, [
|
|
27
|
-
vue.createElementVNode("div", {
|
|
28
|
-
class:
|
|
29
|
-
}, [
|
|
27
|
+
vue.createElementVNode("div", vue.mergeProps(_ctx.$attrs, {
|
|
28
|
+
class: ["ele-bottom-bar", { "is-deactivated": !isActivated.value }]
|
|
29
|
+
}), [
|
|
30
30
|
vue.createElementVNode("div", {
|
|
31
31
|
class: "ele-bottom-bar-body",
|
|
32
32
|
style: vue.normalizeStyle(_ctx.bodyStyle)
|
|
@@ -39,7 +39,7 @@ const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
|
39
39
|
}, [
|
|
40
40
|
vue.renderSlot(_ctx.$slots, "extra")
|
|
41
41
|
], 4)
|
|
42
|
-
],
|
|
42
|
+
], 16)
|
|
43
43
|
], 8, ["to", "disabled"]);
|
|
44
44
|
};
|
|
45
45
|
}
|