@yh-ui/components 0.1.21 → 0.1.23

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 (485) hide show
  1. package/README.md +2 -0
  2. package/dist/breadcrumb/src/breadcrumb-item.vue +10 -6
  3. package/dist/form/index.cjs +1 -1
  4. package/dist/form/index.d.ts +1 -1
  5. package/dist/form/index.mjs +1 -1
  6. package/dist/icon/index.cjs +1 -1
  7. package/dist/icon/index.d.ts +1 -1
  8. package/dist/icon/index.mjs +1 -1
  9. package/dist/loading/index.cjs +1 -1
  10. package/dist/loading/index.d.ts +1 -1
  11. package/dist/loading/index.mjs +1 -1
  12. package/dist/message/src/method.cjs +1 -1
  13. package/dist/message/src/method.d.ts +1 -1
  14. package/dist/message/src/method.mjs +1 -1
  15. package/dist/message-box/index.cjs +1 -1
  16. package/dist/message-box/index.d.ts +1 -1
  17. package/dist/message-box/index.mjs +1 -1
  18. package/dist/notification/src/method.cjs +1 -1
  19. package/dist/notification/src/method.d.ts +1 -1
  20. package/dist/notification/src/method.mjs +1 -1
  21. package/dist/resolver.cjs +1 -1
  22. package/dist/resolver.d.ts +7 -5
  23. package/dist/resolver.mjs +1 -1
  24. package/dist/style.css +584 -0
  25. package/package.json +9 -8
  26. package/dist/affix/__tests__/affix.bottom.test.cjs +0 -101
  27. package/dist/affix/__tests__/affix.bottom.test.mjs +0 -88
  28. package/dist/affix/__tests__/affix.ssr.test.cjs +0 -38
  29. package/dist/affix/__tests__/affix.ssr.test.mjs +0 -51
  30. package/dist/affix/__tests__/affix.test.cjs +0 -185
  31. package/dist/affix/__tests__/affix.test.mjs +0 -180
  32. package/dist/ai-action-group/__tests__/ai-action-group.ssr.test.cjs +0 -55
  33. package/dist/ai-action-group/__tests__/ai-action-group.ssr.test.mjs +0 -39
  34. package/dist/ai-action-group/__tests__/ai-action-group.test.cjs +0 -235
  35. package/dist/ai-action-group/__tests__/ai-action-group.test.mjs +0 -157
  36. package/dist/ai-agent-card/__tests__/ai-agent-card.ssr.test.cjs +0 -61
  37. package/dist/ai-agent-card/__tests__/ai-agent-card.ssr.test.mjs +0 -65
  38. package/dist/ai-agent-card/__tests__/ai-agent-card.test.cjs +0 -205
  39. package/dist/ai-agent-card/__tests__/ai-agent-card.test.mjs +0 -133
  40. package/dist/ai-artifacts/__tests__/ai-artifacts.ssr.test.cjs +0 -73
  41. package/dist/ai-artifacts/__tests__/ai-artifacts.ssr.test.mjs +0 -68
  42. package/dist/ai-artifacts/__tests__/ai-artifacts.test.cjs +0 -128
  43. package/dist/ai-artifacts/__tests__/ai-artifacts.test.mjs +0 -109
  44. package/dist/ai-attachments/__tests__/ai-attachments.ssr.test.cjs +0 -50
  45. package/dist/ai-attachments/__tests__/ai-attachments.ssr.test.mjs +0 -33
  46. package/dist/ai-attachments/__tests__/ai-attachments.test.cjs +0 -113
  47. package/dist/ai-attachments/__tests__/ai-attachments.test.mjs +0 -81
  48. package/dist/ai-bubble/__tests__/ai-bubble.ssr.test.cjs +0 -95
  49. package/dist/ai-bubble/__tests__/ai-bubble.ssr.test.mjs +0 -66
  50. package/dist/ai-bubble/__tests__/ai-bubble.test.cjs +0 -624
  51. package/dist/ai-bubble/__tests__/ai-bubble.test.mjs +0 -393
  52. package/dist/ai-bubble-list/__tests__/ai-bubble-list.ssr.test.cjs +0 -51
  53. package/dist/ai-bubble-list/__tests__/ai-bubble-list.ssr.test.mjs +0 -51
  54. package/dist/ai-bubble-list/__tests__/ai-bubble-list.test.cjs +0 -138
  55. package/dist/ai-bubble-list/__tests__/ai-bubble-list.test.mjs +0 -112
  56. package/dist/ai-chat/__tests__/ai-chat.ssr.test.cjs +0 -90
  57. package/dist/ai-chat/__tests__/ai-chat.ssr.test.mjs +0 -77
  58. package/dist/ai-chat/__tests__/ai-chat.test.cjs +0 -177
  59. package/dist/ai-chat/__tests__/ai-chat.test.mjs +0 -129
  60. package/dist/ai-code-block/__tests__/ai-code-block.ssr.test.cjs +0 -75
  61. package/dist/ai-code-block/__tests__/ai-code-block.ssr.test.mjs +0 -57
  62. package/dist/ai-code-block/__tests__/ai-code-block.test.cjs +0 -174
  63. package/dist/ai-code-block/__tests__/ai-code-block.test.mjs +0 -108
  64. package/dist/ai-code-editor/__tests__/ai-code-editor.ssr.test.cjs +0 -46
  65. package/dist/ai-code-editor/__tests__/ai-code-editor.ssr.test.mjs +0 -39
  66. package/dist/ai-code-editor/__tests__/ai-code-editor.test.cjs +0 -90
  67. package/dist/ai-code-editor/__tests__/ai-code-editor.test.mjs +0 -78
  68. package/dist/ai-code-runner/__tests__/ai-code-runner.ssr.test.cjs +0 -28
  69. package/dist/ai-code-runner/__tests__/ai-code-runner.ssr.test.mjs +0 -26
  70. package/dist/ai-code-runner/__tests__/ai-code-runner.test.cjs +0 -69
  71. package/dist/ai-code-runner/__tests__/ai-code-runner.test.mjs +0 -66
  72. package/dist/ai-conversations/__tests__/ai-conversations.ssr.test.cjs +0 -50
  73. package/dist/ai-conversations/__tests__/ai-conversations.ssr.test.mjs +0 -42
  74. package/dist/ai-conversations/__tests__/ai-conversations.test.cjs +0 -67
  75. package/dist/ai-conversations/__tests__/ai-conversations.test.mjs +0 -51
  76. package/dist/ai-editor-sender/__tests__/ai-editor-sender.ssr.test.cjs +0 -62
  77. package/dist/ai-editor-sender/__tests__/ai-editor-sender.ssr.test.mjs +0 -50
  78. package/dist/ai-editor-sender/__tests__/ai-editor-sender.test.cjs +0 -315
  79. package/dist/ai-editor-sender/__tests__/ai-editor-sender.test.mjs +0 -226
  80. package/dist/ai-file-card/__tests__/ai-file-card.ssr.test.cjs +0 -45
  81. package/dist/ai-file-card/__tests__/ai-file-card.ssr.test.mjs +0 -29
  82. package/dist/ai-file-card/__tests__/ai-file-card.test.cjs +0 -160
  83. package/dist/ai-file-card/__tests__/ai-file-card.test.mjs +0 -109
  84. package/dist/ai-mention/__tests__/ai-mention.ssr.test.cjs +0 -38
  85. package/dist/ai-mention/__tests__/ai-mention.ssr.test.mjs +0 -37
  86. package/dist/ai-mention/__tests__/ai-mention.test.cjs +0 -113
  87. package/dist/ai-mention/__tests__/ai-mention.test.mjs +0 -84
  88. package/dist/ai-mermaid/__tests__/ai-mermaid.ssr.test.cjs +0 -43
  89. package/dist/ai-mermaid/__tests__/ai-mermaid.ssr.test.mjs +0 -33
  90. package/dist/ai-mermaid/__tests__/ai-mermaid.test.cjs +0 -113
  91. package/dist/ai-mermaid/__tests__/ai-mermaid.test.mjs +0 -92
  92. package/dist/ai-prompts/__tests__/ai-prompts.ssr.test.cjs +0 -49
  93. package/dist/ai-prompts/__tests__/ai-prompts.ssr.test.mjs +0 -41
  94. package/dist/ai-prompts/__tests__/ai-prompts.test.cjs +0 -54
  95. package/dist/ai-prompts/__tests__/ai-prompts.test.mjs +0 -38
  96. package/dist/ai-provider/__tests__/ai-provider.ssr.test.cjs +0 -33
  97. package/dist/ai-provider/__tests__/ai-provider.ssr.test.mjs +0 -34
  98. package/dist/ai-provider/__tests__/ai-provider.test.cjs +0 -38
  99. package/dist/ai-provider/__tests__/ai-provider.test.mjs +0 -33
  100. package/dist/ai-sender/__tests__/ai-sender.ssr.test.cjs +0 -46
  101. package/dist/ai-sender/__tests__/ai-sender.ssr.test.mjs +0 -37
  102. package/dist/ai-sender/__tests__/ai-sender.test.cjs +0 -511
  103. package/dist/ai-sender/__tests__/ai-sender.test.mjs +0 -322
  104. package/dist/ai-sources/__tests__/ai-sources.ssr.test.cjs +0 -72
  105. package/dist/ai-sources/__tests__/ai-sources.ssr.test.mjs +0 -82
  106. package/dist/ai-sources/__tests__/ai-sources.test.cjs +0 -200
  107. package/dist/ai-sources/__tests__/ai-sources.test.mjs +0 -160
  108. package/dist/ai-thinking/__tests__/ai-thinking.ssr.test.cjs +0 -56
  109. package/dist/ai-thinking/__tests__/ai-thinking.ssr.test.mjs +0 -42
  110. package/dist/ai-thinking/__tests__/ai-thinking.test.cjs +0 -151
  111. package/dist/ai-thinking/__tests__/ai-thinking.test.mjs +0 -96
  112. package/dist/ai-thought-chain/__tests__/ai-thought-chain.ssr.test.cjs +0 -88
  113. package/dist/ai-thought-chain/__tests__/ai-thought-chain.ssr.test.mjs +0 -55
  114. package/dist/ai-thought-chain/__tests__/ai-thought-chain.test.cjs +0 -344
  115. package/dist/ai-thought-chain/__tests__/ai-thought-chain.test.mjs +0 -237
  116. package/dist/ai-voice-trigger/__tests__/ai-voice-trigger.ssr.test.cjs +0 -32
  117. package/dist/ai-voice-trigger/__tests__/ai-voice-trigger.ssr.test.mjs +0 -25
  118. package/dist/ai-voice-trigger/__tests__/ai-voice-trigger.test.cjs +0 -130
  119. package/dist/ai-voice-trigger/__tests__/ai-voice-trigger.test.mjs +0 -103
  120. package/dist/ai-welcome/__tests__/ai-welcome.ssr.test.cjs +0 -57
  121. package/dist/ai-welcome/__tests__/ai-welcome.ssr.test.mjs +0 -39
  122. package/dist/ai-welcome/__tests__/ai-welcome.test.cjs +0 -169
  123. package/dist/ai-welcome/__tests__/ai-welcome.test.mjs +0 -113
  124. package/dist/alert/__tests__/alert.ssr.test.cjs +0 -28
  125. package/dist/alert/__tests__/alert.ssr.test.mjs +0 -29
  126. package/dist/alert/__tests__/alert.test.cjs +0 -123
  127. package/dist/alert/__tests__/alert.test.mjs +0 -110
  128. package/dist/autocomplete/__tests__/autocomplete.ssr.test.cjs +0 -54
  129. package/dist/autocomplete/__tests__/autocomplete.ssr.test.mjs +0 -47
  130. package/dist/autocomplete/__tests__/autocomplete.test.cjs +0 -299
  131. package/dist/autocomplete/__tests__/autocomplete.test.mjs +0 -263
  132. package/dist/avatar/__tests__/avatar.ssr.test.cjs +0 -103
  133. package/dist/avatar/__tests__/avatar.ssr.test.mjs +0 -108
  134. package/dist/avatar/__tests__/avatar.test.cjs +0 -146
  135. package/dist/avatar/__tests__/avatar.test.mjs +0 -125
  136. package/dist/back-top/__tests__/back-top.ssr.test.cjs +0 -13
  137. package/dist/back-top/__tests__/back-top.ssr.test.mjs +0 -10
  138. package/dist/back-top/__tests__/back-top.test.cjs +0 -88
  139. package/dist/back-top/__tests__/back-top.test.mjs +0 -76
  140. package/dist/badge/__tests__/badge.ssr.test.cjs +0 -36
  141. package/dist/badge/__tests__/badge.ssr.test.mjs +0 -33
  142. package/dist/badge/__tests__/badge.test.cjs +0 -115
  143. package/dist/badge/__tests__/badge.test.mjs +0 -112
  144. package/dist/breadcrumb/__tests__/breadcrumb.ssr.test.cjs +0 -22
  145. package/dist/breadcrumb/__tests__/breadcrumb.ssr.test.mjs +0 -20
  146. package/dist/breadcrumb/__tests__/breadcrumb.test.cjs +0 -64
  147. package/dist/breadcrumb/__tests__/breadcrumb.test.mjs +0 -51
  148. package/dist/button/__tests__/button.ssr.test.cjs +0 -52
  149. package/dist/button/__tests__/button.ssr.test.mjs +0 -55
  150. package/dist/button/__tests__/button.test.cjs +0 -207
  151. package/dist/button/__tests__/button.test.mjs +0 -141
  152. package/dist/calendar/__tests__/calendar.ssr.test.cjs +0 -65
  153. package/dist/calendar/__tests__/calendar.ssr.test.mjs +0 -63
  154. package/dist/calendar/__tests__/calendar.test.cjs +0 -263
  155. package/dist/calendar/__tests__/calendar.test.mjs +0 -255
  156. package/dist/card/__tests__/card.ssr.test.cjs +0 -37
  157. package/dist/card/__tests__/card.ssr.test.mjs +0 -40
  158. package/dist/card/__tests__/card.test.cjs +0 -131
  159. package/dist/card/__tests__/card.test.mjs +0 -124
  160. package/dist/carousel/__tests__/carousel.ssr.test.cjs +0 -27
  161. package/dist/carousel/__tests__/carousel.ssr.test.mjs +0 -27
  162. package/dist/carousel/__tests__/carousel.test.cjs +0 -115
  163. package/dist/carousel/__tests__/carousel.test.mjs +0 -98
  164. package/dist/cascader/__tests__/cascader-panel.test.cjs +0 -162
  165. package/dist/cascader/__tests__/cascader-panel.test.mjs +0 -151
  166. package/dist/cascader/__tests__/cascader.ssr.test.cjs +0 -61
  167. package/dist/cascader/__tests__/cascader.ssr.test.mjs +0 -55
  168. package/dist/cascader/__tests__/cascader.test.cjs +0 -342
  169. package/dist/cascader/__tests__/cascader.test.mjs +0 -316
  170. package/dist/category-nav/__tests__/category-nav.ssr.test.cjs +0 -35
  171. package/dist/category-nav/__tests__/category-nav.ssr.test.mjs +0 -21
  172. package/dist/category-nav/__tests__/category-nav.test.cjs +0 -53
  173. package/dist/category-nav/__tests__/category-nav.test.mjs +0 -33
  174. package/dist/checkbox/__tests__/checkbox.ssr.test.cjs +0 -52
  175. package/dist/checkbox/__tests__/checkbox.ssr.test.mjs +0 -57
  176. package/dist/checkbox/__tests__/checkbox.test.cjs +0 -173
  177. package/dist/checkbox/__tests__/checkbox.test.mjs +0 -133
  178. package/dist/col/__tests__/col.ssr.test.cjs +0 -44
  179. package/dist/col/__tests__/col.ssr.test.mjs +0 -42
  180. package/dist/col/__tests__/col.test.cjs +0 -128
  181. package/dist/col/__tests__/col.test.mjs +0 -116
  182. package/dist/color-picker/__tests__/color-picker.ssr.test.cjs +0 -34
  183. package/dist/color-picker/__tests__/color-picker.ssr.test.mjs +0 -39
  184. package/dist/color-picker/__tests__/color-picker.test.cjs +0 -227
  185. package/dist/color-picker/__tests__/color-picker.test.mjs +0 -176
  186. package/dist/config-provider/__tests__/config-provider.ssr.test.cjs +0 -43
  187. package/dist/config-provider/__tests__/config-provider.ssr.test.mjs +0 -42
  188. package/dist/config-provider/__tests__/config-provider.test.cjs +0 -75
  189. package/dist/config-provider/__tests__/config-provider.test.mjs +0 -64
  190. package/dist/container/__tests__/container.ssr.test.cjs +0 -71
  191. package/dist/container/__tests__/container.ssr.test.mjs +0 -50
  192. package/dist/container/__tests__/container.test.cjs +0 -111
  193. package/dist/container/__tests__/container.test.mjs +0 -84
  194. package/dist/countdown/__tests__/countdown.ssr.test.cjs +0 -86
  195. package/dist/countdown/__tests__/countdown.ssr.test.mjs +0 -78
  196. package/dist/countdown/__tests__/countdown.test.cjs +0 -767
  197. package/dist/countdown/__tests__/countdown.test.mjs +0 -722
  198. package/dist/coupon-card/__tests__/coupon-card.ssr.test.cjs +0 -21
  199. package/dist/coupon-card/__tests__/coupon-card.ssr.test.mjs +0 -18
  200. package/dist/coupon-card/__tests__/coupon-card.test.cjs +0 -67
  201. package/dist/coupon-card/__tests__/coupon-card.test.mjs +0 -64
  202. package/dist/date-picker/__tests__/date-picker-extended.test.cjs +0 -581
  203. package/dist/date-picker/__tests__/date-picker-extended.test.mjs +0 -455
  204. package/dist/date-picker/__tests__/date-picker.ssr.test.cjs +0 -26
  205. package/dist/date-picker/__tests__/date-picker.ssr.test.mjs +0 -23
  206. package/dist/date-picker/__tests__/date-picker.test.cjs +0 -170
  207. package/dist/date-picker/__tests__/date-picker.test.mjs +0 -136
  208. package/dist/descriptions/__tests__/descriptions.ssr.test.cjs +0 -67
  209. package/dist/descriptions/__tests__/descriptions.ssr.test.mjs +0 -72
  210. package/dist/descriptions/__tests__/descriptions.test.cjs +0 -150
  211. package/dist/descriptions/__tests__/descriptions.test.mjs +0 -130
  212. package/dist/dialog/__tests__/dialog.functional.test.cjs +0 -49
  213. package/dist/dialog/__tests__/dialog.functional.test.mjs +0 -49
  214. package/dist/dialog/__tests__/dialog.ssr.test.cjs +0 -31
  215. package/dist/dialog/__tests__/dialog.ssr.test.mjs +0 -29
  216. package/dist/dialog/__tests__/dialog.test.cjs +0 -561
  217. package/dist/dialog/__tests__/dialog.test.mjs +0 -388
  218. package/dist/divider/__tests__/divider.ssr.test.cjs +0 -41
  219. package/dist/divider/__tests__/divider.ssr.test.mjs +0 -44
  220. package/dist/divider/__tests__/divider.test.cjs +0 -71
  221. package/dist/divider/__tests__/divider.test.mjs +0 -68
  222. package/dist/drawer/__tests__/drawer.ssr.test.cjs +0 -25
  223. package/dist/drawer/__tests__/drawer.ssr.test.mjs +0 -23
  224. package/dist/drawer/__tests__/drawer.test.cjs +0 -145
  225. package/dist/drawer/__tests__/drawer.test.mjs +0 -122
  226. package/dist/dropdown/__tests__/dropdown.ssr.test.cjs +0 -49
  227. package/dist/dropdown/__tests__/dropdown.ssr.test.mjs +0 -64
  228. package/dist/dropdown/__tests__/dropdown.test.cjs +0 -310
  229. package/dist/dropdown/__tests__/dropdown.test.mjs +0 -269
  230. package/dist/empty/__tests__/empty.ssr.test.cjs +0 -96
  231. package/dist/empty/__tests__/empty.ssr.test.mjs +0 -99
  232. package/dist/empty/__tests__/empty.test.cjs +0 -110
  233. package/dist/empty/__tests__/empty.test.mjs +0 -101
  234. package/dist/filter-bar/__tests__/filter-bar.ssr.test.cjs +0 -29
  235. package/dist/filter-bar/__tests__/filter-bar.ssr.test.mjs +0 -16
  236. package/dist/filter-bar/__tests__/filter-bar.test.cjs +0 -51
  237. package/dist/filter-bar/__tests__/filter-bar.test.mjs +0 -29
  238. package/dist/form/__tests__/form-schema.test.cjs +0 -636
  239. package/dist/form/__tests__/form-schema.test.mjs +0 -366
  240. package/dist/form/__tests__/form.ssr.test.cjs +0 -74
  241. package/dist/form/__tests__/form.ssr.test.mjs +0 -73
  242. package/dist/form/__tests__/form.test.cjs +0 -208
  243. package/dist/form/__tests__/form.test.mjs +0 -128
  244. package/dist/gantt-chart/__tests__/debug_ssr.test.cjs +0 -51
  245. package/dist/gantt-chart/__tests__/debug_ssr.test.mjs +0 -37
  246. package/dist/gantt-chart/__tests__/gantt-chart.ssr.test.cjs +0 -95
  247. package/dist/gantt-chart/__tests__/gantt-chart.ssr.test.mjs +0 -94
  248. package/dist/gantt-chart/__tests__/gantt-chart.test.cjs +0 -86
  249. package/dist/gantt-chart/__tests__/gantt-chart.test.mjs +0 -79
  250. package/dist/grid/__tests__/grid.ssr.test.cjs +0 -81
  251. package/dist/grid/__tests__/grid.ssr.test.mjs +0 -63
  252. package/dist/grid/__tests__/grid.test.cjs +0 -142
  253. package/dist/grid/__tests__/grid.test.mjs +0 -89
  254. package/dist/icon/__tests__/icon.ssr.test.cjs +0 -35
  255. package/dist/icon/__tests__/icon.ssr.test.mjs +0 -26
  256. package/dist/icon/__tests__/icon.test.cjs +0 -144
  257. package/dist/icon/__tests__/icon.test.mjs +0 -123
  258. package/dist/image/__tests__/image-viewer.test.cjs +0 -101
  259. package/dist/image/__tests__/image-viewer.test.mjs +0 -94
  260. package/dist/image/__tests__/image.ssr.test.cjs +0 -73
  261. package/dist/image/__tests__/image.ssr.test.mjs +0 -72
  262. package/dist/image/__tests__/image.test.cjs +0 -171
  263. package/dist/image/__tests__/image.test.mjs +0 -159
  264. package/dist/image-magnifier/__tests__/image-magnifier.ssr.test.cjs +0 -54
  265. package/dist/image-magnifier/__tests__/image-magnifier.ssr.test.mjs +0 -35
  266. package/dist/image-magnifier/__tests__/image-magnifier.test.cjs +0 -257
  267. package/dist/image-magnifier/__tests__/image-magnifier.test.mjs +0 -177
  268. package/dist/infinite-scroll/__tests__/infinite-scroll.ssr.test.cjs +0 -59
  269. package/dist/infinite-scroll/__tests__/infinite-scroll.ssr.test.mjs +0 -84
  270. package/dist/infinite-scroll/__tests__/infinite-scroll.test.cjs +0 -255
  271. package/dist/infinite-scroll/__tests__/infinite-scroll.test.mjs +0 -187
  272. package/dist/input/__tests__/input-utils.test.cjs +0 -77
  273. package/dist/input/__tests__/input-utils.test.mjs +0 -75
  274. package/dist/input/__tests__/input.ssr.test.cjs +0 -100
  275. package/dist/input/__tests__/input.ssr.test.mjs +0 -85
  276. package/dist/input/__tests__/input.test.cjs +0 -127
  277. package/dist/input/__tests__/input.test.mjs +0 -112
  278. package/dist/input-number/__tests__/input-number.hydration.test.cjs +0 -24
  279. package/dist/input-number/__tests__/input-number.hydration.test.mjs +0 -21
  280. package/dist/input-number/__tests__/input-number.ssr.test.cjs +0 -95
  281. package/dist/input-number/__tests__/input-number.ssr.test.mjs +0 -92
  282. package/dist/input-number/__tests__/input-number.test.cjs +0 -199
  283. package/dist/input-number/__tests__/input-number.test.mjs +0 -173
  284. package/dist/input-tag/__tests__/input-tag.ssr.test.cjs +0 -47
  285. package/dist/input-tag/__tests__/input-tag.ssr.test.mjs +0 -41
  286. package/dist/input-tag/__tests__/input-tag.test.cjs +0 -268
  287. package/dist/input-tag/__tests__/input-tag.test.mjs +0 -201
  288. package/dist/loading/__tests__/loading.ssr.test.cjs +0 -37
  289. package/dist/loading/__tests__/loading.ssr.test.mjs +0 -27
  290. package/dist/loading/__tests__/loading.test.cjs +0 -91
  291. package/dist/loading/__tests__/loading.test.mjs +0 -75
  292. package/dist/lucky-draw/__tests__/lucky-draw.ssr.test.cjs +0 -33
  293. package/dist/lucky-draw/__tests__/lucky-draw.ssr.test.mjs +0 -31
  294. package/dist/lucky-draw/__tests__/lucky-draw.test.cjs +0 -56
  295. package/dist/lucky-draw/__tests__/lucky-draw.test.mjs +0 -48
  296. package/dist/marquee/__tests__/marquee.ssr.test.cjs +0 -59
  297. package/dist/marquee/__tests__/marquee.ssr.test.mjs +0 -60
  298. package/dist/marquee/__tests__/marquee.test.cjs +0 -94
  299. package/dist/marquee/__tests__/marquee.test.mjs +0 -92
  300. package/dist/mention/__tests__/mention.ssr.test.cjs +0 -92
  301. package/dist/mention/__tests__/mention.ssr.test.mjs +0 -70
  302. package/dist/mention/__tests__/mention.test.cjs +0 -650
  303. package/dist/mention/__tests__/mention.test.mjs +0 -523
  304. package/dist/menu/__tests__/menu.ssr.test.cjs +0 -92
  305. package/dist/menu/__tests__/menu.ssr.test.mjs +0 -124
  306. package/dist/menu/__tests__/menu.test.cjs +0 -209
  307. package/dist/menu/__tests__/menu.test.mjs +0 -182
  308. package/dist/message/__tests__/message.ssr.test.cjs +0 -29
  309. package/dist/message/__tests__/message.ssr.test.mjs +0 -23
  310. package/dist/message/__tests__/message.test.cjs +0 -170
  311. package/dist/message/__tests__/message.test.mjs +0 -154
  312. package/dist/message-box/__tests__/message-box.ssr.test.cjs +0 -33
  313. package/dist/message-box/__tests__/message-box.ssr.test.mjs +0 -30
  314. package/dist/message-box/__tests__/message-box.test.cjs +0 -100
  315. package/dist/message-box/__tests__/message-box.test.mjs +0 -95
  316. package/dist/notification/__tests__/notification.ssr.test.cjs +0 -31
  317. package/dist/notification/__tests__/notification.ssr.test.mjs +0 -25
  318. package/dist/notification/__tests__/notification.test.cjs +0 -248
  319. package/dist/notification/__tests__/notification.test.mjs +0 -206
  320. package/dist/pagination/__tests__/pagination.ssr.test.cjs +0 -61
  321. package/dist/pagination/__tests__/pagination.ssr.test.mjs +0 -59
  322. package/dist/pagination/__tests__/pagination.test.cjs +0 -135
  323. package/dist/pagination/__tests__/pagination.test.mjs +0 -131
  324. package/dist/popconfirm/__tests__/popconfirm.ssr.test.cjs +0 -48
  325. package/dist/popconfirm/__tests__/popconfirm.ssr.test.mjs +0 -63
  326. package/dist/popconfirm/__tests__/popconfirm.test.cjs +0 -62
  327. package/dist/popconfirm/__tests__/popconfirm.test.mjs +0 -56
  328. package/dist/popover/__tests__/popover.ssr.test.cjs +0 -48
  329. package/dist/popover/__tests__/popover.ssr.test.mjs +0 -63
  330. package/dist/popover/__tests__/popover.test.cjs +0 -107
  331. package/dist/popover/__tests__/popover.test.mjs +0 -93
  332. package/dist/price/__tests__/price.ssr.test.cjs +0 -20
  333. package/dist/price/__tests__/price.ssr.test.mjs +0 -19
  334. package/dist/price/__tests__/price.test.cjs +0 -45
  335. package/dist/price/__tests__/price.test.mjs +0 -42
  336. package/dist/product-card/__tests__/product-card.ssr.test.cjs +0 -21
  337. package/dist/product-card/__tests__/product-card.ssr.test.mjs +0 -18
  338. package/dist/product-card/__tests__/product-card.test.cjs +0 -54
  339. package/dist/product-card/__tests__/product-card.test.mjs +0 -53
  340. package/dist/progress/__tests__/progress.ssr.test.cjs +0 -31
  341. package/dist/progress/__tests__/progress.ssr.test.mjs +0 -29
  342. package/dist/progress/__tests__/progress.test.cjs +0 -119
  343. package/dist/progress/__tests__/progress.test.mjs +0 -77
  344. package/dist/radio/__tests__/radio-button.test.cjs +0 -99
  345. package/dist/radio/__tests__/radio-button.test.mjs +0 -83
  346. package/dist/radio/__tests__/radio.ssr.test.cjs +0 -132
  347. package/dist/radio/__tests__/radio.ssr.test.mjs +0 -165
  348. package/dist/radio/__tests__/radio.test.cjs +0 -170
  349. package/dist/radio/__tests__/radio.test.mjs +0 -143
  350. package/dist/rate/__tests__/rate.ssr.test.cjs +0 -106
  351. package/dist/rate/__tests__/rate.ssr.test.mjs +0 -103
  352. package/dist/rate/__tests__/rate.test.cjs +0 -88
  353. package/dist/rate/__tests__/rate.test.mjs +0 -85
  354. package/dist/result/__tests__/result.ssr.test.cjs +0 -62
  355. package/dist/result/__tests__/result.ssr.test.mjs +0 -51
  356. package/dist/result/__tests__/result.test.cjs +0 -135
  357. package/dist/result/__tests__/result.test.mjs +0 -92
  358. package/dist/row/__tests__/row.ssr.test.cjs +0 -29
  359. package/dist/row/__tests__/row.ssr.test.mjs +0 -30
  360. package/dist/row/__tests__/row.test.cjs +0 -89
  361. package/dist/row/__tests__/row.test.mjs +0 -86
  362. package/dist/row/__tests__/row_ts.test.cjs +0 -31
  363. package/dist/row/__tests__/row_ts.test.mjs +0 -28
  364. package/dist/scrollbar/__tests__/scrollbar.ssr.test.cjs +0 -49
  365. package/dist/scrollbar/__tests__/scrollbar.ssr.test.mjs +0 -54
  366. package/dist/scrollbar/__tests__/scrollbar.test.cjs +0 -43
  367. package/dist/scrollbar/__tests__/scrollbar.test.mjs +0 -40
  368. package/dist/select/__tests__/select.perf.test.cjs +0 -191
  369. package/dist/select/__tests__/select.perf.test.mjs +0 -185
  370. package/dist/select/__tests__/select.ssr.test.cjs +0 -58
  371. package/dist/select/__tests__/select.ssr.test.mjs +0 -52
  372. package/dist/select/__tests__/select.test.cjs +0 -414
  373. package/dist/select/__tests__/select.test.mjs +0 -345
  374. package/dist/skeleton/__tests__/skeleton.ssr.test.cjs +0 -81
  375. package/dist/skeleton/__tests__/skeleton.ssr.test.mjs +0 -83
  376. package/dist/skeleton/__tests__/skeleton.test.cjs +0 -72
  377. package/dist/skeleton/__tests__/skeleton.test.mjs +0 -65
  378. package/dist/sku-selector/__tests__/sku-selector.ssr.test.cjs +0 -32
  379. package/dist/sku-selector/__tests__/sku-selector.ssr.test.mjs +0 -19
  380. package/dist/sku-selector/__tests__/sku-selector.test.cjs +0 -64
  381. package/dist/sku-selector/__tests__/sku-selector.test.mjs +0 -53
  382. package/dist/slider/__tests__/repro.test.cjs +0 -25
  383. package/dist/slider/__tests__/repro.test.mjs +0 -22
  384. package/dist/slider/__tests__/slider.ssr.test.cjs +0 -118
  385. package/dist/slider/__tests__/slider.ssr.test.mjs +0 -115
  386. package/dist/slider/__tests__/slider.test.cjs +0 -155
  387. package/dist/slider/__tests__/slider.test.mjs +0 -120
  388. package/dist/smart-address/__tests__/smart-address.ssr.test.cjs +0 -28
  389. package/dist/smart-address/__tests__/smart-address.ssr.test.mjs +0 -25
  390. package/dist/smart-address/__tests__/smart-address.test.cjs +0 -68
  391. package/dist/smart-address/__tests__/smart-address.test.mjs +0 -56
  392. package/dist/space/__tests__/space.ssr.test.cjs +0 -115
  393. package/dist/space/__tests__/space.ssr.test.mjs +0 -150
  394. package/dist/space/__tests__/space.test.cjs +0 -227
  395. package/dist/space/__tests__/space.test.mjs +0 -187
  396. package/dist/spin/__tests__/spin.ssr.test.cjs +0 -46
  397. package/dist/spin/__tests__/spin.ssr.test.mjs +0 -43
  398. package/dist/spin/__tests__/spin.test.cjs +0 -65
  399. package/dist/spin/__tests__/spin.test.mjs +0 -63
  400. package/dist/steps/__tests__/steps.ssr.test.cjs +0 -73
  401. package/dist/steps/__tests__/steps.ssr.test.mjs +0 -55
  402. package/dist/steps/__tests__/steps.test.cjs +0 -152
  403. package/dist/steps/__tests__/steps.test.mjs +0 -123
  404. package/dist/submit-bar/__tests__/submit-bar.ssr.test.cjs +0 -21
  405. package/dist/submit-bar/__tests__/submit-bar.ssr.test.mjs +0 -18
  406. package/dist/submit-bar/__tests__/submit-bar.test.cjs +0 -50
  407. package/dist/submit-bar/__tests__/submit-bar.test.mjs +0 -36
  408. package/dist/switch/__tests__/switch.ssr.test.cjs +0 -105
  409. package/dist/switch/__tests__/switch.ssr.test.mjs +0 -102
  410. package/dist/switch/__tests__/switch.test.cjs +0 -251
  411. package/dist/switch/__tests__/switch.test.mjs +0 -193
  412. package/dist/table/__tests__/table-advance.test.cjs +0 -180
  413. package/dist/table/__tests__/table-advance.test.mjs +0 -118
  414. package/dist/table/__tests__/table-interaction.test.cjs +0 -236
  415. package/dist/table/__tests__/table-interaction.test.mjs +0 -162
  416. package/dist/table/__tests__/table-utils.test.cjs +0 -690
  417. package/dist/table/__tests__/table-utils.test.mjs +0 -485
  418. package/dist/table/__tests__/table.perf.test.cjs +0 -231
  419. package/dist/table/__tests__/table.perf.test.mjs +0 -225
  420. package/dist/table/__tests__/table.ssr.test.cjs +0 -296
  421. package/dist/table/__tests__/table.ssr.test.mjs +0 -265
  422. package/dist/table/__tests__/table.test.cjs +0 -682
  423. package/dist/table/__tests__/table.test.mjs +0 -617
  424. package/dist/table/__tests__/use-column-drag.test.cjs +0 -238
  425. package/dist/table/__tests__/use-column-drag.test.mjs +0 -150
  426. package/dist/table/__tests__/use-table-export.test.cjs +0 -179
  427. package/dist/table/__tests__/use-table-export.test.mjs +0 -105
  428. package/dist/table/__tests__/use-table-import.test.cjs +0 -206
  429. package/dist/table/__tests__/use-table-import.test.mjs +0 -144
  430. package/dist/table/__tests__/use-table-print.test.cjs +0 -190
  431. package/dist/table/__tests__/use-table-print.test.mjs +0 -134
  432. package/dist/table/__tests__/use-virtual-scroll.test.cjs +0 -286
  433. package/dist/table/__tests__/use-virtual-scroll.test.mjs +0 -196
  434. package/dist/tabs/__tests__/tabs.ssr.test.cjs +0 -57
  435. package/dist/tabs/__tests__/tabs.ssr.test.mjs +0 -41
  436. package/dist/tabs/__tests__/tabs.test.cjs +0 -171
  437. package/dist/tabs/__tests__/tabs.test.mjs +0 -134
  438. package/dist/tag/__tests__/tag.ssr.test.cjs +0 -45
  439. package/dist/tag/__tests__/tag.ssr.test.mjs +0 -48
  440. package/dist/tag/__tests__/tag.test.cjs +0 -194
  441. package/dist/tag/__tests__/tag.test.mjs +0 -167
  442. package/dist/time-picker/__tests__/time-picker.ssr.test.cjs +0 -46
  443. package/dist/time-picker/__tests__/time-picker.ssr.test.mjs +0 -43
  444. package/dist/time-picker/__tests__/time-picker.test.cjs +0 -228
  445. package/dist/time-picker/__tests__/time-picker.test.mjs +0 -218
  446. package/dist/time-picker/__tests__/time-spinner.test.cjs +0 -196
  447. package/dist/time-picker/__tests__/time-spinner.test.mjs +0 -162
  448. package/dist/time-select/__tests__/time-select.ssr.test.cjs +0 -42
  449. package/dist/time-select/__tests__/time-select.ssr.test.mjs +0 -37
  450. package/dist/time-select/__tests__/time-select.test.cjs +0 -390
  451. package/dist/time-select/__tests__/time-select.test.mjs +0 -374
  452. package/dist/tooltip/__tests__/tooltip.ssr.test.cjs +0 -55
  453. package/dist/tooltip/__tests__/tooltip.ssr.test.mjs +0 -76
  454. package/dist/tooltip/__tests__/tooltip.test.cjs +0 -132
  455. package/dist/tooltip/__tests__/tooltip.test.mjs +0 -121
  456. package/dist/transfer/__tests__/transfer.ssr.test.cjs +0 -47
  457. package/dist/transfer/__tests__/transfer.ssr.test.mjs +0 -44
  458. package/dist/transfer/__tests__/transfer.test.cjs +0 -422
  459. package/dist/transfer/__tests__/transfer.test.mjs +0 -405
  460. package/dist/tree/__tests__/tree.perf.test.cjs +0 -182
  461. package/dist/tree/__tests__/tree.perf.test.mjs +0 -198
  462. package/dist/tree/__tests__/tree.ssr.test.cjs +0 -56
  463. package/dist/tree/__tests__/tree.ssr.test.mjs +0 -45
  464. package/dist/tree/__tests__/tree.test.cjs +0 -488
  465. package/dist/tree/__tests__/tree.test.mjs +0 -333
  466. package/dist/tree-select/__tests__/tree-select.ssr.test.cjs +0 -52
  467. package/dist/tree-select/__tests__/tree-select.ssr.test.mjs +0 -55
  468. package/dist/tree-select/__tests__/tree-select.test.cjs +0 -231
  469. package/dist/tree-select/__tests__/tree-select.test.mjs +0 -189
  470. package/dist/typography/__tests__/typography.ssr.test.cjs +0 -85
  471. package/dist/typography/__tests__/typography.ssr.test.mjs +0 -63
  472. package/dist/typography/__tests__/typography.test.cjs +0 -362
  473. package/dist/typography/__tests__/typography.test.mjs +0 -161
  474. package/dist/upload/__tests__/upload.ssr.test.cjs +0 -28
  475. package/dist/upload/__tests__/upload.ssr.test.mjs +0 -26
  476. package/dist/upload/__tests__/upload.test.cjs +0 -467
  477. package/dist/upload/__tests__/upload.test.mjs +0 -336
  478. package/dist/waterfall/__tests__/waterfall.ssr.test.cjs +0 -38
  479. package/dist/waterfall/__tests__/waterfall.ssr.test.mjs +0 -39
  480. package/dist/waterfall/__tests__/waterfall.test.cjs +0 -122
  481. package/dist/waterfall/__tests__/waterfall.test.mjs +0 -85
  482. package/dist/watermark/__tests__/watermark.ssr.test.cjs +0 -32
  483. package/dist/watermark/__tests__/watermark.ssr.test.mjs +0 -30
  484. package/dist/watermark/__tests__/watermark.test.cjs +0 -127
  485. package/dist/watermark/__tests__/watermark.test.mjs +0 -124
@@ -1,112 +0,0 @@
1
- import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
2
- import { mount } from "@vue/test-utils";
3
- import AiBubbleList from "../src/ai-bubble-list.vue";
4
- import YhAiBubble from "../../ai-bubble/src/ai-bubble.vue";
5
- describe("YhAiBubbleList", () => {
6
- beforeEach(() => {
7
- vi.clearAllMocks();
8
- });
9
- afterEach(() => {
10
- vi.restoreAllMocks();
11
- });
12
- const mockItems = [
13
- { id: 1, content: "Hello", role: "user" },
14
- { id: 2, content: "Hi there!", role: "assistant" },
15
- { id: 3, content: "How can I help you?", role: "assistant" }
16
- ];
17
- it("should render correct number of items", () => {
18
- const wrapper = mount(AiBubbleList, {
19
- props: {
20
- items: mockItems
21
- }
22
- });
23
- expect(wrapper.findAll(".yh-ai-bubble-list__item")).toHaveLength(3);
24
- expect(wrapper.findAllComponents(YhAiBubble)).toHaveLength(3);
25
- });
26
- it("should apply custom height", () => {
27
- const wrapper = mount(AiBubbleList, {
28
- props: {
29
- items: mockItems,
30
- height: 500
31
- }
32
- });
33
- const el = wrapper.element;
34
- expect(el.style.height).toBe("500px");
35
- });
36
- it("should render loading state", () => {
37
- const wrapper = mount(AiBubbleList, {
38
- props: {
39
- items: mockItems,
40
- loading: true
41
- }
42
- });
43
- expect(wrapper.find(".yh-ai-bubble-list__loading").exists()).toBe(true);
44
- });
45
- it("should use virtual scroll when virtualScroll=true", () => {
46
- const wrapper = mount(AiBubbleList, {
47
- props: {
48
- items: Array.from({ length: 100 }).map((_, i) => ({
49
- id: i,
50
- content: `msg ${i}`,
51
- role: "user"
52
- })),
53
- virtualScroll: true,
54
- height: 400,
55
- itemHeight: 50
56
- }
57
- });
58
- expect(wrapper.classes()).toContain("is-virtual");
59
- expect(wrapper.find(".yh-ai-bubble-list__virtual-phantom").exists()).toBe(true);
60
- expect(wrapper.findAll(".yh-ai-bubble-list__item").length).toBeLessThan(100);
61
- });
62
- it("should support custom bubble slot", () => {
63
- const wrapper = mount(AiBubbleList, {
64
- props: {
65
- items: [{ id: 1, content: "test", role: "user" }]
66
- },
67
- slots: {
68
- bubble: `
69
- <template #bubble="{ item }">
70
- <div class="custom-bubble">{{ item.content }}</div>
71
- </template>
72
- `
73
- }
74
- });
75
- expect(wrapper.find(".custom-bubble").exists()).toBe(true);
76
- expect(wrapper.find(".custom-bubble").text()).toBe("test");
77
- });
78
- it("should support custom loading slot", () => {
79
- const wrapper = mount(AiBubbleList, {
80
- props: {
81
- items: [],
82
- loading: true
83
- },
84
- slots: {
85
- loading: '<div class="custom-loading">Loading...</div>'
86
- }
87
- });
88
- expect(wrapper.find(".custom-loading").exists()).toBe(true);
89
- });
90
- it("should expose scrollToBottom method", async () => {
91
- const wrapper = mount(AiBubbleList, {
92
- props: {
93
- items: mockItems
94
- }
95
- });
96
- expect(typeof wrapper.vm.scrollToBottom).toBe("function");
97
- });
98
- it("should automatically scroll to bottom when items change", async () => {
99
- const wrapper = mount(AiBubbleList, {
100
- props: {
101
- items: mockItems,
102
- autoScroll: true
103
- }
104
- });
105
- const scrollRef = { value: { scrollTop: 0, scrollHeight: 1e3 } };
106
- wrapper.vm.scrollRef = scrollRef;
107
- await wrapper.setProps({
108
- items: [...mockItems, { id: 4, content: "new msg", role: "user" }]
109
- });
110
- await new Promise((resolve) => setTimeout(resolve, 0));
111
- });
112
- });
@@ -1,90 +0,0 @@
1
- "use strict";
2
-
3
- var _vitest = require("vitest");
4
- var _serverRenderer = require("@vue/server-renderer");
5
- var _vue = require("vue");
6
- _vitest.vi.mock("markdown-it", async () => {
7
- class MockMd {
8
- inline = {
9
- ruler: {
10
- after: _vitest.vi.fn()
11
- }
12
- };
13
- block = {
14
- ruler: {
15
- before: _vitest.vi.fn()
16
- }
17
- };
18
- renderer = {
19
- rules: {}
20
- };
21
- render(content) {
22
- return `<p>${content}</p>`;
23
- }
24
- }
25
- return {
26
- default: MockMd
27
- };
28
- });
29
- _vitest.vi.mock("highlight.js", () => ({
30
- default: {
31
- getLanguage: () => false,
32
- highlight: _vitest.vi.fn(),
33
- highlightAuto: _vitest.vi.fn(() => ({
34
- value: ""
35
- }))
36
- }
37
- }));
38
- _vitest.vi.mock("highlight.js/styles/atom-one-dark.css", () => ({}));
39
- const {
40
- default: AiChat
41
- } = await Promise.resolve().then(() => require("../src/ai-chat.vue"));
42
- (0, _vitest.describe)("YhAiChat SSR", () => {
43
- (0, _vitest.it)("should render to string on server", async () => {
44
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiChat));
45
- (0, _vitest.expect)(html).toContain("yh-ai-chat");
46
- });
47
- (0, _vitest.it)("should render content area on server", async () => {
48
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiChat));
49
- (0, _vitest.expect)(html).toContain("yh-ai-chat__content");
50
- });
51
- (0, _vitest.it)("should render footer on server", async () => {
52
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiChat));
53
- (0, _vitest.expect)(html).toContain("yh-ai-chat__footer");
54
- });
55
- (0, _vitest.it)("should render message content on server", async () => {
56
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiChat, {
57
- messages: [{
58
- id: "1",
59
- role: "user",
60
- content: "SSR hello"
61
- }]
62
- }));
63
- (0, _vitest.expect)(html).toContain("SSR hello");
64
- });
65
- (0, _vitest.it)("should render suggestions on server when messages empty", async () => {
66
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiChat, {
67
- messages: [],
68
- suggestions: ["Write code", "Translate"]
69
- }));
70
- (0, _vitest.expect)(html).toContain("Write code");
71
- (0, _vitest.expect)(html).toContain("Translate");
72
- });
73
- (0, _vitest.it)("should render header with clear button when messages exist on server", async () => {
74
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiChat, {
75
- messages: [{
76
- id: "1",
77
- role: "user",
78
- content: "hi"
79
- }]
80
- }));
81
- (0, _vitest.expect)(html).toContain("yh-ai-chat__header");
82
- });
83
- (0, _vitest.it)("should render loading bubble on server when loading=true", async () => {
84
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiChat, {
85
- loading: true,
86
- messages: []
87
- }));
88
- (0, _vitest.expect)(html).toContain("is-loading");
89
- });
90
- });
@@ -1,77 +0,0 @@
1
- import { describe, it, expect, vi } from "vitest";
2
- import { renderToString } from "@vue/server-renderer";
3
- import { h } from "vue";
4
- vi.mock("markdown-it", async () => {
5
- class MockMd {
6
- inline = {
7
- ruler: {
8
- after: vi.fn()
9
- }
10
- };
11
- block = {
12
- ruler: {
13
- before: vi.fn()
14
- }
15
- };
16
- renderer = {
17
- rules: {}
18
- };
19
- render(content) {
20
- return `<p>${content}</p>`;
21
- }
22
- }
23
- return { default: MockMd };
24
- });
25
- vi.mock("highlight.js", () => ({
26
- default: {
27
- getLanguage: () => false,
28
- highlight: vi.fn(),
29
- highlightAuto: vi.fn(() => ({ value: "" }))
30
- }
31
- }));
32
- vi.mock("highlight.js/styles/atom-one-dark.css", () => ({}));
33
- const { default: AiChat } = await import("../src/ai-chat.vue");
34
- describe("YhAiChat SSR", () => {
35
- it("should render to string on server", async () => {
36
- const html = await renderToString(h(AiChat));
37
- expect(html).toContain("yh-ai-chat");
38
- });
39
- it("should render content area on server", async () => {
40
- const html = await renderToString(h(AiChat));
41
- expect(html).toContain("yh-ai-chat__content");
42
- });
43
- it("should render footer on server", async () => {
44
- const html = await renderToString(h(AiChat));
45
- expect(html).toContain("yh-ai-chat__footer");
46
- });
47
- it("should render message content on server", async () => {
48
- const html = await renderToString(
49
- h(AiChat, {
50
- messages: [{ id: "1", role: "user", content: "SSR hello" }]
51
- })
52
- );
53
- expect(html).toContain("SSR hello");
54
- });
55
- it("should render suggestions on server when messages empty", async () => {
56
- const html = await renderToString(
57
- h(AiChat, {
58
- messages: [],
59
- suggestions: ["Write code", "Translate"]
60
- })
61
- );
62
- expect(html).toContain("Write code");
63
- expect(html).toContain("Translate");
64
- });
65
- it("should render header with clear button when messages exist on server", async () => {
66
- const html = await renderToString(
67
- h(AiChat, {
68
- messages: [{ id: "1", role: "user", content: "hi" }]
69
- })
70
- );
71
- expect(html).toContain("yh-ai-chat__header");
72
- });
73
- it("should render loading bubble on server when loading=true", async () => {
74
- const html = await renderToString(h(AiChat, { loading: true, messages: [] }));
75
- expect(html).toContain("is-loading");
76
- });
77
- });
@@ -1,177 +0,0 @@
1
- "use strict";
2
-
3
- var _vitest = require("vitest");
4
- var _testUtils = require("@vue/test-utils");
5
- _vitest.vi.mock("markdown-it", async () => {
6
- class MockMd {
7
- inline = {
8
- ruler: {
9
- after: _vitest.vi.fn()
10
- }
11
- };
12
- block = {
13
- ruler: {
14
- before: _vitest.vi.fn()
15
- }
16
- };
17
- renderer = {
18
- rules: {}
19
- };
20
- render(content) {
21
- return `<p>${content}</p>`;
22
- }
23
- }
24
- return {
25
- default: MockMd
26
- };
27
- });
28
- _vitest.vi.mock("highlight.js", () => ({
29
- default: {
30
- getLanguage: () => false,
31
- highlight: _vitest.vi.fn(),
32
- highlightAuto: _vitest.vi.fn(() => ({
33
- value: ""
34
- }))
35
- }
36
- }));
37
- _vitest.vi.mock("highlight.js/styles/atom-one-dark.css", () => ({}));
38
- const {
39
- default: AiChat
40
- } = await Promise.resolve().then(() => require("../src/ai-chat.vue"));
41
- const makeMsg = (id, role, content, status) => ({
42
- id,
43
- role,
44
- content,
45
- ...(status ? {
46
- status
47
- } : {})
48
- });
49
- (0, _vitest.describe)("YhAiChat", () => {
50
- (0, _vitest.it)("should render with base class", () => {
51
- const wrapper = (0, _testUtils.mount)(AiChat);
52
- (0, _vitest.expect)(wrapper.find(".yh-ai-chat").exists()).toBe(true);
53
- });
54
- (0, _vitest.it)("should render content area", () => {
55
- const wrapper = (0, _testUtils.mount)(AiChat);
56
- (0, _vitest.expect)(wrapper.find(".yh-ai-chat__content").exists()).toBe(true);
57
- });
58
- (0, _vitest.it)("should render footer with sender by default", () => {
59
- const wrapper = (0, _testUtils.mount)(AiChat);
60
- (0, _vitest.expect)(wrapper.find(".yh-ai-chat__footer").exists()).toBe(true);
61
- });
62
- (0, _vitest.it)("should not render header when no messages and no header slot", () => {
63
- const wrapper = (0, _testUtils.mount)(AiChat, {
64
- props: {
65
- messages: []
66
- }
67
- });
68
- (0, _vitest.expect)(wrapper.find(".yh-ai-chat__header").exists()).toBe(false);
69
- });
70
- (0, _vitest.it)("should render header with clear button when messages exist", () => {
71
- const wrapper = (0, _testUtils.mount)(AiChat, {
72
- props: {
73
- messages: [makeMsg("1", "user", "hello")]
74
- }
75
- });
76
- (0, _vitest.expect)(wrapper.find(".yh-ai-chat__header").exists()).toBe(true);
77
- });
78
- (0, _vitest.it)("should render suggestions when messages are empty", () => {
79
- const wrapper = (0, _testUtils.mount)(AiChat, {
80
- props: {
81
- messages: [],
82
- suggestions: ["Help me", "Write code"]
83
- }
84
- });
85
- const buttons = wrapper.findAll(".yh-ai-chat__suggestions .yh-button");
86
- (0, _vitest.expect)(buttons.length).toBe(2);
87
- (0, _vitest.expect)(buttons[0].text()).toBe("Help me");
88
- });
89
- (0, _vitest.it)("should not render suggestions when messages exist", () => {
90
- const wrapper = (0, _testUtils.mount)(AiChat, {
91
- props: {
92
- messages: [makeMsg("1", "user", "hi")],
93
- suggestions: ["Suggestion"]
94
- }
95
- });
96
- (0, _vitest.expect)(wrapper.find(".yh-ai-chat__suggestions").exists()).toBe(false);
97
- });
98
- (0, _vitest.it)("should show loading bubble when loading=true and no messages", () => {
99
- const wrapper = (0, _testUtils.mount)(AiChat, {
100
- props: {
101
- loading: true,
102
- messages: []
103
- }
104
- });
105
- (0, _vitest.expect)(wrapper.html()).toContain("is-loading");
106
- });
107
- (0, _vitest.it)("should emit send when suggestion clicked", async () => {
108
- const wrapper = (0, _testUtils.mount)(AiChat, {
109
- props: {
110
- messages: [],
111
- suggestions: ["Write me code"]
112
- }
113
- });
114
- await wrapper.find(".yh-ai-chat__suggestions .yh-button").trigger("click");
115
- (0, _vitest.expect)(wrapper.emitted("send")).toBeTruthy();
116
- (0, _vitest.expect)(wrapper.emitted("send")[0][0]).toBe("Write me code");
117
- });
118
- (0, _vitest.it)("should emit clear and update:messages on clear button click", async () => {
119
- const wrapper = (0, _testUtils.mount)(AiChat, {
120
- props: {
121
- messages: [makeMsg("1", "user", "hello")]
122
- }
123
- });
124
- await wrapper.find(".yh-ai-chat__header .yh-button").trigger("click");
125
- (0, _vitest.expect)(wrapper.emitted("clear")).toBeTruthy();
126
- (0, _vitest.expect)(wrapper.emitted("update:messages")).toBeTruthy();
127
- (0, _vitest.expect)(wrapper.emitted("update:messages")[0][0]).toEqual([]);
128
- });
129
- (0, _vitest.it)("should render message content from messages prop", () => {
130
- const wrapper = (0, _testUtils.mount)(AiChat, {
131
- props: {
132
- messages: [makeMsg("1", "user", "test message content")]
133
- }
134
- });
135
- (0, _vitest.expect)(wrapper.html()).toContain("test message content");
136
- });
137
- (0, _vitest.it)("should render multiple messages", () => {
138
- const messages = [makeMsg("1", "user", "Hello"), makeMsg("2", "assistant", "Hi there")];
139
- const wrapper = (0, _testUtils.mount)(AiChat, {
140
- props: {
141
- messages
142
- }
143
- });
144
- (0, _vitest.expect)(wrapper.html()).toContain("Hello");
145
- (0, _vitest.expect)(wrapper.html()).toContain("Hi there");
146
- });
147
- (0, _vitest.it)("should render header slot", () => {
148
- const wrapper = (0, _testUtils.mount)(AiChat, {
149
- props: {
150
- messages: [makeMsg("1", "user", "hi")]
151
- },
152
- slots: {
153
- header: '<div class="custom-header">Custom Header</div>'
154
- }
155
- });
156
- (0, _vitest.expect)(wrapper.find(".custom-header").exists()).toBe(true);
157
- });
158
- (0, _vitest.it)("should render sender slot", () => {
159
- const wrapper = (0, _testUtils.mount)(AiChat, {
160
- slots: {
161
- sender: '<div class="custom-sender">Custom Sender</div>'
162
- }
163
- });
164
- (0, _vitest.expect)(wrapper.find(".custom-sender").exists()).toBe(true);
165
- });
166
- (0, _vitest.it)("should render custom message via message slot", () => {
167
- const wrapper = (0, _testUtils.mount)(AiChat, {
168
- props: {
169
- messages: [makeMsg("1", "user", "any")]
170
- },
171
- slots: {
172
- message: '<div class="custom-msg">Custom Message</div>'
173
- }
174
- });
175
- (0, _vitest.expect)(wrapper.find(".custom-msg").exists()).toBe(true);
176
- });
177
- });
@@ -1,129 +0,0 @@
1
- import { describe, it, expect, vi } from "vitest";
2
- import { mount } from "@vue/test-utils";
3
- vi.mock("markdown-it", async () => {
4
- class MockMd {
5
- inline = {
6
- ruler: {
7
- after: vi.fn()
8
- }
9
- };
10
- block = {
11
- ruler: {
12
- before: vi.fn()
13
- }
14
- };
15
- renderer = {
16
- rules: {}
17
- };
18
- render(content) {
19
- return `<p>${content}</p>`;
20
- }
21
- }
22
- return { default: MockMd };
23
- });
24
- vi.mock("highlight.js", () => ({
25
- default: {
26
- getLanguage: () => false,
27
- highlight: vi.fn(),
28
- highlightAuto: vi.fn(() => ({ value: "" }))
29
- }
30
- }));
31
- vi.mock("highlight.js/styles/atom-one-dark.css", () => ({}));
32
- const { default: AiChat } = await import("../src/ai-chat.vue");
33
- const makeMsg = (id, role, content, status) => ({ id, role, content, ...status ? { status } : {} });
34
- describe("YhAiChat", () => {
35
- it("should render with base class", () => {
36
- const wrapper = mount(AiChat);
37
- expect(wrapper.find(".yh-ai-chat").exists()).toBe(true);
38
- });
39
- it("should render content area", () => {
40
- const wrapper = mount(AiChat);
41
- expect(wrapper.find(".yh-ai-chat__content").exists()).toBe(true);
42
- });
43
- it("should render footer with sender by default", () => {
44
- const wrapper = mount(AiChat);
45
- expect(wrapper.find(".yh-ai-chat__footer").exists()).toBe(true);
46
- });
47
- it("should not render header when no messages and no header slot", () => {
48
- const wrapper = mount(AiChat, { props: { messages: [] } });
49
- expect(wrapper.find(".yh-ai-chat__header").exists()).toBe(false);
50
- });
51
- it("should render header with clear button when messages exist", () => {
52
- const wrapper = mount(AiChat, {
53
- props: { messages: [makeMsg("1", "user", "hello")] }
54
- });
55
- expect(wrapper.find(".yh-ai-chat__header").exists()).toBe(true);
56
- });
57
- it("should render suggestions when messages are empty", () => {
58
- const wrapper = mount(AiChat, {
59
- props: { messages: [], suggestions: ["Help me", "Write code"] }
60
- });
61
- const buttons = wrapper.findAll(".yh-ai-chat__suggestions .yh-button");
62
- expect(buttons.length).toBe(2);
63
- expect(buttons[0].text()).toBe("Help me");
64
- });
65
- it("should not render suggestions when messages exist", () => {
66
- const wrapper = mount(AiChat, {
67
- props: {
68
- messages: [makeMsg("1", "user", "hi")],
69
- suggestions: ["Suggestion"]
70
- }
71
- });
72
- expect(wrapper.find(".yh-ai-chat__suggestions").exists()).toBe(false);
73
- });
74
- it("should show loading bubble when loading=true and no messages", () => {
75
- const wrapper = mount(AiChat, { props: { loading: true, messages: [] } });
76
- expect(wrapper.html()).toContain("is-loading");
77
- });
78
- it("should emit send when suggestion clicked", async () => {
79
- const wrapper = mount(AiChat, {
80
- props: { messages: [], suggestions: ["Write me code"] }
81
- });
82
- await wrapper.find(".yh-ai-chat__suggestions .yh-button").trigger("click");
83
- expect(wrapper.emitted("send")).toBeTruthy();
84
- expect(wrapper.emitted("send")[0][0]).toBe("Write me code");
85
- });
86
- it("should emit clear and update:messages on clear button click", async () => {
87
- const wrapper = mount(AiChat, {
88
- props: { messages: [makeMsg("1", "user", "hello")] }
89
- });
90
- await wrapper.find(".yh-ai-chat__header .yh-button").trigger("click");
91
- expect(wrapper.emitted("clear")).toBeTruthy();
92
- expect(wrapper.emitted("update:messages")).toBeTruthy();
93
- expect(wrapper.emitted("update:messages")[0][0]).toEqual([]);
94
- });
95
- it("should render message content from messages prop", () => {
96
- const wrapper = mount(AiChat, {
97
- props: { messages: [makeMsg("1", "user", "test message content")] }
98
- });
99
- expect(wrapper.html()).toContain("test message content");
100
- });
101
- it("should render multiple messages", () => {
102
- const messages = [makeMsg("1", "user", "Hello"), makeMsg("2", "assistant", "Hi there")];
103
- const wrapper = mount(AiChat, { props: { messages } });
104
- expect(wrapper.html()).toContain("Hello");
105
- expect(wrapper.html()).toContain("Hi there");
106
- });
107
- it("should render header slot", () => {
108
- const wrapper = mount(AiChat, {
109
- props: { messages: [makeMsg("1", "user", "hi")] },
110
- slots: { header: '<div class="custom-header">Custom Header</div>' }
111
- });
112
- expect(wrapper.find(".custom-header").exists()).toBe(true);
113
- });
114
- it("should render sender slot", () => {
115
- const wrapper = mount(AiChat, {
116
- slots: { sender: '<div class="custom-sender">Custom Sender</div>' }
117
- });
118
- expect(wrapper.find(".custom-sender").exists()).toBe(true);
119
- });
120
- it("should render custom message via message slot", () => {
121
- const wrapper = mount(AiChat, {
122
- props: { messages: [makeMsg("1", "user", "any")] },
123
- slots: {
124
- message: '<div class="custom-msg">Custom Message</div>'
125
- }
126
- });
127
- expect(wrapper.find(".custom-msg").exists()).toBe(true);
128
- });
129
- });
@@ -1,75 +0,0 @@
1
- "use strict";
2
-
3
- var _vitest = require("vitest");
4
- var _serverRenderer = require("@vue/server-renderer");
5
- var _vue = require("vue");
6
- _vitest.vi.mock("highlight.js", () => ({
7
- default: {
8
- getLanguage: lang => lang === "typescript",
9
- highlight: _vitest.vi.fn(() => ({
10
- value: "highlighted"
11
- })),
12
- highlightAuto: _vitest.vi.fn(() => ({
13
- value: "auto"
14
- }))
15
- }
16
- }));
17
- _vitest.vi.mock("highlight.js/styles/atom-one-dark.css", () => ({}));
18
- _vitest.vi.mock("monaco-editor", () => {
19
- return {
20
- editor: {
21
- create: _vitest.vi.fn(),
22
- setModelLanguage: _vitest.vi.fn(),
23
- setTheme: _vitest.vi.fn()
24
- }
25
- };
26
- });
27
- const {
28
- default: AiCodeBlock
29
- } = await Promise.resolve().then(() => require("../src/ai-code-block.vue"));
30
- (0, _vitest.describe)("YhAiCodeBlock SSR", () => {
31
- (0, _vitest.it)("should render to string on server", async () => {
32
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiCodeBlock, {
33
- code: "const x = 1",
34
- language: "typescript"
35
- }));
36
- (0, _vitest.expect)(html).toContain("yh-ai-code-block");
37
- });
38
- (0, _vitest.it)("should render filename in header on server", async () => {
39
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiCodeBlock, {
40
- code: "const x = 1",
41
- filename: "utils.ts"
42
- }));
43
- (0, _vitest.expect)(html).toContain("utils.ts");
44
- (0, _vitest.expect)(html).toContain("yh-ai-code-block__lang");
45
- });
46
- (0, _vitest.it)("should render language in header when no filename on server", async () => {
47
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiCodeBlock, {
48
- code: "const x = 1",
49
- language: "typescript"
50
- }));
51
- (0, _vitest.expect)(html).toContain("typescript");
52
- });
53
- (0, _vitest.it)("should render language class in code element on server", async () => {
54
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiCodeBlock, {
55
- code: "const x = 1",
56
- language: "typescript"
57
- }));
58
- (0, _vitest.expect)(html).toContain("language-typescript");
59
- });
60
- (0, _vitest.it)("should render code body on server", async () => {
61
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiCodeBlock, {
62
- code: "sample code",
63
- language: "text",
64
- highlight: false
65
- }));
66
- (0, _vitest.expect)(html).toContain("sample code");
67
- (0, _vitest.expect)(html).toContain("yh-ai-code-block__body");
68
- });
69
- (0, _vitest.it)("should render copy button on server", async () => {
70
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiCodeBlock, {
71
- code: "code"
72
- }));
73
- (0, _vitest.expect)(html).toContain("yh-ai-code-block__actions");
74
- });
75
- });