@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,624 +0,0 @@
1
- "use strict";
2
-
3
- var _vitest = require("vitest");
4
- var _testUtils = require("@vue/test-utils");
5
- var _aiBubble = _interopRequireDefault(require("../src/ai-bubble.vue"));
6
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
7
- (0, _vitest.describe)("YhAiBubble", () => {
8
- (0, _vitest.beforeEach)(() => {
9
- _vitest.vi.clearAllMocks();
10
- });
11
- (0, _vitest.afterEach)(() => {
12
- _vitest.vi.restoreAllMocks();
13
- });
14
- (0, _vitest.it)("should render with base class", () => {
15
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
16
- props: {
17
- content: "hello",
18
- role: "assistant"
19
- }
20
- });
21
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble").exists()).toBe(true);
22
- });
23
- (0, _vitest.it)("should apply role class for user", () => {
24
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
25
- props: {
26
- content: "hi",
27
- role: "user"
28
- }
29
- });
30
- (0, _vitest.expect)(wrapper.classes()).toContain("yh-ai-bubble--user");
31
- });
32
- (0, _vitest.it)("should apply role class for assistant", () => {
33
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
34
- props: {
35
- content: "hi",
36
- role: "assistant"
37
- }
38
- });
39
- (0, _vitest.expect)(wrapper.classes()).toContain("yh-ai-bubble--assistant");
40
- });
41
- (0, _vitest.it)("should not render avatar for system role", () => {
42
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
43
- props: {
44
- content: "sys msg",
45
- role: "system"
46
- }
47
- });
48
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__avatar").exists()).toBe(false);
49
- });
50
- (0, _vitest.it)("should default placement to end for user role", () => {
51
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
52
- props: {
53
- content: "hi",
54
- role: "user"
55
- }
56
- });
57
- (0, _vitest.expect)(wrapper.classes()).toContain("yh-ai-bubble--placement-end");
58
- });
59
- (0, _vitest.it)("should default placement to start for assistant role", () => {
60
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
61
- props: {
62
- content: "hi",
63
- role: "assistant"
64
- }
65
- });
66
- (0, _vitest.expect)(wrapper.classes()).toContain("yh-ai-bubble--placement-start");
67
- });
68
- (0, _vitest.it)("should override placement via prop", () => {
69
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
70
- props: {
71
- content: "hi",
72
- role: "user",
73
- placement: "start"
74
- }
75
- });
76
- (0, _vitest.expect)(wrapper.classes()).toContain("yh-ai-bubble--placement-start");
77
- });
78
- (0, _vitest.it)("should apply shape class", () => {
79
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
80
- props: {
81
- content: "hi",
82
- shape: "round"
83
- }
84
- });
85
- (0, _vitest.expect)(wrapper.classes()).toContain("yh-ai-bubble--shape-round");
86
- });
87
- (0, _vitest.it)("should apply variant class", () => {
88
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
89
- props: {
90
- content: "hi",
91
- variant: "borderless"
92
- }
93
- });
94
- (0, _vitest.expect)(wrapper.classes()).toContain("yh-ai-bubble--variant-borderless");
95
- });
96
- (0, _vitest.it)("should show loading indicator when loading=true and content is empty", () => {
97
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
98
- props: {
99
- loading: true,
100
- content: ""
101
- }
102
- });
103
- (0, _vitest.expect)(wrapper.classes()).toContain("is-loading");
104
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__typing-indicator").exists()).toBe(true);
105
- });
106
- (0, _vitest.it)("should not show typing indicator when content exists even if loading=true", () => {
107
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
108
- props: {
109
- loading: true,
110
- content: "some text"
111
- }
112
- });
113
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__typing-indicator").exists()).toBe(false);
114
- });
115
- (0, _vitest.it)("should render plain text when markdown=false", () => {
116
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
117
- props: {
118
- content: "plain text",
119
- markdown: false
120
- }
121
- });
122
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__text").text()).toBe("plain text");
123
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__markdown").exists()).toBe(false);
124
- });
125
- (0, _vitest.it)("should render markdown container when markdown=true", () => {
126
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
127
- props: {
128
- content: "hello",
129
- markdown: true
130
- }
131
- });
132
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__markdown").exists()).toBe(true);
133
- });
134
- (0, _vitest.it)("should render time when provided", () => {
135
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
136
- props: {
137
- content: "hi",
138
- time: "10:00"
139
- }
140
- });
141
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__time").text()).toBe("10:00");
142
- });
143
- (0, _vitest.it)("should not render header without time and header slot", () => {
144
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
145
- props: {
146
- content: "hi"
147
- }
148
- });
149
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__header").exists()).toBe(false);
150
- });
151
- (0, _vitest.it)("should apply is-typing class when typing=true", () => {
152
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
153
- props: {
154
- content: "hi",
155
- typing: true
156
- }
157
- });
158
- (0, _vitest.expect)(wrapper.classes()).toContain("is-typing");
159
- });
160
- (0, _vitest.it)("should render content via default slot", () => {
161
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
162
- slots: {
163
- default: '<span class="custom-content">Custom</span>'
164
- }
165
- });
166
- (0, _vitest.expect)(wrapper.find(".custom-content").exists()).toBe(true);
167
- });
168
- (0, _vitest.it)("should render footer slot when provided", () => {
169
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
170
- props: {
171
- content: "hi"
172
- },
173
- slots: {
174
- footer: '<div class="custom-footer">Actions</div>'
175
- }
176
- });
177
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__footer").exists()).toBe(true);
178
- (0, _vitest.expect)(wrapper.find(".custom-footer").exists()).toBe(true);
179
- });
180
- (0, _vitest.it)("should render header slot when provided", () => {
181
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
182
- props: {
183
- content: "hi"
184
- },
185
- slots: {
186
- header: '<span class="custom-header">Header</span>'
187
- }
188
- });
189
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__header").exists()).toBe(true);
190
- (0, _vitest.expect)(wrapper.find(".custom-header").exists()).toBe(true);
191
- });
192
- (0, _vitest.it)("should render avatar slot when provided", () => {
193
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
194
- props: {
195
- content: "hi",
196
- role: "user"
197
- },
198
- slots: {
199
- avatar: '<img class="custom-avatar" src="test.png" />'
200
- }
201
- });
202
- (0, _vitest.expect)(wrapper.find(".custom-avatar").exists()).toBe(true);
203
- });
204
- (0, _vitest.it)("should render multimodal content - image", () => {
205
- const multimodal = [{
206
- type: "image",
207
- url: "img.png",
208
- title: "test image"
209
- }];
210
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
211
- props: {
212
- content: "",
213
- multimodal
214
- }
215
- });
216
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__image-grid").exists()).toBe(true);
217
- });
218
- (0, _vitest.it)("should render multimodal content - audio", async () => {
219
- const multimodal = [{
220
- type: "audio",
221
- url: "audio.mp3",
222
- title: "test audio"
223
- }];
224
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
225
- props: {
226
- content: "",
227
- multimodal
228
- }
229
- });
230
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__audio-player").exists()).toBe(true);
231
- const playMock = _vitest.vi.fn().mockResolvedValue(void 0);
232
- const pauseMock = _vitest.vi.fn();
233
- class MockAudio {
234
- play = playMock;
235
- pause = pauseMock;
236
- onended = null;
237
- }
238
- _vitest.vi.stubGlobal("Audio", MockAudio);
239
- await wrapper.find(".yh-ai-bubble__audio-player button").trigger("click");
240
- (0, _vitest.expect)(playMock).toHaveBeenCalled();
241
- await wrapper.find(".yh-ai-bubble__audio-player button").trigger("click");
242
- (0, _vitest.expect)(pauseMock).toHaveBeenCalled();
243
- });
244
- (0, _vitest.it)("should render multimodal content - file", () => {
245
- const multimodal = [{
246
- type: "file",
247
- url: "test.pdf",
248
- title: "test.pdf",
249
- size: "10KB"
250
- }];
251
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
252
- props: {
253
- content: "",
254
- multimodal
255
- }
256
- });
257
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__file-card").exists()).toBe(true);
258
- (0, _vitest.expect)(wrapper.html()).toContain("10KB");
259
- });
260
- (0, _vitest.it)("should render JSON structured data", () => {
261
- const structuredData = {
262
- type: "json",
263
- data: {
264
- name: "test"
265
- }
266
- };
267
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
268
- props: {
269
- content: "",
270
- structuredData
271
- }
272
- });
273
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__json-viewer").exists()).toBe(true);
274
- });
275
- (0, _vitest.it)("should render thought-chain structured data", () => {
276
- const structuredData = {
277
- type: "thought-chain",
278
- data: []
279
- };
280
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
281
- props: {
282
- content: "",
283
- structuredData
284
- }
285
- });
286
- (0, _vitest.expect)(wrapper.findComponent({
287
- name: "YhAiThoughtChain"
288
- }).exists()).toBe(true);
289
- });
290
- (0, _vitest.it)("should handle citation click", async () => {
291
- const onCitationClick = _vitest.vi.fn();
292
- const cita = {
293
- id: 1,
294
- title: "link",
295
- url: "http://x.com"
296
- };
297
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
298
- props: {
299
- content: "test [1]",
300
- citations: [cita],
301
- onCitationClick
302
- }
303
- });
304
- await wrapper.find(".yh-ai-bubble__citation-item").trigger("click");
305
- (0, _vitest.expect)(onCitationClick).toHaveBeenCalledWith(cita);
306
- const openSpy = _vitest.vi.spyOn(window, "open").mockImplementation(() => null);
307
- const wrapper2 = (0, _testUtils.mount)(_aiBubble.default, {
308
- props: {
309
- content: "test",
310
- citations: [cita]
311
- }
312
- });
313
- await wrapper2.find(".yh-ai-bubble__citation-item").trigger("click");
314
- (0, _vitest.expect)(openSpy).toHaveBeenCalledWith("http://x.com", "_blank");
315
- });
316
- (0, _vitest.it)("should show citation tooltip on hover", async () => {
317
- _vitest.vi.useFakeTimers();
318
- const cita = {
319
- id: "1",
320
- title: "ref 1",
321
- content: "detailed info"
322
- };
323
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
324
- props: {
325
- content: "test",
326
- citations: [cita]
327
- }
328
- });
329
- const mockEvent = {
330
- target: {
331
- classList: {
332
- contains: c => c === "yh-ai-citation"
333
- },
334
- getAttribute: a => a === "data-id" ? "1" : null,
335
- getBoundingClientRect: () => ({
336
- top: 100,
337
- left: 100,
338
- width: 20
339
- })
340
- }
341
- };
342
- wrapper.vm.handleCitationHover(mockEvent);
343
- (0, _vitest.expect)(wrapper.vm.hoveredCitation).toEqual(cita);
344
- wrapper.vm.handleCitationLeave(mockEvent);
345
- _vitest.vi.advanceTimersByTime(300);
346
- (0, _vitest.expect)(wrapper.vm.hoveredCitation).toBeNull();
347
- _vitest.vi.useRealTimers();
348
- });
349
- (0, _vitest.it)("should handle code block actions - collapse", async () => {
350
- const wrapper = (0, _testUtils.mount)(_aiBubble.default);
351
- const mockEvent = {
352
- target: {
353
- classList: {
354
- contains: c => c === "collapse-btn" || c === "code-action-btn"
355
- },
356
- getAttribute: a => a === "data-id" ? "cb-1" : null
357
- }
358
- };
359
- await wrapper.vm.handleCodeBlockAction(mockEvent);
360
- (0, _vitest.expect)(wrapper.vm.expandedCodeBlocks.has("cb-1")).toBe(true);
361
- });
362
- (0, _vitest.it)("should trigger download on button click", async () => {
363
- const openSpy = _vitest.vi.spyOn(window, "open").mockImplementation(() => null);
364
- const multimodal = [{
365
- type: "file",
366
- url: "test.zip",
367
- title: "test"
368
- }];
369
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
370
- props: {
371
- content: "",
372
- multimodal
373
- }
374
- });
375
- await wrapper.find(".yh-ai-bubble__file-card button").trigger("click");
376
- (0, _vitest.expect)(openSpy).toHaveBeenCalledWith("test.zip", "_blank");
377
- });
378
- (0, _vitest.it)("getFileIcon should return correct icons", () => {
379
- const wrapper = (0, _testUtils.mount)(_aiBubble.default);
380
- const getFileIcon = wrapper.vm.getFileIcon;
381
- (0, _vitest.expect)(getFileIcon("test.pdf")).toBe("file-pdf");
382
- (0, _vitest.expect)(getFileIcon("test.xlsx")).toBe("file-excel");
383
- (0, _vitest.expect)(getFileIcon("test.docx")).toBe("file-word");
384
- (0, _vitest.expect)(getFileIcon("test.mp4")).toBe("file-video");
385
- (0, _vitest.expect)(getFileIcon("test.mp3")).toBe("file-audio");
386
- (0, _vitest.expect)(getFileIcon("test.txt")).toBe("file-txt");
387
- (0, _vitest.expect)(getFileIcon("unknown")).toBe("document");
388
- });
389
- (0, _vitest.it)("should handle code block actions - copy", async () => {
390
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
391
- props: {
392
- content: "```js\nconsole.log(1)\n```"
393
- }
394
- });
395
- const copySpy = _vitest.vi.spyOn(navigator.clipboard, "writeText").mockResolvedValue(void 0);
396
- const mockEvent = {
397
- target: {
398
- classList: {
399
- contains: c => c === "code-action-btn" || c === "copy-btn"
400
- },
401
- getAttribute: a => {
402
- if (a === "data-code") return encodeURIComponent("console.log(1)");
403
- if (a === "data-id") return "cb-1";
404
- return null;
405
- }
406
- }
407
- };
408
- await wrapper.vm.handleCodeBlockAction(mockEvent);
409
- (0, _vitest.expect)(copySpy).toHaveBeenCalledWith("console.log(1)");
410
- });
411
- (0, _vitest.it)("should handle code block actions - run", async () => {
412
- const onRunCode = _vitest.vi.fn().mockResolvedValue({
413
- output: "done"
414
- });
415
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
416
- props: {
417
- content: "```js\n1+1\n```",
418
- onRunCode
419
- }
420
- });
421
- const mockEvent = {
422
- target: {
423
- classList: {
424
- contains: c => c === "code-action-btn" || c === "run-btn"
425
- },
426
- getAttribute: a => {
427
- if (a === "data-code") return encodeURIComponent("1+1");
428
- if (a === "data-lang") return "js";
429
- if (a === "data-id") return "cb-1";
430
- return null;
431
- }
432
- }
433
- };
434
- await wrapper.vm.handleCodeBlockAction(mockEvent);
435
- (0, _vitest.expect)(onRunCode).toHaveBeenCalled();
436
- });
437
- (0, _vitest.it)("should toggle code block expansion", () => {
438
- const wrapper = (0, _testUtils.mount)(_aiBubble.default);
439
- wrapper.vm.toggleCodeBlock("cb-1");
440
- (0, _vitest.expect)(wrapper.vm.expandedCodeBlocks.has("cb-1")).toBe(true);
441
- wrapper.vm.toggleCodeBlock("cb-1");
442
- (0, _vitest.expect)(wrapper.vm.expandedCodeBlocks.has("cb-1")).toBe(false);
443
- });
444
- (0, _vitest.it)("should handle explain code block", async () => {
445
- const onExplainCode = _vitest.vi.fn().mockResolvedValue("explanation");
446
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
447
- props: {
448
- onExplainCode
449
- }
450
- });
451
- const mockEvent = {
452
- target: {
453
- classList: {
454
- contains: c => c === "explain-btn" || c === "code-action-btn"
455
- },
456
- getAttribute: a => {
457
- if (a === "data-code") return "code";
458
- if (a === "data-lang") return "js";
459
- if (a === "data-id") return "cb-1";
460
- return null;
461
- }
462
- }
463
- };
464
- await wrapper.vm.handleCodeBlockAction(mockEvent);
465
- (0, _vitest.expect)(onExplainCode).toHaveBeenCalled();
466
- (0, _vitest.expect)(wrapper.vm.codeOutput["cb-1"]).toEqual(["explanation"]);
467
- });
468
- (0, _vitest.it)("should handle code block actions - edit", async () => {
469
- const mockEditor = {
470
- dispose: _vitest.vi.fn(),
471
- getValue: _vitest.vi.fn().mockReturnValue("edited code")
472
- };
473
- const mockMonaco = {
474
- editor: {
475
- create: _vitest.vi.fn().mockReturnValue(mockEditor)
476
- }
477
- };
478
- const wrapper = (0, _testUtils.mount)(_aiBubble.default);
479
- wrapper.vm.monaco = mockMonaco;
480
- const mockEvent = {
481
- target: {
482
- classList: {
483
- contains: c => c === "code-action-btn" || c === "edit-btn"
484
- },
485
- getAttribute: a => {
486
- if (a === "data-code") return encodeURIComponent("raw context");
487
- if (a === "data-lang") return "javascript";
488
- if (a === "data-id") return "cb-1";
489
- return null;
490
- }
491
- }
492
- };
493
- await wrapper.vm.handleCodeBlockAction(mockEvent);
494
- (0, _vitest.expect)(wrapper.vm.editingCodeBlock).toBe("cb-1");
495
- await wrapper.vm.saveEditCode("cb-1");
496
- (0, _vitest.expect)(wrapper.vm.editingCodeBlock).toBeNull();
497
- });
498
- (0, _vitest.it)("should handle onRunCode with async iterator", async () => {
499
- const mockGenerator = async function* () {
500
- yield {
501
- output: "chunk 1"
502
- };
503
- yield {
504
- output: "chunk 2"
505
- };
506
- };
507
- const onRunCode = _vitest.vi.fn().mockResolvedValue(mockGenerator());
508
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
509
- props: {
510
- onRunCode
511
- }
512
- });
513
- const mockEvent = {
514
- target: {
515
- classList: {
516
- contains: c => c === "run-btn" || c === "code-action-btn"
517
- },
518
- getAttribute: a => {
519
- if (a === "data-code") return "code";
520
- if (a === "data-lang") return "js";
521
- if (a === "data-id") return "cb-1";
522
- return null;
523
- }
524
- }
525
- };
526
- await wrapper.vm.handleCodeBlockAction(mockEvent);
527
- (0, _vitest.expect)(onRunCode).toHaveBeenCalled();
528
- });
529
- (0, _vitest.it)("should support streaming increments", async () => {
530
- _vitest.vi.useFakeTimers();
531
- const onStreamComplete = _vitest.vi.fn();
532
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
533
- props: {
534
- content: "hello world",
535
- typing: true,
536
- streaming: true,
537
- streamSpeed: 2,
538
- streamInterval: 10,
539
- onStreamComplete
540
- }
541
- });
542
- _vitest.vi.advanceTimersByTime(100);
543
- await wrapper.vm.$nextTick();
544
- (0, _vitest.expect)(onStreamComplete).toHaveBeenCalled();
545
- _vitest.vi.useRealTimers();
546
- });
547
- (0, _vitest.it)("should render table structured data", () => {
548
- const structuredData = {
549
- type: "table",
550
- data: {
551
- headers: ["A", "B"],
552
- rows: [["1", "2"]]
553
- }
554
- };
555
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
556
- props: {
557
- content: "",
558
- structuredData
559
- }
560
- });
561
- (0, _vitest.expect)(wrapper.find("table").exists()).toBe(true);
562
- (0, _vitest.expect)(wrapper.find("th").text()).toBe("A");
563
- });
564
- (0, _vitest.it)("should handle markdown=true but no mdi initialized", async () => {
565
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
566
- props: {
567
- content: "hi",
568
- markdown: true
569
- }
570
- });
571
- (0, _vitest.expect)(wrapper.find(".yh-ai-bubble__markdown").exists()).toBe(true);
572
- });
573
- (0, _vitest.it)("should handle multimodal download", async () => {
574
- const openSpy = _vitest.vi.spyOn(window, "open").mockImplementation(() => null);
575
- const wrapper = (0, _testUtils.mount)(_aiBubble.default);
576
- wrapper.vm.handleDownload("test.zip");
577
- (0, _vitest.expect)(openSpy).toHaveBeenCalledWith("test.zip", "_blank");
578
- });
579
- (0, _vitest.it)("should hit onBeforeUnmount", () => {
580
- const wrapper = (0, _testUtils.mount)(_aiBubble.default, {
581
- props: {
582
- content: "test"
583
- }
584
- });
585
- wrapper.unmount();
586
- });
587
- (0, _vitest.it)("should test escapeHtml utility", () => {
588
- const wrapper = (0, _testUtils.mount)(_aiBubble.default);
589
- const escapeHtml = wrapper.vm.escapeHtml;
590
- (0, _vitest.expect)(escapeHtml(`<div>&"'</div>`)).toBe("&lt;div&gt;&amp;&quot;&#39;&lt;/div&gt;");
591
- });
592
- (0, _vitest.it)("should support sentence stream mode", async () => {
593
- _vitest.vi.useFakeTimers();
594
- const onStreamComplete = _vitest.vi.fn();
595
- (0, _testUtils.mount)(_aiBubble.default, {
596
- props: {
597
- content: "Sentence one. Sentence two!",
598
- typing: true,
599
- streaming: true,
600
- streamMode: "sentence",
601
- onStreamComplete
602
- }
603
- });
604
- _vitest.vi.advanceTimersByTime(1e3);
605
- (0, _vitest.expect)(onStreamComplete).toHaveBeenCalled();
606
- _vitest.vi.useRealTimers();
607
- });
608
- (0, _vitest.it)("should support paragraph stream mode", async () => {
609
- _vitest.vi.useFakeTimers();
610
- const onStreamComplete = _vitest.vi.fn();
611
- (0, _testUtils.mount)(_aiBubble.default, {
612
- props: {
613
- content: "Para one\n\nPara two",
614
- typing: true,
615
- streaming: true,
616
- streamMode: "paragraph",
617
- onStreamComplete
618
- }
619
- });
620
- _vitest.vi.advanceTimersByTime(1e3);
621
- (0, _vitest.expect)(onStreamComplete).toHaveBeenCalled();
622
- _vitest.vi.useRealTimers();
623
- });
624
- });