vft 0.0.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/package.json +54 -0
- package/src/app/index.ts +3 -0
- package/src/app/page-loading/assets/spin.gif +0 -0
- package/src/app/page-loading/index.less +10 -0
- package/src/app/page-loading/index.ts +3 -0
- package/src/app/page-loading/index.vue +38 -0
- package/src/app/table/assets/sort_triangle.png +0 -0
- package/src/app/table/demos/basic.vue +117 -0
- package/src/app/table/demos/complex.vue +2543 -0
- package/src/app/table/demos/index.vue +453 -0
- package/src/app/table/demos/rightAngle.png +0 -0
- package/src/app/table/header.vue +203 -0
- package/src/app/table/index.less +119 -0
- package/src/app/table/index.ts +5 -0
- package/src/app/table/index.vue +478 -0
- package/src/app/table/md/api.md +23 -0
- package/src/app/table/md/demo.md +3 -0
- package/src/app/table/types.ts +45 -0
- package/src/common/badge/index.scss +78 -0
- package/src/common/badge/index.ts +4 -0
- package/src/common/badge/index.vue +111 -0
- package/src/common/badge/types.ts +1 -0
- package/src/common/clamp/clamp-toggle.vue +91 -0
- package/src/common/clamp/index.ts +4 -0
- package/src/common/clamp/index.vue +247 -0
- package/src/common/code/index.less +321 -0
- package/src/common/code/index.ts +3 -0
- package/src/common/code/index.vue +60 -0
- package/src/common/config-provider/index.ts +4 -0
- package/src/common/config-provider/index.vue +94 -0
- package/src/common/config-provider/types.ts +29 -0
- package/src/common/icon/iconfont/iconfont.css +334 -0
- package/src/common/icon/index.scss +31 -0
- package/src/common/icon/index.ts +4 -0
- package/src/common/icon/index.vue +74 -0
- package/src/common/icon/types.ts +16 -0
- package/src/common/index.ts +6 -0
- package/src/common/message/index.ts +5 -0
- package/src/common/message/instance.ts +29 -0
- package/src/common/message/message.scss +108 -0
- package/src/common/message/message.ts +80 -0
- package/src/common/message/message.vue +162 -0
- package/src/common/message/method.ts +172 -0
- package/src/common/overlay/index.scss +14 -0
- package/src/common/overlay/index.ts +3 -0
- package/src/common/overlay/index.vue +117 -0
- package/src/constants/comp.ts +1 -0
- package/src/constants/index.ts +1 -0
- package/src/index.ts +3 -0
- package/src/page/index.ts +1 -0
- package/src/page/page-wrapper/index.scss +31 -0
- package/src/page/page-wrapper/index.ts +5 -0
- package/src/page/page-wrapper/index.vue +31 -0
- package/src/styles/vars.scss +500 -0
- package/src/use/index.ts +14 -0
- package/src/use/onPopupReopen.ts +15 -0
- package/src/use/use-delayed-toggle/index.ts +30 -0
- package/src/use/use-floating/index.ts +121 -0
- package/src/use/use-forward-ref.ts +35 -0
- package/src/use/use-global-config/index.ts +81 -0
- package/src/use/use-id/index.ts +43 -0
- package/src/use/use-model-toggle/index.ts +151 -0
- package/src/use/use-namespace/index.ts +91 -0
- package/src/use/use-ordered-children/index.ts +43 -0
- package/src/use/use-popper-container/index.ts +43 -0
- package/src/use/use-timeout/index.ts +18 -0
- package/src/use/use-z-index/index.ts +20 -0
- package/src/use/useGlobalZIndex.ts +24 -0
- package/src/use/useLazyRender.ts +17 -0
- package/src/use/useLockScroll.ts +66 -0
- package/src/utils/aria.ts +126 -0
- package/src/utils/arrays.ts +13 -0
- package/src/utils/error.ts +23 -0
- package/src/utils/event.ts +15 -0
- package/src/utils/helper.ts +7 -0
- package/src/utils/index.ts +8 -0
- package/src/utils/interceptor.ts +39 -0
- package/src/utils/mount-component.ts +65 -0
- package/src/utils/popper.ts +6 -0
- package/src/utils/rand.ts +12 -0
- package/src/utils/scroll.ts +101 -0
- package/src/utils/vnode.ts +169 -0
- package/src/web/avatar/index.scss +50 -0
- package/src/web/avatar/index.ts +3 -0
- package/src/web/avatar/index.vue +83 -0
- package/src/web/back-top/index.scss +35 -0
- package/src/web/back-top/index.ts +3 -0
- package/src/web/back-top/index.vue +72 -0
- package/src/web/back-top/types.ts +14 -0
- package/src/web/back-top/use-back-top.ts +65 -0
- package/src/web/cascader/index.scss +214 -0
- package/src/web/cascader/index.ts +5 -0
- package/src/web/cascader/index.vue +767 -0
- package/src/web/cascader-panel/config.ts +44 -0
- package/src/web/cascader-panel/index.scss +134 -0
- package/src/web/cascader-panel/index.ts +5 -0
- package/src/web/cascader-panel/index.vue +319 -0
- package/src/web/cascader-panel/menu.vue +135 -0
- package/src/web/cascader-panel/node-content.ts +23 -0
- package/src/web/cascader-panel/node.ts +218 -0
- package/src/web/cascader-panel/node.vue +197 -0
- package/src/web/cascader-panel/store.ts +83 -0
- package/src/web/cascader-panel/types.ts +56 -0
- package/src/web/cascader-panel/utils.ts +40 -0
- package/src/web/cascader-select/README.md +31 -0
- package/src/web/cascader-select/index.scss +54 -0
- package/src/web/cascader-select/index.ts +5 -0
- package/src/web/cascader-select/index.vue +132 -0
- package/src/web/cascader-select/types.ts +9 -0
- package/src/web/context-menu/createContextMenu.ts +72 -0
- package/src/web/context-menu/index.ts +4 -0
- package/src/web/context-menu/index.vue +89 -0
- package/src/web/context-menu/types.ts +27 -0
- package/src/web/context-menu/useContextMenu.ts +14 -0
- package/src/web/descriptions/description-item.vue +34 -0
- package/src/web/descriptions/description.vue +124 -0
- package/src/web/descriptions/descriptions-cell.ts +95 -0
- package/src/web/descriptions/descriptions-item.scss +68 -0
- package/src/web/descriptions/descriptions-row.vue +49 -0
- package/src/web/descriptions/descriptions.scss +153 -0
- package/src/web/descriptions/descriptions.type.ts +19 -0
- package/src/web/descriptions/index.ts +4 -0
- package/src/web/descriptions/token.ts +4 -0
- package/src/web/divider/index.scss +53 -0
- package/src/web/divider/index.ts +5 -0
- package/src/web/divider/index.vue +60 -0
- package/src/web/divider/types.ts +2 -0
- package/src/web/empty/assets/no-collect.png +0 -0
- package/src/web/empty/assets/no-data.png +0 -0
- package/src/web/empty/assets/no-filter.png +0 -0
- package/src/web/empty/assets/no-page-data.png +0 -0
- package/src/web/empty/assets/no-search.png +0 -0
- package/src/web/empty/constants.ts +12 -0
- package/src/web/empty/index.scss +57 -0
- package/src/web/empty/index.ts +5 -0
- package/src/web/empty/index.vue +96 -0
- package/src/web/exception/exception.png +0 -0
- package/src/web/exception/index.ts +3 -0
- package/src/web/exception/index.vue +44 -0
- package/src/web/filter/README.md +25 -0
- package/src/web/filter/index.scss +14 -0
- package/src/web/filter/index.ts +5 -0
- package/src/web/filter/index.vue +60 -0
- package/src/web/filter/type.ts +13 -0
- package/src/web/focus-trap/index.ts +6 -0
- package/src/web/focus-trap/index.vue +328 -0
- package/src/web/focus-trap/tokens.ts +23 -0
- package/src/web/focus-trap/utils.ts +178 -0
- package/src/web/full-screen/index.scss +22 -0
- package/src/web/full-screen/index.ts +3 -0
- package/src/web/full-screen/index.vue +24 -0
- package/src/web/icon-text/index.ts +3 -0
- package/src/web/icon-text/index.vue +77 -0
- package/src/web/image/index.scss +46 -0
- package/src/web/image/index.ts +5 -0
- package/src/web/image/index.vue +251 -0
- package/src/web/image/types.ts +1 -0
- package/src/web/index.ts +33 -0
- package/src/web/input/index.scss +473 -0
- package/src/web/input/index.ts +3 -0
- package/src/web/input/index.vue +533 -0
- package/src/web/input/utils.ts +102 -0
- package/src/web/layouts/blank.vue +4 -0
- package/src/web/layouts/footer/index.scss +31 -0
- package/src/web/layouts/footer/index.ts +3 -0
- package/src/web/layouts/footer/index.vue +38 -0
- package/src/web/layouts/header/index.scss +35 -0
- package/src/web/layouts/header/index.ts +3 -0
- package/src/web/layouts/header/index.vue +47 -0
- package/src/web/layouts/iframe/index.scss +18 -0
- package/src/web/layouts/iframe/index.vue +36 -0
- package/src/web/layouts/iframe/page.vue +30 -0
- package/src/web/layouts/index.ts +8 -0
- package/src/web/layouts/router-view-content/index.vue +70 -0
- package/src/web/link/index.scss +95 -0
- package/src/web/link/index.ts +3 -0
- package/src/web/link/index.vue +68 -0
- package/src/web/loading/directive.ts +104 -0
- package/src/web/loading/index.ts +6 -0
- package/src/web/loading/loading.scss +108 -0
- package/src/web/loading/loading.ts +156 -0
- package/src/web/loading/service.ts +145 -0
- package/src/web/loading/types.ts +29 -0
- package/src/web/logo/index.scss +31 -0
- package/src/web/logo/index.ts +5 -0
- package/src/web/logo/index.vue +45 -0
- package/src/web/logo/types.ts +6 -0
- package/src/web/menu/index.scss +336 -0
- package/src/web/menu/index.ts +8 -0
- package/src/web/menu/menu-collapse-transition.vue +62 -0
- package/src/web/menu/menu-item-group.vue +27 -0
- package/src/web/menu/menu-item.vue +126 -0
- package/src/web/menu/menu.vue +459 -0
- package/src/web/menu/sub-menu.vue +440 -0
- package/src/web/menu/types.ts +66 -0
- package/src/web/menu/use-menu-css-var.ts +11 -0
- package/src/web/menu/use-menu.ts +60 -0
- package/src/web/menu/utils/menu-bar.ts +19 -0
- package/src/web/menu/utils/menu-item.ts +55 -0
- package/src/web/menu/utils/submenu.ts +66 -0
- package/src/web/multiple-select-flat/index.ts +5 -0
- package/src/web/multiple-select-flat/index.vue +53 -0
- package/src/web/multiple-select-flat/types.ts +5 -0
- package/src/web/multiple-tabs/index.scss +16 -0
- package/src/web/multiple-tabs/index.ts +5 -0
- package/src/web/multiple-tabs/index.vue +193 -0
- package/src/web/multiple-tabs/tab-content.vue +40 -0
- package/src/web/multiple-tabs/types.ts +3 -0
- package/src/web/multiple-tabs/use/index.ts +2 -0
- package/src/web/multiple-tabs/use/use-multiple-tabs.ts +86 -0
- package/src/web/multiple-tabs/use/use-tab-dropdown.ts +101 -0
- package/src/web/nodata/README.md +42 -0
- package/src/web/nodata/fail.vue +13 -0
- package/src/web/nodata/img/100.png +0 -0
- package/src/web/nodata/img/101.png +0 -0
- package/src/web/nodata/img/102.png +0 -0
- package/src/web/nodata/img/103.png +0 -0
- package/src/web/nodata/img/104.png +0 -0
- package/src/web/nodata/img/105.png +0 -0
- package/src/web/nodata/img/106.png +0 -0
- package/src/web/nodata/img/107.png +0 -0
- package/src/web/nodata/img/200.png +0 -0
- package/src/web/nodata/img/201.png +0 -0
- package/src/web/nodata/img/202.png +0 -0
- package/src/web/nodata/img/203.png +0 -0
- package/src/web/nodata/index.scss +37 -0
- package/src/web/nodata/index.ts +6 -0
- package/src/web/nodata/index.vue +46 -0
- package/src/web/nodata/types.ts +17 -0
- package/src/web/only-child/index.tsx +69 -0
- package/src/web/pagination/components/jumper.vue +49 -0
- package/src/web/pagination/components/next.vue +40 -0
- package/src/web/pagination/components/pager.vue +215 -0
- package/src/web/pagination/components/prev.vue +35 -0
- package/src/web/pagination/components/sizes.vue +76 -0
- package/src/web/pagination/components/total.vue +21 -0
- package/src/web/pagination/index.scss +231 -0
- package/src/web/pagination/index.ts +5 -0
- package/src/web/pagination/pagination.ts +363 -0
- package/src/web/pagination/usePagination.ts +13 -0
- package/src/web/popover/directive.ts +21 -0
- package/src/web/popover/index.scss +58 -0
- package/src/web/popover/index.ts +3 -0
- package/src/web/popover/index.vue +161 -0
- package/src/web/popover/types.ts +26 -0
- package/src/web/popper/arrow.vue +45 -0
- package/src/web/popper/content.vue +311 -0
- package/src/web/popper/index.scss +108 -0
- package/src/web/popper/index.ts +11 -0
- package/src/web/popper/popper.vue +57 -0
- package/src/web/popper/tokens.ts +28 -0
- package/src/web/popper/trigger.vue +166 -0
- package/src/web/popper/types.ts +49 -0
- package/src/web/popper/utils.ts +81 -0
- package/src/web/qrcode/drawCanvas.ts +32 -0
- package/src/web/qrcode/drawLogo.ts +82 -0
- package/src/web/qrcode/index.ts +5 -0
- package/src/web/qrcode/index.vue +107 -0
- package/src/web/qrcode/qrcodePlus.ts +4 -0
- package/src/web/qrcode/toCanvas.ts +11 -0
- package/src/web/qrcode/types.ts +38 -0
- package/src/web/result/index.scss +69 -0
- package/src/web/result/index.ts +3 -0
- package/src/web/result/index.vue +63 -0
- package/src/web/scrollbar/bar.vue +48 -0
- package/src/web/scrollbar/index.scss +91 -0
- package/src/web/scrollbar/index.ts +5 -0
- package/src/web/scrollbar/index.vue +236 -0
- package/src/web/scrollbar/thumb.vue +183 -0
- package/src/web/scrollbar/tokens.ts +10 -0
- package/src/web/scrollbar/types.ts +7 -0
- package/src/web/scrollbar/util.ts +38 -0
- package/src/web/select/constants.ts +13 -0
- package/src/web/select/index.ts +11 -0
- package/src/web/select/index.vue +555 -0
- package/src/web/select/option-group.scss +49 -0
- package/src/web/select/option-group.vue +97 -0
- package/src/web/select/option-item.scss +66 -0
- package/src/web/select/option.scss +32 -0
- package/src/web/select/option.vue +110 -0
- package/src/web/select/select-dropdown.scss +86 -0
- package/src/web/select/select-dropdown.vue +51 -0
- package/src/web/select/select.scss +213 -0
- package/src/web/select/token.ts +56 -0
- package/src/web/select/useOption.ts +146 -0
- package/src/web/select/useSelect.ts +942 -0
- package/src/web/select/utils.ts +5 -0
- package/src/web/side-menu/index.scss +66 -0
- package/src/web/side-menu/index.ts +4 -0
- package/src/web/side-menu/index.vue +228 -0
- package/src/web/side-menu/types.ts +20 -0
- package/src/web/single-select/index.scss +60 -0
- package/src/web/single-select/index.ts +5 -0
- package/src/web/single-select/index.vue +70 -0
- package/src/web/single-select/select@2x.png +0 -0
- package/src/web/single-select/types.ts +5 -0
- package/src/web/svg/index.ts +3 -0
- package/src/web/svg/index.vue +22 -0
- package/src/web/tabs/index.scss +579 -0
- package/src/web/tabs/index.ts +6 -0
- package/src/web/tabs/index.vue +236 -0
- package/src/web/tabs/tab-bar.vue +90 -0
- package/src/web/tabs/tab-nav.vue +403 -0
- package/src/web/tabs/tab-pane.vue +90 -0
- package/src/web/tabs/types.ts +66 -0
- package/src/web/tag/index.scss +182 -0
- package/src/web/tag/index.ts +5 -0
- package/src/web/tag/index.vue +78 -0
- package/src/web/tag/types.ts +2 -0
- package/src/web/tooltip/content.vue +239 -0
- package/src/web/tooltip/index.ts +4 -0
- package/src/web/tooltip/tokens.ts +21 -0
- package/src/web/tooltip/tooltip.vue +270 -0
- package/src/web/tooltip/trigger.vue +119 -0
- package/src/web/tooltip/types.ts +56 -0
- package/src/web/tooltip/utils.ts +20 -0
- package/src/web/transition/collapse-transition.vue +73 -0
- package/src/web/transition/index.ts +5 -0
- package/tsconfig.json +8 -0
- package/types/component.ts +1 -0
- package/types/index.d.ts +286 -0
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<ul v-show="visible" :class="ns.be('group', 'wrap')">
|
|
3
|
+
<li :class="ns.be('group', 'title')">{{ label }}</li>
|
|
4
|
+
<li>
|
|
5
|
+
<ul :class="ns.b('group')">
|
|
6
|
+
<slot />
|
|
7
|
+
</ul>
|
|
8
|
+
</li>
|
|
9
|
+
</ul>
|
|
10
|
+
</template>
|
|
11
|
+
|
|
12
|
+
<script lang="ts">
|
|
13
|
+
import {
|
|
14
|
+
defineComponent,
|
|
15
|
+
getCurrentInstance,
|
|
16
|
+
inject,
|
|
17
|
+
onMounted,
|
|
18
|
+
provide,
|
|
19
|
+
reactive,
|
|
20
|
+
ref,
|
|
21
|
+
toRaw,
|
|
22
|
+
toRefs,
|
|
23
|
+
watch
|
|
24
|
+
} from 'vue';
|
|
25
|
+
import { useNamespace } from '../../use';
|
|
26
|
+
import { selectGroupKey, selectKey } from './token';
|
|
27
|
+
|
|
28
|
+
export default defineComponent({
|
|
29
|
+
name: 'VriOptionGroup',
|
|
30
|
+
componentName: 'VriOptionGroup',
|
|
31
|
+
|
|
32
|
+
props: {
|
|
33
|
+
label: String,
|
|
34
|
+
disabled: {
|
|
35
|
+
type: Boolean,
|
|
36
|
+
default: false
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
setup(props) {
|
|
40
|
+
const ns = useNamespace('select');
|
|
41
|
+
const visible = ref(true);
|
|
42
|
+
const instance = getCurrentInstance()!;
|
|
43
|
+
const children = ref([]);
|
|
44
|
+
|
|
45
|
+
provide(
|
|
46
|
+
selectGroupKey,
|
|
47
|
+
reactive({
|
|
48
|
+
...toRefs(props)
|
|
49
|
+
})
|
|
50
|
+
);
|
|
51
|
+
|
|
52
|
+
const select = inject(selectKey);
|
|
53
|
+
|
|
54
|
+
onMounted(() => {
|
|
55
|
+
children.value = flattedChildren(instance.subTree);
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
// get all instances of options
|
|
59
|
+
const flattedChildren = (node: any) => {
|
|
60
|
+
const children: any[] = [];
|
|
61
|
+
if (Array.isArray(node.children)) {
|
|
62
|
+
node.children.forEach((child: { type: { name: string; }; component: { proxy: any; }; children: string | any[]; }) => {
|
|
63
|
+
if (
|
|
64
|
+
child.type &&
|
|
65
|
+
child.type.name === 'ElOption' &&
|
|
66
|
+
child.component &&
|
|
67
|
+
child.component.proxy
|
|
68
|
+
) {
|
|
69
|
+
children.push(child.component.proxy);
|
|
70
|
+
} else if (child.children?.length) {
|
|
71
|
+
children.push(...flattedChildren(child));
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
return children;
|
|
76
|
+
};
|
|
77
|
+
|
|
78
|
+
const { groupQueryChange } = toRaw(select);
|
|
79
|
+
watch(
|
|
80
|
+
groupQueryChange,
|
|
81
|
+
() => {
|
|
82
|
+
visible.value = children.value.some((option) => option.visible === true);
|
|
83
|
+
},
|
|
84
|
+
{ flush: 'post' }
|
|
85
|
+
);
|
|
86
|
+
|
|
87
|
+
return {
|
|
88
|
+
visible,
|
|
89
|
+
ns
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
</script>
|
|
94
|
+
|
|
95
|
+
<style lang="scss">
|
|
96
|
+
@import "./option-group.scss";
|
|
97
|
+
</style>
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
|
|
2
|
+
|
|
3
|
+
@include b(select-dropdown) {
|
|
4
|
+
@include e(option-item) {
|
|
5
|
+
font-size: getCssVar('select-font-size');
|
|
6
|
+
// 20 as the padding of option item, 12 as the size of ✓ icon size
|
|
7
|
+
padding: 0 #{20 + 12}px 0 20px;
|
|
8
|
+
position: relative;
|
|
9
|
+
white-space: nowrap;
|
|
10
|
+
overflow: hidden;
|
|
11
|
+
text-overflow: ellipsis;
|
|
12
|
+
color: map-get($select-option, 'text-color');
|
|
13
|
+
height: map-get($select-option, 'height');
|
|
14
|
+
line-height: map-get($select-option, 'height');
|
|
15
|
+
box-sizing: border-box;
|
|
16
|
+
cursor: pointer;
|
|
17
|
+
|
|
18
|
+
@include when(disabled) {
|
|
19
|
+
color: map-get($select-option, 'disabled-color');
|
|
20
|
+
cursor: not-allowed;
|
|
21
|
+
|
|
22
|
+
&:hover {
|
|
23
|
+
background-color: getCssVar('bg-color');
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
@include when(selected) {
|
|
28
|
+
background-color: map-get($select-option, 'hover-background');
|
|
29
|
+
font-weight: 700;
|
|
30
|
+
|
|
31
|
+
&:not(.is-multiple) {
|
|
32
|
+
color: map-get($select-option, 'selected-text-color');
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
&.hover {
|
|
37
|
+
background-color: map-get($select-option, 'hover-background') !important;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
&:hover {
|
|
41
|
+
background-color: map-get($select-option, 'hover-background');
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
@include when(multiple) {
|
|
46
|
+
.#{$namespace}-select-dropdown__option-item {
|
|
47
|
+
&.is-selected {
|
|
48
|
+
color: map-get($select-option, 'selected-text-color');
|
|
49
|
+
background-color: map-get($select-dropdown, 'bg-color');
|
|
50
|
+
|
|
51
|
+
& .#{$namespace}-icon {
|
|
52
|
+
position: absolute;
|
|
53
|
+
right: 20px;
|
|
54
|
+
top: 0;
|
|
55
|
+
height: inherit;
|
|
56
|
+
font-size: 12px;
|
|
57
|
+
|
|
58
|
+
svg {
|
|
59
|
+
height: inherit;
|
|
60
|
+
vertical-align: middle;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
@include b(select-dropdown) {
|
|
2
|
+
@include e(item) {
|
|
3
|
+
font-size: map-get($select, 'font-size');
|
|
4
|
+
// 20 as the padding of option item, 12 as the size of ✓ icon size
|
|
5
|
+
padding: 0 #{20 + 12}px 0 20px;
|
|
6
|
+
position: relative;
|
|
7
|
+
white-space: nowrap;
|
|
8
|
+
overflow: hidden;
|
|
9
|
+
text-overflow: ellipsis;
|
|
10
|
+
color: map-get($select-option, 'text-color');
|
|
11
|
+
height: map-get($select-option, 'height');
|
|
12
|
+
line-height: map-get($select-option, 'height');
|
|
13
|
+
box-sizing: border-box;
|
|
14
|
+
cursor: pointer;
|
|
15
|
+
|
|
16
|
+
@include when(disabled) {
|
|
17
|
+
color: map-get($select-option, 'disabled-color');
|
|
18
|
+
cursor: not-allowed;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
&.hover,
|
|
22
|
+
&:hover {
|
|
23
|
+
background-color: map-get($select-option, 'hover-background');
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
&.selected {
|
|
27
|
+
color: map-get($select-option, 'selected-text-color');
|
|
28
|
+
font-weight: 400;
|
|
29
|
+
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<li
|
|
3
|
+
v-show="visible"
|
|
4
|
+
:class="[
|
|
5
|
+
ns.be('dropdown', 'item'),
|
|
6
|
+
ns.is('disabled', isDisabled),
|
|
7
|
+
{
|
|
8
|
+
selected: itemSelected,
|
|
9
|
+
hover,
|
|
10
|
+
},
|
|
11
|
+
]"
|
|
12
|
+
@mouseenter="hoverItem"
|
|
13
|
+
@click.stop="selectOptionClick"
|
|
14
|
+
>
|
|
15
|
+
<slot>
|
|
16
|
+
<span>{{ currentLabel }}</span>
|
|
17
|
+
</slot>
|
|
18
|
+
</li>
|
|
19
|
+
</template>
|
|
20
|
+
|
|
21
|
+
<script lang="ts">
|
|
22
|
+
import {
|
|
23
|
+
defineComponent,
|
|
24
|
+
getCurrentInstance,
|
|
25
|
+
nextTick,
|
|
26
|
+
onBeforeUnmount,
|
|
27
|
+
reactive,
|
|
28
|
+
toRefs
|
|
29
|
+
} from 'vue';
|
|
30
|
+
import { useNamespace } from '../../use';
|
|
31
|
+
import { useOption } from './useOption';
|
|
32
|
+
import type { SelectOptionProxy } from './token';
|
|
33
|
+
|
|
34
|
+
export default defineComponent({
|
|
35
|
+
name: 'VriOption',
|
|
36
|
+
componentName: 'VriOption',
|
|
37
|
+
|
|
38
|
+
props: {
|
|
39
|
+
value: {
|
|
40
|
+
required: true,
|
|
41
|
+
type: [String, Number, Boolean, Object]
|
|
42
|
+
},
|
|
43
|
+
label: [String, Number],
|
|
44
|
+
created: Boolean,
|
|
45
|
+
disabled: {
|
|
46
|
+
type: Boolean,
|
|
47
|
+
default: false
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
|
|
51
|
+
setup(props) {
|
|
52
|
+
const ns = useNamespace('select');
|
|
53
|
+
const states = reactive({
|
|
54
|
+
index: -1,
|
|
55
|
+
groupDisabled: false,
|
|
56
|
+
visible: true,
|
|
57
|
+
hitState: false,
|
|
58
|
+
hover: false
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
const { currentLabel, itemSelected, isDisabled, select, hoverItem } =
|
|
62
|
+
useOption(props, states);
|
|
63
|
+
|
|
64
|
+
const { visible, hover } = toRefs(states);
|
|
65
|
+
|
|
66
|
+
const vm = getCurrentInstance()!.proxy;
|
|
67
|
+
|
|
68
|
+
select?.onOptionCreate(vm as unknown as SelectOptionProxy);
|
|
69
|
+
|
|
70
|
+
onBeforeUnmount(() => {
|
|
71
|
+
const key = (vm as unknown as SelectOptionProxy).value;
|
|
72
|
+
const { selected } = select;
|
|
73
|
+
const selectedOptions = select?.props.multiple ? selected : [selected];
|
|
74
|
+
const doesSelected = selectedOptions.some((item: { value: string | number | Record<string, string>; }) => {
|
|
75
|
+
return item.value === (vm as unknown as SelectOptionProxy).value;
|
|
76
|
+
});
|
|
77
|
+
// if option is not selected, remove it from cache
|
|
78
|
+
nextTick(() => {
|
|
79
|
+
if (select?.cachedOptions.get(key) === vm && !doesSelected) {
|
|
80
|
+
select?.cachedOptions.delete(key);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
select?.onOptionDestroy(key, vm);
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
function selectOptionClick() {
|
|
87
|
+
if (props.disabled !== true && states.groupDisabled !== true) {
|
|
88
|
+
select?.handleOptionSelect(vm, true);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
return {
|
|
93
|
+
ns,
|
|
94
|
+
currentLabel,
|
|
95
|
+
itemSelected,
|
|
96
|
+
isDisabled,
|
|
97
|
+
select,
|
|
98
|
+
hoverItem,
|
|
99
|
+
visible,
|
|
100
|
+
hover,
|
|
101
|
+
selectOptionClick,
|
|
102
|
+
states
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
</script>
|
|
107
|
+
|
|
108
|
+
<style lang="scss">
|
|
109
|
+
@import "./option.scss";
|
|
110
|
+
</style>
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
$checked-icon: "data:image/svg+xml;utf8,%3Csvg class='icon' width='200' height='200' viewBox='0 0 1024 1024' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='currentColor' d='M406.656 706.944L195.84 496.256a32 32 0 10-45.248 45.248l256 256 512-512a32 32 0 00-45.248-45.248L406.592 706.944z'%3E%3C/path%3E%3C/svg%3E";
|
|
2
|
+
|
|
3
|
+
@mixin checked-icon {
|
|
4
|
+
content: '';
|
|
5
|
+
position: absolute;
|
|
6
|
+
top: 50%;
|
|
7
|
+
right: 20px;
|
|
8
|
+
border-top: none;
|
|
9
|
+
border-right: none;
|
|
10
|
+
background-repeat: no-repeat;
|
|
11
|
+
background-position: center;
|
|
12
|
+
background-color: map-get($select-option, 'selected-text-color');
|
|
13
|
+
mask: url('#{$checked-icon}') no-repeat;
|
|
14
|
+
mask-size: 100% 100%;
|
|
15
|
+
-webkit-mask: url('#{$checked-icon}') no-repeat;
|
|
16
|
+
-webkit-mask-size: 100% 100%;
|
|
17
|
+
transform: translateY(-50%);
|
|
18
|
+
width: 12px;
|
|
19
|
+
height: 12px;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
@include b(select-dropdown) {
|
|
23
|
+
z-index: calc(#{getCssVar('index-top')} + 1);
|
|
24
|
+
border-radius: getCssVar('border-radius-base');
|
|
25
|
+
box-sizing: border-box;
|
|
26
|
+
|
|
27
|
+
@include when(multiple) {
|
|
28
|
+
& .#{$namespace}-select-dropdown__item.selected {
|
|
29
|
+
color: map-get($select-option, 'selected-text-color');
|
|
30
|
+
background-color: map-get($select-dropdown, 'bg-color');
|
|
31
|
+
|
|
32
|
+
&.hover {
|
|
33
|
+
background-color: map-get($select-option, 'hover-background');
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
&::after {
|
|
37
|
+
@include checked-icon;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
&.is-disabled {
|
|
41
|
+
&::after {
|
|
42
|
+
background-color: getCssVar('text-placeholder-color');
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
& .#{$namespace}-select-dropdown__option-item.is-selected {
|
|
49
|
+
&::after {
|
|
50
|
+
@include checked-icon;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.#{$namespace}-scrollbar.is-empty .#{$namespace}-select-dropdown__list {
|
|
55
|
+
padding: 0;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.#{$namespace}-select-dropdown__item.is-disabled {
|
|
59
|
+
&:hover {
|
|
60
|
+
background-color: unset;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
&.selected {
|
|
64
|
+
color: getCssVar('text-placeholder-color');
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
@include b(select-dropdown__empty) {
|
|
70
|
+
padding: map-get($select-dropdown, 'empty-padding');
|
|
71
|
+
margin: 0;
|
|
72
|
+
text-align: center;
|
|
73
|
+
color: map-get($select-dropdown, 'empty-color');
|
|
74
|
+
font-size: getCssVar('select-font-size');
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
@include b(select-dropdown__wrap) {
|
|
78
|
+
max-height: map-get($select-dropdown, 'max-height');
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
@include b(select-dropdown__list) {
|
|
82
|
+
list-style: none;
|
|
83
|
+
padding: map-get($select-dropdown, 'padding');
|
|
84
|
+
margin: 0;
|
|
85
|
+
box-sizing: border-box;
|
|
86
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div
|
|
3
|
+
:class="[ns.b('dropdown'), ns.is('multiple', isMultiple), popperClass]"
|
|
4
|
+
:style="{ [isFitInputWidth ? 'width' : 'minWidth']: minWidth }"
|
|
5
|
+
>
|
|
6
|
+
<slot />
|
|
7
|
+
</div>
|
|
8
|
+
</template>
|
|
9
|
+
|
|
10
|
+
<script lang="ts">
|
|
11
|
+
import { computed, defineComponent, inject, onMounted, ref } from 'vue';
|
|
12
|
+
import { useResizeObserver } from '@vueuse/core';
|
|
13
|
+
import { useNamespace } from '../../use';
|
|
14
|
+
import { selectKey } from './token';
|
|
15
|
+
|
|
16
|
+
export default defineComponent({
|
|
17
|
+
name: 'VriSelectDropdown',
|
|
18
|
+
|
|
19
|
+
componentName: 'VriSelectDropdown',
|
|
20
|
+
|
|
21
|
+
setup() {
|
|
22
|
+
const select = inject(selectKey)!;
|
|
23
|
+
const ns = useNamespace('select');
|
|
24
|
+
|
|
25
|
+
// computed
|
|
26
|
+
const popperClass = computed(() => select.props.popperClass);
|
|
27
|
+
const isMultiple = computed(() => select.props.multiple);
|
|
28
|
+
const isFitInputWidth = computed(() => select.props.fitInputWidth);
|
|
29
|
+
const minWidth = ref('');
|
|
30
|
+
|
|
31
|
+
function updateMinWidth() {
|
|
32
|
+
minWidth.value = `${select.selectWrapper?.offsetWidth}px`;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
onMounted(() => {
|
|
36
|
+
// TODO: updatePopper
|
|
37
|
+
// popper.value.update()
|
|
38
|
+
updateMinWidth();
|
|
39
|
+
useResizeObserver(select.selectWrapper, updateMinWidth);
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
return {
|
|
43
|
+
ns,
|
|
44
|
+
minWidth,
|
|
45
|
+
popperClass,
|
|
46
|
+
isMultiple,
|
|
47
|
+
isFitInputWidth
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
</script>
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
@import './select-dropdown.scss';
|
|
2
|
+
|
|
3
|
+
@mixin select-common($name) {
|
|
4
|
+
.#{$namespace}-#{$name}__tags-text {
|
|
5
|
+
@include line-clamp(1);
|
|
6
|
+
|
|
7
|
+
display: inline-block;
|
|
8
|
+
line-height: normal;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
@mixin select-tag-normal {
|
|
13
|
+
white-space: normal;
|
|
14
|
+
z-index: getCssVar('index-normal');
|
|
15
|
+
display: flex;
|
|
16
|
+
align-items: center;
|
|
17
|
+
flex-wrap: wrap;
|
|
18
|
+
cursor: pointer;
|
|
19
|
+
|
|
20
|
+
.#{$namespace}-tag {
|
|
21
|
+
box-sizing: border-box;
|
|
22
|
+
border-color: transparent;
|
|
23
|
+
margin: 2px 6px 2px 0;
|
|
24
|
+
|
|
25
|
+
&:last-child {
|
|
26
|
+
margin-right: 0;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.#{$namespace}-icon-close {
|
|
30
|
+
background-color: getCssVar('text-color', 'placeholder');
|
|
31
|
+
right: -7px;
|
|
32
|
+
top: 0;
|
|
33
|
+
color: $color-white;
|
|
34
|
+
|
|
35
|
+
&:hover {
|
|
36
|
+
background-color: getCssVar('text-color', 'secondary');
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
&::before {
|
|
40
|
+
display: block;
|
|
41
|
+
transform: translate(0, 0.5px);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
.#{$namespace}-tag--info {
|
|
46
|
+
background-color: getCssVar('fill-color');
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
@include b(select) {
|
|
51
|
+
@include set-component-css-var('select', $select);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
@include b(select) {
|
|
55
|
+
@include e(popper) {
|
|
56
|
+
@include picker-popper(map-get($select-dropdown, 'bg-color'), map-get($select-dropdown, 'border'), map-get($select-dropdown, 'shadow'));
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
@each $size in (large, small) {
|
|
60
|
+
@include m($size) {
|
|
61
|
+
line-height: map-get($input-height, $size);
|
|
62
|
+
.#{$namespace}-select-tags-wrapper {
|
|
63
|
+
&.has-prefix {
|
|
64
|
+
margin-left: map-get($select-tags-prefix-padding, $size);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
@include select-common(select);
|
|
71
|
+
|
|
72
|
+
@include e(input) {
|
|
73
|
+
@include when(small) {
|
|
74
|
+
height: 14px;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
border: none;
|
|
78
|
+
outline: none;
|
|
79
|
+
padding: 0;
|
|
80
|
+
margin-left: 15px;
|
|
81
|
+
color: getCssVar('select-multiple-input-color');
|
|
82
|
+
font-size: getCssVar('select-font-size');
|
|
83
|
+
appearance: none;
|
|
84
|
+
height: 28px;
|
|
85
|
+
background-color: transparent;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
@include e(close) {
|
|
89
|
+
cursor: pointer;
|
|
90
|
+
position: absolute;
|
|
91
|
+
top: 8px;
|
|
92
|
+
z-index: getCssVar('index-top');
|
|
93
|
+
right: 25px;
|
|
94
|
+
color: getCssVar('select-input-color');
|
|
95
|
+
line-height: 18px;
|
|
96
|
+
font-size: getCssVar('select-input-font-size');
|
|
97
|
+
|
|
98
|
+
&:hover {
|
|
99
|
+
color: getCssVar('select-close-hover-color');
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
@include e(tags) {
|
|
104
|
+
@include select-tag-normal;
|
|
105
|
+
|
|
106
|
+
position: absolute;
|
|
107
|
+
line-height: normal;
|
|
108
|
+
top: 50%;
|
|
109
|
+
transform: translateY(-50%);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
@include e(collapse-tags) {
|
|
113
|
+
@include select-tag-normal;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
@include e(collapse-tag) {
|
|
117
|
+
line-height: inherit;
|
|
118
|
+
height: inherit;
|
|
119
|
+
display: flex;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
display: inline-block;
|
|
123
|
+
position: relative;
|
|
124
|
+
vertical-align: middle;
|
|
125
|
+
line-height: map-get($input-height, 'default');
|
|
126
|
+
|
|
127
|
+
.#{$namespace}-select-tags-wrapper {
|
|
128
|
+
&.has-prefix {
|
|
129
|
+
margin-left: map-get($select-tags-prefix-padding, 'default');
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
.#{$namespace}-select__tags > span {
|
|
134
|
+
display: inline-block;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
&:hover:not(.#{$namespace}-select--disabled) {
|
|
138
|
+
.#{$namespace}-input__wrapper {
|
|
139
|
+
box-shadow: 0 0 0 1px getCssVar('select-border-color-hover') inset;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
.#{$namespace}-input__wrapper {
|
|
144
|
+
//@include when(focus) {
|
|
145
|
+
// @include inset-input-border(getCssVar('select-input-focus-border-color'), true);
|
|
146
|
+
//}
|
|
147
|
+
|
|
148
|
+
cursor: pointer;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
.#{$namespace}-input__inner {
|
|
152
|
+
cursor: pointer;
|
|
153
|
+
|
|
154
|
+
&::selection {
|
|
155
|
+
outline: none;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
.#{$namespace}-input {
|
|
160
|
+
display: flex;
|
|
161
|
+
|
|
162
|
+
& .#{$namespace}-select__caret {
|
|
163
|
+
@include when(reverse) {
|
|
164
|
+
transform: rotateZ(-180deg);
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
@include when(show-close) {
|
|
168
|
+
font-size: getCssVar('select-font-size');
|
|
169
|
+
text-align: center;
|
|
170
|
+
transform: rotateZ(0deg);
|
|
171
|
+
border-radius: getCssVar('border-radius-circle');
|
|
172
|
+
color: getCssVar('select-input-color');
|
|
173
|
+
transition: getCssVar('transition', 'color');
|
|
174
|
+
|
|
175
|
+
&:hover {
|
|
176
|
+
color: getCssVar('select-close-hover-color');
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
color: getCssVar('select-input-color');
|
|
181
|
+
font-size: getCssVar('select-input-font-size');
|
|
182
|
+
transition: transform getCssVar('transition-duration');
|
|
183
|
+
transform: rotateZ(0deg);
|
|
184
|
+
cursor: pointer;
|
|
185
|
+
|
|
186
|
+
&.#{$namespace}-icon {
|
|
187
|
+
position: relative;
|
|
188
|
+
height: inherit;
|
|
189
|
+
z-index: 2;
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
&.is-disabled {
|
|
194
|
+
& .#{$namespace}-input__wrapper {
|
|
195
|
+
cursor: not-allowed;
|
|
196
|
+
|
|
197
|
+
&:hover {
|
|
198
|
+
//@include inset-input-border(#{getCssVar('select-disabled-border')});
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
& .#{$namespace}-input__inner {
|
|
202
|
+
cursor: not-allowed;
|
|
203
|
+
}
|
|
204
|
+
& .#{$namespace}-select__caret {
|
|
205
|
+
cursor: not-allowed;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
&.is-focus .#{$namespace}-input__wrapper {
|
|
210
|
+
//@include inset-input-border(getCssVar('select-input-focus-border-color'), true);
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import type { InjectionKey, Ref } from 'vue';
|
|
2
|
+
|
|
3
|
+
interface SelectGroupContext {
|
|
4
|
+
disabled: boolean
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export interface QueryChangeCtx {
|
|
8
|
+
query: string
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export interface SelectContext {
|
|
12
|
+
props: {
|
|
13
|
+
multiple?: boolean
|
|
14
|
+
multipleLimit?: number
|
|
15
|
+
valueKey?: string
|
|
16
|
+
modelValue?: string | number | unknown | unknown[]
|
|
17
|
+
popperClass?: string
|
|
18
|
+
remote?: boolean
|
|
19
|
+
fitInputWidth?: boolean
|
|
20
|
+
}
|
|
21
|
+
queryChange: Ref<QueryChangeCtx>
|
|
22
|
+
groupQueryChange: Ref<string>
|
|
23
|
+
selectWrapper: HTMLElement
|
|
24
|
+
cachedOptions: Map<any, any>
|
|
25
|
+
hoverIndex: number
|
|
26
|
+
optionsCount: number
|
|
27
|
+
filteredOptionsCount: number
|
|
28
|
+
options: Map<any, any>
|
|
29
|
+
optionsArray: any[]
|
|
30
|
+
selected: any | any[]
|
|
31
|
+
setSelected(): void
|
|
32
|
+
onOptionCreate(vm: SelectOptionProxy): void
|
|
33
|
+
onOptionDestroy(key: number | string | Record<string, any>): void
|
|
34
|
+
handleOptionSelect(vm: unknown, byClick: boolean): void
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
// For individual build sharing injection key, we had to make `Symbol` to string
|
|
38
|
+
export const selectGroupKey =
|
|
39
|
+
'VriSelectGroup' as unknown as InjectionKey<SelectGroupContext>;
|
|
40
|
+
|
|
41
|
+
export const selectKey = 'VriSelect' as unknown as InjectionKey<SelectContext>;
|
|
42
|
+
|
|
43
|
+
export interface SelectOptionProxy {
|
|
44
|
+
value: string | number | Record<string, string>
|
|
45
|
+
label: string | number
|
|
46
|
+
created: boolean
|
|
47
|
+
disabled: boolean
|
|
48
|
+
currentLabel: string
|
|
49
|
+
itemSelected: boolean
|
|
50
|
+
isDisabled: boolean
|
|
51
|
+
select: SelectContext
|
|
52
|
+
hoverItem: () => void
|
|
53
|
+
visible: boolean
|
|
54
|
+
hover: boolean
|
|
55
|
+
selectOptionClick: () => void
|
|
56
|
+
}
|