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.
Files changed (319) hide show
  1. package/.nvmrc +1 -0
  2. package/.prettierrc.cjs +41 -0
  3. package/.stylelintignore +5 -0
  4. package/LICENSE +21 -0
  5. package/README.md +265 -0
  6. package/commitlint.config.cjs +162 -0
  7. package/global.d.ts +27 -0
  8. package/index.html +16 -0
  9. package/lib.sh +9 -0
  10. package/lint-staged.config.cjs +8 -0
  11. package/package.json +149 -0
  12. package/packages/components/adaptive-page/index.ts +5 -0
  13. package/packages/components/adaptive-page/src/index.vue +85 -0
  14. package/packages/components/adaptive-page/src/type.ts +9 -0
  15. package/packages/components/adaptive-page/style/css.ts +1 -0
  16. package/packages/components/adaptive-page/style/index.ts +1 -0
  17. package/packages/components/button/index.ts +5 -0
  18. package/packages/components/button/src/index.vue +41 -0
  19. package/packages/components/button/src/type.ts +11 -0
  20. package/packages/components/button/style/css.ts +1 -0
  21. package/packages/components/button/style/index.ts +1 -0
  22. package/packages/components/chart/index.ts +5 -0
  23. package/packages/components/chart/src/index.vue +121 -0
  24. package/packages/components/chart/src/type.ts +7 -0
  25. package/packages/components/chart/style/css.ts +1 -0
  26. package/packages/components/chart/style/index.ts +1 -0
  27. package/packages/components/checkbox/index.ts +3 -0
  28. package/packages/components/checkbox/src/checkbox.d.ts +5 -0
  29. package/packages/components/checkbox/src/index.vue +67 -0
  30. package/packages/components/checkbox/style/css.ts +1 -0
  31. package/packages/components/checkbox/style/index.ts +1 -0
  32. package/packages/components/date-picker/index.ts +5 -0
  33. package/packages/components/date-picker/src/index.vue +228 -0
  34. package/packages/components/date-picker/src/type.ts +22 -0
  35. package/packages/components/date-picker/style/css.ts +1 -0
  36. package/packages/components/date-picker/style/index.ts +1 -0
  37. package/packages/components/detail/index.ts +5 -0
  38. package/packages/components/detail/src/index.vue +102 -0
  39. package/packages/components/detail/src/renderLabel.vue +15 -0
  40. package/packages/components/detail/src/renderTooltip.vue +15 -0
  41. package/packages/components/detail/src/type.ts +28 -0
  42. package/packages/components/detail/style/css.ts +1 -0
  43. package/packages/components/detail/style/index.ts +1 -0
  44. package/packages/components/form/index.ts +5 -0
  45. package/packages/components/form/src/index.vue +407 -0
  46. package/packages/components/form/src/renderBtn.vue +15 -0
  47. package/packages/components/form/src/renderComp.vue +15 -0
  48. package/packages/components/form/src/type.ts +26 -0
  49. package/packages/components/form/style/css.ts +1 -0
  50. package/packages/components/form/style/index.ts +1 -0
  51. package/packages/components/index.ts +20 -0
  52. package/packages/components/input/index.ts +5 -0
  53. package/packages/components/input/src/index.vue +225 -0
  54. package/packages/components/input/src/type.ts +14 -0
  55. package/packages/components/input/style/css.ts +1 -0
  56. package/packages/components/input/style/index.ts +1 -0
  57. package/packages/components/layout-page/index.ts +4 -0
  58. package/packages/components/layout-page/src/index.vue +74 -0
  59. package/packages/components/layout-page/style/css.ts +1 -0
  60. package/packages/components/layout-page/style/index.ts +1 -0
  61. package/packages/components/layout-page-item/index.ts +3 -0
  62. package/packages/components/layout-page-item/src/index.vue +16 -0
  63. package/packages/components/layout-page-item/style/css.ts +1 -0
  64. package/packages/components/layout-page-item/style/index.ts +1 -0
  65. package/packages/components/module-form/index.ts +4 -0
  66. package/packages/components/module-form/src/index.vue +243 -0
  67. package/packages/components/module-form/src/moduleDetail.vue +61 -0
  68. package/packages/components/module-form/src/moduleForm.vue +88 -0
  69. package/packages/components/module-form/src/type.ts +16 -0
  70. package/packages/components/module-form/style/css.ts +1 -0
  71. package/packages/components/module-form/style/index.ts +1 -0
  72. package/packages/components/package.json +9 -0
  73. package/packages/components/query-condition/index.ts +4 -0
  74. package/packages/components/query-condition/src/index.vue +478 -0
  75. package/packages/components/query-condition/src/moreChoose.vue +159 -0
  76. package/packages/components/query-condition/src/renderComp.vue +15 -0
  77. package/packages/components/query-condition/src/type.ts +22 -0
  78. package/packages/components/query-condition/src/useComputed.ts +94 -0
  79. package/packages/components/query-condition/style/css.ts +1 -0
  80. package/packages/components/query-condition/style/index.ts +1 -0
  81. package/packages/components/radio/index.ts +3 -0
  82. package/packages/components/radio/src/index.vue +73 -0
  83. package/packages/components/radio/src/radio.d.ts +12 -0
  84. package/packages/components/radio/style/css.ts +1 -0
  85. package/packages/components/radio/style/index.ts +1 -0
  86. package/packages/components/select/index.ts +4 -0
  87. package/packages/components/select/src/index.vue +240 -0
  88. package/packages/components/select/src/type.ts +43 -0
  89. package/packages/components/select/style/css.ts +1 -0
  90. package/packages/components/select/style/index.ts +1 -0
  91. package/packages/components/select-icon/index.ts +4 -0
  92. package/packages/components/select-icon/src/index.vue +128 -0
  93. package/packages/components/select-icon/style/css.ts +1 -0
  94. package/packages/components/select-icon/style/index.ts +1 -0
  95. package/packages/components/select-table/index.ts +4 -0
  96. package/packages/components/select-table/src/ClickOutside.ts +106 -0
  97. package/packages/components/select-table/src/index.vue +851 -0
  98. package/packages/components/select-table/src/renderCol.vue +20 -0
  99. package/packages/components/select-table/src/type.ts +56 -0
  100. package/packages/components/select-table/src/useVirtualized.ts +86 -0
  101. package/packages/components/select-table/style/css.ts +1 -0
  102. package/packages/components/select-table/style/index.ts +1 -0
  103. package/packages/components/step-wizard/index.ts +4 -0
  104. package/packages/components/step-wizard/src/index.vue +99 -0
  105. package/packages/components/step-wizard/src/type.ts +17 -0
  106. package/packages/components/step-wizard/style/css.ts +1 -0
  107. package/packages/components/step-wizard/style/index.ts +1 -0
  108. package/packages/components/table/index.ts +5 -0
  109. package/packages/components/table/src/ColumnSet.vue +176 -0
  110. package/packages/components/table/src/TTableColumn.vue +100 -0
  111. package/packages/components/table/src/densitySet.vue +91 -0
  112. package/packages/components/table/src/firstColumn.vue +132 -0
  113. package/packages/components/table/src/index.vue +926 -0
  114. package/packages/components/table/src/operator.vue +246 -0
  115. package/packages/components/table/src/renderCol.vue +20 -0
  116. package/packages/components/table/src/renderHeader.vue +18 -0
  117. package/packages/components/table/src/singleEdit.vue +354 -0
  118. package/packages/components/table/src/singleEditCell.vue +303 -0
  119. package/packages/components/table/src/tableProps.ts +162 -0
  120. package/packages/components/table/src/useExpose.ts +74 -0
  121. package/packages/components/table/src/useVirtualized.ts +70 -0
  122. package/packages/components/table/style/css.ts +1 -0
  123. package/packages/components/table/style/index.ts +1 -0
  124. package/packages/components/tabs/index.ts +4 -0
  125. package/packages/components/tabs/src/index.vue +50 -0
  126. package/packages/components/tabs/style/css.ts +1 -0
  127. package/packages/components/tabs/style/index.ts +1 -0
  128. package/packages/components/timer-btn/index.ts +4 -0
  129. package/packages/components/timer-btn/src/index.vue +57 -0
  130. package/packages/components/timer-btn/style/css.ts +1 -0
  131. package/packages/components/timer-btn/style/index.ts +1 -0
  132. package/packages/components/utils/index.ts +142 -0
  133. package/packages/components/utils/install.ts +16 -0
  134. package/packages/eslint-config/build.config.ts +16 -0
  135. package/packages/eslint-config/dist/index.cjs +122 -0
  136. package/packages/eslint-config/dist/index.d.cts +92 -0
  137. package/packages/eslint-config/dist/index.d.mts +92 -0
  138. package/packages/eslint-config/dist/index.d.ts +92 -0
  139. package/packages/eslint-config/dist/index.mjs +120 -0
  140. package/packages/eslint-config/package.json +34 -0
  141. package/packages/eslint-config/src/index.ts +121 -0
  142. package/packages/ff-ui-plus/component.ts +55 -0
  143. package/packages/ff-ui-plus/defaults.ts +4 -0
  144. package/packages/ff-ui-plus/index.ts +9 -0
  145. package/packages/ff-ui-plus/make-installer.ts +10 -0
  146. package/packages/ff-ui-plus/package.json +117 -0
  147. package/packages/ff-ui-plus/version.ts +1 -0
  148. package/packages/hooks/index.ts +1 -0
  149. package/packages/hooks/package.json +9 -0
  150. package/packages/hooks/useLocale.ts +53 -0
  151. package/packages/locale/index.ts +11 -0
  152. package/packages/locale/lang/en.ts +157 -0
  153. package/packages/locale/lang/zh-cn.ts +155 -0
  154. package/packages/locale/package.json +12 -0
  155. package/packages/resolver/package.json +23 -0
  156. package/packages/resolver/src/index.ts +99 -0
  157. package/packages/theme-chalk/build.ts +76 -0
  158. package/packages/theme-chalk/dist/index.css +1 -0
  159. package/packages/theme-chalk/dist/src/adaptive-page.scss +48 -0
  160. package/packages/theme-chalk/dist/src/button.scss +23 -0
  161. package/packages/theme-chalk/dist/src/chart.scss +10 -0
  162. package/packages/theme-chalk/dist/src/checkbox.scss +0 -0
  163. package/packages/theme-chalk/dist/src/date-picker.scss +3 -0
  164. package/packages/theme-chalk/dist/src/detail.scss +7 -0
  165. package/packages/theme-chalk/dist/src/form.scss +104 -0
  166. package/packages/theme-chalk/dist/src/index.scss +19 -0
  167. package/packages/theme-chalk/dist/src/input.scss +0 -0
  168. package/packages/theme-chalk/dist/src/layout-page-item.scss +10 -0
  169. package/packages/theme-chalk/dist/src/layout-page.scss +37 -0
  170. package/packages/theme-chalk/dist/src/module-form.scss +335 -0
  171. package/packages/theme-chalk/dist/src/query-condition.scss +132 -0
  172. package/packages/theme-chalk/dist/src/radio.scss +0 -0
  173. package/packages/theme-chalk/dist/src/select-icon.scss +61 -0
  174. package/packages/theme-chalk/dist/src/select-table.scss +71 -0
  175. package/packages/theme-chalk/dist/src/select.scss +7 -0
  176. package/packages/theme-chalk/dist/src/step-wizard.scss +51 -0
  177. package/packages/theme-chalk/dist/src/table.scss +381 -0
  178. package/packages/theme-chalk/dist/src/tabs.scss +20 -0
  179. package/packages/theme-chalk/dist/src/timer-btn.scss +21 -0
  180. package/packages/theme-chalk/dist/t-adaptive-page.css +1 -0
  181. package/packages/theme-chalk/dist/t-button.css +1 -0
  182. package/packages/theme-chalk/dist/t-chart.css +1 -0
  183. package/packages/theme-chalk/dist/t-checkbox.css +0 -0
  184. package/packages/theme-chalk/dist/t-date-picker.css +1 -0
  185. package/packages/theme-chalk/dist/t-detail.css +1 -0
  186. package/packages/theme-chalk/dist/t-form.css +1 -0
  187. package/packages/theme-chalk/dist/t-input.css +0 -0
  188. package/packages/theme-chalk/dist/t-layout-page-item.css +1 -0
  189. package/packages/theme-chalk/dist/t-layout-page.css +1 -0
  190. package/packages/theme-chalk/dist/t-module-form.css +1 -0
  191. package/packages/theme-chalk/dist/t-query-condition.css +1 -0
  192. package/packages/theme-chalk/dist/t-radio.css +0 -0
  193. package/packages/theme-chalk/dist/t-select-icon.css +1 -0
  194. package/packages/theme-chalk/dist/t-select-table.css +1 -0
  195. package/packages/theme-chalk/dist/t-select.css +1 -0
  196. package/packages/theme-chalk/dist/t-step-wizard.css +1 -0
  197. package/packages/theme-chalk/dist/t-table.css +1 -0
  198. package/packages/theme-chalk/dist/t-tabs.css +1 -0
  199. package/packages/theme-chalk/dist/t-timer-btn.css +1 -0
  200. package/packages/theme-chalk/mixins/config.scss +8 -0
  201. package/packages/theme-chalk/mixins/function.scss +71 -0
  202. package/packages/theme-chalk/mixins/mixins.scss +79 -0
  203. package/packages/theme-chalk/package.json +21 -0
  204. package/packages/theme-chalk/src/adaptive-page.scss +48 -0
  205. package/packages/theme-chalk/src/button.scss +23 -0
  206. package/packages/theme-chalk/src/chart.scss +10 -0
  207. package/packages/theme-chalk/src/checkbox.scss +0 -0
  208. package/packages/theme-chalk/src/date-picker.scss +3 -0
  209. package/packages/theme-chalk/src/detail.scss +7 -0
  210. package/packages/theme-chalk/src/form.scss +104 -0
  211. package/packages/theme-chalk/src/index.scss +19 -0
  212. package/packages/theme-chalk/src/input.scss +0 -0
  213. package/packages/theme-chalk/src/layout-page-item.scss +10 -0
  214. package/packages/theme-chalk/src/layout-page.scss +37 -0
  215. package/packages/theme-chalk/src/module-form.scss +335 -0
  216. package/packages/theme-chalk/src/query-condition.scss +132 -0
  217. package/packages/theme-chalk/src/radio.scss +0 -0
  218. package/packages/theme-chalk/src/select-icon.scss +61 -0
  219. package/packages/theme-chalk/src/select-table.scss +71 -0
  220. package/packages/theme-chalk/src/select.scss +7 -0
  221. package/packages/theme-chalk/src/step-wizard.scss +51 -0
  222. package/packages/theme-chalk/src/table.scss +381 -0
  223. package/packages/theme-chalk/src/tabs.scss +20 -0
  224. package/packages/theme-chalk/src/timer-btn.scss +21 -0
  225. package/packages/types/global.ts +34 -0
  226. package/packages/types/index.ts +1 -0
  227. package/packages/types/package.json +10 -0
  228. package/packages/utils/build.config.ts +23 -0
  229. package/packages/utils/dist/cookie.cjs +1 -0
  230. package/packages/utils/dist/cookie.d.cts +16 -0
  231. package/packages/utils/dist/cookie.d.mts +16 -0
  232. package/packages/utils/dist/cookie.d.ts +16 -0
  233. package/packages/utils/dist/cookie.mjs +1 -0
  234. package/packages/utils/dist/day.cjs +1 -0
  235. package/packages/utils/dist/day.d.cts +37 -0
  236. package/packages/utils/dist/day.d.mts +37 -0
  237. package/packages/utils/dist/day.d.ts +37 -0
  238. package/packages/utils/dist/day.mjs +1 -0
  239. package/packages/utils/dist/file.cjs +1 -0
  240. package/packages/utils/dist/file.d.cts +61 -0
  241. package/packages/utils/dist/file.d.mts +61 -0
  242. package/packages/utils/dist/file.d.ts +61 -0
  243. package/packages/utils/dist/file.mjs +1 -0
  244. package/packages/utils/dist/index.cjs +1 -0
  245. package/packages/utils/dist/index.d.cts +13 -0
  246. package/packages/utils/dist/index.d.mts +13 -0
  247. package/packages/utils/dist/index.d.ts +13 -0
  248. package/packages/utils/dist/index.mjs +1 -0
  249. package/packages/utils/dist/is.cjs +1 -0
  250. package/packages/utils/dist/is.d.cts +117 -0
  251. package/packages/utils/dist/is.d.mts +117 -0
  252. package/packages/utils/dist/is.d.ts +117 -0
  253. package/packages/utils/dist/is.mjs +1 -0
  254. package/packages/utils/dist/letter.cjs +1 -0
  255. package/packages/utils/dist/letter.d.cts +12 -0
  256. package/packages/utils/dist/letter.d.mts +12 -0
  257. package/packages/utils/dist/letter.d.ts +12 -0
  258. package/packages/utils/dist/letter.mjs +1 -0
  259. package/packages/utils/dist/number.cjs +1 -0
  260. package/packages/utils/dist/number.d.cts +23 -0
  261. package/packages/utils/dist/number.d.mts +23 -0
  262. package/packages/utils/dist/number.d.ts +23 -0
  263. package/packages/utils/dist/number.mjs +1 -0
  264. package/packages/utils/dist/openExe.cjs +1 -0
  265. package/packages/utils/dist/openExe.d.cts +9 -0
  266. package/packages/utils/dist/openExe.d.mts +9 -0
  267. package/packages/utils/dist/openExe.d.ts +9 -0
  268. package/packages/utils/dist/openExe.mjs +1 -0
  269. package/packages/utils/dist/storage.cjs +1 -0
  270. package/packages/utils/dist/storage.d.cts +46 -0
  271. package/packages/utils/dist/storage.d.mts +46 -0
  272. package/packages/utils/dist/storage.d.ts +46 -0
  273. package/packages/utils/dist/storage.mjs +1 -0
  274. package/packages/utils/dist/validate.cjs +1 -0
  275. package/packages/utils/dist/validate.d.cts +32 -0
  276. package/packages/utils/dist/validate.d.mts +32 -0
  277. package/packages/utils/dist/validate.d.ts +32 -0
  278. package/packages/utils/dist/validate.mjs +1 -0
  279. package/packages/utils/dist/ws.cjs +1 -0
  280. package/packages/utils/dist/ws.d.cts +86 -0
  281. package/packages/utils/dist/ws.d.mts +86 -0
  282. package/packages/utils/dist/ws.d.ts +86 -0
  283. package/packages/utils/dist/ws.mjs +1 -0
  284. package/packages/utils/package.json +42 -0
  285. package/packages/utils/src/cookie.ts +24 -0
  286. package/packages/utils/src/day.ts +66 -0
  287. package/packages/utils/src/file.ts +173 -0
  288. package/packages/utils/src/index.ts +10 -0
  289. package/packages/utils/src/is.ts +159 -0
  290. package/packages/utils/src/letter.ts +15 -0
  291. package/packages/utils/src/number.ts +37 -0
  292. package/packages/utils/src/openExe.ts +45 -0
  293. package/packages/utils/src/storage.ts +77 -0
  294. package/packages/utils/src/validate.ts +55 -0
  295. package/packages/utils/src/ws.ts +191 -0
  296. package/pnpm-workspace.yaml +3 -0
  297. package/publish.sh +37 -0
  298. package/resolver.sh +9 -0
  299. package/scripts/build/all.ts +152 -0
  300. package/scripts/build/build.config.ts +10 -0
  301. package/scripts/build/dist/index.cjs +7 -0
  302. package/scripts/build/dist/index.d.ts +2 -0
  303. package/scripts/build/dist/index.mjs +12 -0
  304. package/scripts/build/index.ts +63 -0
  305. package/scripts/build/modules.ts +141 -0
  306. package/scripts/build/package.json +14 -0
  307. package/scripts/release/gen-version.ts +12 -0
  308. package/scripts/release/index.ts +209 -0
  309. package/scripts/utils/excludeFiles.ts +14 -0
  310. package/scripts/utils/index.ts +88 -0
  311. package/scripts/utils/main.ts +14 -0
  312. package/scripts/utils/paths.ts +40 -0
  313. package/scripts/utils/plugin.ts +61 -0
  314. package/tsconfig.base.json +23 -0
  315. package/tsconfig.vitest.json +11 -0
  316. package/tsconfig.web.json +18 -0
  317. package/typings/env.d.ts +22 -0
  318. package/typings/index.d.ts +161 -0
  319. 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,4 @@
1
+ import SelectTable from "./src/index.vue"
2
+ export * from "./src/type"
3
+ export * from "./src/ClickOutside"
4
+ export const TSelectTable = SelectTable
@@ -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