@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,315 +0,0 @@
1
- "use strict";
2
-
3
- var _vitest = require("vitest");
4
- var _testUtils = require("@vue/test-utils");
5
- var _vue = require("vue");
6
- var _aiEditorSender = _interopRequireDefault(require("../src/ai-editor-sender.vue"));
7
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
8
- (0, _vitest.describe)("YhAiEditorSender", () => {
9
- (0, _vitest.it)("should render with base class", () => {
10
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default);
11
- (0, _vitest.expect)(wrapper.find(".yh-ai-editor-sender").exists()).toBe(true);
12
- });
13
- (0, _vitest.it)("should render textarea", () => {
14
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default);
15
- (0, _vitest.expect)(wrapper.find("textarea").exists()).toBe(true);
16
- });
17
- (0, _vitest.it)("should render with placeholder", () => {
18
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
19
- props: {
20
- placeholder: "Type here..."
21
- }
22
- });
23
- (0, _vitest.expect)(wrapper.find("textarea").attributes("placeholder")).toBe("Type here...");
24
- });
25
- (0, _vitest.it)("should render modelValue in textarea", () => {
26
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
27
- props: {
28
- modelValue: "initial text"
29
- }
30
- });
31
- (0, _vitest.expect)(wrapper.find("textarea").element.value).toBe("initial text");
32
- });
33
- (0, _vitest.it)("should emit update:modelValue on input", async () => {
34
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
35
- props: {
36
- modelValue: ""
37
- }
38
- });
39
- const textarea = wrapper.find("textarea");
40
- await textarea.setValue("hello");
41
- const emitted = wrapper.emitted("update:modelValue");
42
- (0, _vitest.expect)(emitted).toBeTruthy();
43
- (0, _vitest.expect)(emitted[emitted.length - 1][0]).toBe("hello");
44
- });
45
- (0, _vitest.it)("should emit change on input", async () => {
46
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
47
- props: {
48
- modelValue: ""
49
- }
50
- });
51
- await wrapper.find("textarea").setValue("changed");
52
- (0, _vitest.expect)(wrapper.emitted("change")).toBeTruthy();
53
- });
54
- (0, _vitest.it)("should apply is-disabled class when disabled=true", () => {
55
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
56
- props: {
57
- disabled: true
58
- }
59
- });
60
- (0, _vitest.expect)(wrapper.classes()).toContain("is-disabled");
61
- });
62
- (0, _vitest.it)("should disable textarea when disabled=true", () => {
63
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
64
- props: {
65
- disabled: true
66
- }
67
- });
68
- (0, _vitest.expect)(wrapper.find("textarea").element.disabled).toBe(true);
69
- });
70
- (0, _vitest.it)("should apply is-loading class when loading=true", () => {
71
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
72
- props: {
73
- loading: true
74
- }
75
- });
76
- (0, _vitest.expect)(wrapper.classes()).toContain("is-loading");
77
- });
78
- (0, _vitest.it)("should disable textarea when loading=true", () => {
79
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
80
- props: {
81
- loading: true
82
- }
83
- });
84
- (0, _vitest.expect)(wrapper.find("textarea").element.disabled).toBe(true);
85
- });
86
- (0, _vitest.it)("should emit send event when send button clicked with text", async () => {
87
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
88
- props: {
89
- modelValue: "Hello"
90
- }
91
- });
92
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
93
- await sendBtn.trigger("click");
94
- (0, _vitest.expect)(wrapper.emitted("send")).toBeTruthy();
95
- const emitted = wrapper.emitted("send");
96
- (0, _vitest.expect)(emitted[0][0]).toBe("Hello");
97
- });
98
- (0, _vitest.it)("should NOT emit send if textarea is empty", async () => {
99
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
100
- props: {
101
- modelValue: ""
102
- }
103
- });
104
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
105
- await sendBtn.trigger("click");
106
- (0, _vitest.expect)(wrapper.emitted("send")).toBeFalsy();
107
- });
108
- (0, _vitest.it)("should NOT emit send if disabled", async () => {
109
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
110
- props: {
111
- modelValue: "some text",
112
- disabled: true
113
- }
114
- });
115
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
116
- await sendBtn.trigger("click");
117
- (0, _vitest.expect)(wrapper.emitted("send")).toBeFalsy();
118
- });
119
- (0, _vitest.it)("should NOT emit send if loading", async () => {
120
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
121
- props: {
122
- modelValue: "some text",
123
- loading: true
124
- }
125
- });
126
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
127
- await sendBtn.trigger("click");
128
- (0, _vitest.expect)(wrapper.emitted("send")).toBeFalsy();
129
- });
130
- (0, _vitest.it)("should emit send on Enter key (without Shift)", async () => {
131
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
132
- props: {
133
- modelValue: "Hello"
134
- }
135
- });
136
- await wrapper.find("textarea").trigger("keydown", {
137
- key: "Enter",
138
- shiftKey: false
139
- });
140
- (0, _vitest.expect)(wrapper.emitted("send")).toBeTruthy();
141
- });
142
- (0, _vitest.it)("should NOT emit send on Shift+Enter", async () => {
143
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
144
- props: {
145
- modelValue: "Hello"
146
- }
147
- });
148
- await wrapper.find("textarea").trigger("keydown", {
149
- key: "Enter",
150
- shiftKey: true
151
- });
152
- (0, _vitest.expect)(wrapper.emitted("send")).toBeFalsy();
153
- });
154
- (0, _vitest.it)("should NOT emit send on Enter key when empty (prevents default)", async () => {
155
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
156
- props: {
157
- modelValue: " "
158
- }
159
- });
160
- await wrapper.find("textarea").trigger("keydown", {
161
- key: "Enter",
162
- shiftKey: false
163
- });
164
- (0, _vitest.expect)(wrapper.emitted("send")).toBeFalsy();
165
- });
166
- (0, _vitest.it)("should clear value after send", async () => {
167
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
168
- props: {
169
- modelValue: "Hello"
170
- }
171
- });
172
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
173
- await sendBtn.trigger("click");
174
- await (0, _vue.nextTick)();
175
- const emitted = wrapper.emitted("update:modelValue");
176
- const lastEmit = emitted[emitted.length - 1][0];
177
- (0, _vitest.expect)(lastEmit).toBe("");
178
- });
179
- (0, _vitest.it)("should render attachments header when attachments provided", () => {
180
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
181
- props: {
182
- attachments: [{
183
- name: "file.ts",
184
- type: "document"
185
- }]
186
- }
187
- });
188
- (0, _vitest.expect)(wrapper.find(".yh-ai-editor-sender__header").exists()).toBe(true);
189
- (0, _vitest.expect)(wrapper.find(".yh-ai-editor-sender__attachment").exists()).toBe(true);
190
- });
191
- (0, _vitest.it)("should not render attachments header when empty", () => {
192
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
193
- props: {
194
- attachments: []
195
- }
196
- });
197
- (0, _vitest.expect)(wrapper.find(".yh-ai-editor-sender__header").exists()).toBe(false);
198
- });
199
- (0, _vitest.it)("should emit remove-attachment when remove icon clicked", async () => {
200
- const attachments = [{
201
- name: "file.ts",
202
- type: "document"
203
- }];
204
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
205
- props: {
206
- attachments
207
- }
208
- });
209
- const removeBtn = wrapper.find(".yh-ai-editor-sender__attachment-remove");
210
- await removeBtn.trigger("click");
211
- (0, _vitest.expect)(wrapper.emitted("remove-attachment")).toBeTruthy();
212
- const emitted = wrapper.emitted("remove-attachment");
213
- (0, _vitest.expect)(emitted[0][0]).toBe(0);
214
- });
215
- (0, _vitest.it)("should render word limit when showWordLimit=true and maxLength provided", () => {
216
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
217
- props: {
218
- modelValue: "hi",
219
- showWordLimit: true,
220
- maxLength: 100
221
- }
222
- });
223
- (0, _vitest.expect)(wrapper.find(".yh-ai-editor-sender__word-limit").exists()).toBe(true);
224
- (0, _vitest.expect)(wrapper.find(".yh-ai-editor-sender__word-limit").text()).toContain("100");
225
- });
226
- (0, _vitest.it)("should not render word limit without maxLength", () => {
227
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
228
- props: {
229
- showWordLimit: true
230
- }
231
- });
232
- (0, _vitest.expect)(wrapper.find(".yh-ai-editor-sender__word-limit").exists()).toBe(false);
233
- });
234
- (0, _vitest.it)("should apply is-focused class on textarea focus", async () => {
235
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default);
236
- await wrapper.find("textarea").trigger("focus");
237
- (0, _vitest.expect)(wrapper.classes()).toContain("is-focused");
238
- });
239
- (0, _vitest.it)("should remove is-focused class on textarea blur", async () => {
240
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default);
241
- await wrapper.find("textarea").trigger("focus");
242
- await wrapper.find("textarea").trigger("blur");
243
- (0, _vitest.expect)(wrapper.classes()).not.toContain("is-focused");
244
- });
245
- (0, _vitest.it)("should render toolbar slot", () => {
246
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
247
- slots: {
248
- toolbar: '<button class="toolbar-btn">Tool</button>'
249
- }
250
- });
251
- (0, _vitest.expect)(wrapper.find(".toolbar-btn").exists()).toBe(true);
252
- });
253
- (0, _vitest.it)("should render actions slot", () => {
254
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
255
- slots: {
256
- actions: '<span class="custom-action">Model</span>'
257
- }
258
- });
259
- (0, _vitest.expect)(wrapper.find(".custom-action").exists()).toBe(true);
260
- });
261
- (0, _vitest.it)("should render header slot as attachment override", () => {
262
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
263
- props: {
264
- attachments: [{
265
- name: "f.ts",
266
- type: "document"
267
- }]
268
- },
269
- slots: {
270
- header: '<div class="custom-header">Header</div>'
271
- }
272
- });
273
- (0, _vitest.expect)(wrapper.find(".custom-header").exists()).toBe(true);
274
- });
275
- (0, _vitest.it)("should set rows attribute on textarea", () => {
276
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
277
- props: {
278
- rows: 5
279
- }
280
- });
281
- (0, _vitest.expect)(wrapper.find("textarea").attributes("rows")).toBe("5");
282
- });
283
- (0, _vitest.it)("should update textarea when modelValue prop changes", async () => {
284
- const wrapper = (0, _testUtils.mount)(_aiEditorSender.default, {
285
- props: {
286
- modelValue: "old text"
287
- }
288
- });
289
- await wrapper.setProps({
290
- modelValue: "new text"
291
- });
292
- await (0, _vue.nextTick)();
293
- (0, _vitest.expect)(wrapper.find("textarea").element.value).toBe("new text");
294
- });
295
- (0, _vitest.describe)("aiEditorSenderEmits", () => {
296
- (0, _vitest.it)("should validate send event", async () => {
297
- const {
298
- aiEditorSenderEmits
299
- } = await Promise.resolve().then(() => require("../src/ai-editor-sender.cjs"));
300
- (0, _vitest.expect)(aiEditorSenderEmits.send("hello")).toBe(true);
301
- (0, _vitest.expect)(aiEditorSenderEmits.send("")).toBe(false);
302
- });
303
- (0, _vitest.it)("should pass-through other event validators", async () => {
304
- const {
305
- aiEditorSenderEmits
306
- } = await Promise.resolve().then(() => require("../src/ai-editor-sender.cjs"));
307
- (0, _vitest.expect)(aiEditorSenderEmits["update:modelValue"]("text")).toBe(true);
308
- (0, _vitest.expect)(aiEditorSenderEmits.change("text")).toBe(true);
309
- (0, _vitest.expect)(aiEditorSenderEmits["remove-attachment"](0, {
310
- name: "f"
311
- })).toBe(true);
312
- (0, _vitest.expect)(aiEditorSenderEmits.clear()).toBe(true);
313
- });
314
- });
315
- });
@@ -1,226 +0,0 @@
1
- import { describe, it, expect } from "vitest";
2
- import { mount } from "@vue/test-utils";
3
- import { nextTick } from "vue";
4
- import AiEditorSender from "../src/ai-editor-sender.vue";
5
- describe("YhAiEditorSender", () => {
6
- it("should render with base class", () => {
7
- const wrapper = mount(AiEditorSender);
8
- expect(wrapper.find(".yh-ai-editor-sender").exists()).toBe(true);
9
- });
10
- it("should render textarea", () => {
11
- const wrapper = mount(AiEditorSender);
12
- expect(wrapper.find("textarea").exists()).toBe(true);
13
- });
14
- it("should render with placeholder", () => {
15
- const wrapper = mount(AiEditorSender, {
16
- props: { placeholder: "Type here..." }
17
- });
18
- expect(wrapper.find("textarea").attributes("placeholder")).toBe("Type here...");
19
- });
20
- it("should render modelValue in textarea", () => {
21
- const wrapper = mount(AiEditorSender, {
22
- props: { modelValue: "initial text" }
23
- });
24
- expect(wrapper.find("textarea").element.value).toBe("initial text");
25
- });
26
- it("should emit update:modelValue on input", async () => {
27
- const wrapper = mount(AiEditorSender, {
28
- props: { modelValue: "" }
29
- });
30
- const textarea = wrapper.find("textarea");
31
- await textarea.setValue("hello");
32
- const emitted = wrapper.emitted("update:modelValue");
33
- expect(emitted).toBeTruthy();
34
- expect(emitted[emitted.length - 1][0]).toBe("hello");
35
- });
36
- it("should emit change on input", async () => {
37
- const wrapper = mount(AiEditorSender, {
38
- props: { modelValue: "" }
39
- });
40
- await wrapper.find("textarea").setValue("changed");
41
- expect(wrapper.emitted("change")).toBeTruthy();
42
- });
43
- it("should apply is-disabled class when disabled=true", () => {
44
- const wrapper = mount(AiEditorSender, { props: { disabled: true } });
45
- expect(wrapper.classes()).toContain("is-disabled");
46
- });
47
- it("should disable textarea when disabled=true", () => {
48
- const wrapper = mount(AiEditorSender, { props: { disabled: true } });
49
- expect(wrapper.find("textarea").element.disabled).toBe(true);
50
- });
51
- it("should apply is-loading class when loading=true", () => {
52
- const wrapper = mount(AiEditorSender, { props: { loading: true } });
53
- expect(wrapper.classes()).toContain("is-loading");
54
- });
55
- it("should disable textarea when loading=true", () => {
56
- const wrapper = mount(AiEditorSender, { props: { loading: true } });
57
- expect(wrapper.find("textarea").element.disabled).toBe(true);
58
- });
59
- it("should emit send event when send button clicked with text", async () => {
60
- const wrapper = mount(AiEditorSender, {
61
- props: { modelValue: "Hello" }
62
- });
63
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
64
- await sendBtn.trigger("click");
65
- expect(wrapper.emitted("send")).toBeTruthy();
66
- const emitted = wrapper.emitted("send");
67
- expect(emitted[0][0]).toBe("Hello");
68
- });
69
- it("should NOT emit send if textarea is empty", async () => {
70
- const wrapper = mount(AiEditorSender, {
71
- props: { modelValue: "" }
72
- });
73
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
74
- await sendBtn.trigger("click");
75
- expect(wrapper.emitted("send")).toBeFalsy();
76
- });
77
- it("should NOT emit send if disabled", async () => {
78
- const wrapper = mount(AiEditorSender, {
79
- props: { modelValue: "some text", disabled: true }
80
- });
81
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
82
- await sendBtn.trigger("click");
83
- expect(wrapper.emitted("send")).toBeFalsy();
84
- });
85
- it("should NOT emit send if loading", async () => {
86
- const wrapper = mount(AiEditorSender, {
87
- props: { modelValue: "some text", loading: true }
88
- });
89
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
90
- await sendBtn.trigger("click");
91
- expect(wrapper.emitted("send")).toBeFalsy();
92
- });
93
- it("should emit send on Enter key (without Shift)", async () => {
94
- const wrapper = mount(AiEditorSender, {
95
- props: { modelValue: "Hello" }
96
- });
97
- await wrapper.find("textarea").trigger("keydown", { key: "Enter", shiftKey: false });
98
- expect(wrapper.emitted("send")).toBeTruthy();
99
- });
100
- it("should NOT emit send on Shift+Enter", async () => {
101
- const wrapper = mount(AiEditorSender, {
102
- props: { modelValue: "Hello" }
103
- });
104
- await wrapper.find("textarea").trigger("keydown", { key: "Enter", shiftKey: true });
105
- expect(wrapper.emitted("send")).toBeFalsy();
106
- });
107
- it("should NOT emit send on Enter key when empty (prevents default)", async () => {
108
- const wrapper = mount(AiEditorSender, {
109
- props: { modelValue: " " }
110
- });
111
- await wrapper.find("textarea").trigger("keydown", { key: "Enter", shiftKey: false });
112
- expect(wrapper.emitted("send")).toBeFalsy();
113
- });
114
- it("should clear value after send", async () => {
115
- const wrapper = mount(AiEditorSender, {
116
- props: { modelValue: "Hello" }
117
- });
118
- const sendBtn = wrapper.find(".yh-ai-editor-sender__send-btn");
119
- await sendBtn.trigger("click");
120
- await nextTick();
121
- const emitted = wrapper.emitted("update:modelValue");
122
- const lastEmit = emitted[emitted.length - 1][0];
123
- expect(lastEmit).toBe("");
124
- });
125
- it("should render attachments header when attachments provided", () => {
126
- const wrapper = mount(AiEditorSender, {
127
- props: {
128
- attachments: [{ name: "file.ts", type: "document" }]
129
- }
130
- });
131
- expect(wrapper.find(".yh-ai-editor-sender__header").exists()).toBe(true);
132
- expect(wrapper.find(".yh-ai-editor-sender__attachment").exists()).toBe(true);
133
- });
134
- it("should not render attachments header when empty", () => {
135
- const wrapper = mount(AiEditorSender, {
136
- props: { attachments: [] }
137
- });
138
- expect(wrapper.find(".yh-ai-editor-sender__header").exists()).toBe(false);
139
- });
140
- it("should emit remove-attachment when remove icon clicked", async () => {
141
- const attachments = [{ name: "file.ts", type: "document" }];
142
- const wrapper = mount(AiEditorSender, {
143
- props: { attachments }
144
- });
145
- const removeBtn = wrapper.find(".yh-ai-editor-sender__attachment-remove");
146
- await removeBtn.trigger("click");
147
- expect(wrapper.emitted("remove-attachment")).toBeTruthy();
148
- const emitted = wrapper.emitted("remove-attachment");
149
- expect(emitted[0][0]).toBe(0);
150
- });
151
- it("should render word limit when showWordLimit=true and maxLength provided", () => {
152
- const wrapper = mount(AiEditorSender, {
153
- props: { modelValue: "hi", showWordLimit: true, maxLength: 100 }
154
- });
155
- expect(wrapper.find(".yh-ai-editor-sender__word-limit").exists()).toBe(true);
156
- expect(wrapper.find(".yh-ai-editor-sender__word-limit").text()).toContain("100");
157
- });
158
- it("should not render word limit without maxLength", () => {
159
- const wrapper = mount(AiEditorSender, {
160
- props: { showWordLimit: true }
161
- });
162
- expect(wrapper.find(".yh-ai-editor-sender__word-limit").exists()).toBe(false);
163
- });
164
- it("should apply is-focused class on textarea focus", async () => {
165
- const wrapper = mount(AiEditorSender);
166
- await wrapper.find("textarea").trigger("focus");
167
- expect(wrapper.classes()).toContain("is-focused");
168
- });
169
- it("should remove is-focused class on textarea blur", async () => {
170
- const wrapper = mount(AiEditorSender);
171
- await wrapper.find("textarea").trigger("focus");
172
- await wrapper.find("textarea").trigger("blur");
173
- expect(wrapper.classes()).not.toContain("is-focused");
174
- });
175
- it("should render toolbar slot", () => {
176
- const wrapper = mount(AiEditorSender, {
177
- slots: {
178
- toolbar: '<button class="toolbar-btn">Tool</button>'
179
- }
180
- });
181
- expect(wrapper.find(".toolbar-btn").exists()).toBe(true);
182
- });
183
- it("should render actions slot", () => {
184
- const wrapper = mount(AiEditorSender, {
185
- slots: {
186
- actions: '<span class="custom-action">Model</span>'
187
- }
188
- });
189
- expect(wrapper.find(".custom-action").exists()).toBe(true);
190
- });
191
- it("should render header slot as attachment override", () => {
192
- const wrapper = mount(AiEditorSender, {
193
- props: { attachments: [{ name: "f.ts", type: "document" }] },
194
- slots: {
195
- header: '<div class="custom-header">Header</div>'
196
- }
197
- });
198
- expect(wrapper.find(".custom-header").exists()).toBe(true);
199
- });
200
- it("should set rows attribute on textarea", () => {
201
- const wrapper = mount(AiEditorSender, { props: { rows: 5 } });
202
- expect(wrapper.find("textarea").attributes("rows")).toBe("5");
203
- });
204
- it("should update textarea when modelValue prop changes", async () => {
205
- const wrapper = mount(AiEditorSender, {
206
- props: { modelValue: "old text" }
207
- });
208
- await wrapper.setProps({ modelValue: "new text" });
209
- await nextTick();
210
- expect(wrapper.find("textarea").element.value).toBe("new text");
211
- });
212
- describe("aiEditorSenderEmits", () => {
213
- it("should validate send event", async () => {
214
- const { aiEditorSenderEmits } = await import("../src/ai-editor-sender.mjs");
215
- expect(aiEditorSenderEmits.send("hello")).toBe(true);
216
- expect(aiEditorSenderEmits.send("")).toBe(false);
217
- });
218
- it("should pass-through other event validators", async () => {
219
- const { aiEditorSenderEmits } = await import("../src/ai-editor-sender.mjs");
220
- expect(aiEditorSenderEmits["update:modelValue"]("text")).toBe(true);
221
- expect(aiEditorSenderEmits.change("text")).toBe(true);
222
- expect(aiEditorSenderEmits["remove-attachment"](0, { name: "f" })).toBe(true);
223
- expect(aiEditorSenderEmits.clear()).toBe(true);
224
- });
225
- });
226
- });
@@ -1,45 +0,0 @@
1
- "use strict";
2
-
3
- var _vitest = require("vitest");
4
- var _serverRenderer = require("@vue/server-renderer");
5
- var _vue = require("vue");
6
- const {
7
- default: AiFileCard
8
- } = await Promise.resolve().then(() => require("../src/ai-file-card.vue"));
9
- (0, _vitest.describe)("YhAiFileCard SSR", () => {
10
- (0, _vitest.it)("should render to string on server", async () => {
11
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiFileCard, {
12
- name: "doc.pdf"
13
- }));
14
- (0, _vitest.expect)(html).toContain("yh-ai-file-card");
15
- (0, _vitest.expect)(html).toContain("doc.pdf");
16
- });
17
- (0, _vitest.it)("should render size modifier on server", async () => {
18
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiFileCard, {
19
- name: "x.pdf",
20
- size: "small"
21
- }));
22
- (0, _vitest.expect)(html).toContain("yh-ai-file-card--small");
23
- });
24
- (0, _vitest.it)("should render file size on server", async () => {
25
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiFileCard, {
26
- name: "x.pdf",
27
- byte: 1024
28
- }));
29
- (0, _vitest.expect)(html).toContain("yh-ai-file-card__size");
30
- });
31
- (0, _vitest.it)("should render description on server", async () => {
32
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiFileCard, {
33
- name: "x.pdf",
34
- description: "SSR description"
35
- }));
36
- (0, _vitest.expect)(html).toContain("SSR description");
37
- });
38
- (0, _vitest.it)("should render loading state on server", async () => {
39
- const html = await (0, _serverRenderer.renderToString)((0, _vue.h)(AiFileCard, {
40
- name: "x.pdf",
41
- loading: true
42
- }));
43
- (0, _vitest.expect)(html).toContain("yh-ai-file-card");
44
- });
45
- });
@@ -1,29 +0,0 @@
1
- import { describe, it, expect } from "vitest";
2
- import { renderToString } from "@vue/server-renderer";
3
- import { h } from "vue";
4
- const { default: AiFileCard } = await import("../src/ai-file-card.vue");
5
- describe("YhAiFileCard SSR", () => {
6
- it("should render to string on server", async () => {
7
- const html = await renderToString(h(AiFileCard, { name: "doc.pdf" }));
8
- expect(html).toContain("yh-ai-file-card");
9
- expect(html).toContain("doc.pdf");
10
- });
11
- it("should render size modifier on server", async () => {
12
- const html = await renderToString(h(AiFileCard, { name: "x.pdf", size: "small" }));
13
- expect(html).toContain("yh-ai-file-card--small");
14
- });
15
- it("should render file size on server", async () => {
16
- const html = await renderToString(h(AiFileCard, { name: "x.pdf", byte: 1024 }));
17
- expect(html).toContain("yh-ai-file-card__size");
18
- });
19
- it("should render description on server", async () => {
20
- const html = await renderToString(
21
- h(AiFileCard, { name: "x.pdf", description: "SSR description" })
22
- );
23
- expect(html).toContain("SSR description");
24
- });
25
- it("should render loading state on server", async () => {
26
- const html = await renderToString(h(AiFileCard, { name: "x.pdf", loading: true }));
27
- expect(html).toContain("yh-ai-file-card");
28
- });
29
- });