@yh-ui/components 0.1.16 → 0.1.21

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 (892) hide show
  1. package/README.md +193 -6
  2. package/dist/affix/index.d.ts +202 -1
  3. package/dist/affix/src/affix.vue.d.ts +55 -6
  4. package/dist/ai-action-group/__tests__/ai-action-group.test.cjs +86 -0
  5. package/dist/ai-action-group/__tests__/ai-action-group.test.mjs +53 -0
  6. package/dist/ai-action-group/index.d.ts +110 -1
  7. package/dist/ai-action-group/src/ai-action-group.vue +8 -8
  8. package/dist/ai-action-group/src/ai-action-group.vue.d.ts +29 -4
  9. package/dist/ai-agent-card/__tests__/ai-agent-card.test.cjs +135 -0
  10. package/dist/ai-agent-card/__tests__/ai-agent-card.test.mjs +69 -0
  11. package/dist/ai-agent-card/index.d.ts +176 -1
  12. package/dist/ai-agent-card/src/ai-agent-card.vue +4 -4
  13. package/dist/ai-agent-card/src/ai-agent-card.vue.d.ts +50 -7
  14. package/dist/ai-artifacts/index.d.ts +276 -1
  15. package/dist/ai-artifacts/src/ai-artifacts.cjs +60 -0
  16. package/dist/ai-artifacts/src/ai-artifacts.css +5 -1
  17. package/dist/ai-artifacts/src/ai-artifacts.d.ts +99 -18
  18. package/dist/ai-artifacts/src/ai-artifacts.mjs +60 -0
  19. package/dist/ai-artifacts/src/ai-artifacts.vue +177 -28
  20. package/dist/ai-artifacts/src/ai-artifacts.vue.d.ts +149 -36
  21. package/dist/ai-attachments/__tests__/ai-attachments.ssr.test.cjs +50 -0
  22. package/dist/ai-attachments/__tests__/ai-attachments.ssr.test.mjs +33 -0
  23. package/dist/ai-attachments/__tests__/ai-attachments.test.cjs +113 -0
  24. package/dist/ai-attachments/__tests__/ai-attachments.test.mjs +81 -0
  25. package/dist/ai-attachments/index.cjs +26 -0
  26. package/dist/ai-attachments/index.d.ts +363 -0
  27. package/dist/ai-attachments/index.mjs +5 -0
  28. package/dist/ai-attachments/src/ai-attachments.cjs +96 -0
  29. package/dist/ai-attachments/src/ai-attachments.css +685 -0
  30. package/dist/ai-attachments/src/ai-attachments.d.ts +127 -0
  31. package/dist/ai-attachments/src/ai-attachments.mjs +90 -0
  32. package/dist/ai-attachments/src/ai-attachments.vue +1012 -0
  33. package/dist/ai-attachments/src/ai-attachments.vue.d.ts +218 -0
  34. package/dist/ai-bubble/__tests__/ai-bubble.ssr.test.cjs +8 -0
  35. package/dist/ai-bubble/__tests__/ai-bubble.ssr.test.mjs +8 -0
  36. package/dist/ai-bubble/__tests__/ai-bubble.test.cjs +442 -45
  37. package/dist/ai-bubble/__tests__/ai-bubble.test.mjs +288 -18
  38. package/dist/ai-bubble/index.d.ts +442 -1
  39. package/dist/ai-bubble/src/ai-bubble.cjs +130 -0
  40. package/dist/ai-bubble/src/ai-bubble.css +104 -0
  41. package/dist/ai-bubble/src/ai-bubble.d.ts +369 -30
  42. package/dist/ai-bubble/src/ai-bubble.mjs +172 -0
  43. package/dist/ai-bubble/src/ai-bubble.vue +1228 -54
  44. package/dist/ai-bubble/src/ai-bubble.vue.d.ts +235 -72
  45. package/dist/ai-bubble-list/__tests__/ai-bubble-list.ssr.test.cjs +51 -0
  46. package/dist/ai-bubble-list/__tests__/ai-bubble-list.ssr.test.mjs +51 -0
  47. package/dist/ai-bubble-list/__tests__/ai-bubble-list.test.cjs +138 -0
  48. package/dist/ai-bubble-list/__tests__/ai-bubble-list.test.mjs +112 -0
  49. package/dist/ai-bubble-list/index.cjs +26 -0
  50. package/dist/ai-bubble-list/index.d.ts +156 -0
  51. package/dist/ai-bubble-list/index.mjs +5 -0
  52. package/dist/ai-bubble-list/src/ai-bubble-list.cjs +57 -0
  53. package/dist/ai-bubble-list/src/ai-bubble-list.css +490 -0
  54. package/dist/ai-bubble-list/src/ai-bubble-list.d.ts +58 -0
  55. package/dist/ai-bubble-list/src/ai-bubble-list.mjs +51 -0
  56. package/dist/ai-bubble-list/src/ai-bubble-list.vue +594 -0
  57. package/dist/ai-bubble-list/src/ai-bubble-list.vue.d.ts +93 -0
  58. package/dist/ai-chat/__tests__/ai-chat.ssr.test.cjs +8 -0
  59. package/dist/ai-chat/__tests__/ai-chat.ssr.test.mjs +8 -0
  60. package/dist/ai-chat/__tests__/ai-chat.test.cjs +8 -0
  61. package/dist/ai-chat/__tests__/ai-chat.test.mjs +8 -0
  62. package/dist/ai-chat/index.d.ts +164 -1
  63. package/dist/ai-chat/src/ai-chat.cjs +21 -0
  64. package/dist/ai-chat/src/ai-chat.css +25 -0
  65. package/dist/ai-chat/src/ai-chat.d.ts +21 -0
  66. package/dist/ai-chat/src/ai-chat.mjs +21 -0
  67. package/dist/ai-chat/src/ai-chat.vue +93 -16
  68. package/dist/ai-chat/src/ai-chat.vue.d.ts +64 -7
  69. package/dist/ai-code-block/__tests__/ai-code-block.ssr.test.cjs +9 -0
  70. package/dist/ai-code-block/__tests__/ai-code-block.ssr.test.mjs +9 -0
  71. package/dist/ai-code-block/index.d.ts +220 -1
  72. package/dist/ai-code-block/src/ai-code-block.cjs +17 -1
  73. package/dist/ai-code-block/src/ai-code-block.css +23 -0
  74. package/dist/ai-code-block/src/ai-code-block.d.ts +18 -1
  75. package/dist/ai-code-block/src/ai-code-block.mjs +17 -1
  76. package/dist/ai-code-block/src/ai-code-block.vue +132 -27
  77. package/dist/ai-code-block/src/ai-code-block.vue.d.ts +72 -6
  78. package/dist/ai-code-editor/__tests__/ai-code-editor.ssr.test.cjs +46 -0
  79. package/dist/ai-code-editor/__tests__/ai-code-editor.ssr.test.mjs +39 -0
  80. package/dist/ai-code-editor/__tests__/ai-code-editor.test.cjs +90 -0
  81. package/dist/ai-code-editor/__tests__/ai-code-editor.test.mjs +78 -0
  82. package/dist/ai-code-editor/index.cjs +26 -0
  83. package/dist/ai-code-editor/index.d.ts +135 -0
  84. package/dist/ai-code-editor/index.mjs +5 -0
  85. package/dist/ai-code-editor/src/ai-code-editor.cjs +100 -0
  86. package/dist/ai-code-editor/src/ai-code-editor.css +473 -0
  87. package/dist/ai-code-editor/src/ai-code-editor.d.ts +104 -0
  88. package/dist/ai-code-editor/src/ai-code-editor.mjs +94 -0
  89. package/dist/ai-code-editor/src/ai-code-editor.vue +673 -0
  90. package/dist/ai-code-editor/src/ai-code-editor.vue.d.ts +132 -0
  91. package/dist/ai-code-runner/__tests__/ai-code-runner.ssr.test.cjs +28 -0
  92. package/dist/ai-code-runner/__tests__/ai-code-runner.ssr.test.mjs +26 -0
  93. package/dist/ai-code-runner/__tests__/ai-code-runner.test.cjs +69 -0
  94. package/dist/ai-code-runner/__tests__/ai-code-runner.test.mjs +66 -0
  95. package/dist/ai-code-runner/index.cjs +26 -0
  96. package/dist/ai-code-runner/index.d.ts +70 -0
  97. package/dist/ai-code-runner/index.mjs +5 -0
  98. package/dist/ai-code-runner/src/ai-code-runner.cjs +50 -0
  99. package/dist/ai-code-runner/src/ai-code-runner.css +504 -0
  100. package/dist/ai-code-runner/src/ai-code-runner.d.ts +55 -0
  101. package/dist/ai-code-runner/src/ai-code-runner.mjs +44 -0
  102. package/dist/ai-code-runner/src/ai-code-runner.vue +692 -0
  103. package/dist/ai-code-runner/src/ai-code-runner.vue.d.ts +67 -0
  104. package/dist/ai-code-runner/src/webcontainer.cjs +17 -0
  105. package/dist/ai-code-runner/src/webcontainer.d.ts +4 -0
  106. package/dist/ai-code-runner/src/webcontainer.mjs +9 -0
  107. package/dist/ai-conversations/index.d.ts +216 -1
  108. package/dist/ai-conversations/src/ai-conversations.cjs +29 -0
  109. package/dist/ai-conversations/src/ai-conversations.css +45 -7
  110. package/dist/ai-conversations/src/ai-conversations.d.ts +28 -0
  111. package/dist/ai-conversations/src/ai-conversations.mjs +29 -0
  112. package/dist/ai-conversations/src/ai-conversations.vue +172 -42
  113. package/dist/ai-conversations/src/ai-conversations.vue.d.ts +78 -3
  114. package/dist/ai-editor-sender/index.d.ts +417 -1
  115. package/dist/ai-editor-sender/src/ai-editor-sender.cjs +92 -1
  116. package/dist/ai-editor-sender/src/ai-editor-sender.css +96 -0
  117. package/dist/ai-editor-sender/src/ai-editor-sender.d.ts +144 -29
  118. package/dist/ai-editor-sender/src/ai-editor-sender.mjs +92 -1
  119. package/dist/ai-editor-sender/src/ai-editor-sender.vue +309 -3
  120. package/dist/ai-editor-sender/src/ai-editor-sender.vue.d.ts +221 -50
  121. package/dist/ai-file-card/__tests__/ai-file-card.ssr.test.cjs +45 -0
  122. package/dist/ai-file-card/__tests__/ai-file-card.ssr.test.mjs +29 -0
  123. package/dist/ai-file-card/__tests__/ai-file-card.test.cjs +160 -0
  124. package/dist/ai-file-card/__tests__/ai-file-card.test.mjs +109 -0
  125. package/dist/ai-file-card/index.cjs +26 -0
  126. package/dist/ai-file-card/index.d.ts +231 -0
  127. package/dist/ai-file-card/index.mjs +5 -0
  128. package/dist/ai-file-card/src/ai-file-card.cjs +76 -0
  129. package/dist/ai-file-card/src/ai-file-card.css +757 -0
  130. package/dist/ai-file-card/src/ai-file-card.d.ts +176 -0
  131. package/dist/ai-file-card/src/ai-file-card.mjs +70 -0
  132. package/dist/ai-file-card/src/ai-file-card.vue +1054 -0
  133. package/dist/ai-file-card/src/ai-file-card.vue.d.ts +135 -0
  134. package/dist/ai-mention/index.d.ts +368 -14
  135. package/dist/ai-mention/src/ai-mention.cjs +73 -2
  136. package/dist/ai-mention/src/ai-mention.css +125 -0
  137. package/dist/ai-mention/src/ai-mention.d.ts +105 -1
  138. package/dist/ai-mention/src/ai-mention.mjs +73 -2
  139. package/dist/ai-mention/src/ai-mention.vue +596 -10
  140. package/dist/ai-mention/src/ai-mention.vue.d.ts +158 -15
  141. package/dist/ai-mermaid/__tests__/ai-mermaid.ssr.test.cjs +43 -0
  142. package/dist/ai-mermaid/__tests__/ai-mermaid.ssr.test.mjs +33 -0
  143. package/dist/ai-mermaid/__tests__/ai-mermaid.test.cjs +113 -0
  144. package/dist/ai-mermaid/__tests__/ai-mermaid.test.mjs +92 -0
  145. package/dist/ai-mermaid/index.cjs +26 -0
  146. package/dist/ai-mermaid/index.d.ts +228 -0
  147. package/dist/ai-mermaid/index.mjs +5 -0
  148. package/dist/ai-mermaid/src/ai-mermaid.cjs +72 -0
  149. package/dist/ai-mermaid/src/ai-mermaid.css +601 -0
  150. package/dist/ai-mermaid/src/ai-mermaid.d.ts +113 -0
  151. package/dist/ai-mermaid/src/ai-mermaid.mjs +66 -0
  152. package/dist/ai-mermaid/src/ai-mermaid.vue +841 -0
  153. package/dist/ai-mermaid/src/ai-mermaid.vue.d.ts +133 -0
  154. package/dist/ai-prompts/index.d.ts +104 -1
  155. package/dist/ai-prompts/src/ai-prompts.vue.d.ts +27 -6
  156. package/dist/ai-provider/index.d.ts +139 -1
  157. package/dist/ai-provider/src/ai-provider.cjs +61 -1
  158. package/dist/ai-provider/src/ai-provider.d.ts +116 -6
  159. package/dist/ai-provider/src/ai-provider.mjs +57 -0
  160. package/dist/ai-provider/src/ai-provider.vue +58 -3
  161. package/dist/ai-provider/src/ai-provider.vue.d.ts +44 -7
  162. package/dist/ai-sender/__tests__/ai-sender.test.cjs +118 -2
  163. package/dist/ai-sender/__tests__/ai-sender.test.mjs +68 -1
  164. package/dist/ai-sender/index.d.ts +236 -1
  165. package/dist/ai-sender/src/ai-sender.cjs +5 -1
  166. package/dist/ai-sender/src/ai-sender.css +38 -0
  167. package/dist/ai-sender/src/ai-sender.d.ts +4 -0
  168. package/dist/ai-sender/src/ai-sender.mjs +5 -1
  169. package/dist/ai-sender/src/ai-sender.vue +86 -2
  170. package/dist/ai-sender/src/ai-sender.vue.d.ts +77 -15
  171. package/dist/ai-sources/__tests__/ai-sources.test.cjs +112 -5
  172. package/dist/ai-sources/__tests__/ai-sources.test.mjs +78 -7
  173. package/dist/ai-sources/index.d.ts +136 -1
  174. package/dist/ai-sources/src/ai-sources.css +24 -0
  175. package/dist/ai-sources/src/ai-sources.d.ts +3 -0
  176. package/dist/ai-sources/src/ai-sources.vue +88 -21
  177. package/dist/ai-sources/src/ai-sources.vue.d.ts +38 -5
  178. package/dist/ai-thinking/index.d.ts +152 -1
  179. package/dist/ai-thinking/src/ai-thinking.cjs +28 -0
  180. package/dist/ai-thinking/src/ai-thinking.d.ts +28 -0
  181. package/dist/ai-thinking/src/ai-thinking.mjs +28 -0
  182. package/dist/ai-thinking/src/ai-thinking.vue +9 -6
  183. package/dist/ai-thinking/src/ai-thinking.vue.d.ts +58 -2
  184. package/dist/ai-thought-chain/__tests__/ai-thought-chain.ssr.test.cjs +6 -1
  185. package/dist/ai-thought-chain/__tests__/ai-thought-chain.ssr.test.mjs +4 -1
  186. package/dist/ai-thought-chain/__tests__/ai-thought-chain.test.cjs +141 -1
  187. package/dist/ai-thought-chain/__tests__/ai-thought-chain.test.mjs +104 -1
  188. package/dist/ai-thought-chain/index.d.ts +286 -1
  189. package/dist/ai-thought-chain/src/ai-thought-chain.cjs +61 -1
  190. package/dist/ai-thought-chain/src/ai-thought-chain.css +106 -0
  191. package/dist/ai-thought-chain/src/ai-thought-chain.d.ts +68 -0
  192. package/dist/ai-thought-chain/src/ai-thought-chain.mjs +61 -1
  193. package/dist/ai-thought-chain/src/ai-thought-chain.vue +285 -20
  194. package/dist/ai-thought-chain/src/ai-thought-chain.vue.d.ts +95 -11
  195. package/dist/ai-voice-trigger/index.d.ts +155 -1
  196. package/dist/ai-voice-trigger/src/ai-voice-trigger.vue +2 -2
  197. package/dist/ai-voice-trigger/src/ai-voice-trigger.vue.d.ts +43 -4
  198. package/dist/ai-welcome/index.d.ts +131 -1
  199. package/dist/ai-welcome/src/ai-welcome.vue.d.ts +32 -3
  200. package/dist/alert/index.d.ts +289 -1
  201. package/dist/alert/src/alert.vue.d.ts +81 -10
  202. package/dist/autocomplete/index.d.ts +134 -1
  203. package/dist/autocomplete/src/autocomplete.vue.d.ts +15 -12
  204. package/dist/avatar/index.d.ts +9 -6
  205. package/dist/avatar/src/avatar.d.ts +4 -0
  206. package/dist/avatar/src/avatar.vue +2 -0
  207. package/dist/avatar/src/avatar.vue.d.ts +2 -1
  208. package/dist/back-top/index.d.ts +153 -1
  209. package/dist/back-top/src/back-top.vue.d.ts +42 -5
  210. package/dist/badge/index.d.ts +40 -1
  211. package/dist/badge/src/badge.vue.d.ts +1 -1
  212. package/dist/breadcrumb/index.d.ts +177 -2
  213. package/dist/breadcrumb/src/breadcrumb-item.vue.d.ts +1 -1
  214. package/dist/button/index.d.ts +33 -33
  215. package/dist/button/src/button.css +11 -6
  216. package/dist/button/src/button.vue +11 -6
  217. package/dist/button/src/button.vue.d.ts +6 -6
  218. package/dist/calendar/index.d.ts +1653 -1
  219. package/dist/calendar/src/calendar.vue +12 -11
  220. package/dist/calendar/src/calendar.vue.d.ts +241 -121
  221. package/dist/card/index.d.ts +44 -1
  222. package/dist/card/src/card.vue.d.ts +2 -2
  223. package/dist/carousel/__tests__/carousel.ssr.test.cjs +27 -0
  224. package/dist/carousel/__tests__/carousel.ssr.test.mjs +27 -0
  225. package/dist/carousel/__tests__/carousel.test.cjs +115 -0
  226. package/dist/carousel/__tests__/carousel.test.mjs +98 -0
  227. package/dist/carousel/index.cjs +43 -0
  228. package/dist/carousel/index.d.ts +456 -0
  229. package/dist/carousel/index.mjs +10 -0
  230. package/dist/carousel/src/carousel-item.cjs +10 -0
  231. package/dist/carousel/src/carousel-item.d.ts +9 -0
  232. package/dist/carousel/src/carousel-item.mjs +4 -0
  233. package/dist/carousel/src/carousel-item.vue +277 -0
  234. package/dist/{menu/src/menu-item-group.d.vue.ts → carousel/src/carousel-item.vue.d.ts} +4 -12
  235. package/dist/carousel/src/carousel.cjs +118 -0
  236. package/dist/carousel/src/carousel.css +705 -0
  237. package/dist/carousel/src/carousel.d.ts +137 -0
  238. package/dist/carousel/src/carousel.mjs +112 -0
  239. package/dist/carousel/src/carousel.vue +1070 -0
  240. package/dist/carousel/src/carousel.vue.d.ts +235 -0
  241. package/dist/cascader/index.d.ts +211 -2
  242. package/dist/cascader/src/cascader-panel.vue.d.ts +3 -3
  243. package/dist/cascader/src/cascader.vue.d.ts +14 -14
  244. package/dist/category-nav/__tests__/category-nav.ssr.test.cjs +35 -0
  245. package/dist/category-nav/__tests__/category-nav.ssr.test.mjs +21 -0
  246. package/dist/category-nav/__tests__/category-nav.test.cjs +53 -0
  247. package/dist/category-nav/__tests__/category-nav.test.mjs +33 -0
  248. package/dist/category-nav/index.cjs +26 -0
  249. package/dist/category-nav/index.d.ts +225 -0
  250. package/dist/category-nav/index.mjs +5 -0
  251. package/dist/category-nav/src/category-nav.cjs +66 -0
  252. package/dist/category-nav/src/category-nav.css +663 -0
  253. package/dist/category-nav/src/category-nav.d.ts +86 -0
  254. package/dist/category-nav/src/category-nav.mjs +60 -0
  255. package/dist/category-nav/src/category-nav.vue +966 -0
  256. package/dist/category-nav/src/category-nav.vue.d.ts +137 -0
  257. package/dist/checkbox/index.d.ts +44 -44
  258. package/dist/checkbox/src/checkbox-group.vue.d.ts +1 -1
  259. package/dist/checkbox/src/checkbox.vue.d.ts +2 -2
  260. package/dist/col/index.d.ts +338 -1
  261. package/dist/col/src/col.vue.d.ts +4 -4
  262. package/dist/color-picker/index.d.ts +84 -1
  263. package/dist/color-picker/src/color-picker.vue.d.ts +45 -4
  264. package/dist/component.d.ts +56 -1
  265. package/dist/config-provider/index.d.ts +2 -2
  266. package/dist/config-provider/src/config-provider.d.ts +2 -2
  267. package/dist/container/index.d.ts +103 -5
  268. package/dist/countdown/index.d.ts +419 -1
  269. package/dist/countdown/src/countdown.vue.d.ts +121 -16
  270. package/dist/coupon-card/__tests__/coupon-card.ssr.test.cjs +21 -0
  271. package/dist/coupon-card/__tests__/coupon-card.ssr.test.mjs +18 -0
  272. package/dist/coupon-card/__tests__/coupon-card.test.cjs +67 -0
  273. package/dist/coupon-card/__tests__/coupon-card.test.mjs +64 -0
  274. package/dist/coupon-card/index.cjs +26 -0
  275. package/dist/coupon-card/index.d.ts +346 -0
  276. package/dist/coupon-card/index.mjs +5 -0
  277. package/dist/coupon-card/src/coupon-card.cjs +108 -0
  278. package/dist/coupon-card/src/coupon-card.css +786 -0
  279. package/dist/coupon-card/src/coupon-card.d.ts +106 -0
  280. package/dist/coupon-card/src/coupon-card.mjs +102 -0
  281. package/dist/coupon-card/src/coupon-card.vue +963 -0
  282. package/dist/coupon-card/src/coupon-card.vue.d.ts +206 -0
  283. package/dist/date-picker/index.d.ts +606 -1
  284. package/dist/date-picker/src/date-picker.vue +3 -1
  285. package/dist/date-picker/src/date-picker.vue.d.ts +29 -27
  286. package/dist/date-picker/src/date-table.vue.d.ts +2 -1
  287. package/dist/descriptions/index.d.ts +492 -2
  288. package/dist/descriptions/src/description-item.vue.d.ts +5 -5
  289. package/dist/descriptions/src/descriptions.vue.d.ts +4 -4
  290. package/dist/dialog/index.d.ts +665 -2
  291. package/dist/dialog/src/dialog.vue +3 -2
  292. package/dist/dialog/src/dialog.vue.d.ts +200 -22
  293. package/dist/divider/index.d.ts +113 -1
  294. package/dist/divider/src/divider.vue.d.ts +3 -3
  295. package/dist/drawer/index.d.ts +391 -13
  296. package/dist/drawer/src/drawer.vue.d.ts +120 -10
  297. package/dist/dropdown/index.d.ts +627 -3
  298. package/dist/dropdown/src/dropdown-item.vue.d.ts +2 -2
  299. package/dist/dropdown/src/dropdown.vue.d.ts +135 -18
  300. package/dist/empty/index.d.ts +27 -1
  301. package/dist/env.d.ts +6 -0
  302. package/dist/filter-bar/__tests__/filter-bar.ssr.test.cjs +29 -0
  303. package/dist/filter-bar/__tests__/filter-bar.ssr.test.mjs +16 -0
  304. package/dist/filter-bar/__tests__/filter-bar.test.cjs +51 -0
  305. package/dist/filter-bar/__tests__/filter-bar.test.mjs +29 -0
  306. package/dist/filter-bar/index.cjs +26 -0
  307. package/dist/filter-bar/index.d.ts +287 -0
  308. package/dist/filter-bar/index.mjs +5 -0
  309. package/dist/filter-bar/src/filter-bar.cjs +90 -0
  310. package/dist/filter-bar/src/filter-bar.css +761 -0
  311. package/dist/filter-bar/src/filter-bar.d.ts +124 -0
  312. package/dist/filter-bar/src/filter-bar.mjs +81 -0
  313. package/dist/filter-bar/src/filter-bar.vue +1087 -0
  314. package/dist/filter-bar/src/filter-bar.vue.d.ts +170 -0
  315. package/dist/form/index.d.ts +690 -3
  316. package/dist/form/src/form-item.vue.d.ts +7 -7
  317. package/dist/form/src/form-schema.vue.d.ts +32 -26
  318. package/dist/form/src/form.vue.d.ts +3 -3
  319. package/dist/gantt-chart/__tests__/debug_ssr.test.cjs +51 -0
  320. package/dist/gantt-chart/__tests__/debug_ssr.test.mjs +37 -0
  321. package/dist/gantt-chart/__tests__/gantt-chart.ssr.test.cjs +95 -0
  322. package/dist/gantt-chart/__tests__/gantt-chart.ssr.test.mjs +94 -0
  323. package/dist/gantt-chart/__tests__/gantt-chart.test.cjs +86 -0
  324. package/dist/gantt-chart/__tests__/gantt-chart.test.mjs +79 -0
  325. package/dist/gantt-chart/index.cjs +26 -0
  326. package/dist/gantt-chart/index.d.ts +115 -0
  327. package/dist/gantt-chart/index.mjs +5 -0
  328. package/dist/gantt-chart/src/gantt-chart.cjs +1 -0
  329. package/dist/gantt-chart/src/gantt-chart.css +853 -0
  330. package/dist/gantt-chart/src/gantt-chart.d.ts +112 -0
  331. package/dist/gantt-chart/src/gantt-chart.mjs +0 -0
  332. package/dist/gantt-chart/src/gantt-chart.vue +1583 -0
  333. package/dist/gantt-chart/src/gantt-chart.vue.d.ts +51 -0
  334. package/dist/grid/index.d.ts +67 -2
  335. package/dist/grid/src/grid-item.vue.d.ts +1 -1
  336. package/dist/grid/src/grid.vue.d.ts +1 -1
  337. package/dist/icon/index.d.ts +15 -15
  338. package/dist/icon/src/icon.vue.d.ts +5 -5
  339. package/dist/icon/src/icons/index.cjs +39 -2
  340. package/dist/icon/src/icons/index.d.ts +7 -0
  341. package/dist/icon/src/icons/index.mjs +44 -1
  342. package/dist/image/index.d.ts +72 -21
  343. package/dist/image/src/image-viewer.vue.d.ts +55 -4
  344. package/dist/image/src/image.vue.d.ts +5 -5
  345. package/dist/image-magnifier/__tests__/image-magnifier.ssr.test.cjs +54 -0
  346. package/dist/image-magnifier/__tests__/image-magnifier.ssr.test.mjs +35 -0
  347. package/dist/image-magnifier/__tests__/image-magnifier.test.cjs +257 -0
  348. package/dist/image-magnifier/__tests__/image-magnifier.test.mjs +177 -0
  349. package/dist/image-magnifier/index.cjs +26 -0
  350. package/dist/image-magnifier/index.d.ts +468 -0
  351. package/dist/image-magnifier/index.mjs +5 -0
  352. package/dist/image-magnifier/src/image-magnifier.cjs +142 -0
  353. package/dist/image-magnifier/src/image-magnifier.css +754 -0
  354. package/dist/image-magnifier/src/image-magnifier.d.ts +146 -0
  355. package/dist/image-magnifier/src/image-magnifier.mjs +136 -0
  356. package/dist/image-magnifier/src/image-magnifier.vue +1134 -0
  357. package/dist/image-magnifier/src/image-magnifier.vue.d.ts +271 -0
  358. package/dist/index.cjs +229 -1
  359. package/dist/index.d.ts +19 -0
  360. package/dist/index.mjs +59 -1
  361. package/dist/infinite-scroll/index.d.ts +270 -1
  362. package/dist/infinite-scroll/src/infinite-scroll.vue.d.ts +71 -6
  363. package/dist/input/index.d.ts +51 -51
  364. package/dist/input/src/input.vue.d.ts +16 -16
  365. package/dist/input-number/index.d.ts +33 -33
  366. package/dist/input-number/src/input-number.vue.d.ts +9 -9
  367. package/dist/input-tag/index.d.ts +151 -1
  368. package/dist/input-tag/src/input-tag.vue.d.ts +22 -22
  369. package/dist/loading/index.d.ts +1 -1
  370. package/dist/lucky-draw/__tests__/lucky-draw.ssr.test.cjs +33 -0
  371. package/dist/lucky-draw/__tests__/lucky-draw.ssr.test.mjs +31 -0
  372. package/dist/lucky-draw/__tests__/lucky-draw.test.cjs +56 -0
  373. package/dist/lucky-draw/__tests__/lucky-draw.test.mjs +48 -0
  374. package/dist/lucky-draw/index.cjs +26 -0
  375. package/dist/lucky-draw/index.d.ts +209 -0
  376. package/dist/lucky-draw/index.mjs +5 -0
  377. package/dist/lucky-draw/src/lucky-draw.cjs +63 -0
  378. package/dist/lucky-draw/src/lucky-draw.css +683 -0
  379. package/dist/lucky-draw/src/lucky-draw.d.ts +69 -0
  380. package/dist/lucky-draw/src/lucky-draw.mjs +57 -0
  381. package/dist/lucky-draw/src/lucky-draw.vue +865 -0
  382. package/dist/lucky-draw/src/lucky-draw.vue.d.ts +123 -0
  383. package/dist/marquee/index.d.ts +305 -1
  384. package/dist/marquee/src/marquee.vue.d.ts +80 -6
  385. package/dist/mention/index.d.ts +75 -75
  386. package/dist/mention/src/mention.vue.d.ts +26 -26
  387. package/dist/menu/index.d.ts +890 -4
  388. package/dist/menu/src/menu-item.vue.d.ts +1 -1
  389. package/dist/menu/src/menu-recursive-item.vue +30 -11
  390. package/dist/menu/src/menu.cjs +1 -1
  391. package/dist/menu/src/menu.d.ts +3 -3
  392. package/dist/menu/src/menu.mjs +1 -1
  393. package/dist/menu/src/menu.vue +1 -1
  394. package/dist/menu/src/menu.vue.d.ts +179 -16
  395. package/dist/menu/src/sub-menu.vue +10 -3
  396. package/dist/menu/src/sub-menu.vue.d.ts +1 -1
  397. package/dist/message/index.d.ts +1 -1
  398. package/dist/message/src/message.vue.d.ts +2 -2
  399. package/dist/message-box/index.cjs +1 -1
  400. package/dist/message-box/index.d.ts +1 -1
  401. package/dist/message-box/index.mjs +1 -1
  402. package/dist/notification/index.d.ts +1 -1
  403. package/dist/notification/src/notification.vue.d.ts +2 -2
  404. package/dist/pagination/index.d.ts +15 -15
  405. package/dist/pagination/src/pagination.vue.d.ts +5 -5
  406. package/dist/popconfirm/index.d.ts +433 -1
  407. package/dist/popconfirm/src/popconfirm.cjs +1 -1
  408. package/dist/popconfirm/src/popconfirm.d.ts +2 -2
  409. package/dist/popconfirm/src/popconfirm.mjs +1 -1
  410. package/dist/popconfirm/src/popconfirm.vue.d.ts +125 -16
  411. package/dist/popover/index.d.ts +392 -1
  412. package/dist/popover/src/popover.cjs +1 -1
  413. package/dist/popover/src/popover.d.ts +2 -2
  414. package/dist/popover/src/popover.mjs +1 -1
  415. package/dist/popover/src/popover.vue.d.ts +113 -16
  416. package/dist/price/__tests__/price.ssr.test.cjs +20 -0
  417. package/dist/price/__tests__/price.ssr.test.mjs +19 -0
  418. package/dist/price/__tests__/price.test.cjs +45 -0
  419. package/dist/price/__tests__/price.test.mjs +42 -0
  420. package/dist/price/index.cjs +26 -0
  421. package/dist/price/index.d.ts +369 -0
  422. package/dist/price/index.mjs +5 -0
  423. package/dist/price/src/price.cjs +118 -0
  424. package/dist/price/src/price.css +601 -0
  425. package/dist/price/src/price.d.ts +114 -0
  426. package/dist/price/src/price.mjs +112 -0
  427. package/dist/price/src/price.vue +749 -0
  428. package/dist/price/src/price.vue.d.ts +223 -0
  429. package/dist/product-card/__tests__/product-card.ssr.test.cjs +21 -0
  430. package/dist/product-card/__tests__/product-card.ssr.test.mjs +18 -0
  431. package/dist/product-card/__tests__/product-card.test.cjs +54 -0
  432. package/dist/product-card/__tests__/product-card.test.mjs +53 -0
  433. package/dist/product-card/index.cjs +26 -0
  434. package/dist/product-card/index.d.ts +563 -0
  435. package/dist/product-card/index.mjs +5 -0
  436. package/dist/product-card/src/product-card.cjs +184 -0
  437. package/dist/product-card/src/product-card.css +856 -0
  438. package/dist/product-card/src/product-card.d.ts +188 -0
  439. package/dist/product-card/src/product-card.mjs +178 -0
  440. package/dist/product-card/src/product-card.vue +1097 -0
  441. package/dist/product-card/src/product-card.vue.d.ts +333 -0
  442. package/dist/progress/index.d.ts +321 -1
  443. package/dist/progress/src/progress.vue.d.ts +9 -9
  444. package/dist/radio/index.d.ts +147 -3
  445. package/dist/radio/src/radio-button.vue +19 -5
  446. package/dist/radio/src/radio-group.vue.d.ts +1 -1
  447. package/dist/rate/index.d.ts +313 -1
  448. package/dist/rate/src/rate.vue.d.ts +90 -11
  449. package/dist/result/index.d.ts +31 -1
  450. package/dist/row/index.d.ts +98 -1
  451. package/dist/row/src/row.d.ts +2 -2
  452. package/dist/row/src/row.vue.d.ts +2 -2
  453. package/dist/scrollbar/__tests__/scrollbar.ssr.test.cjs +49 -0
  454. package/dist/scrollbar/__tests__/scrollbar.ssr.test.mjs +54 -0
  455. package/dist/scrollbar/__tests__/scrollbar.test.cjs +43 -0
  456. package/dist/scrollbar/__tests__/scrollbar.test.mjs +40 -0
  457. package/dist/scrollbar/index.cjs +26 -0
  458. package/dist/scrollbar/index.d.ts +213 -0
  459. package/dist/scrollbar/index.mjs +5 -0
  460. package/dist/scrollbar/src/scrollbar.cjs +82 -0
  461. package/dist/scrollbar/src/scrollbar.css +521 -0
  462. package/dist/scrollbar/src/scrollbar.d.ts +82 -0
  463. package/dist/scrollbar/src/scrollbar.mjs +73 -0
  464. package/dist/scrollbar/src/scrollbar.vue +680 -0
  465. package/dist/scrollbar/src/scrollbar.vue.d.ts +115 -0
  466. package/dist/scrollbar/src/thumb.vue +112 -0
  467. package/dist/scrollbar/src/thumb.vue.d.ts +16 -0
  468. package/dist/scrollbar/src/util.cjs +42 -0
  469. package/dist/scrollbar/src/util.d.ts +27 -0
  470. package/dist/scrollbar/src/util.mjs +35 -0
  471. package/dist/select/index.d.ts +177 -2
  472. package/dist/select/src/select.vue.d.ts +18 -18
  473. package/dist/skeleton/index.d.ts +278 -2
  474. package/dist/skeleton/src/skeleton-item.vue +12 -1
  475. package/dist/skeleton/src/skeleton-item.vue.d.ts +2 -2
  476. package/dist/skeleton/src/skeleton.css +12 -1
  477. package/dist/skeleton/src/skeleton.vue +12 -1
  478. package/dist/skeleton/src/skeleton.vue.d.ts +1 -1
  479. package/dist/sku-selector/__tests__/sku-selector.ssr.test.cjs +32 -0
  480. package/dist/sku-selector/__tests__/sku-selector.ssr.test.mjs +19 -0
  481. package/dist/sku-selector/__tests__/sku-selector.test.cjs +64 -0
  482. package/dist/sku-selector/__tests__/sku-selector.test.mjs +53 -0
  483. package/dist/sku-selector/index.cjs +26 -0
  484. package/dist/sku-selector/index.d.ts +228 -0
  485. package/dist/sku-selector/index.mjs +5 -0
  486. package/dist/sku-selector/src/sku-selector.cjs +70 -0
  487. package/dist/sku-selector/src/sku-selector.css +664 -0
  488. package/dist/sku-selector/src/sku-selector.d.ts +96 -0
  489. package/dist/sku-selector/src/sku-selector.mjs +64 -0
  490. package/dist/sku-selector/src/sku-selector.vue +779 -0
  491. package/dist/sku-selector/src/sku-selector.vue.d.ts +137 -0
  492. package/dist/slider/index.d.ts +463 -1
  493. package/dist/slider/src/slider-button.vue.d.ts +4 -4
  494. package/dist/slider/src/slider.vue.d.ts +133 -13
  495. package/dist/smart-address/__tests__/smart-address.ssr.test.cjs +28 -0
  496. package/dist/smart-address/__tests__/smart-address.ssr.test.mjs +25 -0
  497. package/dist/smart-address/__tests__/smart-address.test.cjs +68 -0
  498. package/dist/smart-address/__tests__/smart-address.test.mjs +56 -0
  499. package/dist/smart-address/index.cjs +38 -0
  500. package/dist/smart-address/index.d.ts +331 -0
  501. package/dist/smart-address/index.mjs +6 -0
  502. package/dist/smart-address/src/smart-address.cjs +108 -0
  503. package/dist/smart-address/src/smart-address.css +616 -0
  504. package/dist/smart-address/src/smart-address.d.ts +114 -0
  505. package/dist/smart-address/src/smart-address.mjs +102 -0
  506. package/dist/smart-address/src/smart-address.vue +966 -0
  507. package/dist/smart-address/src/smart-address.vue.d.ts +204 -0
  508. package/dist/smart-address/src/use-address-parser.cjs +137 -0
  509. package/dist/smart-address/src/use-address-parser.d.ts +28 -0
  510. package/dist/smart-address/src/use-address-parser.mjs +132 -0
  511. package/dist/space/index.d.ts +40 -1
  512. package/dist/space/src/space.vue.d.ts +2 -2
  513. package/dist/spin/index.d.ts +162 -7
  514. package/dist/spin/src/spin.vue.d.ts +48 -5
  515. package/dist/steps/index.d.ts +606 -2
  516. package/dist/steps/src/step.vue.d.ts +4 -4
  517. package/dist/steps/src/steps.vue.d.ts +77 -8
  518. package/dist/submit-bar/__tests__/submit-bar.ssr.test.cjs +21 -0
  519. package/dist/submit-bar/__tests__/submit-bar.ssr.test.mjs +18 -0
  520. package/dist/submit-bar/__tests__/submit-bar.test.cjs +50 -0
  521. package/dist/submit-bar/__tests__/submit-bar.test.mjs +36 -0
  522. package/dist/submit-bar/index.cjs +26 -0
  523. package/dist/submit-bar/index.d.ts +297 -0
  524. package/dist/submit-bar/index.mjs +5 -0
  525. package/dist/submit-bar/src/submit-bar.cjs +94 -0
  526. package/dist/submit-bar/src/submit-bar.css +639 -0
  527. package/dist/submit-bar/src/submit-bar.d.ts +93 -0
  528. package/dist/submit-bar/src/submit-bar.mjs +88 -0
  529. package/dist/submit-bar/src/submit-bar.vue +749 -0
  530. package/dist/submit-bar/src/submit-bar.vue.d.ts +175 -0
  531. package/dist/switch/index.d.ts +372 -1
  532. package/dist/switch/src/switch.vue.d.ts +98 -7
  533. package/dist/table/index.d.ts +1248 -2
  534. package/dist/table/src/table-column.vue +7 -3
  535. package/dist/table/src/table-column.vue.d.ts +10 -20
  536. package/dist/table/src/table.d.ts +3 -3
  537. package/dist/table/src/table.vue +28 -9
  538. package/dist/table/src/table.vue.d.ts +346 -34
  539. package/dist/table/src/use-table-import.cjs +1 -1
  540. package/dist/table/src/use-table-import.mjs +1 -1
  541. package/dist/tabs/index.d.ts +583 -2
  542. package/dist/tabs/src/tab-pane.vue.d.ts +2 -2
  543. package/dist/tabs/src/tabs.vue.d.ts +98 -8
  544. package/dist/tag/index.d.ts +86 -1
  545. package/dist/tag/src/tag.vue.d.ts +8 -8
  546. package/dist/time-picker/index.d.ts +166 -1
  547. package/dist/time-picker/src/time-picker.vue.d.ts +19 -19
  548. package/dist/time-select/index.d.ts +112 -1
  549. package/dist/time-select/src/time-select.vue.d.ts +12 -12
  550. package/dist/tooltip/index.d.ts +467 -19
  551. package/dist/tooltip/src/tooltip.cjs +4 -4
  552. package/dist/tooltip/src/tooltip.d.ts +5 -5
  553. package/dist/tooltip/src/tooltip.mjs +4 -4
  554. package/dist/tooltip/src/tooltip.vue +2 -1
  555. package/dist/tooltip/src/tooltip.vue.d.ts +146 -21
  556. package/dist/transfer/src/transfer-panel.vue.d.ts +6 -6
  557. package/dist/transfer/src/transfer.vue.d.ts +10 -10
  558. package/dist/tree/index.d.ts +623 -2
  559. package/dist/tree/src/tree.vue.d.ts +176 -28
  560. package/dist/tree-select/index.d.ts +435 -1
  561. package/dist/tree-select/src/tree-select.vue.d.ts +128 -18
  562. package/dist/typography/index.d.ts +180 -4
  563. package/dist/typography/src/link.vue.d.ts +1 -1
  564. package/dist/typography/src/paragraph.vue.d.ts +2 -2
  565. package/dist/typography/src/text.vue.d.ts +4 -4
  566. package/dist/typography/src/title.vue.d.ts +3 -3
  567. package/dist/upload/index.d.ts +391 -1
  568. package/dist/upload/src/upload.css +0 -441
  569. package/dist/upload/src/upload.vue +1 -441
  570. package/dist/upload/src/upload.vue.d.ts +108 -11
  571. package/dist/waterfall/index.d.ts +57 -1
  572. package/dist/waterfall/src/waterfall.vue.d.ts +3 -3
  573. package/dist/watermark/index.d.ts +284 -1
  574. package/dist/watermark/src/watermark.vue.d.ts +6 -6
  575. package/package.json +26 -11
  576. package/dist/__tests__/resolver.test.cjs +0 -56
  577. package/dist/__tests__/resolver.test.d.ts +0 -1
  578. package/dist/__tests__/resolver.test.mjs +0 -52
  579. package/dist/__tests__/utils/ssr.cjs +0 -114
  580. package/dist/__tests__/utils/ssr.d.ts +0 -29
  581. package/dist/__tests__/utils/ssr.mjs +0 -119
  582. package/dist/affix/__tests__/affix.bottom.test.d.ts +0 -1
  583. package/dist/affix/__tests__/affix.ssr.test.d.ts +0 -1
  584. package/dist/affix/__tests__/affix.test.d.ts +0 -1
  585. package/dist/affix/src/affix.d.vue.ts +0 -66
  586. package/dist/ai-action-group/__tests__/ai-action-group.ssr.test.d.ts +0 -1
  587. package/dist/ai-action-group/__tests__/ai-action-group.test.d.ts +0 -1
  588. package/dist/ai-action-group/src/ai-action-group.d.vue.ts +0 -40
  589. package/dist/ai-agent-card/__tests__/ai-agent-card.ssr.test.d.ts +0 -1
  590. package/dist/ai-agent-card/__tests__/ai-agent-card.test.d.ts +0 -1
  591. package/dist/ai-agent-card/src/ai-agent-card.d.vue.ts +0 -62
  592. package/dist/ai-artifacts/__tests__/ai-artifacts.ssr.test.d.ts +0 -1
  593. package/dist/ai-artifacts/__tests__/ai-artifacts.test.d.ts +0 -1
  594. package/dist/ai-artifacts/src/ai-artifacts.d.vue.ts +0 -50
  595. package/dist/ai-bubble/__tests__/ai-bubble.ssr.test.d.ts +0 -1
  596. package/dist/ai-bubble/__tests__/ai-bubble.test.d.ts +0 -1
  597. package/dist/ai-bubble/src/ai-bubble.d.vue.ts +0 -110
  598. package/dist/ai-chat/__tests__/ai-chat.ssr.test.d.ts +0 -1
  599. package/dist/ai-chat/__tests__/ai-chat.test.d.ts +0 -1
  600. package/dist/ai-chat/src/ai-chat.d.vue.ts +0 -43
  601. package/dist/ai-code-block/__tests__/ai-code-block.ssr.test.d.ts +0 -1
  602. package/dist/ai-code-block/__tests__/ai-code-block.test.d.ts +0 -1
  603. package/dist/ai-code-block/src/ai-code-block.d.vue.ts +0 -63
  604. package/dist/ai-conversations/__tests__/ai-conversations.ssr.test.d.ts +0 -1
  605. package/dist/ai-conversations/__tests__/ai-conversations.test.d.ts +0 -1
  606. package/dist/ai-conversations/src/ai-conversations.d.vue.ts +0 -52
  607. package/dist/ai-editor-sender/__tests__/ai-editor-sender.ssr.test.d.ts +0 -1
  608. package/dist/ai-editor-sender/__tests__/ai-editor-sender.test.d.ts +0 -1
  609. package/dist/ai-editor-sender/src/ai-editor-sender.d.vue.ts +0 -70
  610. package/dist/ai-mention/__tests__/ai-mention.ssr.test.d.ts +0 -1
  611. package/dist/ai-mention/__tests__/ai-mention.test.d.ts +0 -1
  612. package/dist/ai-mention/src/ai-mention.d.vue.ts +0 -68
  613. package/dist/ai-prompts/__tests__/ai-prompts.ssr.test.d.ts +0 -1
  614. package/dist/ai-prompts/__tests__/ai-prompts.test.d.ts +0 -1
  615. package/dist/ai-prompts/src/ai-prompts.d.vue.ts +0 -44
  616. package/dist/ai-provider/__tests__/ai-provider.ssr.test.d.ts +0 -1
  617. package/dist/ai-provider/__tests__/ai-provider.test.d.ts +0 -1
  618. package/dist/ai-provider/src/ai-provider.d.vue.ts +0 -48
  619. package/dist/ai-sender/__tests__/ai-sender.ssr.test.d.ts +0 -1
  620. package/dist/ai-sender/__tests__/ai-sender.test.d.ts +0 -1
  621. package/dist/ai-sender/src/ai-sender.d.vue.ts +0 -74
  622. package/dist/ai-sources/__tests__/ai-sources.ssr.test.d.ts +0 -1
  623. package/dist/ai-sources/__tests__/ai-sources.test.d.ts +0 -1
  624. package/dist/ai-sources/src/ai-sources.d.vue.ts +0 -45
  625. package/dist/ai-thinking/__tests__/ai-thinking.ssr.test.d.ts +0 -1
  626. package/dist/ai-thinking/__tests__/ai-thinking.test.d.ts +0 -1
  627. package/dist/ai-thinking/src/ai-thinking.d.vue.ts +0 -33
  628. package/dist/ai-thought-chain/__tests__/ai-thought-chain.ssr.test.d.ts +0 -1
  629. package/dist/ai-thought-chain/__tests__/ai-thought-chain.test.d.ts +0 -1
  630. package/dist/ai-thought-chain/src/ai-thought-chain.d.vue.ts +0 -83
  631. package/dist/ai-voice-trigger/__tests__/ai-voice-trigger.ssr.test.d.ts +0 -1
  632. package/dist/ai-voice-trigger/__tests__/ai-voice-trigger.test.d.ts +0 -1
  633. package/dist/ai-voice-trigger/src/ai-voice-trigger.d.vue.ts +0 -49
  634. package/dist/ai-welcome/__tests__/ai-welcome.ssr.test.d.ts +0 -1
  635. package/dist/ai-welcome/__tests__/ai-welcome.test.d.ts +0 -1
  636. package/dist/ai-welcome/src/ai-welcome.d.vue.ts +0 -51
  637. package/dist/alert/__tests__/alert.ssr.test.d.ts +0 -1
  638. package/dist/alert/__tests__/alert.test.d.ts +0 -1
  639. package/dist/alert/src/alert.d.vue.ts +0 -106
  640. package/dist/autocomplete/__tests__/autocomplete.ssr.test.d.ts +0 -1
  641. package/dist/autocomplete/__tests__/autocomplete.test.d.ts +0 -1
  642. package/dist/autocomplete/src/autocomplete.d.vue.ts +0 -63
  643. package/dist/avatar/__tests__/avatar.ssr.test.d.ts +0 -1
  644. package/dist/avatar/__tests__/avatar.test.d.ts +0 -1
  645. package/dist/avatar/src/avatar.d.vue.ts +0 -21
  646. package/dist/back-top/__tests__/back-top.ssr.test.d.ts +0 -1
  647. package/dist/back-top/__tests__/back-top.test.d.ts +0 -1
  648. package/dist/back-top/src/back-top.d.vue.ts +0 -54
  649. package/dist/badge/__tests__/badge.ssr.test.d.ts +0 -1
  650. package/dist/badge/__tests__/badge.test.d.ts +0 -1
  651. package/dist/badge/src/badge.d.vue.ts +0 -22
  652. package/dist/breadcrumb/__tests__/breadcrumb.ssr.test.d.ts +0 -1
  653. package/dist/breadcrumb/__tests__/breadcrumb.test.d.ts +0 -1
  654. package/dist/breadcrumb/src/breadcrumb-item.d.vue.ts +0 -42
  655. package/dist/breadcrumb/src/breadcrumb.d.vue.ts +0 -41
  656. package/dist/button/__tests__/button.ssr.test.d.ts +0 -1
  657. package/dist/button/__tests__/button.test.d.ts +0 -1
  658. package/dist/button/src/button.d.vue.ts +0 -44
  659. package/dist/calendar/__tests__/calendar.ssr.test.d.ts +0 -1
  660. package/dist/calendar/__tests__/calendar.test.d.ts +0 -1
  661. package/dist/calendar/src/calendar.d.vue.ts +0 -551
  662. package/dist/card/__tests__/card.ssr.test.d.ts +0 -1
  663. package/dist/card/__tests__/card.test.d.ts +0 -1
  664. package/dist/card/src/card.d.vue.ts +0 -26
  665. package/dist/cascader/__tests__/cascader-panel.test.d.ts +0 -1
  666. package/dist/cascader/__tests__/cascader.ssr.test.d.ts +0 -1
  667. package/dist/cascader/__tests__/cascader.test.d.ts +0 -1
  668. package/dist/cascader/src/cascader-panel.d.vue.ts +0 -39
  669. package/dist/cascader/src/cascader.d.vue.ts +0 -63
  670. package/dist/checkbox/__tests__/checkbox.ssr.test.d.ts +0 -1
  671. package/dist/checkbox/__tests__/checkbox.test.d.ts +0 -1
  672. package/dist/checkbox/src/checkbox-group.d.vue.ts +0 -24
  673. package/dist/checkbox/src/checkbox.d.vue.ts +0 -32
  674. package/dist/col/__tests__/col.ssr.test.d.ts +0 -1
  675. package/dist/col/__tests__/col.test.d.ts +0 -1
  676. package/dist/col/src/col.d.vue.ts +0 -189
  677. package/dist/color-picker/__tests__/color-picker.ssr.test.d.ts +0 -1
  678. package/dist/color-picker/__tests__/color-picker.test.d.ts +0 -1
  679. package/dist/color-picker/src/alpha-slider.d.vue.ts +0 -10
  680. package/dist/color-picker/src/color-picker.d.vue.ts +0 -55
  681. package/dist/color-picker/src/hue-slider.d.vue.ts +0 -9
  682. package/dist/color-picker/src/sv-panel.d.vue.ts +0 -11
  683. package/dist/config-provider/__tests__/config-provider.ssr.test.d.ts +0 -1
  684. package/dist/config-provider/__tests__/config-provider.test.d.ts +0 -1
  685. package/dist/container/__tests__/container.ssr.test.d.ts +0 -1
  686. package/dist/container/__tests__/container.test.d.ts +0 -1
  687. package/dist/container/src/aside.d.vue.ts +0 -15
  688. package/dist/container/src/container.d.vue.ts +0 -13
  689. package/dist/container/src/footer.d.vue.ts +0 -15
  690. package/dist/container/src/header.d.vue.ts +0 -15
  691. package/dist/container/src/main.d.vue.ts +0 -13
  692. package/dist/countdown/__tests__/countdown.ssr.test.d.ts +0 -1
  693. package/dist/countdown/__tests__/countdown.test.d.ts +0 -1
  694. package/dist/countdown/src/countdown.d.vue.ts +0 -146
  695. package/dist/date-picker/__tests__/date-picker-extended.test.d.ts +0 -1
  696. package/dist/date-picker/__tests__/date-picker.ssr.test.d.ts +0 -1
  697. package/dist/date-picker/__tests__/date-picker.test.d.ts +0 -1
  698. package/dist/date-picker/src/date-picker.d.vue.ts +0 -372
  699. package/dist/date-picker/src/date-table.d.vue.ts +0 -37
  700. package/dist/date-picker/src/month-table.d.vue.ts +0 -19
  701. package/dist/date-picker/src/quarter-table.d.vue.ts +0 -19
  702. package/dist/date-picker/src/year-table.d.vue.ts +0 -19
  703. package/dist/descriptions/__tests__/descriptions.ssr.test.d.ts +0 -1
  704. package/dist/descriptions/__tests__/descriptions.test.d.ts +0 -1
  705. package/dist/descriptions/src/description-item.d.vue.ts +0 -99
  706. package/dist/descriptions/src/descriptions.d.vue.ts +0 -106
  707. package/dist/dialog/__tests__/dialog.functional.test.d.ts +0 -1
  708. package/dist/dialog/__tests__/dialog.ssr.test.d.ts +0 -1
  709. package/dist/dialog/__tests__/dialog.test.d.ts +0 -1
  710. package/dist/dialog/src/dialog.d.vue.ts +0 -217
  711. package/dist/divider/__tests__/divider.ssr.test.d.ts +0 -1
  712. package/dist/divider/__tests__/divider.test.d.ts +0 -1
  713. package/dist/divider/src/divider.d.vue.ts +0 -69
  714. package/dist/drawer/__tests__/drawer.ssr.test.d.ts +0 -1
  715. package/dist/drawer/__tests__/drawer.test.d.ts +0 -1
  716. package/dist/drawer/src/drawer.d.vue.ts +0 -141
  717. package/dist/dropdown/__tests__/dropdown.ssr.test.d.ts +0 -1
  718. package/dist/dropdown/__tests__/dropdown.test.d.ts +0 -1
  719. package/dist/dropdown/src/dropdown-item.d.vue.ts +0 -78
  720. package/dist/dropdown/src/dropdown-menu.d.vue.ts +0 -24
  721. package/dist/dropdown/src/dropdown.d.vue.ts +0 -158
  722. package/dist/empty/__tests__/empty.ssr.test.d.ts +0 -1
  723. package/dist/empty/__tests__/empty.test.d.ts +0 -1
  724. package/dist/empty/src/empty.d.vue.ts +0 -19
  725. package/dist/form/__tests__/form-schema.test.d.ts +0 -1
  726. package/dist/form/__tests__/form.ssr.test.d.ts +0 -1
  727. package/dist/form/__tests__/form.test.d.ts +0 -1
  728. package/dist/form/src/form-item.d.vue.ts +0 -144
  729. package/dist/form/src/form-schema.d.vue.ts +0 -116
  730. package/dist/form/src/form.d.vue.ts +0 -158
  731. package/dist/grid/__tests__/grid.ssr.test.d.ts +0 -1
  732. package/dist/grid/__tests__/grid.test.d.ts +0 -1
  733. package/dist/grid/src/grid-item.d.vue.ts +0 -17
  734. package/dist/grid/src/grid.d.vue.ts +0 -20
  735. package/dist/icon/__tests__/icon.ssr.test.d.ts +0 -1
  736. package/dist/icon/__tests__/icon.test.d.ts +0 -1
  737. package/dist/icon/src/icon.d.vue.ts +0 -87
  738. package/dist/image/__tests__/image-viewer.test.d.ts +0 -1
  739. package/dist/image/__tests__/image.ssr.test.d.ts +0 -1
  740. package/dist/image/__tests__/image.test.d.ts +0 -1
  741. package/dist/image/src/image-viewer.d.vue.ts +0 -60
  742. package/dist/image/src/image.d.vue.ts +0 -178
  743. package/dist/infinite-scroll/__tests__/infinite-scroll.ssr.test.d.ts +0 -1
  744. package/dist/infinite-scroll/__tests__/infinite-scroll.test.d.ts +0 -1
  745. package/dist/infinite-scroll/src/infinite-scroll.d.vue.ts +0 -95
  746. package/dist/input/__tests__/input-utils.test.d.ts +0 -1
  747. package/dist/input/__tests__/input.ssr.test.d.ts +0 -1
  748. package/dist/input/__tests__/input.test.d.ts +0 -1
  749. package/dist/input/src/input.d.vue.ts +0 -76
  750. package/dist/input-number/__tests__/input-number.hydration.test.d.ts +0 -1
  751. package/dist/input-number/__tests__/input-number.ssr.test.d.ts +0 -1
  752. package/dist/input-number/__tests__/input-number.test.d.ts +0 -1
  753. package/dist/input-number/src/input-number.d.vue.ts +0 -50
  754. package/dist/input-tag/__tests__/input-tag.ssr.test.d.ts +0 -1
  755. package/dist/input-tag/__tests__/input-tag.test.d.ts +0 -1
  756. package/dist/input-tag/src/input-tag.d.vue.ts +0 -71
  757. package/dist/loading/__tests__/loading.ssr.test.d.ts +0 -1
  758. package/dist/loading/__tests__/loading.test.d.ts +0 -1
  759. package/dist/marquee/__tests__/marquee.ssr.test.d.ts +0 -1
  760. package/dist/marquee/__tests__/marquee.test.d.ts +0 -1
  761. package/dist/marquee/src/marquee.d.vue.ts +0 -109
  762. package/dist/mention/__tests__/mention.ssr.test.d.ts +0 -1
  763. package/dist/mention/__tests__/mention.test.d.ts +0 -1
  764. package/dist/mention/src/mention.d.vue.ts +0 -84
  765. package/dist/menu/__tests__/menu.ssr.test.d.ts +0 -1
  766. package/dist/menu/__tests__/menu.test.d.ts +0 -1
  767. package/dist/menu/src/menu-item.d.vue.ts +0 -52
  768. package/dist/menu/src/menu-recursive-item.d.vue.ts +0 -6
  769. package/dist/menu/src/menu.d.vue.ts +0 -209
  770. package/dist/menu/src/sub-menu.d.vue.ts +0 -87
  771. package/dist/message/__tests__/message.ssr.test.d.ts +0 -1
  772. package/dist/message/__tests__/message.test.d.ts +0 -1
  773. package/dist/message/src/message.d.vue.ts +0 -32
  774. package/dist/message-box/__tests__/message-box.ssr.test.d.ts +0 -1
  775. package/dist/message-box/__tests__/message-box.test.d.ts +0 -1
  776. package/dist/message-box/src/message-box.d.vue.ts +0 -17
  777. package/dist/notification/__tests__/notification.ssr.test.d.ts +0 -1
  778. package/dist/notification/__tests__/notification.test.d.ts +0 -1
  779. package/dist/notification/src/notification.d.vue.ts +0 -30
  780. package/dist/pagination/__tests__/pagination.ssr.test.d.ts +0 -1
  781. package/dist/pagination/__tests__/pagination.test.d.ts +0 -1
  782. package/dist/pagination/src/pagination.d.vue.ts +0 -149
  783. package/dist/popconfirm/__tests__/popconfirm.ssr.test.d.ts +0 -1
  784. package/dist/popconfirm/__tests__/popconfirm.test.d.ts +0 -1
  785. package/dist/popconfirm/src/popconfirm.d.vue.ts +0 -148
  786. package/dist/popover/__tests__/popover.ssr.test.d.ts +0 -1
  787. package/dist/popover/__tests__/popover.test.d.ts +0 -1
  788. package/dist/popover/src/popover.d.vue.ts +0 -140
  789. package/dist/progress/__tests__/progress.ssr.test.d.ts +0 -1
  790. package/dist/progress/__tests__/progress.test.d.ts +0 -1
  791. package/dist/progress/src/progress.d.vue.ts +0 -199
  792. package/dist/radio/__tests__/radio-button.test.d.ts +0 -1
  793. package/dist/radio/__tests__/radio.ssr.test.d.ts +0 -1
  794. package/dist/radio/__tests__/radio.test.d.ts +0 -1
  795. package/dist/radio/src/radio-button.d.vue.ts +0 -25
  796. package/dist/radio/src/radio-group.d.vue.ts +0 -23
  797. package/dist/radio/src/radio.d.vue.ts +0 -26
  798. package/dist/rate/__tests__/rate.ssr.test.d.ts +0 -1
  799. package/dist/rate/__tests__/rate.test.d.ts +0 -1
  800. package/dist/rate/src/rate.d.vue.ts +0 -109
  801. package/dist/result/__tests__/result.ssr.test.d.ts +0 -1
  802. package/dist/result/__tests__/result.test.d.ts +0 -1
  803. package/dist/result/src/result.d.vue.ts +0 -23
  804. package/dist/row/__tests__/row.ssr.test.d.ts +0 -1
  805. package/dist/row/__tests__/row.test.d.ts +0 -1
  806. package/dist/row/__tests__/row_ts.test.d.ts +0 -1
  807. package/dist/row/src/row.d.vue.ts +0 -60
  808. package/dist/select/__tests__/select.perf.test.d.ts +0 -1
  809. package/dist/select/__tests__/select.ssr.test.d.ts +0 -1
  810. package/dist/select/__tests__/select.test.d.ts +0 -1
  811. package/dist/select/src/option.d.vue.ts +0 -15
  812. package/dist/select/src/select.d.vue.ts +0 -68
  813. package/dist/skeleton/__tests__/skeleton.ssr.test.d.ts +0 -1
  814. package/dist/skeleton/__tests__/skeleton.test.d.ts +0 -1
  815. package/dist/skeleton/src/skeleton-item.d.vue.ts +0 -83
  816. package/dist/skeleton/src/skeleton.d.vue.ts +0 -89
  817. package/dist/slider/__tests__/repro.test.d.ts +0 -1
  818. package/dist/slider/__tests__/slider.ssr.test.d.ts +0 -1
  819. package/dist/slider/__tests__/slider.test.d.ts +0 -1
  820. package/dist/slider/src/slider-button.d.vue.ts +0 -43
  821. package/dist/slider/src/slider.d.vue.ts +0 -160
  822. package/dist/space/__tests__/space.ssr.test.d.ts +0 -1
  823. package/dist/space/__tests__/space.test.d.ts +0 -1
  824. package/dist/space/src/space.d.vue.ts +0 -22
  825. package/dist/spin/__tests__/spin.ssr.test.d.ts +0 -1
  826. package/dist/spin/__tests__/spin.test.d.ts +0 -1
  827. package/dist/spin/src/spin.d.vue.ts +0 -67
  828. package/dist/steps/__tests__/steps.ssr.test.d.ts +0 -1
  829. package/dist/steps/__tests__/steps.test.d.ts +0 -1
  830. package/dist/steps/src/step.d.vue.ts +0 -105
  831. package/dist/steps/src/steps.d.vue.ts +0 -94
  832. package/dist/switch/__tests__/switch.ssr.test.d.ts +0 -1
  833. package/dist/switch/__tests__/switch.test.d.ts +0 -1
  834. package/dist/switch/src/switch.d.vue.ts +0 -133
  835. package/dist/table/__tests__/table-advance.test.d.ts +0 -1
  836. package/dist/table/__tests__/table-interaction.test.d.ts +0 -1
  837. package/dist/table/__tests__/table-utils.test.d.ts +0 -1
  838. package/dist/table/__tests__/table.perf.test.d.ts +0 -1
  839. package/dist/table/__tests__/table.ssr.test.d.ts +0 -5
  840. package/dist/table/__tests__/table.test.d.ts +0 -1
  841. package/dist/table/__tests__/use-column-drag.test.d.ts +0 -1
  842. package/dist/table/__tests__/use-table-export.test.d.ts +0 -1
  843. package/dist/table/__tests__/use-table-import.test.d.ts +0 -1
  844. package/dist/table/__tests__/use-table-print.test.d.ts +0 -1
  845. package/dist/table/__tests__/use-virtual-scroll.test.d.ts +0 -1
  846. package/dist/table/src/table-column.d.vue.ts +0 -81
  847. package/dist/table/src/table.d.vue.ts +0 -493
  848. package/dist/tabs/__tests__/tabs.ssr.test.d.ts +0 -1
  849. package/dist/tabs/__tests__/tabs.test.d.ts +0 -1
  850. package/dist/tabs/src/tab-pane.d.vue.ts +0 -77
  851. package/dist/tabs/src/tabs.d.vue.ts +0 -110
  852. package/dist/tag/__tests__/tag.ssr.test.d.ts +0 -1
  853. package/dist/tag/__tests__/tag.test.d.ts +0 -1
  854. package/dist/tag/src/tag.d.vue.ts +0 -42
  855. package/dist/time-picker/__tests__/time-picker.ssr.test.d.ts +0 -1
  856. package/dist/time-picker/__tests__/time-picker.test.d.ts +0 -1
  857. package/dist/time-picker/__tests__/time-spinner.test.d.ts +0 -1
  858. package/dist/time-picker/src/time-picker.d.vue.ts +0 -67
  859. package/dist/time-picker/src/time-spinner.d.vue.ts +0 -46
  860. package/dist/time-select/__tests__/time-select.ssr.test.d.ts +0 -1
  861. package/dist/time-select/__tests__/time-select.test.d.ts +0 -5
  862. package/dist/time-select/src/time-select.d.vue.ts +0 -51
  863. package/dist/tooltip/__tests__/tooltip.ssr.test.d.ts +0 -1
  864. package/dist/tooltip/__tests__/tooltip.test.d.ts +0 -1
  865. package/dist/tooltip/src/tooltip.d.vue.ts +0 -167
  866. package/dist/transfer/__tests__/transfer.ssr.test.d.ts +0 -1
  867. package/dist/transfer/__tests__/transfer.test.d.ts +0 -5
  868. package/dist/transfer/src/transfer-panel.d.vue.ts +0 -45
  869. package/dist/transfer/src/transfer.d.vue.ts +0 -68
  870. package/dist/tree/__tests__/tree.perf.test.d.ts +0 -1
  871. package/dist/tree/__tests__/tree.ssr.test.d.ts +0 -1
  872. package/dist/tree/__tests__/tree.test.d.ts +0 -1
  873. package/dist/tree/src/tree-node.d.vue.ts +0 -18
  874. package/dist/tree/src/tree.d.vue.ts +0 -228
  875. package/dist/tree-select/__tests__/tree-select.ssr.test.d.ts +0 -1
  876. package/dist/tree-select/__tests__/tree-select.test.d.ts +0 -1
  877. package/dist/tree-select/src/tree-select.d.vue.ts +0 -141
  878. package/dist/typography/__tests__/typography.ssr.test.d.ts +0 -1
  879. package/dist/typography/__tests__/typography.test.d.ts +0 -1
  880. package/dist/typography/src/link.d.vue.ts +0 -21
  881. package/dist/typography/src/paragraph.d.vue.ts +0 -22
  882. package/dist/typography/src/text.d.vue.ts +0 -29
  883. package/dist/typography/src/title.d.vue.ts +0 -26
  884. package/dist/upload/__tests__/upload.ssr.test.d.ts +0 -1
  885. package/dist/upload/__tests__/upload.test.d.ts +0 -1
  886. package/dist/upload/src/upload.d.vue.ts +0 -133
  887. package/dist/waterfall/__tests__/waterfall.ssr.test.d.ts +0 -1
  888. package/dist/waterfall/__tests__/waterfall.test.d.ts +0 -1
  889. package/dist/waterfall/src/waterfall.d.vue.ts +0 -56
  890. package/dist/watermark/__tests__/watermark.ssr.test.d.ts +0 -1
  891. package/dist/watermark/__tests__/watermark.test.d.ts +0 -1
  892. package/dist/watermark/src/watermark.d.vue.ts +0 -167
@@ -0,0 +1,1087 @@
1
+ <script setup>
2
+ import { ref, computed, watch, onMounted, onUnmounted } from "vue";
3
+ import { useNamespace } from "@yh-ui/hooks";
4
+ import { useComponentTheme } from "@yh-ui/theme";
5
+ import { useLocale } from "@yh-ui/hooks";
6
+ import { filterBarProps, filterBarEmits } from "./filter-bar";
7
+ defineOptions({ name: "YhFilterBar" });
8
+ const props = defineProps(filterBarProps);
9
+ const emit = defineEmits(filterBarEmits);
10
+ const ns = useNamespace("filter-bar");
11
+ const { themeStyle } = useComponentTheme(
12
+ "filter-bar",
13
+ computed(() => props.themeOverrides)
14
+ );
15
+ const { t } = useLocale();
16
+ const innerSort = ref({ ...props.sort });
17
+ watch(
18
+ () => props.sort,
19
+ (v) => {
20
+ innerSort.value = { ...v };
21
+ },
22
+ { deep: true }
23
+ );
24
+ function handleSortClick(key) {
25
+ let order;
26
+ if (innerSort.value.key !== key) {
27
+ order = "desc";
28
+ } else if (innerSort.value.order === "desc") {
29
+ order = "asc";
30
+ } else if (innerSort.value.order === "asc") {
31
+ order = null;
32
+ } else {
33
+ order = "desc";
34
+ }
35
+ const newSort = { key: order === null ? null : key, order };
36
+ innerSort.value = newSort;
37
+ emit("update:sort", newSort);
38
+ emit("sortChange", newSort);
39
+ }
40
+ const isPanelOpen = ref(false);
41
+ const panelFilter = ref(null);
42
+ const tempPanelValue = ref({});
43
+ const innerFilterValue = ref({ ...props.filterValue });
44
+ watch(
45
+ () => props.filterValue,
46
+ (v) => {
47
+ innerFilterValue.value = { ...v };
48
+ },
49
+ { deep: true }
50
+ );
51
+ function openFilterPanel(item) {
52
+ panelFilter.value = item;
53
+ tempPanelValue.value = { ...innerFilterValue.value };
54
+ isPanelOpen.value = true;
55
+ }
56
+ function closePanel() {
57
+ isPanelOpen.value = false;
58
+ panelFilter.value = null;
59
+ }
60
+ function confirmPanel() {
61
+ innerFilterValue.value = { ...tempPanelValue.value };
62
+ emit("update:filterValue", { ...innerFilterValue.value });
63
+ emit("filterChange", { ...innerFilterValue.value });
64
+ emit("confirm", { ...innerFilterValue.value });
65
+ closePanel();
66
+ }
67
+ function resetPanel() {
68
+ if (panelFilter.value) {
69
+ const key = panelFilter.value.key;
70
+ tempPanelValue.value = { ...tempPanelValue.value, [key]: null };
71
+ emit("resetPanel", panelFilter.value, tempPanelValue.value);
72
+ confirmPanel();
73
+ }
74
+ }
75
+ function resetAll() {
76
+ innerFilterValue.value = {};
77
+ innerSort.value = { key: null, order: null };
78
+ emit("update:filterValue", {});
79
+ emit("update:sort", { key: null, order: null });
80
+ emit("reset");
81
+ }
82
+ function toggleOption(item, option) {
83
+ const key = item.key;
84
+ const currentVal = tempPanelValue.value[key];
85
+ if (item.type === "checkbox") {
86
+ const arr = Array.isArray(currentVal) ? [...currentVal] : [];
87
+ const idx = arr.indexOf(option.value);
88
+ if (idx >= 0) arr.splice(idx, 1);
89
+ else arr.push(option.value);
90
+ tempPanelValue.value = { ...tempPanelValue.value, [key]: arr.length ? arr : null };
91
+ } else {
92
+ const newVal = currentVal === option.value ? null : option.value;
93
+ tempPanelValue.value = { ...tempPanelValue.value, [key]: newVal };
94
+ if (!props.filterInPanel) {
95
+ innerFilterValue.value = { ...tempPanelValue.value };
96
+ emit("update:filterValue", { ...innerFilterValue.value });
97
+ emit("filterChange", { ...innerFilterValue.value });
98
+ }
99
+ }
100
+ }
101
+ function isOptionSelected(item, option) {
102
+ const val = props.filterInPanel ? tempPanelValue.value[item.key] : innerFilterValue.value[item.key];
103
+ if (item.type === "checkbox") {
104
+ return Array.isArray(val) && val.includes(option.value);
105
+ }
106
+ return val === option.value;
107
+ }
108
+ const activeFilterCount = computed(() => {
109
+ return Object.values(innerFilterValue.value).filter((v) => {
110
+ if (v === null || v === void 0) return false;
111
+ if (Array.isArray(v)) return v.length > 0;
112
+ return true;
113
+ }).length;
114
+ });
115
+ const barRef = ref(null);
116
+ const isStuck = ref(false);
117
+ let observer = null;
118
+ onMounted(() => {
119
+ if (!props.sticky || typeof IntersectionObserver === "undefined") return;
120
+ observer = new IntersectionObserver(
121
+ ([entry]) => {
122
+ isStuck.value = !entry.isIntersecting;
123
+ },
124
+ { rootMargin: `-${props.stickyOffset}px 0px 0px 0px`, threshold: 1 }
125
+ );
126
+ if (barRef.value) observer.observe(barRef.value);
127
+ });
128
+ onUnmounted(() => {
129
+ observer?.disconnect();
130
+ });
131
+ function handleViewToggle() {
132
+ const next = props.viewType === "list" ? "grid" : "list";
133
+ emit("update:viewType", next);
134
+ emit("viewChange", next);
135
+ }
136
+ </script>
137
+
138
+ <template>
139
+ <div
140
+ ref="barRef"
141
+ :class="[ns.b(), ns.is('sticky', sticky), ns.is('stuck', isStuck)]"
142
+ :style="[themeStyle, sticky ? {
143
+ top: `${stickyOffset}px`
144
+ } : {}]"
145
+ >
146
+ <!-- 筛选/排序 tab 行 -->
147
+ <div :class="ns.e('bar')">
148
+ <!-- 全部 tab -->
149
+ <button
150
+ v-if="showAll"
151
+ :class="[ns.e('tab'), ns.is('active', !innerSort.key && !activeFilterCount)]"
152
+ @click="resetAll"
153
+ >
154
+ {{ t('filterbar.all') }}
155
+ </button>
156
+
157
+ <!-- 排序 tabs -->
158
+ <button
159
+ v-for="sortItem in sorts"
160
+ :key="sortItem.key"
161
+ :class="[ns.e('tab'), ns.e('sort-tab'), ns.is('active', innerSort.key === sortItem.key)]"
162
+ @click="handleSortClick(sortItem.key)"
163
+ >
164
+ <span>{{ sortItem.label }}</span>
165
+ <span :class="[ns.e('sort-arrows')]">
166
+ <i
167
+ :class="[ns.e('arrow-up'), ns.is('active', innerSort.key === sortItem.key && innerSort.order === 'asc')]"
168
+ >
169
+ <svg viewBox="0 0 1024 1024" width="1em" height="1em" fill="currentColor">
170
+ <path d="M512 320L192 704h640z" />
171
+ </svg>
172
+ </i>
173
+ <i
174
+ :class="[ns.e('arrow-down'), ns.is('active', innerSort.key === sortItem.key && innerSort.order === 'desc')]"
175
+ >
176
+ <svg viewBox="0 0 1024 1024" width="1em" height="1em" fill="currentColor">
177
+ <path d="M512 704L832 320H192z" />
178
+ </svg>
179
+ </i>
180
+ </span>
181
+ </button>
182
+
183
+ <!-- 筛选 tabs -->
184
+ <template v-if="filterInPanel">
185
+ <button
186
+ v-for="filterItem in filters"
187
+ :key="filterItem.key"
188
+ :class="[ns.e('tab'), ns.e('filter-tab'), ns.is('active', !!innerFilterValue[filterItem.key] && (Array.isArray(innerFilterValue[filterItem.key]) ? innerFilterValue[filterItem.key].length > 0 : true))]"
189
+ @click="openFilterPanel(filterItem)"
190
+ >
191
+ <span>{{ filterItem.label }}</span>
192
+ <i :class="ns.e('arrow-icon')">
193
+ <svg viewBox="0 0 1024 1024" width="1em" height="1em" fill="currentColor">
194
+ <path d="M512 704L832 320H192z" />
195
+ </svg>
196
+ </i>
197
+ </button>
198
+ <!-- 综合筛选按钮 -->
199
+ <button
200
+ v-if="showGlobalFilter"
201
+ :class="[ns.e('tab'), ns.e('filter-btn'), ns.is('active', activeFilterCount > 0)]"
202
+ @click="emit('openFilter')"
203
+ >
204
+ <span>{{ t("filterbar.filter") }}</span>
205
+ <span v-if="activeFilterCount" :class="ns.e('badge')">{{ activeFilterCount }}</span>
206
+ <slot name="filter-icon">
207
+ <i :class="ns.e('filter-icon')">
208
+ <svg viewBox="0 0 1024 1024" width="1em" height="1em" fill="currentColor">
209
+ <path
210
+ d="M880.005 224H143.995c-23.778 0-38.653 25.492-22.95 45.418L384 602.822v263.854c0 15.365 17.554 24.088 29.818 14.89l185.394-139.046c6.242-4.682 9.924-12.072 9.924-19.866V602.823l293.818-333.406c15.704-19.926.83-45.417-22.949-45.417z"
211
+ ></path>
212
+ </svg>
213
+ </i>
214
+ </slot>
215
+ </button>
216
+ </template>
217
+
218
+ <!-- 内联筛选 -->
219
+ <template v-else>
220
+ <div v-for="filterItem in filters" :key="filterItem.key" :class="ns.e('inline-filter')">
221
+ <span :class="ns.e('inline-label')">{{ filterItem.label }}</span>
222
+ <button
223
+ v-for="opt in filterItem.options"
224
+ :key="String(opt.value)"
225
+ :class="[ns.e('inline-opt'), ns.is('active', isOptionSelected(filterItem, opt))]"
226
+ @click="toggleOption(filterItem, opt)"
227
+ >
228
+ {{ opt.label }}
229
+ </button>
230
+ </div>
231
+ </template>
232
+
233
+ <!-- 视图切换按钮 -->
234
+ <button
235
+ v-if="showViewToggle"
236
+ :class="[ns.e('tab'), ns.e('view-btn')]"
237
+ @click="handleViewToggle"
238
+ >
239
+ <slot name="view-icon" :view-type="viewType">
240
+ <svg
241
+ v-if="viewType === 'list'"
242
+ viewBox="0 0 1024 1024"
243
+ width="1.2em"
244
+ height="1.2em"
245
+ fill="currentColor"
246
+ >
247
+ <path d="M128 320h768v85.333H128V320zM128 618.667h768V704H128v-85.333z" />
248
+ </svg>
249
+ <svg v-else viewBox="0 0 1024 1024" width="1.2em" height="1.2em" fill="currentColor">
250
+ <path
251
+ d="M213.333 213.333h256v256h-256v-256zM554.667 213.333h256v256h-256v-256zM213.333 554.667h256v256h-256v-256zM554.667 554.667h256v256h-256v-256z"
252
+ />
253
+ </svg>
254
+ </slot>
255
+ </button>
256
+
257
+ <!-- 自定义扩展区 -->
258
+ <slot name="extra" />
259
+ </div>
260
+
261
+ <!-- 筛选面板(下拉浮层) -->
262
+ <Transition :name="ns.b('panel')">
263
+ <div
264
+ v-if="isPanelOpen && filterInPanel && panelFilter"
265
+ :class="ns.e('panel')"
266
+ role="dialog"
267
+ :aria-label="t('filterbar.filter')"
268
+ >
269
+ <!-- 面板遮罩 -->
270
+ <div :class="ns.e('overlay')" @click="closePanel" />
271
+ <div :class="ns.e('panel-body')">
272
+ <!-- 标题 -->
273
+ <div :class="ns.e('panel-header')">
274
+ <span :class="ns.e('panel-title')">{{ panelFilter.label }}</span>
275
+ <button
276
+ :class="ns.e('panel-close')"
277
+ :aria-label="t('filterbar.cancel')"
278
+ @click="closePanel"
279
+ >
280
+ <svg viewBox="0 0 1024 1024" width="14" height="14" fill="currentColor">
281
+ <path
282
+ d="M563.8 512l262.5-312.9c4.4-5.2.7-13.1-6.1-13.1h-79.8c-4.7 0-9.2 2.1-12.3 5.7L511.6 449.8 295.1 191.7c-3-3.6-7.5-5.7-12.3-5.7H203c-6.8 0-10.5 7.9-6.1 13.1L459.4 512 196.9 824.9c-4.4 5.2-.7 13.1 6.1 13.1h79.8c4.7 0 9.2-2.1 12.3-5.7l216.5-258.1 216.5 258.1c3 3.6 7.5 5.7 12.3 5.7h79.8c6.8 0 10.5-7.9 6.1-13.1L563.8 512z"
283
+ />
284
+ </svg>
285
+ </button>
286
+ </div>
287
+ <!-- 内容 -->
288
+ <div :class="ns.e('panel-content')">
289
+ <slot
290
+ name="panel-content"
291
+ :filter="panelFilter"
292
+ :value="tempPanelValue"
293
+ :toggle="toggleOption"
294
+ >
295
+ <div v-if="panelFilter.options?.length" :class="ns.e('panel-options')">
296
+ <button
297
+ v-for="opt in panelFilter.options"
298
+ :key="String(opt.value)"
299
+ :class="[ns.e('panel-opt'), ns.is('active', isOptionSelected(panelFilter, opt))]"
300
+ @click="toggleOption(panelFilter, opt)"
301
+ >
302
+ {{ opt.label }}
303
+ </button>
304
+ </div>
305
+ <p v-else :class="ns.e('no-options')">
306
+ {{ t("filterbar.noOptions") }}
307
+ </p>
308
+ </slot>
309
+ </div>
310
+ <!-- 操作区 -->
311
+ <div :class="ns.e('panel-footer')">
312
+ <button :class="[ns.e('btn'), ns.e('btn-reset')]" @click="resetPanel">
313
+ {{ t("filterbar.reset") }}
314
+ </button>
315
+ <button :class="[ns.e('btn'), ns.e('btn-confirm')]" @click="confirmPanel">
316
+ {{ t("filterbar.confirm") }}
317
+ </button>
318
+ </div>
319
+ </div>
320
+ </div>
321
+ </Transition>
322
+ </div>
323
+ </template>
324
+
325
+ <style>
326
+ @charset "UTF-8";
327
+ /**
328
+ * YH-UI CSS Variables
329
+ * 全局 CSS 变量定义 - 业内最佳主题系统
330
+ */
331
+ :root {
332
+ /* ==================== 密度/紧凑度系统 ==================== */
333
+ --yh-density-factor: 1;
334
+ --yh-component-size-default: 32px;
335
+ --yh-component-size-small: 24px;
336
+ --yh-component-size-large: 40px;
337
+ --yh-padding-default: 12px 16px;
338
+ --yh-padding-small: 8px 12px;
339
+ --yh-padding-large: 16px 20px;
340
+ --yh-spacing-unit: 8px;
341
+ /* ==================== 基础颜色 ==================== */
342
+ --yh-color-white: #ffffff;
343
+ --yh-color-black: #000000;
344
+ /* ==================== 颜色系统 ==================== */
345
+ /* 主色 */
346
+ --yh-color-primary: #409eff;
347
+ --yh-color-primary-light-1: #53a8ff;
348
+ --yh-color-primary-light-2: #66b1ff;
349
+ --yh-color-primary-light-3: #79bbff;
350
+ --yh-color-primary-light-4: #8cc5ff;
351
+ --yh-color-primary-light-5: #a0cfff;
352
+ --yh-color-primary-light-6: #b3d8ff;
353
+ --yh-color-primary-light-7: #c6e2ff;
354
+ --yh-color-primary-light-8: #d9ecff;
355
+ --yh-color-primary-light-9: #ecf5ff;
356
+ --yh-color-primary-dark-2: #337ecc;
357
+ /* 成功色 */
358
+ --yh-color-success: #67c23a;
359
+ --yh-color-success-light-3: #95d475;
360
+ --yh-color-success-light-5: #b3e19d;
361
+ --yh-color-success-light-7: #d1edc4;
362
+ --yh-color-success-light-9: #f0f9eb;
363
+ --yh-color-success-dark-2: #529b2e;
364
+ /* 警告色 */
365
+ --yh-color-warning: #e6a23c;
366
+ --yh-color-warning-light-3: #eebe77;
367
+ --yh-color-warning-light-5: #f3d19e;
368
+ --yh-color-warning-light-7: #f8e3c5;
369
+ --yh-color-warning-light-9: #fdf6ec;
370
+ --yh-color-warning-dark-2: #b88230;
371
+ /* 危险色 */
372
+ --yh-color-danger: #f56c6c;
373
+ --yh-color-danger-light-3: #f89898;
374
+ --yh-color-danger-light-5: #fab6b6;
375
+ --yh-color-danger-light-7: #fcd3d3;
376
+ --yh-color-danger-light-9: #fef0f0;
377
+ --yh-color-danger-dark-2: #c45656;
378
+ /* 信息色 */
379
+ --yh-color-info: #909399;
380
+ --yh-color-info-light-3: #b1b3b8;
381
+ --yh-color-info-light-5: #c8c9cc;
382
+ --yh-color-info-light-7: #dedfe0;
383
+ --yh-color-info-light-9: #f4f4f5;
384
+ --yh-color-info-dark-2: #73767a;
385
+ /* 文字颜色 */
386
+ --yh-text-color-primary: #303133;
387
+ --yh-text-color-regular: #606266;
388
+ --yh-text-color-secondary: #909399;
389
+ --yh-text-color-placeholder: #a8abb2;
390
+ --yh-text-color-disabled: #c0c4cc;
391
+ /* 边框颜色 */
392
+ --yh-border-color: #dcdfe6;
393
+ --yh-border-color-hover: var(--yh-color-primary);
394
+ --yh-border-color-light: #e4e7ed;
395
+ --yh-border-color-lighter: #ebeef5;
396
+ --yh-border-color-extra-light: #f2f6fc;
397
+ --yh-border-color-dark: #d4d7de;
398
+ --yh-border-color-darker: #cdd0d6;
399
+ /* 填充颜色 */
400
+ --yh-fill-color: #f0f2f5;
401
+ --yh-fill-color-light: #f5f7fa;
402
+ --yh-fill-color-lighter: #fafafa;
403
+ --yh-fill-color-extra-light: #fafcff;
404
+ --yh-fill-color-dark: #ebedf0;
405
+ --yh-fill-color-darker: #e6e8eb;
406
+ --yh-fill-color-blank: #ffffff;
407
+ /* 背景颜色 */
408
+ --yh-bg-color: #ffffff;
409
+ --yh-bg-color-page: #f2f3f5;
410
+ --yh-bg-color-overlay: #ffffff;
411
+ /* ==================== 间距系统 ==================== */
412
+ --yh-spacing-none: 0;
413
+ --yh-spacing-xs: 4px;
414
+ --yh-spacing-sm: 8px;
415
+ --yh-spacing-md: 16px;
416
+ --yh-spacing-lg: 24px;
417
+ --yh-spacing-xl: 32px;
418
+ --yh-spacing-xxl: 48px;
419
+ /* ==================== 圆角系统 ==================== */
420
+ --yh-radius-none: 0;
421
+ --yh-radius-sm: 2px;
422
+ --yh-radius-base: 4px;
423
+ --yh-radius-md: 8px;
424
+ --yh-radius-lg: 12px;
425
+ --yh-radius-xl: 16px;
426
+ --yh-radius-round: 20px;
427
+ --yh-radius-circle: 50%;
428
+ /* ==================== 字体系统 ==================== */
429
+ --yh-font-family:
430
+ -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans',
431
+ sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';
432
+ /* 字号 */
433
+ --yh-font-size-xs: 12px;
434
+ --yh-font-size-sm: 13px;
435
+ --yh-font-size-base: 14px;
436
+ --yh-font-size-md: 16px;
437
+ --yh-font-size-lg: 18px;
438
+ --yh-font-size-xl: 20px;
439
+ --yh-font-size-xxl: 24px;
440
+ /* 行高 */
441
+ --yh-line-height-none: 1;
442
+ --yh-line-height-tight: 1.25;
443
+ --yh-line-height-snug: 1.375;
444
+ --yh-line-height-normal: 1.5;
445
+ --yh-line-height-relaxed: 1.625;
446
+ --yh-line-height-loose: 2;
447
+ /* 字重 */
448
+ --yh-font-weight-light: 300;
449
+ --yh-font-weight-normal: 400;
450
+ --yh-font-weight-medium: 500;
451
+ --yh-font-weight-semibold: 600;
452
+ --yh-font-weight-bold: 700;
453
+ /* ==================== 阴影系统 ==================== */
454
+ --yh-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
455
+ --yh-shadow-base: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
456
+ --yh-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
457
+ --yh-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
458
+ --yh-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
459
+ /* ==================== 过渡动效 ==================== */
460
+ --yh-duration-fast: 150ms;
461
+ --yh-duration-base: 200ms;
462
+ --yh-duration-slow: 300ms;
463
+ --yh-timing-ease: ease;
464
+ --yh-timing-ease-in: cubic-bezier(0.4, 0, 1, 1);
465
+ --yh-timing-ease-out: cubic-bezier(0, 0, 0.2, 1);
466
+ --yh-timing-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
467
+ --yh-timing-linear: linear;
468
+ --yh-transition-base: all var(--yh-duration-base) var(--yh-timing-ease-in-out);
469
+ --yh-transition-fast: all var(--yh-duration-fast) var(--yh-timing-ease-in-out);
470
+ --yh-transition-slow: all var(--yh-duration-slow) var(--yh-timing-ease-in-out);
471
+ /* ==================== 层级系统 ==================== */
472
+ --yh-z-index-normal: 1;
473
+ --yh-z-index-top: 1000;
474
+ --yh-z-index-popper: 2000;
475
+ --yh-z-index-overlay: 2001;
476
+ --yh-z-index-modal: 2002;
477
+ --yh-z-index-popover: 2003;
478
+ --yh-z-index-tooltip: 2004;
479
+ --yh-z-index-loading: 2005;
480
+ /* ==================== 组件尺寸 ==================== */
481
+ /* Large */
482
+ --yh-component-size-large: 40px;
483
+ --yh-component-size-large-font: 14px;
484
+ --yh-component-size-large-padding: 20px;
485
+ /* Default */
486
+ --yh-component-size-default: 32px;
487
+ --yh-component-size-default-font: 14px;
488
+ --yh-component-size-default-padding: 16px;
489
+ /* Small */
490
+ --yh-component-size-small: 24px;
491
+ --yh-component-size-small-font: 12px;
492
+ --yh-component-size-small-padding: 12px;
493
+ /* ==================== 组件语义化变量 ==================== */
494
+ --yh-border-radius-base: var(--yh-radius-base);
495
+ --yh-border-radius-small: var(--yh-radius-sm);
496
+ --yh-border-radius-round: var(--yh-radius-round);
497
+ /* Message 消息提示 */
498
+ --yh-message-bg-color: var(--yh-bg-color-overlay);
499
+ --yh-message-border-color: var(--yh-border-color-lighter);
500
+ --yh-message-shadow: var(--yh-shadow-lg);
501
+ --yh-message-text-color: var(--yh-text-color-primary);
502
+ --yh-message-close-color: var(--yh-text-color-secondary);
503
+ --yh-message-close-hover-color: var(--yh-text-color-primary);
504
+ /* Notification 通知 */
505
+ --yh-notification-bg-color: var(--yh-bg-color-overlay);
506
+ --yh-notification-border-color: var(--yh-border-color-lighter);
507
+ --yh-notification-shadow: var(--yh-shadow-lg);
508
+ --yh-notification-title-color: var(--yh-text-color-primary);
509
+ --yh-notification-content-color: var(--yh-text-color-regular);
510
+ /* Badge 徽标 */
511
+ --yh-badge-bg-color: var(--yh-color-danger);
512
+ --yh-badge-text-color: #ffffff;
513
+ --yh-badge-border-color: var(--yh-bg-color);
514
+ /* Card 卡片 */
515
+ --yh-card-bg-color: var(--yh-bg-color-overlay);
516
+ --yh-card-border-color: var(--yh-border-color-lighter);
517
+ --yh-card-shadow: var(--yh-shadow-base);
518
+ --yh-card-header-padding: 18px 20px;
519
+ --yh-card-body-padding: 20px;
520
+ /* Input 输入框 */
521
+ --yh-input-bg-color: var(--yh-fill-color-blank);
522
+ --yh-input-text-color: var(--yh-text-color-regular);
523
+ --yh-input-border-color: var(--yh-border-color);
524
+ --yh-input-hover-border-color: var(--yh-color-primary);
525
+ --yh-input-focus-border-color: var(--yh-color-primary);
526
+ --yh-input-placeholder-color: var(--yh-text-color-placeholder);
527
+ --yh-input-icon-color: var(--yh-text-color-placeholder);
528
+ --yh-input-disabled-bg-color: var(--yh-fill-color-light);
529
+ --yh-input-disabled-text-color: var(--yh-text-color-disabled);
530
+ --yh-input-disabled-border-color: var(--yh-border-color-light);
531
+ /* Image 图片 */
532
+ --yh-image-placeholder-bg-color: var(--yh-fill-color-light);
533
+ --yh-image-placeholder-text-color: var(--yh-text-color-placeholder);
534
+ --yh-image-error-bg-color: var(--yh-fill-color-extra-light);
535
+ --yh-image-error-text-color: var(--yh-text-color-placeholder);
536
+ /* Image Viewer 预览器 */
537
+ --yh-image-viewer-mask-bg-color: rgba(0, 0, 0, 0.5);
538
+ --yh-image-viewer-btn-bg-color: var(--yh-text-color-regular);
539
+ --yh-image-viewer-btn-color: #ffffff;
540
+ --yh-image-viewer-btn-hover-bg-color: var(--yh-color-primary);
541
+ /* Calendar 日历 */
542
+ --yh-calendar-bg: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
543
+ --yh-calendar-border-color: rgba(0, 0, 0, 0.06);
544
+ --yh-calendar-border-radius: var(--yh-radius-xl);
545
+ --yh-calendar-header-bg: rgba(255, 255, 255, 0.95);
546
+ --yh-calendar-header-border: rgba(0, 0, 0, 0.04);
547
+ --yh-calendar-header-padding: 18px 22px;
548
+ --yh-calendar-body-padding: 14px 18px 18px;
549
+ /* Calendar 尺寸 */
550
+ --yh-calendar-cell-height: 85px;
551
+ --yh-calendar-cell-height-small: 52px;
552
+ --yh-calendar-cell-height-large: 110px;
553
+ --yh-calendar-cell-radius: 10px;
554
+ --yh-calendar-cell-radius-small: 6px;
555
+ --yh-calendar-cell-radius-large: 12px;
556
+ /* Calendar 颜色 */
557
+ --yh-calendar-primary: var(--yh-color-primary);
558
+ --yh-calendar-primary-light: rgba(59, 130, 246, 0.1);
559
+ --yh-calendar-selected-bg: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
560
+ --yh-calendar-selected-border: rgba(59, 130, 246, 0.4);
561
+ --yh-calendar-today-dot: var(--yh-color-primary);
562
+ --yh-calendar-weekend-color: #f97316;
563
+ --yh-calendar-disabled-color: var(--yh-text-color-disabled);
564
+ --yh-calendar-other-month-opacity: 0.35;
565
+ /* Calendar 假日 */
566
+ --yh-calendar-holiday-color: var(--yh-color-success);
567
+ --yh-calendar-holiday-bg: rgba(16, 185, 129, 0.12);
568
+ --yh-calendar-holiday-border: rgba(16, 185, 129, 0.25);
569
+ --yh-calendar-workday-color: var(--yh-color-warning);
570
+ --yh-calendar-workday-bg: rgba(245, 158, 11, 0.12);
571
+ --yh-calendar-workday-border: rgba(245, 158, 11, 0.25);
572
+ /* Calendar 范围选择 */
573
+ --yh-calendar-range-bg: rgba(59, 130, 246, 0.08);
574
+ --yh-calendar-range-border: rgba(59, 130, 246, 0.2);
575
+ /* Calendar 字体 */
576
+ --yh-calendar-weekday-font-size: var(--yh-font-size-sm);
577
+ --yh-calendar-weekday-color: var(--yh-text-color-secondary);
578
+ --yh-calendar-day-font-size: 15px;
579
+ --yh-calendar-day-color: var(--yh-text-color-primary);
580
+ --yh-calendar-badge-font-size: 9px;
581
+ /* Table 表格 */
582
+ --yh-table-border-color: var(--yh-border-color-lighter);
583
+ --yh-table-header-bg: var(--yh-fill-color-light);
584
+ --yh-table-header-text-color: var(--yh-text-color-primary);
585
+ --yh-table-header-font-weight: var(--yh-font-weight-semibold);
586
+ --yh-table-row-bg: var(--yh-bg-color);
587
+ --yh-table-row-hover-bg: var(--yh-fill-color-light);
588
+ --yh-table-row-stripe-bg: var(--yh-fill-color-lighter);
589
+ --yh-table-row-current-bg: var(--yh-color-primary-light-9);
590
+ --yh-table-row-selected-bg: var(--yh-color-primary-light-8);
591
+ --yh-table-row-success-bg: var(--yh-color-success-light-9);
592
+ --yh-table-row-warning-bg: var(--yh-color-warning-light-9);
593
+ --yh-table-text-color: var(--yh-text-color-regular);
594
+ --yh-table-empty-text-color: var(--yh-text-color-secondary);
595
+ --yh-table-font-size: var(--yh-font-size-base);
596
+ --yh-table-cell-padding: 12px 0;
597
+ --yh-table-cell-spacing: 12px;
598
+ --yh-table-fixed-left-shadow: inset 10px 0 8px -8px rgba(0, 0, 0, 0.15);
599
+ --yh-table-fixed-right-shadow: inset -10px 0 8px -8px rgba(0, 0, 0, 0.15);
600
+ /* ==================== 边框基础 ==================== */
601
+ --yh-border-width: 1px;
602
+ --yh-border-style: solid;
603
+ --yh-border: var(--yh-border-width) var(--yh-border-style) var(--yh-border-color);
604
+ /* ==================== 断点系统 ==================== */
605
+ --yh-breakpoint-xs: 0;
606
+ --yh-breakpoint-sm: 576px;
607
+ --yh-breakpoint-md: 768px;
608
+ --yh-breakpoint-lg: 992px;
609
+ --yh-breakpoint-xl: 1200px;
610
+ --yh-breakpoint-xxl: 1400px;
611
+ /* ==================== 字体系统扩展 ==================== */
612
+ --yh-font-family-monospace:
613
+ 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, Courier, monospace;
614
+ --yh-font-family-serif: Georgia, Cambria, 'Times New Roman', Times, serif;
615
+ /* ==================== 无障碍/聚焦系统 ==================== */
616
+ --yh-focus-ring-color: var(--yh-color-primary);
617
+ --yh-focus-ring-width: 2px;
618
+ --yh-focus-ring-offset: 2px;
619
+ --yh-focus-ring-opacity: 0.2;
620
+ --yh-focus-ring:
621
+ 0 0 0 var(--yh-focus-ring-offset) var(--yh-bg-color),
622
+ 0 0 0 calc(var(--yh-focus-ring-offset) + var(--yh-focus-ring-width)) var(--yh-focus-ring-color);
623
+ /* 高对比度模式支持 */
624
+ --yh-high-contrast-outline: 2px solid transparent;
625
+ --yh-high-contrast-outline-offset: 2px;
626
+ /* ==================== 滚动条样式 ==================== */
627
+ --yh-scrollbar-width: 6px;
628
+ --yh-scrollbar-thumb-color: var(--yh-text-color-disabled);
629
+ --yh-scrollbar-thumb-hover-color: var(--yh-text-color-secondary);
630
+ --yh-scrollbar-track-color: transparent;
631
+ --yh-scrollbar-thumb-radius: 3px;
632
+ /* ==================== 遮罩层 ==================== */
633
+ --yh-mask-color: rgba(0, 0, 0, 0.5);
634
+ --yh-mask-color-light: rgba(0, 0, 0, 0.3);
635
+ --yh-mask-color-extra-light: rgba(0, 0, 0, 0.1);
636
+ }
637
+
638
+ /* ==================== 暗黑模式 ==================== */
639
+ html.dark {
640
+ --yh-color-primary: #409eff;
641
+ --yh-color-primary-light-3: #3375b9;
642
+ --yh-color-primary-light-5: #2a598a;
643
+ --yh-color-primary-light-7: #213d5b;
644
+ --yh-color-primary-light-9: #18222c;
645
+ --yh-color-primary-dark-2: #66b1ff;
646
+ --yh-color-success: #67c23a;
647
+ --yh-color-success-light-3: #4e8e2f;
648
+ --yh-color-success-light-5: #3e6b27;
649
+ --yh-color-success-light-7: #2d481f;
650
+ --yh-color-success-light-9: #1d2518;
651
+ --yh-color-warning: #e6a23c;
652
+ --yh-color-warning-light-3: #a77730;
653
+ --yh-color-warning-light-5: #7d5b28;
654
+ --yh-color-warning-light-7: #533f20;
655
+ --yh-color-warning-light-9: #292218;
656
+ --yh-color-danger: #f56c6c;
657
+ --yh-color-danger-light-3: #b25252;
658
+ --yh-color-danger-light-5: #854040;
659
+ --yh-color-danger-light-7: #582e2e;
660
+ --yh-color-danger-light-9: #2b1d1d;
661
+ --yh-color-info: #909399;
662
+ --yh-color-info-light-3: #6b6d71;
663
+ --yh-color-info-light-5: #525457;
664
+ --yh-color-info-light-7: #393b3e;
665
+ --yh-color-info-light-9: #202124;
666
+ --yh-text-color-primary: #e5eaf3;
667
+ --yh-text-color-regular: #cfd3dc;
668
+ --yh-text-color-secondary: #a3a6ad;
669
+ --yh-text-color-placeholder: #8d9095;
670
+ --yh-text-color-disabled: #6c6e72;
671
+ --yh-border-color: #4c4d4f;
672
+ --yh-border-color-light: #414243;
673
+ --yh-border-color-lighter: #363637;
674
+ --yh-border-color-extra-light: #2b2b2c;
675
+ --yh-border-color-dark: #58585b;
676
+ --yh-border-color-darker: #636466;
677
+ --yh-fill-color: #303030;
678
+ --yh-fill-color-light: #262727;
679
+ --yh-fill-color-lighter: #1d1d1d;
680
+ --yh-fill-color-extra-light: #191919;
681
+ --yh-fill-color-dark: #39393a;
682
+ --yh-fill-color-darker: #424243;
683
+ --yh-fill-color-blank: transparent;
684
+ --yh-bg-color: #141414;
685
+ --yh-bg-color-page: #0a0a0a;
686
+ --yh-bg-color-overlay: #1d1e1f;
687
+ /* 组件暗色模式覆盖 */
688
+ --yh-message-bg-color: var(--yh-bg-color-overlay);
689
+ --yh-message-border-color: var(--yh-border-color-lighter);
690
+ --yh-notification-bg-color: var(--yh-bg-color-overlay);
691
+ --yh-notification-border-color: var(--yh-border-color-lighter);
692
+ --yh-badge-border-color: var(--yh-bg-color);
693
+ --yh-card-bg-color: var(--yh-bg-color-overlay);
694
+ --yh-card-border-color: var(--yh-border-color-lighter);
695
+ /* Calendar 暗黑模式 */
696
+ --yh-calendar-bg: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
697
+ --yh-calendar-border-color: rgba(255, 255, 255, 0.08);
698
+ --yh-calendar-header-bg: rgba(30, 30, 30, 0.95);
699
+ --yh-calendar-header-border: rgba(255, 255, 255, 0.06);
700
+ --yh-calendar-day-color: var(--yh-text-color-primary);
701
+ --yh-calendar-weekday-color: var(--yh-text-color-secondary);
702
+ --yh-calendar-selected-bg: linear-gradient(
703
+ 135deg,
704
+ rgba(59, 130, 246, 0.2) 0%,
705
+ rgba(59, 130, 246, 0.1) 100%
706
+ );
707
+ /* Table 暗黑模式 */
708
+ --yh-table-border-color: var(--yh-border-color-lighter);
709
+ --yh-table-header-bg: var(--yh-fill-color-dark);
710
+ --yh-table-header-text-color: var(--yh-text-color-primary);
711
+ --yh-table-row-bg: var(--yh-bg-color);
712
+ --yh-table-row-hover-bg: var(--yh-fill-color);
713
+ --yh-table-row-stripe-bg: var(--yh-fill-color-light);
714
+ --yh-table-row-current-bg: var(--yh-color-primary-light-9);
715
+ --yh-table-row-selected-bg: var(--yh-color-primary-light-9);
716
+ --yh-table-row-success-bg: var(--yh-color-success-light-9);
717
+ --yh-table-row-warning-bg: var(--yh-color-warning-light-9);
718
+ --yh-table-fixed-left-shadow: inset 10px 0 8px -8px rgba(0, 0, 0, 0.3);
719
+ --yh-table-fixed-right-shadow: inset -10px 0 8px -8px rgba(0, 0, 0, 0.3);
720
+ /* 遮罩层暗黑模式 */
721
+ --yh-mask-color: rgba(0, 0, 0, 0.7);
722
+ --yh-mask-color-light: rgba(0, 0, 0, 0.5);
723
+ --yh-mask-color-extra-light: rgba(0, 0, 0, 0.3);
724
+ /* 滚动条暗黑模式 */
725
+ --yh-scrollbar-thumb-color: var(--yh-fill-color-darker);
726
+ --yh-scrollbar-thumb-hover-color: var(--yh-text-color-placeholder);
727
+ }
728
+
729
+ /* ==================== 减少动画偏好支持 ==================== */
730
+ @media (prefers-reduced-motion: reduce) {
731
+ :root,
732
+ html.dark {
733
+ --yh-duration-fast: 0ms;
734
+ --yh-duration-base: 0ms;
735
+ --yh-duration-slow: 0ms;
736
+ --yh-transition-base: none;
737
+ --yh-transition-fast: none;
738
+ --yh-transition-slow: none;
739
+ }
740
+ *,
741
+ *::before,
742
+ *::after {
743
+ animation-duration: 0.01ms !important;
744
+ animation-iteration-count: 1 !important;
745
+ transition-duration: 0.01ms !important;
746
+ scroll-behavior: auto !important;
747
+ }
748
+ }
749
+ /* ==================== 高对比度模式支持 ==================== */
750
+ @media (prefers-contrast: high) {
751
+ :root {
752
+ --yh-border-color: #000000;
753
+ --yh-border-color-light: #333333;
754
+ --yh-text-color-primary: #000000;
755
+ --yh-text-color-regular: #1a1a1a;
756
+ --yh-focus-ring-width: 3px;
757
+ --yh-focus-ring-color: #000000;
758
+ }
759
+ html.dark {
760
+ --yh-border-color: #ffffff;
761
+ --yh-border-color-light: #cccccc;
762
+ --yh-text-color-primary: #ffffff;
763
+ --yh-text-color-regular: #e5e5e5;
764
+ --yh-focus-ring-color: #ffffff;
765
+ }
766
+ }
767
+ /* ==================== 强制颜色模式支持 (Windows 高对比度) ==================== */
768
+ @media (forced-colors: active) {
769
+ :root {
770
+ --yh-color-primary: LinkText;
771
+ --yh-border-color: ButtonBorder;
772
+ --yh-bg-color: Canvas;
773
+ --yh-text-color-primary: CanvasText;
774
+ --yh-focus-ring-color: Highlight;
775
+ }
776
+ }
777
+ .yh-filter-bar {
778
+ --yh-filter-bar-bg: var(--yh-bg-color);
779
+ --yh-filter-bar-border: var(--yh-border-color-lighter);
780
+ --yh-filter-bar-height: 44px;
781
+ --yh-filter-bar-tab-color: var(--yh-text-color-regular);
782
+ --yh-filter-bar-tab-active-color: var(--yh-color-primary);
783
+ --yh-filter-bar-tab-active-bg: var(--yh-color-primary-light-9);
784
+ --yh-filter-bar-tab-radius: var(--yh-radius-base);
785
+ --yh-filter-bar-badge-bg: var(--yh-color-danger);
786
+ --yh-filter-bar-panel-bg: var(--yh-bg-color);
787
+ --yh-filter-bar-panel-shadow: 0 4px 20px var(--yh-shadow-color);
788
+ --yh-filter-bar-panel-opt-bg: var(--yh-fill-color-light);
789
+ --yh-filter-bar-panel-opt-active-bg: var(--yh-color-primary-light-9);
790
+ --yh-filter-bar-panel-opt-active-color: var(--yh-color-primary);
791
+ --yh-filter-bar-panel-opt-active-border: var(--yh-color-primary);
792
+ --yh-filter-bar-z-index: 100;
793
+ position: relative;
794
+ background: var(--yh-filter-bar-bg);
795
+ border-bottom: 1px solid var(--yh-filter-bar-border);
796
+ z-index: var(--yh-filter-bar-z-index);
797
+ transition: box-shadow var(--yh-transition-base);
798
+ }
799
+ .yh-filter-bar.is-sticky {
800
+ position: sticky;
801
+ top: 0;
802
+ }
803
+
804
+ .yh-filter-bar.is-stuck {
805
+ box-shadow: 0 2px 12px var(--yh-shadow-color);
806
+ }
807
+
808
+ .yh-filter-bar__bar {
809
+ display: flex;
810
+ align-items: center;
811
+ gap: 4px;
812
+ padding: 0 12px;
813
+ height: var(--yh-filter-bar-height);
814
+ overflow-x: auto;
815
+ scrollbar-width: none;
816
+ -ms-overflow-style: none;
817
+ }
818
+ .yh-filter-bar__bar::-webkit-scrollbar {
819
+ display: none;
820
+ }
821
+
822
+ .yh-filter-bar__tab {
823
+ display: inline-flex;
824
+ align-items: center;
825
+ gap: 3px;
826
+ padding: 5px 12px;
827
+ border: none;
828
+ background: transparent;
829
+ color: var(--yh-filter-bar-tab-color);
830
+ font-size: var(--yh-font-size-sm);
831
+ font-weight: var(--yh-font-weight-medium);
832
+ border-radius: 999px;
833
+ cursor: pointer;
834
+ white-space: nowrap;
835
+ flex-shrink: 0;
836
+ transition: color var(--yh-transition-base), background var(--yh-transition-base);
837
+ }
838
+ .yh-filter-bar__tab:hover {
839
+ color: var(--yh-filter-bar-tab-active-color);
840
+ }
841
+ .yh-filter-bar__tab:active {
842
+ transform: scale(0.96);
843
+ }
844
+ .yh-filter-bar__tab.is-active {
845
+ color: var(--yh-filter-bar-tab-active-color);
846
+ background: transparent;
847
+ font-weight: 600;
848
+ }
849
+
850
+ .yh-filter-bar__view-btn {
851
+ margin-left: auto;
852
+ padding: 0 4px; /* Slightly tighter padding for the icon */
853
+ font-size: 16px; /* Icon size */
854
+ color: var(--yh-text-color-secondary);
855
+ }
856
+ .yh-filter-bar__view-btn:hover {
857
+ color: var(--yh-filter-bar-tab-active-color);
858
+ }
859
+
860
+ .yh-filter-bar__sort-arrows {
861
+ display: inline-flex;
862
+ flex-direction: column;
863
+ gap: 1px;
864
+ font-size: 10px;
865
+ line-height: 1;
866
+ margin-left: 4px;
867
+ color: var(--yh-text-color-placeholder);
868
+ }
869
+
870
+ .yh-filter-bar__arrow-up {
871
+ display: inline-flex;
872
+ transition: color var(--yh-transition-base);
873
+ }
874
+ .yh-filter-bar__arrow-up.is-active {
875
+ color: var(--yh-filter-bar-tab-active-color);
876
+ }
877
+
878
+ .yh-filter-bar__arrow-down {
879
+ display: inline-flex;
880
+ transition: color var(--yh-transition-base);
881
+ }
882
+ .yh-filter-bar__arrow-down.is-active {
883
+ color: var(--yh-filter-bar-tab-active-color);
884
+ }
885
+
886
+ .yh-filter-bar__arrow-icon {
887
+ font-style: normal;
888
+ display: inline-flex;
889
+ font-size: 10px;
890
+ margin-left: 2px;
891
+ color: var(--yh-text-color-placeholder);
892
+ transition: transform var(--yh-transition-base);
893
+ }
894
+
895
+ .yh-filter-bar__badge {
896
+ display: inline-flex;
897
+ align-items: center;
898
+ justify-content: center;
899
+ min-width: 16px;
900
+ height: 16px;
901
+ padding: 0 4px;
902
+ border-radius: 8px;
903
+ background: var(--yh-filter-bar-badge-bg);
904
+ color: #fff;
905
+ font-size: 10px;
906
+ font-weight: 600;
907
+ line-height: 1;
908
+ }
909
+
910
+ .yh-filter-bar__filter-icon {
911
+ font-style: normal;
912
+ display: inline-flex;
913
+ align-items: center;
914
+ font-size: 14px;
915
+ }
916
+
917
+ .yh-filter-bar__inline-filter {
918
+ display: flex;
919
+ align-items: center;
920
+ gap: 6px;
921
+ flex-shrink: 0;
922
+ }
923
+
924
+ .yh-filter-bar__inline-label {
925
+ font-size: var(--yh-font-size-xs);
926
+ color: var(--yh-text-color-secondary);
927
+ white-space: nowrap;
928
+ }
929
+
930
+ .yh-filter-bar__inline-opt {
931
+ padding: 4px 14px;
932
+ border: none;
933
+ border-radius: 999px;
934
+ background: var(--yh-fill-color-light);
935
+ font-size: var(--yh-font-size-xs);
936
+ font-weight: 500;
937
+ color: var(--yh-text-color-regular);
938
+ cursor: pointer;
939
+ white-space: nowrap;
940
+ transition: color 0.3s ease, background 0.3s ease, transform 0.2s cubic-bezier(0.3, 1.5, 0.4, 1.5);
941
+ }
942
+ .yh-filter-bar__inline-opt:active {
943
+ transform: scale(0.95);
944
+ }
945
+ .yh-filter-bar__inline-opt.is-active {
946
+ color: var(--yh-filter-bar-tab-active-color);
947
+ background: var(--yh-filter-bar-panel-opt-active-bg);
948
+ font-weight: 600;
949
+ }
950
+
951
+ .yh-filter-bar__panel {
952
+ position: fixed;
953
+ inset: 0;
954
+ z-index: calc(var(--yh-filter-bar-z-index) + 1);
955
+ display: flex;
956
+ flex-direction: column;
957
+ justify-content: flex-end;
958
+ }
959
+
960
+ .yh-filter-bar__overlay {
961
+ position: absolute;
962
+ inset: 0;
963
+ background: var(--yh-overlay-color-light, rgba(0, 0, 0, 0.45));
964
+ }
965
+
966
+ .yh-filter-bar__panel-body {
967
+ position: relative;
968
+ background: var(--yh-filter-bar-panel-bg);
969
+ border-radius: var(--yh-radius-large) var(--yh-radius-large) 0 0;
970
+ box-shadow: var(--yh-filter-bar-panel-shadow);
971
+ max-height: 60vh;
972
+ display: flex;
973
+ flex-direction: column;
974
+ }
975
+
976
+ .yh-filter-bar__panel-header {
977
+ display: flex;
978
+ align-items: center;
979
+ justify-content: space-between;
980
+ padding: 14px 16px 10px;
981
+ border-bottom: 1px solid var(--yh-border-color-lighter);
982
+ flex-shrink: 0;
983
+ }
984
+
985
+ .yh-filter-bar__panel-title {
986
+ font-size: var(--yh-font-size-md);
987
+ font-weight: 600;
988
+ color: var(--yh-text-color-primary);
989
+ }
990
+
991
+ .yh-filter-bar__panel-close {
992
+ border: none;
993
+ background: none;
994
+ font-size: var(--yh-font-size-sm);
995
+ color: var(--yh-text-color-secondary);
996
+ cursor: pointer;
997
+ padding: 0;
998
+ }
999
+
1000
+ .yh-filter-bar__panel-content {
1001
+ flex: 1;
1002
+ overflow-y: auto;
1003
+ padding: 12px 16px;
1004
+ }
1005
+
1006
+ .yh-filter-bar__panel-options {
1007
+ display: flex;
1008
+ flex-wrap: wrap;
1009
+ gap: 10px;
1010
+ }
1011
+
1012
+ .yh-filter-bar__panel-opt {
1013
+ padding: 6px 16px;
1014
+ border: none;
1015
+ border-radius: 999px;
1016
+ background: var(--yh-filter-bar-panel-opt-bg);
1017
+ font-size: var(--yh-font-size-sm);
1018
+ color: var(--yh-text-color-regular);
1019
+ cursor: pointer;
1020
+ transition: color 0.3s ease, transform 0.3s ease, background 0.3s ease;
1021
+ }
1022
+ .yh-filter-bar__panel-opt:active {
1023
+ transform: scale(0.95);
1024
+ }
1025
+ .yh-filter-bar__panel-opt.is-active {
1026
+ color: var(--yh-filter-bar-panel-opt-active-color);
1027
+ background: var(--yh-filter-bar-panel-opt-active-bg);
1028
+ font-weight: 600;
1029
+ }
1030
+
1031
+ .yh-filter-bar__no-options {
1032
+ color: var(--yh-text-color-placeholder);
1033
+ text-align: center;
1034
+ font-size: var(--yh-font-size-sm);
1035
+ padding: 20px 0;
1036
+ }
1037
+
1038
+ .yh-filter-bar__panel-footer {
1039
+ display: flex;
1040
+ gap: 12px;
1041
+ padding: 12px 16px;
1042
+ border-top: 1px solid var(--yh-border-color-lighter);
1043
+ flex-shrink: 0;
1044
+ }
1045
+
1046
+ .yh-filter-bar__btn {
1047
+ flex: 1;
1048
+ height: 40px;
1049
+ border-radius: var(--yh-radius-base);
1050
+ font-size: var(--yh-font-size-base);
1051
+ font-weight: 600;
1052
+ cursor: pointer;
1053
+ border: none;
1054
+ transition: background var(--yh-transition-base), color var(--yh-transition-base);
1055
+ }
1056
+
1057
+ .yh-filter-bar__btn-reset {
1058
+ background: var(--yh-fill-color-light);
1059
+ color: var(--yh-text-color-regular);
1060
+ }
1061
+
1062
+ .yh-filter-bar__btn-confirm {
1063
+ background: var(--yh-color-primary);
1064
+ color: #fff;
1065
+ }
1066
+ .yh-filter-bar__btn-confirm:hover {
1067
+ background: var(--yh-color-primary-dark-2);
1068
+ }
1069
+
1070
+ .yh-filter-bar-panel-enter-active,
1071
+ .yh-filter-bar-panel-leave-active {
1072
+ transition: opacity 0.25s ease;
1073
+ }
1074
+ .yh-filter-bar-panel-enter-active .yh-filter-bar__panel-body,
1075
+ .yh-filter-bar-panel-leave-active .yh-filter-bar__panel-body {
1076
+ transition: transform 0.25s ease;
1077
+ }
1078
+
1079
+ .yh-filter-bar-panel-enter-from,
1080
+ .yh-filter-bar-panel-leave-to {
1081
+ opacity: 0;
1082
+ }
1083
+ .yh-filter-bar-panel-enter-from .yh-filter-bar__panel-body,
1084
+ .yh-filter-bar-panel-leave-to .yh-filter-bar__panel-body {
1085
+ transform: translateY(100%);
1086
+ }
1087
+ </style>