ff-ui-plus 2.0.7
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/.nvmrc +1 -0
- package/.prettierrc.cjs +41 -0
- package/.stylelintignore +5 -0
- package/LICENSE +21 -0
- package/README.md +265 -0
- package/commitlint.config.cjs +162 -0
- package/global.d.ts +27 -0
- package/index.html +16 -0
- package/lib.sh +9 -0
- package/lint-staged.config.cjs +8 -0
- package/package.json +149 -0
- package/packages/components/adaptive-page/index.ts +5 -0
- package/packages/components/adaptive-page/src/index.vue +85 -0
- package/packages/components/adaptive-page/src/type.ts +9 -0
- package/packages/components/adaptive-page/style/css.ts +1 -0
- package/packages/components/adaptive-page/style/index.ts +1 -0
- package/packages/components/button/index.ts +5 -0
- package/packages/components/button/src/index.vue +41 -0
- package/packages/components/button/src/type.ts +11 -0
- package/packages/components/button/style/css.ts +1 -0
- package/packages/components/button/style/index.ts +1 -0
- package/packages/components/chart/index.ts +5 -0
- package/packages/components/chart/src/index.vue +121 -0
- package/packages/components/chart/src/type.ts +7 -0
- package/packages/components/chart/style/css.ts +1 -0
- package/packages/components/chart/style/index.ts +1 -0
- package/packages/components/checkbox/index.ts +3 -0
- package/packages/components/checkbox/src/checkbox.d.ts +5 -0
- package/packages/components/checkbox/src/index.vue +67 -0
- package/packages/components/checkbox/style/css.ts +1 -0
- package/packages/components/checkbox/style/index.ts +1 -0
- package/packages/components/date-picker/index.ts +5 -0
- package/packages/components/date-picker/src/index.vue +228 -0
- package/packages/components/date-picker/src/type.ts +22 -0
- package/packages/components/date-picker/style/css.ts +1 -0
- package/packages/components/date-picker/style/index.ts +1 -0
- package/packages/components/detail/index.ts +5 -0
- package/packages/components/detail/src/index.vue +102 -0
- package/packages/components/detail/src/renderLabel.vue +15 -0
- package/packages/components/detail/src/renderTooltip.vue +15 -0
- package/packages/components/detail/src/type.ts +28 -0
- package/packages/components/detail/style/css.ts +1 -0
- package/packages/components/detail/style/index.ts +1 -0
- package/packages/components/form/index.ts +5 -0
- package/packages/components/form/src/index.vue +407 -0
- package/packages/components/form/src/renderBtn.vue +15 -0
- package/packages/components/form/src/renderComp.vue +15 -0
- package/packages/components/form/src/type.ts +26 -0
- package/packages/components/form/style/css.ts +1 -0
- package/packages/components/form/style/index.ts +1 -0
- package/packages/components/index.ts +20 -0
- package/packages/components/input/index.ts +5 -0
- package/packages/components/input/src/index.vue +225 -0
- package/packages/components/input/src/type.ts +14 -0
- package/packages/components/input/style/css.ts +1 -0
- package/packages/components/input/style/index.ts +1 -0
- package/packages/components/layout-page/index.ts +4 -0
- package/packages/components/layout-page/src/index.vue +74 -0
- package/packages/components/layout-page/style/css.ts +1 -0
- package/packages/components/layout-page/style/index.ts +1 -0
- package/packages/components/layout-page-item/index.ts +3 -0
- package/packages/components/layout-page-item/src/index.vue +16 -0
- package/packages/components/layout-page-item/style/css.ts +1 -0
- package/packages/components/layout-page-item/style/index.ts +1 -0
- package/packages/components/module-form/index.ts +4 -0
- package/packages/components/module-form/src/index.vue +243 -0
- package/packages/components/module-form/src/moduleDetail.vue +61 -0
- package/packages/components/module-form/src/moduleForm.vue +88 -0
- package/packages/components/module-form/src/type.ts +16 -0
- package/packages/components/module-form/style/css.ts +1 -0
- package/packages/components/module-form/style/index.ts +1 -0
- package/packages/components/package.json +9 -0
- package/packages/components/query-condition/index.ts +4 -0
- package/packages/components/query-condition/src/index.vue +478 -0
- package/packages/components/query-condition/src/moreChoose.vue +159 -0
- package/packages/components/query-condition/src/renderComp.vue +15 -0
- package/packages/components/query-condition/src/type.ts +22 -0
- package/packages/components/query-condition/src/useComputed.ts +94 -0
- package/packages/components/query-condition/style/css.ts +1 -0
- package/packages/components/query-condition/style/index.ts +1 -0
- package/packages/components/radio/index.ts +3 -0
- package/packages/components/radio/src/index.vue +73 -0
- package/packages/components/radio/src/radio.d.ts +12 -0
- package/packages/components/radio/style/css.ts +1 -0
- package/packages/components/radio/style/index.ts +1 -0
- package/packages/components/select/index.ts +4 -0
- package/packages/components/select/src/index.vue +240 -0
- package/packages/components/select/src/type.ts +43 -0
- package/packages/components/select/style/css.ts +1 -0
- package/packages/components/select/style/index.ts +1 -0
- package/packages/components/select-icon/index.ts +4 -0
- package/packages/components/select-icon/src/index.vue +128 -0
- package/packages/components/select-icon/style/css.ts +1 -0
- package/packages/components/select-icon/style/index.ts +1 -0
- package/packages/components/select-table/index.ts +4 -0
- package/packages/components/select-table/src/ClickOutside.ts +106 -0
- package/packages/components/select-table/src/index.vue +851 -0
- package/packages/components/select-table/src/renderCol.vue +20 -0
- package/packages/components/select-table/src/type.ts +56 -0
- package/packages/components/select-table/src/useVirtualized.ts +86 -0
- package/packages/components/select-table/style/css.ts +1 -0
- package/packages/components/select-table/style/index.ts +1 -0
- package/packages/components/step-wizard/index.ts +4 -0
- package/packages/components/step-wizard/src/index.vue +99 -0
- package/packages/components/step-wizard/src/type.ts +17 -0
- package/packages/components/step-wizard/style/css.ts +1 -0
- package/packages/components/step-wizard/style/index.ts +1 -0
- package/packages/components/table/index.ts +5 -0
- package/packages/components/table/src/ColumnSet.vue +176 -0
- package/packages/components/table/src/TTableColumn.vue +100 -0
- package/packages/components/table/src/densitySet.vue +91 -0
- package/packages/components/table/src/firstColumn.vue +132 -0
- package/packages/components/table/src/index.vue +926 -0
- package/packages/components/table/src/operator.vue +246 -0
- package/packages/components/table/src/renderCol.vue +20 -0
- package/packages/components/table/src/renderHeader.vue +18 -0
- package/packages/components/table/src/singleEdit.vue +354 -0
- package/packages/components/table/src/singleEditCell.vue +303 -0
- package/packages/components/table/src/tableProps.ts +162 -0
- package/packages/components/table/src/useExpose.ts +74 -0
- package/packages/components/table/src/useVirtualized.ts +70 -0
- package/packages/components/table/style/css.ts +1 -0
- package/packages/components/table/style/index.ts +1 -0
- package/packages/components/tabs/index.ts +4 -0
- package/packages/components/tabs/src/index.vue +50 -0
- package/packages/components/tabs/style/css.ts +1 -0
- package/packages/components/tabs/style/index.ts +1 -0
- package/packages/components/timer-btn/index.ts +4 -0
- package/packages/components/timer-btn/src/index.vue +57 -0
- package/packages/components/timer-btn/style/css.ts +1 -0
- package/packages/components/timer-btn/style/index.ts +1 -0
- package/packages/components/utils/index.ts +142 -0
- package/packages/components/utils/install.ts +16 -0
- package/packages/eslint-config/build.config.ts +16 -0
- package/packages/eslint-config/dist/index.cjs +122 -0
- package/packages/eslint-config/dist/index.d.cts +92 -0
- package/packages/eslint-config/dist/index.d.mts +92 -0
- package/packages/eslint-config/dist/index.d.ts +92 -0
- package/packages/eslint-config/dist/index.mjs +120 -0
- package/packages/eslint-config/package.json +34 -0
- package/packages/eslint-config/src/index.ts +121 -0
- package/packages/ff-ui-plus/component.ts +55 -0
- package/packages/ff-ui-plus/defaults.ts +4 -0
- package/packages/ff-ui-plus/index.ts +9 -0
- package/packages/ff-ui-plus/make-installer.ts +10 -0
- package/packages/ff-ui-plus/package.json +117 -0
- package/packages/ff-ui-plus/version.ts +1 -0
- package/packages/hooks/index.ts +1 -0
- package/packages/hooks/package.json +9 -0
- package/packages/hooks/useLocale.ts +53 -0
- package/packages/locale/index.ts +11 -0
- package/packages/locale/lang/en.ts +157 -0
- package/packages/locale/lang/zh-cn.ts +155 -0
- package/packages/locale/package.json +12 -0
- package/packages/resolver/package.json +23 -0
- package/packages/resolver/src/index.ts +99 -0
- package/packages/theme-chalk/build.ts +76 -0
- package/packages/theme-chalk/dist/index.css +1 -0
- package/packages/theme-chalk/dist/src/adaptive-page.scss +48 -0
- package/packages/theme-chalk/dist/src/button.scss +23 -0
- package/packages/theme-chalk/dist/src/chart.scss +10 -0
- package/packages/theme-chalk/dist/src/checkbox.scss +0 -0
- package/packages/theme-chalk/dist/src/date-picker.scss +3 -0
- package/packages/theme-chalk/dist/src/detail.scss +7 -0
- package/packages/theme-chalk/dist/src/form.scss +104 -0
- package/packages/theme-chalk/dist/src/index.scss +19 -0
- package/packages/theme-chalk/dist/src/input.scss +0 -0
- package/packages/theme-chalk/dist/src/layout-page-item.scss +10 -0
- package/packages/theme-chalk/dist/src/layout-page.scss +37 -0
- package/packages/theme-chalk/dist/src/module-form.scss +335 -0
- package/packages/theme-chalk/dist/src/query-condition.scss +132 -0
- package/packages/theme-chalk/dist/src/radio.scss +0 -0
- package/packages/theme-chalk/dist/src/select-icon.scss +61 -0
- package/packages/theme-chalk/dist/src/select-table.scss +71 -0
- package/packages/theme-chalk/dist/src/select.scss +7 -0
- package/packages/theme-chalk/dist/src/step-wizard.scss +51 -0
- package/packages/theme-chalk/dist/src/table.scss +381 -0
- package/packages/theme-chalk/dist/src/tabs.scss +20 -0
- package/packages/theme-chalk/dist/src/timer-btn.scss +21 -0
- package/packages/theme-chalk/dist/t-adaptive-page.css +1 -0
- package/packages/theme-chalk/dist/t-button.css +1 -0
- package/packages/theme-chalk/dist/t-chart.css +1 -0
- package/packages/theme-chalk/dist/t-checkbox.css +0 -0
- package/packages/theme-chalk/dist/t-date-picker.css +1 -0
- package/packages/theme-chalk/dist/t-detail.css +1 -0
- package/packages/theme-chalk/dist/t-form.css +1 -0
- package/packages/theme-chalk/dist/t-input.css +0 -0
- package/packages/theme-chalk/dist/t-layout-page-item.css +1 -0
- package/packages/theme-chalk/dist/t-layout-page.css +1 -0
- package/packages/theme-chalk/dist/t-module-form.css +1 -0
- package/packages/theme-chalk/dist/t-query-condition.css +1 -0
- package/packages/theme-chalk/dist/t-radio.css +0 -0
- package/packages/theme-chalk/dist/t-select-icon.css +1 -0
- package/packages/theme-chalk/dist/t-select-table.css +1 -0
- package/packages/theme-chalk/dist/t-select.css +1 -0
- package/packages/theme-chalk/dist/t-step-wizard.css +1 -0
- package/packages/theme-chalk/dist/t-table.css +1 -0
- package/packages/theme-chalk/dist/t-tabs.css +1 -0
- package/packages/theme-chalk/dist/t-timer-btn.css +1 -0
- package/packages/theme-chalk/mixins/config.scss +8 -0
- package/packages/theme-chalk/mixins/function.scss +71 -0
- package/packages/theme-chalk/mixins/mixins.scss +79 -0
- package/packages/theme-chalk/package.json +21 -0
- package/packages/theme-chalk/src/adaptive-page.scss +48 -0
- package/packages/theme-chalk/src/button.scss +23 -0
- package/packages/theme-chalk/src/chart.scss +10 -0
- package/packages/theme-chalk/src/checkbox.scss +0 -0
- package/packages/theme-chalk/src/date-picker.scss +3 -0
- package/packages/theme-chalk/src/detail.scss +7 -0
- package/packages/theme-chalk/src/form.scss +104 -0
- package/packages/theme-chalk/src/index.scss +19 -0
- package/packages/theme-chalk/src/input.scss +0 -0
- package/packages/theme-chalk/src/layout-page-item.scss +10 -0
- package/packages/theme-chalk/src/layout-page.scss +37 -0
- package/packages/theme-chalk/src/module-form.scss +335 -0
- package/packages/theme-chalk/src/query-condition.scss +132 -0
- package/packages/theme-chalk/src/radio.scss +0 -0
- package/packages/theme-chalk/src/select-icon.scss +61 -0
- package/packages/theme-chalk/src/select-table.scss +71 -0
- package/packages/theme-chalk/src/select.scss +7 -0
- package/packages/theme-chalk/src/step-wizard.scss +51 -0
- package/packages/theme-chalk/src/table.scss +381 -0
- package/packages/theme-chalk/src/tabs.scss +20 -0
- package/packages/theme-chalk/src/timer-btn.scss +21 -0
- package/packages/types/global.ts +34 -0
- package/packages/types/index.ts +1 -0
- package/packages/types/package.json +10 -0
- package/packages/utils/build.config.ts +23 -0
- package/packages/utils/dist/cookie.cjs +1 -0
- package/packages/utils/dist/cookie.d.cts +16 -0
- package/packages/utils/dist/cookie.d.mts +16 -0
- package/packages/utils/dist/cookie.d.ts +16 -0
- package/packages/utils/dist/cookie.mjs +1 -0
- package/packages/utils/dist/day.cjs +1 -0
- package/packages/utils/dist/day.d.cts +37 -0
- package/packages/utils/dist/day.d.mts +37 -0
- package/packages/utils/dist/day.d.ts +37 -0
- package/packages/utils/dist/day.mjs +1 -0
- package/packages/utils/dist/file.cjs +1 -0
- package/packages/utils/dist/file.d.cts +61 -0
- package/packages/utils/dist/file.d.mts +61 -0
- package/packages/utils/dist/file.d.ts +61 -0
- package/packages/utils/dist/file.mjs +1 -0
- package/packages/utils/dist/index.cjs +1 -0
- package/packages/utils/dist/index.d.cts +13 -0
- package/packages/utils/dist/index.d.mts +13 -0
- package/packages/utils/dist/index.d.ts +13 -0
- package/packages/utils/dist/index.mjs +1 -0
- package/packages/utils/dist/is.cjs +1 -0
- package/packages/utils/dist/is.d.cts +117 -0
- package/packages/utils/dist/is.d.mts +117 -0
- package/packages/utils/dist/is.d.ts +117 -0
- package/packages/utils/dist/is.mjs +1 -0
- package/packages/utils/dist/letter.cjs +1 -0
- package/packages/utils/dist/letter.d.cts +12 -0
- package/packages/utils/dist/letter.d.mts +12 -0
- package/packages/utils/dist/letter.d.ts +12 -0
- package/packages/utils/dist/letter.mjs +1 -0
- package/packages/utils/dist/number.cjs +1 -0
- package/packages/utils/dist/number.d.cts +23 -0
- package/packages/utils/dist/number.d.mts +23 -0
- package/packages/utils/dist/number.d.ts +23 -0
- package/packages/utils/dist/number.mjs +1 -0
- package/packages/utils/dist/openExe.cjs +1 -0
- package/packages/utils/dist/openExe.d.cts +9 -0
- package/packages/utils/dist/openExe.d.mts +9 -0
- package/packages/utils/dist/openExe.d.ts +9 -0
- package/packages/utils/dist/openExe.mjs +1 -0
- package/packages/utils/dist/storage.cjs +1 -0
- package/packages/utils/dist/storage.d.cts +46 -0
- package/packages/utils/dist/storage.d.mts +46 -0
- package/packages/utils/dist/storage.d.ts +46 -0
- package/packages/utils/dist/storage.mjs +1 -0
- package/packages/utils/dist/validate.cjs +1 -0
- package/packages/utils/dist/validate.d.cts +32 -0
- package/packages/utils/dist/validate.d.mts +32 -0
- package/packages/utils/dist/validate.d.ts +32 -0
- package/packages/utils/dist/validate.mjs +1 -0
- package/packages/utils/dist/ws.cjs +1 -0
- package/packages/utils/dist/ws.d.cts +86 -0
- package/packages/utils/dist/ws.d.mts +86 -0
- package/packages/utils/dist/ws.d.ts +86 -0
- package/packages/utils/dist/ws.mjs +1 -0
- package/packages/utils/package.json +42 -0
- package/packages/utils/src/cookie.ts +24 -0
- package/packages/utils/src/day.ts +66 -0
- package/packages/utils/src/file.ts +173 -0
- package/packages/utils/src/index.ts +10 -0
- package/packages/utils/src/is.ts +159 -0
- package/packages/utils/src/letter.ts +15 -0
- package/packages/utils/src/number.ts +37 -0
- package/packages/utils/src/openExe.ts +45 -0
- package/packages/utils/src/storage.ts +77 -0
- package/packages/utils/src/validate.ts +55 -0
- package/packages/utils/src/ws.ts +191 -0
- package/pnpm-workspace.yaml +3 -0
- package/publish.sh +37 -0
- package/resolver.sh +9 -0
- package/scripts/build/all.ts +152 -0
- package/scripts/build/build.config.ts +10 -0
- package/scripts/build/dist/index.cjs +7 -0
- package/scripts/build/dist/index.d.ts +2 -0
- package/scripts/build/dist/index.mjs +12 -0
- package/scripts/build/index.ts +63 -0
- package/scripts/build/modules.ts +141 -0
- package/scripts/build/package.json +14 -0
- package/scripts/release/gen-version.ts +12 -0
- package/scripts/release/index.ts +209 -0
- package/scripts/utils/excludeFiles.ts +14 -0
- package/scripts/utils/index.ts +88 -0
- package/scripts/utils/main.ts +14 -0
- package/scripts/utils/paths.ts +40 -0
- package/scripts/utils/plugin.ts +61 -0
- package/tsconfig.base.json +23 -0
- package/tsconfig.vitest.json +11 -0
- package/tsconfig.web.json +18 -0
- package/typings/env.d.ts +22 -0
- package/typings/index.d.ts +161 -0
- package/vitest.config.ts +22 -0
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="t_select_icon">
|
|
3
|
+
<el-input
|
|
4
|
+
ref="inputRef"
|
|
5
|
+
v-model="valueIcon"
|
|
6
|
+
v-bind="attrs"
|
|
7
|
+
@clear="clearIcon"
|
|
8
|
+
@click="
|
|
9
|
+
() => {
|
|
10
|
+
;(dialogVisible = true), (inputValue = '')
|
|
11
|
+
}
|
|
12
|
+
"
|
|
13
|
+
>
|
|
14
|
+
<template #append v-if="isShowIcon">
|
|
15
|
+
<el-button :icon="customIcons[modelValue]" />
|
|
16
|
+
</template>
|
|
17
|
+
</el-input>
|
|
18
|
+
<el-dialog
|
|
19
|
+
v-model="dialogVisible"
|
|
20
|
+
:title="attrs.dialogTitle"
|
|
21
|
+
draggable
|
|
22
|
+
:width="attrs.width"
|
|
23
|
+
class="t_select_icon_dialog"
|
|
24
|
+
>
|
|
25
|
+
<el-input
|
|
26
|
+
v-model="inputValue"
|
|
27
|
+
v-if="isShowSearch"
|
|
28
|
+
:placeholder="attrs.searchPlaceholder"
|
|
29
|
+
clearable
|
|
30
|
+
:prefix-icon="Icons.Search"
|
|
31
|
+
/>
|
|
32
|
+
<el-scrollbar v-if="Object.keys(iconsList).length">
|
|
33
|
+
<div class="icon-list">
|
|
34
|
+
<div
|
|
35
|
+
v-for="item in iconsList"
|
|
36
|
+
:key="item"
|
|
37
|
+
class="icon-item"
|
|
38
|
+
:class="{ 'icon-active': item.name == valueIcon }"
|
|
39
|
+
@click="selectIcon(item)"
|
|
40
|
+
>
|
|
41
|
+
<component :is="item"></component>
|
|
42
|
+
<span>{{ item.name }}</span>
|
|
43
|
+
</div>
|
|
44
|
+
</div>
|
|
45
|
+
</el-scrollbar>
|
|
46
|
+
<el-empty :description="attrs.emptyDescription" v-else />
|
|
47
|
+
</el-dialog>
|
|
48
|
+
</div>
|
|
49
|
+
</template>
|
|
50
|
+
|
|
51
|
+
<script setup lang="ts">
|
|
52
|
+
import { ref, computed, useAttrs } from "vue"
|
|
53
|
+
import * as Icons from "@element-plus/icons-vue"
|
|
54
|
+
import { useLocale } from "@ff-ui-plus/hooks"
|
|
55
|
+
defineOptions({
|
|
56
|
+
name: "TSelectIcon"
|
|
57
|
+
})
|
|
58
|
+
export interface TSelectIconProps {
|
|
59
|
+
modelValue: any
|
|
60
|
+
prefixIcon?: string
|
|
61
|
+
selectBind?: Record<string, any>
|
|
62
|
+
isShowSearch?: boolean
|
|
63
|
+
isShowIcon?: boolean
|
|
64
|
+
}
|
|
65
|
+
const props = withDefaults(defineProps<TSelectIconProps>(), {
|
|
66
|
+
modelValue: "",
|
|
67
|
+
prefixIcon: "Search",
|
|
68
|
+
selectBind: () => ({}),
|
|
69
|
+
isShowSearch: true,
|
|
70
|
+
isShowIcon: true
|
|
71
|
+
})
|
|
72
|
+
const { t } = useLocale()
|
|
73
|
+
const emit = defineEmits(["update:modelValue", "select"])
|
|
74
|
+
let valueIcon = computed({
|
|
75
|
+
get() {
|
|
76
|
+
return props.modelValue
|
|
77
|
+
},
|
|
78
|
+
set(val) {
|
|
79
|
+
emit("update:modelValue", val)
|
|
80
|
+
}
|
|
81
|
+
})
|
|
82
|
+
const $attrs: any = useAttrs()
|
|
83
|
+
const attrs = computed(() => {
|
|
84
|
+
const selectBind = {
|
|
85
|
+
"prefix-icon": customIcons[props.prefixIcon],
|
|
86
|
+
placeholder: t("plus.selectIcon.placeholder"),
|
|
87
|
+
dialogTitle: t("plus.selectIcon.dialogTitle"),
|
|
88
|
+
searchPlaceholder: t("plus.selectIcon.searchPlaceholder"),
|
|
89
|
+
emptyDescription: t("plus.selectIcon.emptyDescription"),
|
|
90
|
+
clearable: true,
|
|
91
|
+
width: "50%",
|
|
92
|
+
...props.selectBind
|
|
93
|
+
}
|
|
94
|
+
return { ...$attrs, ...selectBind }
|
|
95
|
+
})
|
|
96
|
+
// open Dialog
|
|
97
|
+
const dialogVisible = ref(false)
|
|
98
|
+
|
|
99
|
+
// 选择图标
|
|
100
|
+
const selectIcon = (item: any) => {
|
|
101
|
+
dialogVisible.value = false
|
|
102
|
+
valueIcon.value = item.name
|
|
103
|
+
emit("update:modelValue", item.name)
|
|
104
|
+
emit("select", item.name)
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// 清空图标
|
|
108
|
+
const inputRef = ref()
|
|
109
|
+
const clearIcon = () => {
|
|
110
|
+
valueIcon.value = ""
|
|
111
|
+
emit("update:modelValue", "")
|
|
112
|
+
setTimeout(() => inputRef.value.blur(), 0)
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
// 监听搜索框值
|
|
116
|
+
const inputValue = ref("")
|
|
117
|
+
const customIcons: { [key: string]: any } = Icons
|
|
118
|
+
const iconsList = computed((): { [key: string]: any } => {
|
|
119
|
+
if (!inputValue.value) return Icons
|
|
120
|
+
let result: { [key: string]: any } = {}
|
|
121
|
+
for (const key in customIcons) {
|
|
122
|
+
if (key.toLowerCase().indexOf(inputValue.value.toLowerCase()) > -1)
|
|
123
|
+
result[key] = customIcons[key]
|
|
124
|
+
}
|
|
125
|
+
return result
|
|
126
|
+
})
|
|
127
|
+
defineExpose({ clearIcon })
|
|
128
|
+
</script>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "@ff-ui-plus/theme-chalk/t-select-icon.css"
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "@ff-ui-plus/theme-chalk/src/select-icon.scss"
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { isClient } from "@vueuse/core"
|
|
2
|
+
|
|
3
|
+
import type { ComponentPublicInstance, DirectiveBinding, ObjectDirective } from "vue"
|
|
4
|
+
|
|
5
|
+
type DocumentHandler = <T extends MouseEvent>(mouseup: T, mousedown: T) => void
|
|
6
|
+
type FlushList = Map<
|
|
7
|
+
HTMLElement,
|
|
8
|
+
{
|
|
9
|
+
documentHandler: DocumentHandler
|
|
10
|
+
bindingFn: (...args: unknown[]) => unknown
|
|
11
|
+
}[]
|
|
12
|
+
>
|
|
13
|
+
|
|
14
|
+
const nodeList: FlushList = new Map()
|
|
15
|
+
|
|
16
|
+
let startClick: MouseEvent
|
|
17
|
+
|
|
18
|
+
if (isClient) {
|
|
19
|
+
document.addEventListener("mousedown", (e: MouseEvent) => (startClick = e))
|
|
20
|
+
document.addEventListener("mouseup", (e: MouseEvent) => {
|
|
21
|
+
for (const handlers of nodeList.values()) {
|
|
22
|
+
for (const { documentHandler } of handlers) {
|
|
23
|
+
documentHandler(e as MouseEvent, startClick)
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
})
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
function createDocumentHandler(el: HTMLElement, binding: DirectiveBinding): DocumentHandler {
|
|
30
|
+
let excludes: HTMLElement[] = []
|
|
31
|
+
if (Array.isArray(binding.arg)) {
|
|
32
|
+
excludes = binding.arg
|
|
33
|
+
} else if ((binding.arg as unknown) instanceof HTMLElement) {
|
|
34
|
+
// due to current implementation on binding type is wrong the type casting is necessary here
|
|
35
|
+
excludes.push(binding.arg as unknown as HTMLElement)
|
|
36
|
+
}
|
|
37
|
+
return function (mouseup, mousedown) {
|
|
38
|
+
const popperRef = (
|
|
39
|
+
binding.instance as ComponentPublicInstance<{
|
|
40
|
+
popperRef: HTMLElement
|
|
41
|
+
}>
|
|
42
|
+
).popperRef
|
|
43
|
+
const mouseUpTarget = mouseup.target as Node
|
|
44
|
+
const mouseDownTarget = mousedown?.target as Node
|
|
45
|
+
const isBound = !binding || !binding.instance
|
|
46
|
+
const isTargetExists = !mouseUpTarget || !mouseDownTarget
|
|
47
|
+
const isContainedByEl = el.contains(mouseUpTarget) || el.contains(mouseDownTarget)
|
|
48
|
+
const isSelf = el === mouseUpTarget
|
|
49
|
+
|
|
50
|
+
const isTargetExcluded =
|
|
51
|
+
(excludes.length && excludes.some(item => item?.contains(mouseUpTarget))) ||
|
|
52
|
+
(excludes.length && excludes.includes(mouseDownTarget as HTMLElement))
|
|
53
|
+
const isContainedByPopper =
|
|
54
|
+
popperRef && (popperRef.contains(mouseUpTarget) || popperRef.contains(mouseDownTarget))
|
|
55
|
+
if (
|
|
56
|
+
isBound ||
|
|
57
|
+
isTargetExists ||
|
|
58
|
+
isContainedByEl ||
|
|
59
|
+
isSelf ||
|
|
60
|
+
isTargetExcluded ||
|
|
61
|
+
isContainedByPopper
|
|
62
|
+
) {
|
|
63
|
+
return
|
|
64
|
+
}
|
|
65
|
+
binding.value(mouseup, mousedown)
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
const ClickOutside: ObjectDirective = {
|
|
70
|
+
beforeMount(el: HTMLElement, binding: DirectiveBinding) {
|
|
71
|
+
// there could be multiple handlers on the element
|
|
72
|
+
if (!nodeList.has(el)) {
|
|
73
|
+
nodeList.set(el, [])
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
nodeList.get(el)!.push({
|
|
77
|
+
documentHandler: createDocumentHandler(el, binding),
|
|
78
|
+
bindingFn: binding.value
|
|
79
|
+
})
|
|
80
|
+
},
|
|
81
|
+
updated(el: HTMLElement, binding: DirectiveBinding) {
|
|
82
|
+
if (!nodeList.has(el)) {
|
|
83
|
+
nodeList.set(el, [])
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
const handlers = nodeList.get(el)!
|
|
87
|
+
const oldHandlerIndex = handlers.findIndex(item => item.bindingFn === binding.oldValue)
|
|
88
|
+
const newHandler = {
|
|
89
|
+
documentHandler: createDocumentHandler(el, binding),
|
|
90
|
+
bindingFn: binding.value
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
if (oldHandlerIndex >= 0) {
|
|
94
|
+
// replace the old handler to the new handler
|
|
95
|
+
handlers.splice(oldHandlerIndex, 1, newHandler)
|
|
96
|
+
} else {
|
|
97
|
+
handlers.push(newHandler)
|
|
98
|
+
}
|
|
99
|
+
},
|
|
100
|
+
unmounted(el: HTMLElement) {
|
|
101
|
+
// remove all listeners when a component unmounted
|
|
102
|
+
nodeList.delete(el)
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
export default ClickOutside
|