@yh-ui/components 0.1.17 → 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 +9 -19
  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 +7 -7
  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,1097 @@
1
+ <script setup>
2
+ import { ref, computed, onMounted, onUnmounted, watch } from "vue";
3
+ import { useNamespace } from "@yh-ui/hooks";
4
+ import { useComponentTheme } from "@yh-ui/theme";
5
+ import { productCardProps, productCardEmits } from "./product-card";
6
+ defineOptions({ name: "YhProductCard" });
7
+ const props = defineProps(productCardProps);
8
+ const emit = defineEmits(productCardEmits);
9
+ const ns = useNamespace("product-card");
10
+ const { themeStyle } = useComponentTheme(
11
+ "product-card",
12
+ computed(() => props.themeOverrides)
13
+ );
14
+ const cardRef = ref(null);
15
+ let observer = null;
16
+ const hasExposed = ref(false);
17
+ const setupObserver = () => {
18
+ if (!props.exposure || hasExposed.value) return;
19
+ observer = new IntersectionObserver(
20
+ (entries) => {
21
+ entries.forEach((entry) => {
22
+ if (entry.isIntersecting && entry.intersectionRatio >= props.exposureThreshold) {
23
+ emit("expose");
24
+ hasExposed.value = true;
25
+ if (props.exposureOnce) observer?.disconnect();
26
+ }
27
+ });
28
+ },
29
+ { threshold: [props.exposureThreshold] }
30
+ );
31
+ if (cardRef.value) observer.observe(cardRef.value);
32
+ };
33
+ onMounted(setupObserver);
34
+ onUnmounted(() => observer?.disconnect());
35
+ const currentImage = ref(props.image);
36
+ const isHovering = ref(false);
37
+ const videoActive = ref(false);
38
+ watch(
39
+ () => props.image,
40
+ (val) => {
41
+ currentImage.value = val;
42
+ }
43
+ );
44
+ const handleMouseEnter = () => {
45
+ isHovering.value = true;
46
+ if (props.hoverImage) currentImage.value = props.hoverImage;
47
+ if (props.videoSrc) videoActive.value = true;
48
+ };
49
+ const handleMouseLeave = () => {
50
+ isHovering.value = false;
51
+ currentImage.value = props.image;
52
+ if (props.videoSrc) videoActive.value = false;
53
+ };
54
+ const displayPrice = computed(() => {
55
+ const p = Number(props.price);
56
+ return isNaN(p) ? props.price : p.toFixed(2);
57
+ });
58
+ const displayMarketPrice = computed(() => {
59
+ const p = Number(props.marketPrice);
60
+ return isNaN(p) ? props.marketPrice : p.toFixed(2);
61
+ });
62
+ const displayVipPrice = computed(() => {
63
+ const p = Number(props.vipPrice);
64
+ return isNaN(p) ? props.vipPrice : p.toFixed(2);
65
+ });
66
+ const stockStyle = computed(() => ({
67
+ width: `${Math.min(100, Math.max(0, props.stockProgress))}%`,
68
+ background: props.stockColor || "var(--yh-color-primary)"
69
+ }));
70
+ const handleAction = (e) => {
71
+ if (props.soldOut || props.actionLoading) return;
72
+ emit("action", e);
73
+ };
74
+ const handleClick = (e) => {
75
+ emit("click", e);
76
+ };
77
+ const badgeImageErrors = ref({});
78
+ const handleBadgeImageError = (idx) => {
79
+ badgeImageErrors.value[idx] = true;
80
+ };
81
+ </script>
82
+
83
+ <template>
84
+ <div
85
+ ref="cardRef"
86
+ :class="[ns.b(), ns.m(props.layout), ns.is('border', props.border), ns.is('shadow', props.shadow), ns.is('sold-out', props.soldOut)]"
87
+ :style="[themeStyle, {
88
+ '--yh-product-card-title-lines': props.titleLines,
89
+ '--yh-product-card-desc-lines': props.descriptionLines
90
+ }]"
91
+ @click="handleClick"
92
+ @mouseenter="handleMouseEnter"
93
+ @mouseleave="handleMouseLeave"
94
+ >
95
+ <!-- 1. Ribbon System (Feature 1) -->
96
+ <div
97
+ v-if="props.ribbon"
98
+ :class="ns.e('ribbon')"
99
+ :style="{
100
+ backgroundColor: props.ribbonColor
101
+ }"
102
+ >
103
+ {{ props.ribbon }}
104
+ </div>
105
+
106
+ <!-- Media Area (Feature 3) -->
107
+ <div :class="ns.e('image-wrapper')">
108
+ <img
109
+ :src="currentImage"
110
+ :alt="props.title"
111
+ :class="ns.e('image')"
112
+ :loading="props.lazy ? 'lazy' : 'eager'"
113
+ />
114
+
115
+ <!-- Video Preview Overlay -->
116
+ <Transition name="yh-fade">
117
+ <div v-if="videoActive && props.videoSrc" :class="ns.e('video-overlay')">
118
+ <video :src="props.videoSrc" autoplay muted loop playsinline :class="ns.e('video')" />
119
+ </div>
120
+ </Transition>
121
+
122
+ <!-- Sold Out Mask (Feature 4) -->
123
+ <div v-if="props.soldOut" :class="ns.e('sold-out-mask')">
124
+ <span :class="ns.e('sold-out-text')">售罄</span>
125
+ </div>
126
+ </div>
127
+
128
+ <!-- Content Area -->
129
+ <div :class="ns.e('content')">
130
+ <!-- 1. Badges System (Row Style: Above Title) -->
131
+ <div
132
+ v-if="(props.tag || props.badges.length) && props.badgePosition === 'top'"
133
+ :class="ns.e('badges')"
134
+ >
135
+ <span v-if="props.tag" :class="[ns.e('badge-tag'), ns.is(props.tagType)]">{{
136
+ props.tag
137
+ }}</span>
138
+ <template v-for="(badge, idx) in props.badges" :key="idx">
139
+ <span v-if="badge.image && !badgeImageErrors[idx]" :class="ns.e('badge-img-wrap')">
140
+ <img
141
+ :src="badge.image"
142
+ :class="ns.e('badge-img')"
143
+ alt="badge"
144
+ @error="handleBadgeImageError(idx)"
145
+ />
146
+ </span>
147
+ <span
148
+ v-if="badge.text"
149
+ :class="[ns.e('badge-tag'), ns.is(badge.type || 'primary')]"
150
+ :style="{
151
+ backgroundColor: badge.color
152
+ }"
153
+ >{{ badge.text }}</span
154
+ >
155
+ </template>
156
+ </div>
157
+
158
+ <h3 :class="ns.e('title')" :title="props.title">
159
+ <!-- 2. Badges System (Inline Style: Prefix) -->
160
+ <span
161
+ v-if="(props.tag || props.badges.length) && props.badgePosition === 'inline'"
162
+ :class="[ns.e('badges'), ns.is('inline')]"
163
+ >
164
+ <span v-if="props.tag" :class="[ns.e('badge-tag'), ns.is(props.tagType)]">{{
165
+ props.tag
166
+ }}</span>
167
+ <template v-for="(badge, idx) in props.badges" :key="idx">
168
+ <span v-if="badge.image && !badgeImageErrors[idx]" :class="ns.e('badge-img-wrap')">
169
+ <img
170
+ :src="badge.image"
171
+ :class="ns.e('badge-img')"
172
+ alt="badge"
173
+ @error="handleBadgeImageError(idx)"
174
+ />
175
+ </span>
176
+ <span
177
+ v-if="badge.text"
178
+ :class="[ns.e('badge-tag'), ns.is(badge.type || 'primary')]"
179
+ :style="{
180
+ backgroundColor: badge.color
181
+ }"
182
+ >{{ badge.text }}</span
183
+ >
184
+ </template>
185
+ </span>
186
+ <slot name="title">{{ props.title }}</slot>
187
+ </h3>
188
+
189
+ <div
190
+ v-if="props.description || $slots.description"
191
+ :class="ns.e('description')"
192
+ :title="props.description"
193
+ >
194
+ <slot name="description">{{ props.description }}</slot>
195
+ </div>
196
+
197
+ <!-- Price Area (Feature 2) -->
198
+ <div :class="ns.e('price-row')">
199
+ <div :class="ns.e('main-price')">
200
+ <span :class="ns.e('currency')">{{ props.currency }}</span>
201
+ <span :class="ns.e('price-val')">{{ displayPrice }}</span>
202
+ <span v-if="props.unit" :class="ns.e('unit')">{{ props.unit }}</span>
203
+ </div>
204
+
205
+ <div v-if="props.vipPrice" :class="ns.e('vip-row')">
206
+ <span :class="ns.e('vip-label')">{{ props.vipLabel }}</span>
207
+ <span :class="ns.e('currency')">{{ props.currency }}</span>
208
+ <span :class="ns.e('vip-price')">{{ displayVipPrice }}</span>
209
+ </div>
210
+
211
+ <div v-if="props.marketPrice" :class="ns.e('market-price')">
212
+ {{ props.currency }}{{ displayMarketPrice }}
213
+ </div>
214
+ </div>
215
+
216
+ <!-- Stock Progress (Feature 2 & 侧边栏需求) -->
217
+ <div v-if="props.stockProgress" :class="ns.e('stock-area')">
218
+ <div :class="ns.e('stock-bar-bg')">
219
+ <div :class="ns.e('stock-bar-inner')" :style="stockStyle" />
220
+ </div>
221
+ <span v-if="props.stockText" :class="ns.e('stock-text')">{{ props.stockText }}</span>
222
+ </div>
223
+
224
+ <!-- Footer Actions (Feature 4) -->
225
+ <div v-if="!props.readonly" :class="ns.e('footer')">
226
+ <slot name="footer">
227
+ <button
228
+ :class="[ns.e('action-btn'), ns.is('loading', props.actionLoading), ns.is('disabled', props.soldOut)]"
229
+ @click.stop="handleAction"
230
+ >
231
+ <span v-if="props.actionLoading" :class="ns.e('loading-spinner')" />
232
+ {{ props.actionText || "\u7ACB\u5373\u8D2D\u4E70" }}
233
+ </button>
234
+ </slot>
235
+ </div>
236
+ </div>
237
+ </div>
238
+ </template>
239
+
240
+ <style>
241
+ @charset "UTF-8";
242
+ /**
243
+ * YH-UI CSS Variables
244
+ * 全局 CSS 变量定义 - 业内最佳主题系统
245
+ */
246
+ :root {
247
+ /* ==================== 密度/紧凑度系统 ==================== */
248
+ --yh-density-factor: 1;
249
+ --yh-component-size-default: 32px;
250
+ --yh-component-size-small: 24px;
251
+ --yh-component-size-large: 40px;
252
+ --yh-padding-default: 12px 16px;
253
+ --yh-padding-small: 8px 12px;
254
+ --yh-padding-large: 16px 20px;
255
+ --yh-spacing-unit: 8px;
256
+ /* ==================== 基础颜色 ==================== */
257
+ --yh-color-white: #ffffff;
258
+ --yh-color-black: #000000;
259
+ /* ==================== 颜色系统 ==================== */
260
+ /* 主色 */
261
+ --yh-color-primary: #409eff;
262
+ --yh-color-primary-light-1: #53a8ff;
263
+ --yh-color-primary-light-2: #66b1ff;
264
+ --yh-color-primary-light-3: #79bbff;
265
+ --yh-color-primary-light-4: #8cc5ff;
266
+ --yh-color-primary-light-5: #a0cfff;
267
+ --yh-color-primary-light-6: #b3d8ff;
268
+ --yh-color-primary-light-7: #c6e2ff;
269
+ --yh-color-primary-light-8: #d9ecff;
270
+ --yh-color-primary-light-9: #ecf5ff;
271
+ --yh-color-primary-dark-2: #337ecc;
272
+ /* 成功色 */
273
+ --yh-color-success: #67c23a;
274
+ --yh-color-success-light-3: #95d475;
275
+ --yh-color-success-light-5: #b3e19d;
276
+ --yh-color-success-light-7: #d1edc4;
277
+ --yh-color-success-light-9: #f0f9eb;
278
+ --yh-color-success-dark-2: #529b2e;
279
+ /* 警告色 */
280
+ --yh-color-warning: #e6a23c;
281
+ --yh-color-warning-light-3: #eebe77;
282
+ --yh-color-warning-light-5: #f3d19e;
283
+ --yh-color-warning-light-7: #f8e3c5;
284
+ --yh-color-warning-light-9: #fdf6ec;
285
+ --yh-color-warning-dark-2: #b88230;
286
+ /* 危险色 */
287
+ --yh-color-danger: #f56c6c;
288
+ --yh-color-danger-light-3: #f89898;
289
+ --yh-color-danger-light-5: #fab6b6;
290
+ --yh-color-danger-light-7: #fcd3d3;
291
+ --yh-color-danger-light-9: #fef0f0;
292
+ --yh-color-danger-dark-2: #c45656;
293
+ /* 信息色 */
294
+ --yh-color-info: #909399;
295
+ --yh-color-info-light-3: #b1b3b8;
296
+ --yh-color-info-light-5: #c8c9cc;
297
+ --yh-color-info-light-7: #dedfe0;
298
+ --yh-color-info-light-9: #f4f4f5;
299
+ --yh-color-info-dark-2: #73767a;
300
+ /* 文字颜色 */
301
+ --yh-text-color-primary: #303133;
302
+ --yh-text-color-regular: #606266;
303
+ --yh-text-color-secondary: #909399;
304
+ --yh-text-color-placeholder: #a8abb2;
305
+ --yh-text-color-disabled: #c0c4cc;
306
+ /* 边框颜色 */
307
+ --yh-border-color: #dcdfe6;
308
+ --yh-border-color-hover: var(--yh-color-primary);
309
+ --yh-border-color-light: #e4e7ed;
310
+ --yh-border-color-lighter: #ebeef5;
311
+ --yh-border-color-extra-light: #f2f6fc;
312
+ --yh-border-color-dark: #d4d7de;
313
+ --yh-border-color-darker: #cdd0d6;
314
+ /* 填充颜色 */
315
+ --yh-fill-color: #f0f2f5;
316
+ --yh-fill-color-light: #f5f7fa;
317
+ --yh-fill-color-lighter: #fafafa;
318
+ --yh-fill-color-extra-light: #fafcff;
319
+ --yh-fill-color-dark: #ebedf0;
320
+ --yh-fill-color-darker: #e6e8eb;
321
+ --yh-fill-color-blank: #ffffff;
322
+ /* 背景颜色 */
323
+ --yh-bg-color: #ffffff;
324
+ --yh-bg-color-page: #f2f3f5;
325
+ --yh-bg-color-overlay: #ffffff;
326
+ /* ==================== 间距系统 ==================== */
327
+ --yh-spacing-none: 0;
328
+ --yh-spacing-xs: 4px;
329
+ --yh-spacing-sm: 8px;
330
+ --yh-spacing-md: 16px;
331
+ --yh-spacing-lg: 24px;
332
+ --yh-spacing-xl: 32px;
333
+ --yh-spacing-xxl: 48px;
334
+ /* ==================== 圆角系统 ==================== */
335
+ --yh-radius-none: 0;
336
+ --yh-radius-sm: 2px;
337
+ --yh-radius-base: 4px;
338
+ --yh-radius-md: 8px;
339
+ --yh-radius-lg: 12px;
340
+ --yh-radius-xl: 16px;
341
+ --yh-radius-round: 20px;
342
+ --yh-radius-circle: 50%;
343
+ /* ==================== 字体系统 ==================== */
344
+ --yh-font-family:
345
+ -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans',
346
+ sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';
347
+ /* 字号 */
348
+ --yh-font-size-xs: 12px;
349
+ --yh-font-size-sm: 13px;
350
+ --yh-font-size-base: 14px;
351
+ --yh-font-size-md: 16px;
352
+ --yh-font-size-lg: 18px;
353
+ --yh-font-size-xl: 20px;
354
+ --yh-font-size-xxl: 24px;
355
+ /* 行高 */
356
+ --yh-line-height-none: 1;
357
+ --yh-line-height-tight: 1.25;
358
+ --yh-line-height-snug: 1.375;
359
+ --yh-line-height-normal: 1.5;
360
+ --yh-line-height-relaxed: 1.625;
361
+ --yh-line-height-loose: 2;
362
+ /* 字重 */
363
+ --yh-font-weight-light: 300;
364
+ --yh-font-weight-normal: 400;
365
+ --yh-font-weight-medium: 500;
366
+ --yh-font-weight-semibold: 600;
367
+ --yh-font-weight-bold: 700;
368
+ /* ==================== 阴影系统 ==================== */
369
+ --yh-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
370
+ --yh-shadow-base: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
371
+ --yh-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
372
+ --yh-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
373
+ --yh-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
374
+ /* ==================== 过渡动效 ==================== */
375
+ --yh-duration-fast: 150ms;
376
+ --yh-duration-base: 200ms;
377
+ --yh-duration-slow: 300ms;
378
+ --yh-timing-ease: ease;
379
+ --yh-timing-ease-in: cubic-bezier(0.4, 0, 1, 1);
380
+ --yh-timing-ease-out: cubic-bezier(0, 0, 0.2, 1);
381
+ --yh-timing-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
382
+ --yh-timing-linear: linear;
383
+ --yh-transition-base: all var(--yh-duration-base) var(--yh-timing-ease-in-out);
384
+ --yh-transition-fast: all var(--yh-duration-fast) var(--yh-timing-ease-in-out);
385
+ --yh-transition-slow: all var(--yh-duration-slow) var(--yh-timing-ease-in-out);
386
+ /* ==================== 层级系统 ==================== */
387
+ --yh-z-index-normal: 1;
388
+ --yh-z-index-top: 1000;
389
+ --yh-z-index-popper: 2000;
390
+ --yh-z-index-overlay: 2001;
391
+ --yh-z-index-modal: 2002;
392
+ --yh-z-index-popover: 2003;
393
+ --yh-z-index-tooltip: 2004;
394
+ --yh-z-index-loading: 2005;
395
+ /* ==================== 组件尺寸 ==================== */
396
+ /* Large */
397
+ --yh-component-size-large: 40px;
398
+ --yh-component-size-large-font: 14px;
399
+ --yh-component-size-large-padding: 20px;
400
+ /* Default */
401
+ --yh-component-size-default: 32px;
402
+ --yh-component-size-default-font: 14px;
403
+ --yh-component-size-default-padding: 16px;
404
+ /* Small */
405
+ --yh-component-size-small: 24px;
406
+ --yh-component-size-small-font: 12px;
407
+ --yh-component-size-small-padding: 12px;
408
+ /* ==================== 组件语义化变量 ==================== */
409
+ --yh-border-radius-base: var(--yh-radius-base);
410
+ --yh-border-radius-small: var(--yh-radius-sm);
411
+ --yh-border-radius-round: var(--yh-radius-round);
412
+ /* Message 消息提示 */
413
+ --yh-message-bg-color: var(--yh-bg-color-overlay);
414
+ --yh-message-border-color: var(--yh-border-color-lighter);
415
+ --yh-message-shadow: var(--yh-shadow-lg);
416
+ --yh-message-text-color: var(--yh-text-color-primary);
417
+ --yh-message-close-color: var(--yh-text-color-secondary);
418
+ --yh-message-close-hover-color: var(--yh-text-color-primary);
419
+ /* Notification 通知 */
420
+ --yh-notification-bg-color: var(--yh-bg-color-overlay);
421
+ --yh-notification-border-color: var(--yh-border-color-lighter);
422
+ --yh-notification-shadow: var(--yh-shadow-lg);
423
+ --yh-notification-title-color: var(--yh-text-color-primary);
424
+ --yh-notification-content-color: var(--yh-text-color-regular);
425
+ /* Badge 徽标 */
426
+ --yh-badge-bg-color: var(--yh-color-danger);
427
+ --yh-badge-text-color: #ffffff;
428
+ --yh-badge-border-color: var(--yh-bg-color);
429
+ /* Card 卡片 */
430
+ --yh-card-bg-color: var(--yh-bg-color-overlay);
431
+ --yh-card-border-color: var(--yh-border-color-lighter);
432
+ --yh-card-shadow: var(--yh-shadow-base);
433
+ --yh-card-header-padding: 18px 20px;
434
+ --yh-card-body-padding: 20px;
435
+ /* Input 输入框 */
436
+ --yh-input-bg-color: var(--yh-fill-color-blank);
437
+ --yh-input-text-color: var(--yh-text-color-regular);
438
+ --yh-input-border-color: var(--yh-border-color);
439
+ --yh-input-hover-border-color: var(--yh-color-primary);
440
+ --yh-input-focus-border-color: var(--yh-color-primary);
441
+ --yh-input-placeholder-color: var(--yh-text-color-placeholder);
442
+ --yh-input-icon-color: var(--yh-text-color-placeholder);
443
+ --yh-input-disabled-bg-color: var(--yh-fill-color-light);
444
+ --yh-input-disabled-text-color: var(--yh-text-color-disabled);
445
+ --yh-input-disabled-border-color: var(--yh-border-color-light);
446
+ /* Image 图片 */
447
+ --yh-image-placeholder-bg-color: var(--yh-fill-color-light);
448
+ --yh-image-placeholder-text-color: var(--yh-text-color-placeholder);
449
+ --yh-image-error-bg-color: var(--yh-fill-color-extra-light);
450
+ --yh-image-error-text-color: var(--yh-text-color-placeholder);
451
+ /* Image Viewer 预览器 */
452
+ --yh-image-viewer-mask-bg-color: rgba(0, 0, 0, 0.5);
453
+ --yh-image-viewer-btn-bg-color: var(--yh-text-color-regular);
454
+ --yh-image-viewer-btn-color: #ffffff;
455
+ --yh-image-viewer-btn-hover-bg-color: var(--yh-color-primary);
456
+ /* Calendar 日历 */
457
+ --yh-calendar-bg: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
458
+ --yh-calendar-border-color: rgba(0, 0, 0, 0.06);
459
+ --yh-calendar-border-radius: var(--yh-radius-xl);
460
+ --yh-calendar-header-bg: rgba(255, 255, 255, 0.95);
461
+ --yh-calendar-header-border: rgba(0, 0, 0, 0.04);
462
+ --yh-calendar-header-padding: 18px 22px;
463
+ --yh-calendar-body-padding: 14px 18px 18px;
464
+ /* Calendar 尺寸 */
465
+ --yh-calendar-cell-height: 85px;
466
+ --yh-calendar-cell-height-small: 52px;
467
+ --yh-calendar-cell-height-large: 110px;
468
+ --yh-calendar-cell-radius: 10px;
469
+ --yh-calendar-cell-radius-small: 6px;
470
+ --yh-calendar-cell-radius-large: 12px;
471
+ /* Calendar 颜色 */
472
+ --yh-calendar-primary: var(--yh-color-primary);
473
+ --yh-calendar-primary-light: rgba(59, 130, 246, 0.1);
474
+ --yh-calendar-selected-bg: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
475
+ --yh-calendar-selected-border: rgba(59, 130, 246, 0.4);
476
+ --yh-calendar-today-dot: var(--yh-color-primary);
477
+ --yh-calendar-weekend-color: #f97316;
478
+ --yh-calendar-disabled-color: var(--yh-text-color-disabled);
479
+ --yh-calendar-other-month-opacity: 0.35;
480
+ /* Calendar 假日 */
481
+ --yh-calendar-holiday-color: var(--yh-color-success);
482
+ --yh-calendar-holiday-bg: rgba(16, 185, 129, 0.12);
483
+ --yh-calendar-holiday-border: rgba(16, 185, 129, 0.25);
484
+ --yh-calendar-workday-color: var(--yh-color-warning);
485
+ --yh-calendar-workday-bg: rgba(245, 158, 11, 0.12);
486
+ --yh-calendar-workday-border: rgba(245, 158, 11, 0.25);
487
+ /* Calendar 范围选择 */
488
+ --yh-calendar-range-bg: rgba(59, 130, 246, 0.08);
489
+ --yh-calendar-range-border: rgba(59, 130, 246, 0.2);
490
+ /* Calendar 字体 */
491
+ --yh-calendar-weekday-font-size: var(--yh-font-size-sm);
492
+ --yh-calendar-weekday-color: var(--yh-text-color-secondary);
493
+ --yh-calendar-day-font-size: 15px;
494
+ --yh-calendar-day-color: var(--yh-text-color-primary);
495
+ --yh-calendar-badge-font-size: 9px;
496
+ /* Table 表格 */
497
+ --yh-table-border-color: var(--yh-border-color-lighter);
498
+ --yh-table-header-bg: var(--yh-fill-color-light);
499
+ --yh-table-header-text-color: var(--yh-text-color-primary);
500
+ --yh-table-header-font-weight: var(--yh-font-weight-semibold);
501
+ --yh-table-row-bg: var(--yh-bg-color);
502
+ --yh-table-row-hover-bg: var(--yh-fill-color-light);
503
+ --yh-table-row-stripe-bg: var(--yh-fill-color-lighter);
504
+ --yh-table-row-current-bg: var(--yh-color-primary-light-9);
505
+ --yh-table-row-selected-bg: var(--yh-color-primary-light-8);
506
+ --yh-table-row-success-bg: var(--yh-color-success-light-9);
507
+ --yh-table-row-warning-bg: var(--yh-color-warning-light-9);
508
+ --yh-table-text-color: var(--yh-text-color-regular);
509
+ --yh-table-empty-text-color: var(--yh-text-color-secondary);
510
+ --yh-table-font-size: var(--yh-font-size-base);
511
+ --yh-table-cell-padding: 12px 0;
512
+ --yh-table-cell-spacing: 12px;
513
+ --yh-table-fixed-left-shadow: inset 10px 0 8px -8px rgba(0, 0, 0, 0.15);
514
+ --yh-table-fixed-right-shadow: inset -10px 0 8px -8px rgba(0, 0, 0, 0.15);
515
+ /* ==================== 边框基础 ==================== */
516
+ --yh-border-width: 1px;
517
+ --yh-border-style: solid;
518
+ --yh-border: var(--yh-border-width) var(--yh-border-style) var(--yh-border-color);
519
+ /* ==================== 断点系统 ==================== */
520
+ --yh-breakpoint-xs: 0;
521
+ --yh-breakpoint-sm: 576px;
522
+ --yh-breakpoint-md: 768px;
523
+ --yh-breakpoint-lg: 992px;
524
+ --yh-breakpoint-xl: 1200px;
525
+ --yh-breakpoint-xxl: 1400px;
526
+ /* ==================== 字体系统扩展 ==================== */
527
+ --yh-font-family-monospace:
528
+ 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, Courier, monospace;
529
+ --yh-font-family-serif: Georgia, Cambria, 'Times New Roman', Times, serif;
530
+ /* ==================== 无障碍/聚焦系统 ==================== */
531
+ --yh-focus-ring-color: var(--yh-color-primary);
532
+ --yh-focus-ring-width: 2px;
533
+ --yh-focus-ring-offset: 2px;
534
+ --yh-focus-ring-opacity: 0.2;
535
+ --yh-focus-ring:
536
+ 0 0 0 var(--yh-focus-ring-offset) var(--yh-bg-color),
537
+ 0 0 0 calc(var(--yh-focus-ring-offset) + var(--yh-focus-ring-width)) var(--yh-focus-ring-color);
538
+ /* 高对比度模式支持 */
539
+ --yh-high-contrast-outline: 2px solid transparent;
540
+ --yh-high-contrast-outline-offset: 2px;
541
+ /* ==================== 滚动条样式 ==================== */
542
+ --yh-scrollbar-width: 6px;
543
+ --yh-scrollbar-thumb-color: var(--yh-text-color-disabled);
544
+ --yh-scrollbar-thumb-hover-color: var(--yh-text-color-secondary);
545
+ --yh-scrollbar-track-color: transparent;
546
+ --yh-scrollbar-thumb-radius: 3px;
547
+ /* ==================== 遮罩层 ==================== */
548
+ --yh-mask-color: rgba(0, 0, 0, 0.5);
549
+ --yh-mask-color-light: rgba(0, 0, 0, 0.3);
550
+ --yh-mask-color-extra-light: rgba(0, 0, 0, 0.1);
551
+ }
552
+
553
+ /* ==================== 暗黑模式 ==================== */
554
+ html.dark {
555
+ --yh-color-primary: #409eff;
556
+ --yh-color-primary-light-3: #3375b9;
557
+ --yh-color-primary-light-5: #2a598a;
558
+ --yh-color-primary-light-7: #213d5b;
559
+ --yh-color-primary-light-9: #18222c;
560
+ --yh-color-primary-dark-2: #66b1ff;
561
+ --yh-color-success: #67c23a;
562
+ --yh-color-success-light-3: #4e8e2f;
563
+ --yh-color-success-light-5: #3e6b27;
564
+ --yh-color-success-light-7: #2d481f;
565
+ --yh-color-success-light-9: #1d2518;
566
+ --yh-color-warning: #e6a23c;
567
+ --yh-color-warning-light-3: #a77730;
568
+ --yh-color-warning-light-5: #7d5b28;
569
+ --yh-color-warning-light-7: #533f20;
570
+ --yh-color-warning-light-9: #292218;
571
+ --yh-color-danger: #f56c6c;
572
+ --yh-color-danger-light-3: #b25252;
573
+ --yh-color-danger-light-5: #854040;
574
+ --yh-color-danger-light-7: #582e2e;
575
+ --yh-color-danger-light-9: #2b1d1d;
576
+ --yh-color-info: #909399;
577
+ --yh-color-info-light-3: #6b6d71;
578
+ --yh-color-info-light-5: #525457;
579
+ --yh-color-info-light-7: #393b3e;
580
+ --yh-color-info-light-9: #202124;
581
+ --yh-text-color-primary: #e5eaf3;
582
+ --yh-text-color-regular: #cfd3dc;
583
+ --yh-text-color-secondary: #a3a6ad;
584
+ --yh-text-color-placeholder: #8d9095;
585
+ --yh-text-color-disabled: #6c6e72;
586
+ --yh-border-color: #4c4d4f;
587
+ --yh-border-color-light: #414243;
588
+ --yh-border-color-lighter: #363637;
589
+ --yh-border-color-extra-light: #2b2b2c;
590
+ --yh-border-color-dark: #58585b;
591
+ --yh-border-color-darker: #636466;
592
+ --yh-fill-color: #303030;
593
+ --yh-fill-color-light: #262727;
594
+ --yh-fill-color-lighter: #1d1d1d;
595
+ --yh-fill-color-extra-light: #191919;
596
+ --yh-fill-color-dark: #39393a;
597
+ --yh-fill-color-darker: #424243;
598
+ --yh-fill-color-blank: transparent;
599
+ --yh-bg-color: #141414;
600
+ --yh-bg-color-page: #0a0a0a;
601
+ --yh-bg-color-overlay: #1d1e1f;
602
+ /* 组件暗色模式覆盖 */
603
+ --yh-message-bg-color: var(--yh-bg-color-overlay);
604
+ --yh-message-border-color: var(--yh-border-color-lighter);
605
+ --yh-notification-bg-color: var(--yh-bg-color-overlay);
606
+ --yh-notification-border-color: var(--yh-border-color-lighter);
607
+ --yh-badge-border-color: var(--yh-bg-color);
608
+ --yh-card-bg-color: var(--yh-bg-color-overlay);
609
+ --yh-card-border-color: var(--yh-border-color-lighter);
610
+ /* Calendar 暗黑模式 */
611
+ --yh-calendar-bg: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
612
+ --yh-calendar-border-color: rgba(255, 255, 255, 0.08);
613
+ --yh-calendar-header-bg: rgba(30, 30, 30, 0.95);
614
+ --yh-calendar-header-border: rgba(255, 255, 255, 0.06);
615
+ --yh-calendar-day-color: var(--yh-text-color-primary);
616
+ --yh-calendar-weekday-color: var(--yh-text-color-secondary);
617
+ --yh-calendar-selected-bg: linear-gradient(
618
+ 135deg,
619
+ rgba(59, 130, 246, 0.2) 0%,
620
+ rgba(59, 130, 246, 0.1) 100%
621
+ );
622
+ /* Table 暗黑模式 */
623
+ --yh-table-border-color: var(--yh-border-color-lighter);
624
+ --yh-table-header-bg: var(--yh-fill-color-dark);
625
+ --yh-table-header-text-color: var(--yh-text-color-primary);
626
+ --yh-table-row-bg: var(--yh-bg-color);
627
+ --yh-table-row-hover-bg: var(--yh-fill-color);
628
+ --yh-table-row-stripe-bg: var(--yh-fill-color-light);
629
+ --yh-table-row-current-bg: var(--yh-color-primary-light-9);
630
+ --yh-table-row-selected-bg: var(--yh-color-primary-light-9);
631
+ --yh-table-row-success-bg: var(--yh-color-success-light-9);
632
+ --yh-table-row-warning-bg: var(--yh-color-warning-light-9);
633
+ --yh-table-fixed-left-shadow: inset 10px 0 8px -8px rgba(0, 0, 0, 0.3);
634
+ --yh-table-fixed-right-shadow: inset -10px 0 8px -8px rgba(0, 0, 0, 0.3);
635
+ /* 遮罩层暗黑模式 */
636
+ --yh-mask-color: rgba(0, 0, 0, 0.7);
637
+ --yh-mask-color-light: rgba(0, 0, 0, 0.5);
638
+ --yh-mask-color-extra-light: rgba(0, 0, 0, 0.3);
639
+ /* 滚动条暗黑模式 */
640
+ --yh-scrollbar-thumb-color: var(--yh-fill-color-darker);
641
+ --yh-scrollbar-thumb-hover-color: var(--yh-text-color-placeholder);
642
+ }
643
+
644
+ /* ==================== 减少动画偏好支持 ==================== */
645
+ @media (prefers-reduced-motion: reduce) {
646
+ :root,
647
+ html.dark {
648
+ --yh-duration-fast: 0ms;
649
+ --yh-duration-base: 0ms;
650
+ --yh-duration-slow: 0ms;
651
+ --yh-transition-base: none;
652
+ --yh-transition-fast: none;
653
+ --yh-transition-slow: none;
654
+ }
655
+ *,
656
+ *::before,
657
+ *::after {
658
+ animation-duration: 0.01ms !important;
659
+ animation-iteration-count: 1 !important;
660
+ transition-duration: 0.01ms !important;
661
+ scroll-behavior: auto !important;
662
+ }
663
+ }
664
+ /* ==================== 高对比度模式支持 ==================== */
665
+ @media (prefers-contrast: high) {
666
+ :root {
667
+ --yh-border-color: #000000;
668
+ --yh-border-color-light: #333333;
669
+ --yh-text-color-primary: #000000;
670
+ --yh-text-color-regular: #1a1a1a;
671
+ --yh-focus-ring-width: 3px;
672
+ --yh-focus-ring-color: #000000;
673
+ }
674
+ html.dark {
675
+ --yh-border-color: #ffffff;
676
+ --yh-border-color-light: #cccccc;
677
+ --yh-text-color-primary: #ffffff;
678
+ --yh-text-color-regular: #e5e5e5;
679
+ --yh-focus-ring-color: #ffffff;
680
+ }
681
+ }
682
+ /* ==================== 强制颜色模式支持 (Windows 高对比度) ==================== */
683
+ @media (forced-colors: active) {
684
+ :root {
685
+ --yh-color-primary: LinkText;
686
+ --yh-border-color: ButtonBorder;
687
+ --yh-bg-color: Canvas;
688
+ --yh-text-color-primary: CanvasText;
689
+ --yh-focus-ring-color: Highlight;
690
+ }
691
+ }
692
+ .yh-product-card {
693
+ --yh-product-card-bg: var(--yh-bg-color-overlay);
694
+ --yh-product-card-radius: var(--yh-radius-base);
695
+ --yh-product-card-title-size: 15px;
696
+ --yh-product-card-price-color: var(--yh-color-danger);
697
+ --yh-product-card-vip-color: #f7d081;
698
+ --yh-product-card-btn-bg: var(--yh-color-primary);
699
+ position: relative;
700
+ display: flex;
701
+ flex-direction: column;
702
+ background-color: var(--yh-product-card-bg);
703
+ border-radius: var(--yh-product-card-radius);
704
+ overflow: hidden;
705
+ transition: all var(--yh-transition-base);
706
+ cursor: pointer;
707
+ }
708
+ .yh-product-card.is-border {
709
+ border: 1px solid var(--yh-border-color-lighter);
710
+ }
711
+
712
+ .yh-product-card.is-shadow:hover {
713
+ box-shadow: var(--yh-shadow-base);
714
+ transform: translateY(-5px);
715
+ }
716
+
717
+ .yh-product-card.is-sold-out {
718
+ cursor: not-allowed;
719
+ }
720
+ .yh-product-card.is-sold-out .yh-product-card__image {
721
+ filter: grayscale(0.8);
722
+ opacity: 0.8;
723
+ }
724
+
725
+ .yh-product-card.is-sold-out .yh-product-card__title {
726
+ opacity: 0.6;
727
+ }
728
+
729
+ .yh-product-card.is-sold-out .yh-product-card__price-row {
730
+ opacity: 0.6;
731
+ }
732
+
733
+ .yh-product-card__ribbon {
734
+ position: absolute;
735
+ top: 12px;
736
+ right: -28px;
737
+ z-index: 10;
738
+ width: 100px;
739
+ padding: 2px 0;
740
+ background-color: var(--yh-color-danger);
741
+ color: #fff;
742
+ font-size: 11px;
743
+ text-align: center;
744
+ transform: rotate(45deg);
745
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
746
+ font-weight: bold;
747
+ pointer-events: none;
748
+ }
749
+
750
+ .yh-product-card__image-wrapper {
751
+ position: relative;
752
+ width: 100%;
753
+ aspect-ratio: 1/1;
754
+ overflow: hidden;
755
+ background-color: var(--yh-fill-color-light);
756
+ }
757
+ .yh-product-card__image {
758
+ width: 100%;
759
+ height: 100%;
760
+ object-fit: cover;
761
+ transition: transform var(--yh-transition-slow);
762
+ }
763
+
764
+ .yh-product-card__image-wrapper:hover .yh-product-card__image {
765
+ transform: scale(1.08);
766
+ }
767
+
768
+ .yh-product-card__video-overlay {
769
+ position: absolute;
770
+ inset: 0;
771
+ z-index: 5;
772
+ background: rgba(0, 0, 0, 0.1);
773
+ backdrop-filter: blur(2px);
774
+ display: flex;
775
+ align-items: center;
776
+ justify-content: center;
777
+ }
778
+ .yh-product-card__video {
779
+ width: 100%;
780
+ height: 100%;
781
+ object-fit: cover;
782
+ }
783
+
784
+ .yh-product-card__sold-out-mask {
785
+ position: absolute;
786
+ inset: 0;
787
+ z-index: 8;
788
+ background: rgba(0, 0, 0, 0.4);
789
+ display: flex;
790
+ align-items: center;
791
+ justify-content: center;
792
+ }
793
+ .yh-product-card__sold-out-text {
794
+ color: #fff;
795
+ font-size: 18px;
796
+ font-weight: bold;
797
+ border: 2px solid #fff;
798
+ padding: 4px 12px;
799
+ border-radius: 4px;
800
+ letter-spacing: 2px;
801
+ }
802
+
803
+ .yh-product-card__content {
804
+ flex: 1;
805
+ padding: 12px;
806
+ display: flex;
807
+ flex-direction: column;
808
+ gap: 8px;
809
+ }
810
+
811
+ .yh-product-card__badges {
812
+ display: flex;
813
+ flex-wrap: wrap;
814
+ align-items: center;
815
+ gap: 6px;
816
+ margin-bottom: 4px;
817
+ }
818
+ .yh-product-card__badges.is-inline {
819
+ display: inline-flex;
820
+ vertical-align: middle;
821
+ margin-right: 8px;
822
+ margin-bottom: 0;
823
+ }
824
+
825
+ .yh-product-card__badge-img-wrap {
826
+ display: inline-flex;
827
+ align-items: center;
828
+ justify-content: center;
829
+ width: 16px;
830
+ height: 16px;
831
+ flex-shrink: 0;
832
+ vertical-align: middle;
833
+ overflow: hidden;
834
+ }
835
+
836
+ .yh-product-card__badge-img {
837
+ width: 100%;
838
+ height: 100%;
839
+ object-fit: contain;
840
+ display: block;
841
+ }
842
+
843
+ .yh-product-card__badge-tag {
844
+ display: inline-flex;
845
+ align-items: center;
846
+ justify-content: center;
847
+ height: 16px;
848
+ font-size: 10px;
849
+ padding: 0 6px;
850
+ border-radius: 2px;
851
+ white-space: nowrap;
852
+ font-weight: 500;
853
+ }
854
+ .yh-product-card__badge-tag.is-primary {
855
+ background: var(--yh-color-primary-light-9);
856
+ color: var(--yh-color-primary);
857
+ }
858
+
859
+ .yh-product-card__badge-tag.is-danger {
860
+ background: var(--yh-color-danger-light-9);
861
+ color: var(--yh-color-danger);
862
+ }
863
+
864
+ .yh-product-card__badge-tag.is-success {
865
+ background: var(--yh-color-success-light-9);
866
+ color: var(--yh-color-success);
867
+ }
868
+
869
+ .yh-product-card__badge-tag.is-warning {
870
+ background: var(--yh-color-warning-light-9);
871
+ color: var(--yh-color-warning);
872
+ }
873
+
874
+ .yh-product-card__badge-tag.is-info {
875
+ background: var(--yh-color-info-light-9);
876
+ color: var(--yh-color-info);
877
+ }
878
+
879
+ .yh-product-card__title {
880
+ margin: 0;
881
+ font-size: var(--yh-product-card-title-size);
882
+ color: var(--yh-text-color-primary);
883
+ line-height: 1.4;
884
+ font-weight: 500;
885
+ display: -webkit-box;
886
+ -webkit-line-clamp: var(--yh-product-card-title-lines, 2);
887
+ -webkit-box-orient: vertical;
888
+ overflow: hidden;
889
+ }
890
+
891
+ .yh-product-card__description {
892
+ font-size: 12px;
893
+ color: var(--yh-text-color-secondary);
894
+ display: -webkit-box;
895
+ -webkit-line-clamp: var(--yh-product-card-desc-lines, 1);
896
+ -webkit-box-orient: vertical;
897
+ overflow: hidden;
898
+ }
899
+
900
+ .yh-product-card__price-row {
901
+ display: flex;
902
+ flex-direction: column;
903
+ gap: 2px;
904
+ margin-top: 4px;
905
+ }
906
+
907
+ .yh-product-card__main-price {
908
+ color: var(--yh-product-card-price-color);
909
+ display: flex;
910
+ align-items: baseline;
911
+ gap: 1px;
912
+ }
913
+ .yh-product-card__currency {
914
+ font-size: 12px;
915
+ font-weight: bold;
916
+ }
917
+
918
+ .yh-product-card__price-val {
919
+ font-size: 20px;
920
+ font-weight: bold;
921
+ font-family: "Din", sans-serif;
922
+ }
923
+
924
+ .yh-product-card__unit {
925
+ font-size: 11px;
926
+ color: var(--yh-text-color-placeholder);
927
+ margin-left: 2px;
928
+ }
929
+
930
+ .yh-product-card__vip-row {
931
+ display: inline-flex;
932
+ align-items: center;
933
+ background: #1a1a1a;
934
+ color: var(--yh-product-card-vip-color);
935
+ padding: 0 6px;
936
+ border-radius: 2px;
937
+ font-size: 10px;
938
+ width: fit-content;
939
+ }
940
+ .yh-product-card__vip-label {
941
+ font-weight: bold;
942
+ margin-right: 4px;
943
+ }
944
+
945
+ .yh-product-card__vip-price {
946
+ font-weight: bold;
947
+ font-family: "Din";
948
+ }
949
+
950
+ .yh-product-card__market-price {
951
+ font-size: 11px;
952
+ color: var(--yh-text-color-placeholder);
953
+ text-decoration: line-through;
954
+ }
955
+
956
+ .yh-product-card__stock-area {
957
+ display: flex;
958
+ align-items: center;
959
+ gap: 8px;
960
+ margin-top: 4px;
961
+ }
962
+ .yh-product-card__stock-bar-bg {
963
+ flex: 1;
964
+ height: 6px;
965
+ background: var(--yh-fill-color-darker);
966
+ border-radius: 10px;
967
+ overflow: hidden;
968
+ }
969
+
970
+ .yh-product-card__stock-bar-inner {
971
+ height: 100%;
972
+ border-radius: 10px;
973
+ transition: width var(--yh-transition-slow) ease-in-out;
974
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) inset;
975
+ }
976
+
977
+ .yh-product-card__stock-text {
978
+ font-size: 10px;
979
+ color: var(--yh-text-color-secondary);
980
+ flex-shrink: 0;
981
+ }
982
+
983
+ .yh-product-card__footer {
984
+ margin-top: 8px;
985
+ }
986
+
987
+ .yh-product-card__action-btn {
988
+ width: 100%;
989
+ height: 36px;
990
+ border: none;
991
+ background-color: var(--yh-product-card-btn-bg);
992
+ color: #fff;
993
+ border-radius: 4px;
994
+ font-size: 14px;
995
+ font-weight: 500;
996
+ cursor: pointer;
997
+ display: flex;
998
+ align-items: center;
999
+ justify-content: center;
1000
+ gap: 8px;
1001
+ transition: filter var(--yh-transition-fast);
1002
+ }
1003
+ .yh-product-card__action-btn:hover {
1004
+ filter: brightness(1.1);
1005
+ }
1006
+ .yh-product-card__action-btn:active {
1007
+ filter: brightness(0.9);
1008
+ }
1009
+ .yh-product-card__action-btn.is-disabled {
1010
+ background: var(--yh-fill-color-dark) !important;
1011
+ cursor: not-allowed;
1012
+ filter: none;
1013
+ }
1014
+
1015
+ .yh-product-card__action-btn.is-loading {
1016
+ cursor: wait;
1017
+ opacity: 0.8;
1018
+ }
1019
+
1020
+ .yh-product-card__loading-spinner {
1021
+ width: 14px;
1022
+ height: 14px;
1023
+ border: 2px solid rgba(255, 255, 255, 0.3);
1024
+ border-top-color: #fff;
1025
+ border-radius: 50%;
1026
+ animation: yh-rotate 0.8s linear infinite;
1027
+ }
1028
+
1029
+ .yh-product-card {
1030
+ /* --- 布局适配 --- */
1031
+ }
1032
+ .yh-product-card--horizontal {
1033
+ flex-direction: row;
1034
+ height: 160px;
1035
+ }
1036
+ .yh-product-card--horizontal .yh-product-card__image-wrapper {
1037
+ width: 160px;
1038
+ height: 100%;
1039
+ }
1040
+
1041
+ .yh-product-card--horizontal .yh-product-card__content {
1042
+ padding: 12px 16px;
1043
+ justify-content: space-between;
1044
+ }
1045
+
1046
+ .yh-product-card--horizontal .yh-product-card__action-btn {
1047
+ width: auto;
1048
+ padding: 0 24px;
1049
+ align-self: flex-end;
1050
+ }
1051
+
1052
+ .yh-product-card--compact .yh-product-card__content {
1053
+ padding: 8px;
1054
+ gap: 4px;
1055
+ }
1056
+
1057
+ .yh-product-card--compact .yh-product-card__title {
1058
+ font-size: 13px;
1059
+ -webkit-line-clamp: 1;
1060
+ }
1061
+
1062
+ .yh-product-card--compact .yh-product-card__description {
1063
+ font-size: 11px;
1064
+ opacity: 0.8;
1065
+ }
1066
+
1067
+ .yh-product-card--compact .yh-product-card__price-val {
1068
+ font-size: 16px;
1069
+ font-weight: 600;
1070
+ }
1071
+
1072
+ .yh-product-card--compact .yh-product-card__footer {
1073
+ margin-top: 4px;
1074
+ }
1075
+
1076
+ .yh-product-card--compact .yh-product-card__action-btn {
1077
+ height: 26px;
1078
+ font-size: 12px;
1079
+ }
1080
+
1081
+ @keyframes yh-rotate {
1082
+ from {
1083
+ transform: rotate(0deg);
1084
+ }
1085
+ to {
1086
+ transform: rotate(360deg);
1087
+ }
1088
+ }
1089
+ @keyframes yh-fade {
1090
+ from {
1091
+ opacity: 0;
1092
+ }
1093
+ to {
1094
+ opacity: 1;
1095
+ }
1096
+ }
1097
+ </style>