quasar 2.15.1 → 2.15.3

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 (795) hide show
  1. package/dist/api/AddressbarColor.json +1 -1
  2. package/dist/api/AppFullscreen.json +1 -1
  3. package/dist/api/BottomSheet.json +1 -1
  4. package/dist/api/ClosePopup.json +1 -1
  5. package/dist/api/Cookies.json +1 -1
  6. package/dist/api/Dark.json +1 -1
  7. package/dist/api/Dialog.json +1 -1
  8. package/dist/api/IconSet.json +1 -0
  9. package/dist/api/Intersection.json +1 -1
  10. package/dist/api/Lang.json +1 -1
  11. package/dist/api/Loading.json +1 -1
  12. package/dist/api/LoadingBar.json +1 -1
  13. package/dist/api/LocalStorage.json +1 -1
  14. package/dist/api/Morph.json +1 -1
  15. package/dist/api/Mutation.json +1 -1
  16. package/dist/api/Notify.json +1 -1
  17. package/dist/api/Platform.json +1 -1
  18. package/dist/api/QAjaxBar.json +1 -1
  19. package/dist/api/QAvatar.json +1 -1
  20. package/dist/api/QBadge.json +1 -1
  21. package/dist/api/QBanner.json +1 -1
  22. package/dist/api/QBar.json +1 -1
  23. package/dist/api/QBreadcrumbs.json +1 -1
  24. package/dist/api/QBreadcrumbsEl.json +1 -1
  25. package/dist/api/QBtn.json +1 -1
  26. package/dist/api/QBtnDropdown.json +1 -1
  27. package/dist/api/QBtnToggle.json +1 -1
  28. package/dist/api/QCard.json +1 -1
  29. package/dist/api/QCardActions.json +1 -1
  30. package/dist/api/QCardSection.json +1 -1
  31. package/dist/api/QCarousel.json +1 -1
  32. package/dist/api/QCarouselControl.json +1 -1
  33. package/dist/api/QCarouselSlide.json +1 -1
  34. package/dist/api/QChatMessage.json +1 -1
  35. package/dist/api/QCheckbox.json +1 -1
  36. package/dist/api/QChip.json +1 -1
  37. package/dist/api/QCircularProgress.json +1 -1
  38. package/dist/api/QColor.json +1 -1
  39. package/dist/api/QDate.json +1 -1
  40. package/dist/api/QDialog.json +1 -1
  41. package/dist/api/QDrawer.json +1 -1
  42. package/dist/api/QEditor.json +1 -1
  43. package/dist/api/QExpansionItem.json +1 -1
  44. package/dist/api/QFab.json +1 -1
  45. package/dist/api/QFabAction.json +1 -1
  46. package/dist/api/QField.json +1 -1
  47. package/dist/api/QFile.json +1 -1
  48. package/dist/api/QFooter.json +1 -1
  49. package/dist/api/QForm.json +1 -1
  50. package/dist/api/QFormChildMixin.json +1 -1
  51. package/dist/api/QHeader.json +1 -1
  52. package/dist/api/QIcon.json +1 -1
  53. package/dist/api/QImg.json +1 -1
  54. package/dist/api/QInfiniteScroll.json +1 -1
  55. package/dist/api/QInnerLoading.json +1 -1
  56. package/dist/api/QInput.json +1 -1
  57. package/dist/api/QIntersection.json +1 -1
  58. package/dist/api/QItem.json +1 -1
  59. package/dist/api/QKnob.json +1 -1
  60. package/dist/api/QLayout.json +1 -1
  61. package/dist/api/QLinearProgress.json +1 -1
  62. package/dist/api/QList.json +1 -1
  63. package/dist/api/QMarkupTable.json +1 -1
  64. package/dist/api/QMenu.json +1 -1
  65. package/dist/api/QNoSsr.json +1 -1
  66. package/dist/api/QOptionGroup.json +1 -1
  67. package/dist/api/QPage.json +1 -1
  68. package/dist/api/QPageScroller.json +1 -1
  69. package/dist/api/QPageSticky.json +1 -1
  70. package/dist/api/QPagination.json +1 -1
  71. package/dist/api/QParallax.json +1 -1
  72. package/dist/api/QPopupEdit.json +1 -1
  73. package/dist/api/QPopupProxy.json +1 -1
  74. package/dist/api/QPullToRefresh.json +1 -1
  75. package/dist/api/QRadio.json +1 -1
  76. package/dist/api/QRange.json +1 -1
  77. package/dist/api/QRating.json +1 -1
  78. package/dist/api/QResizeObserver.json +1 -1
  79. package/dist/api/QResponsive.json +1 -1
  80. package/dist/api/QRouteTab.json +1 -1
  81. package/dist/api/QScrollArea.json +1 -1
  82. package/dist/api/QScrollObserver.json +1 -1
  83. package/dist/api/QSelect.json +1 -1
  84. package/dist/api/QSeparator.json +1 -1
  85. package/dist/api/QSkeleton.json +1 -1
  86. package/dist/api/QSlideItem.json +1 -1
  87. package/dist/api/QSlideTransition.json +1 -1
  88. package/dist/api/QSlider.json +1 -1
  89. package/dist/api/QSpinner.json +1 -1
  90. package/dist/api/QSpinnerAudio.json +1 -1
  91. package/dist/api/QSpinnerBall.json +1 -1
  92. package/dist/api/QSpinnerBars.json +1 -1
  93. package/dist/api/QSpinnerBox.json +1 -1
  94. package/dist/api/QSpinnerClock.json +1 -1
  95. package/dist/api/QSpinnerComment.json +1 -1
  96. package/dist/api/QSpinnerCube.json +1 -1
  97. package/dist/api/QSpinnerDots.json +1 -1
  98. package/dist/api/QSpinnerFacebook.json +1 -1
  99. package/dist/api/QSpinnerGears.json +1 -1
  100. package/dist/api/QSpinnerGrid.json +1 -1
  101. package/dist/api/QSpinnerHearts.json +1 -1
  102. package/dist/api/QSpinnerHourglass.json +1 -1
  103. package/dist/api/QSpinnerInfinity.json +1 -1
  104. package/dist/api/QSpinnerIos.json +1 -1
  105. package/dist/api/QSpinnerOrbit.json +1 -1
  106. package/dist/api/QSpinnerOval.json +1 -1
  107. package/dist/api/QSpinnerPie.json +1 -1
  108. package/dist/api/QSpinnerPuff.json +1 -1
  109. package/dist/api/QSpinnerRadio.json +1 -1
  110. package/dist/api/QSpinnerRings.json +1 -1
  111. package/dist/api/QSpinnerTail.json +1 -1
  112. package/dist/api/QSplitter.json +1 -1
  113. package/dist/api/QStep.json +1 -1
  114. package/dist/api/QStepper.json +1 -1
  115. package/dist/api/QTab.json +1 -1
  116. package/dist/api/QTabPanel.json +1 -1
  117. package/dist/api/QTabPanels.json +1 -1
  118. package/dist/api/QTable.json +1 -1
  119. package/dist/api/QTabs.json +1 -1
  120. package/dist/api/QTd.json +1 -1
  121. package/dist/api/QTh.json +1 -1
  122. package/dist/api/QTime.json +1 -1
  123. package/dist/api/QTimeline.json +1 -1
  124. package/dist/api/QTimelineEntry.json +1 -1
  125. package/dist/api/QToggle.json +1 -1
  126. package/dist/api/QTooltip.json +1 -1
  127. package/dist/api/QTr.json +1 -1
  128. package/dist/api/QTree.json +1 -1
  129. package/dist/api/QUploader.json +1 -1
  130. package/dist/api/QVideo.json +1 -1
  131. package/dist/api/QVirtualScroll.json +1 -1
  132. package/dist/api/Ripple.json +1 -1
  133. package/dist/api/Screen.json +1 -1
  134. package/dist/api/Scroll.json +1 -1
  135. package/dist/api/ScrollFire.json +1 -1
  136. package/dist/api/SessionStorage.json +1 -1
  137. package/dist/api/TouchHold.json +1 -1
  138. package/dist/api/TouchPan.json +1 -1
  139. package/dist/api/TouchRepeat.json +1 -1
  140. package/dist/api/TouchSwipe.json +1 -1
  141. package/dist/icon-set/bootstrap-icons.umd.prod.js +2 -2
  142. package/dist/icon-set/eva-icons.umd.prod.js +2 -2
  143. package/dist/icon-set/fontawesome-v5-pro.umd.prod.js +2 -2
  144. package/dist/icon-set/fontawesome-v5.umd.prod.js +2 -2
  145. package/dist/icon-set/fontawesome-v6-pro.umd.prod.js +2 -2
  146. package/dist/icon-set/fontawesome-v6.umd.prod.js +2 -2
  147. package/dist/icon-set/ionicons-v4.umd.prod.js +2 -2
  148. package/dist/icon-set/line-awesome.umd.prod.js +2 -2
  149. package/dist/icon-set/material-icons-outlined.umd.prod.js +2 -2
  150. package/dist/icon-set/material-icons-round.umd.prod.js +2 -2
  151. package/dist/icon-set/material-icons-sharp.umd.prod.js +2 -2
  152. package/dist/icon-set/material-icons.umd.prod.js +2 -2
  153. package/dist/icon-set/material-symbols-outlined.umd.prod.js +2 -2
  154. package/dist/icon-set/material-symbols-rounded.umd.prod.js +2 -2
  155. package/dist/icon-set/material-symbols-sharp.umd.prod.js +2 -2
  156. package/dist/icon-set/mdi-v3.umd.prod.js +2 -2
  157. package/dist/icon-set/mdi-v4.umd.prod.js +2 -2
  158. package/dist/icon-set/mdi-v5.umd.prod.js +2 -2
  159. package/dist/icon-set/mdi-v6.umd.prod.js +2 -2
  160. package/dist/icon-set/mdi-v7.umd.prod.js +2 -2
  161. package/dist/icon-set/svg-bootstrap-icons.umd.prod.js +2 -2
  162. package/dist/icon-set/svg-eva-icons.umd.prod.js +2 -2
  163. package/dist/icon-set/svg-fontawesome-v5.umd.prod.js +2 -2
  164. package/dist/icon-set/svg-fontawesome-v6.umd.prod.js +2 -2
  165. package/dist/icon-set/svg-ionicons-v4.umd.prod.js +2 -2
  166. package/dist/icon-set/svg-ionicons-v5.umd.prod.js +2 -2
  167. package/dist/icon-set/svg-ionicons-v6.umd.prod.js +2 -2
  168. package/dist/icon-set/svg-line-awesome.umd.prod.js +2 -2
  169. package/dist/icon-set/svg-material-icons-outlined.umd.prod.js +2 -2
  170. package/dist/icon-set/svg-material-icons-round.umd.prod.js +2 -2
  171. package/dist/icon-set/svg-material-icons-sharp.umd.prod.js +2 -2
  172. package/dist/icon-set/svg-material-icons.umd.prod.js +2 -2
  173. package/dist/icon-set/svg-material-symbols-outlined.umd.prod.js +2 -2
  174. package/dist/icon-set/svg-material-symbols-rounded.umd.prod.js +2 -2
  175. package/dist/icon-set/svg-material-symbols-sharp.umd.prod.js +2 -2
  176. package/dist/icon-set/svg-mdi-v6.umd.prod.js +2 -2
  177. package/dist/icon-set/svg-mdi-v7.umd.prod.js +2 -2
  178. package/dist/icon-set/svg-themify.umd.prod.js +2 -2
  179. package/dist/icon-set/themify.umd.prod.js +2 -2
  180. package/dist/lang/ar-TN.umd.prod.js +2 -2
  181. package/dist/lang/ar.umd.prod.js +2 -2
  182. package/dist/lang/az-Latn.umd.prod.js +2 -2
  183. package/dist/lang/bg.umd.prod.js +2 -2
  184. package/dist/lang/bn.umd.prod.js +2 -2
  185. package/dist/lang/ca.umd.prod.js +2 -2
  186. package/dist/lang/cs.umd.prod.js +2 -2
  187. package/dist/lang/da.umd.prod.js +2 -2
  188. package/dist/lang/de-CH.umd.prod.js +2 -2
  189. package/dist/lang/de-DE.umd.prod.js +2 -2
  190. package/dist/lang/de.umd.prod.js +2 -2
  191. package/dist/lang/el.umd.prod.js +2 -2
  192. package/dist/lang/en-GB.umd.prod.js +2 -2
  193. package/dist/lang/en-US.umd.prod.js +2 -2
  194. package/dist/lang/eo.umd.prod.js +2 -2
  195. package/dist/lang/es.umd.prod.js +2 -2
  196. package/dist/lang/et.umd.prod.js +2 -2
  197. package/dist/lang/eu.umd.prod.js +2 -2
  198. package/dist/lang/fa-IR.umd.prod.js +2 -2
  199. package/dist/lang/fa.umd.prod.js +2 -2
  200. package/dist/lang/fi.umd.prod.js +2 -2
  201. package/dist/lang/fr.umd.prod.js +2 -2
  202. package/dist/lang/gn.umd.prod.js +2 -2
  203. package/dist/lang/he.umd.prod.js +2 -2
  204. package/dist/lang/hi.umd.prod.js +2 -2
  205. package/dist/lang/hr.umd.prod.js +2 -2
  206. package/dist/lang/hu.umd.prod.js +2 -2
  207. package/dist/lang/id.umd.prod.js +2 -2
  208. package/dist/lang/is.umd.prod.js +2 -2
  209. package/dist/lang/it.umd.prod.js +2 -2
  210. package/dist/lang/ja.umd.prod.js +2 -2
  211. package/dist/lang/kk.umd.prod.js +2 -2
  212. package/dist/lang/km.umd.prod.js +2 -2
  213. package/dist/lang/ko-KR.umd.prod.js +2 -2
  214. package/dist/lang/kur-CKB.umd.prod.js +2 -2
  215. package/dist/lang/lt.umd.prod.js +2 -2
  216. package/dist/lang/lu.umd.prod.js +2 -2
  217. package/dist/lang/lv.umd.prod.js +2 -2
  218. package/dist/lang/mk.umd.prod.js +2 -2
  219. package/dist/lang/ml.umd.prod.js +2 -2
  220. package/dist/lang/mm.umd.prod.js +2 -2
  221. package/dist/lang/ms-MY.umd.prod.js +2 -2
  222. package/dist/lang/ms.umd.prod.js +2 -2
  223. package/dist/lang/my.umd.prod.js +2 -2
  224. package/dist/lang/nb-NO.umd.prod.js +2 -2
  225. package/dist/lang/nl.umd.prod.js +2 -2
  226. package/dist/lang/pl.umd.prod.js +2 -2
  227. package/dist/lang/pt-BR.umd.prod.js +2 -2
  228. package/dist/lang/pt.umd.prod.js +2 -2
  229. package/dist/lang/ro.umd.prod.js +2 -2
  230. package/dist/lang/ru.umd.prod.js +2 -2
  231. package/dist/lang/sk.umd.prod.js +2 -2
  232. package/dist/lang/sl.umd.prod.js +2 -2
  233. package/dist/lang/sm.umd.prod.js +2 -2
  234. package/dist/lang/sr-CYR.umd.prod.js +2 -2
  235. package/dist/lang/sr.umd.prod.js +2 -2
  236. package/dist/lang/sv.umd.prod.js +2 -2
  237. package/dist/lang/ta.umd.prod.js +2 -2
  238. package/dist/lang/th.umd.prod.js +2 -2
  239. package/dist/lang/tl.umd.prod.js +2 -2
  240. package/dist/lang/tr.umd.prod.js +2 -2
  241. package/dist/lang/ug.umd.prod.js +2 -2
  242. package/dist/lang/uk.umd.prod.js +2 -2
  243. package/dist/lang/uz-Cyrl.umd.prod.js +2 -2
  244. package/dist/lang/uz-Latn.umd.prod.js +2 -2
  245. package/dist/lang/vi.umd.prod.js +2 -2
  246. package/dist/lang/zh-CN.umd.prod.js +2 -2
  247. package/dist/lang/zh-TW.umd.prod.js +2 -2
  248. package/dist/quasar.addon.prod.css +1 -1
  249. package/dist/quasar.addon.rtl.prod.css +1 -1
  250. package/dist/quasar.cjs.prod.js +19 -19
  251. package/dist/quasar.css +53 -53
  252. package/dist/quasar.esm.js +634 -559
  253. package/dist/quasar.esm.prod.js +14 -14
  254. package/dist/quasar.prod.css +1 -1
  255. package/dist/quasar.rtl.css +65 -65
  256. package/dist/quasar.rtl.prod.css +1 -1
  257. package/dist/quasar.sass +37 -37
  258. package/dist/quasar.umd.js +619 -544
  259. package/dist/quasar.umd.prod.js +23 -23
  260. package/dist/transforms/api-list.json +1 -1
  261. package/dist/transforms/import-map.json +1 -1
  262. package/dist/types/config.d.ts +3 -3
  263. package/dist/types/globals.d.ts +1 -1
  264. package/dist/types/index.d.ts +2245 -336
  265. package/dist/vetur/quasar-attributes.json +1 -1
  266. package/dist/vetur/quasar-tags.json +1 -1
  267. package/dist/web-types/web-types.json +1 -1
  268. package/lang/uk.js +1 -1
  269. package/lang/uk.mjs +1 -1
  270. package/package.json +28 -42
  271. package/src/api.extends.json +23 -21
  272. package/src/components/ajax-bar/QAjaxBar.js +2 -2
  273. package/src/components/ajax-bar/QAjaxBar.json +6 -5
  274. package/src/components/avatar/QAvatar.js +3 -3
  275. package/src/components/avatar/QAvatar.json +2 -2
  276. package/src/components/avatar/QAvatar.test.js +232 -0
  277. package/src/components/badge/QBadge.js +2 -2
  278. package/src/components/badge/QBadge.json +2 -2
  279. package/src/components/badge/QBadge.test.js +267 -0
  280. package/src/components/banner/QBanner.js +3 -3
  281. package/src/components/banner/QBanner.test.js +161 -0
  282. package/src/components/bar/QBar.js +3 -3
  283. package/src/components/bar/QBar.test.js +80 -0
  284. package/src/components/breadcrumbs/QBreadcrumbs.js +6 -4
  285. package/src/components/breadcrumbs/QBreadcrumbs.json +7 -7
  286. package/src/components/breadcrumbs/QBreadcrumbs.test.js +198 -0
  287. package/src/components/breadcrumbs/QBreadcrumbsEl.js +3 -3
  288. package/src/components/breadcrumbs/QBreadcrumbsEl.json +5 -5
  289. package/src/components/breadcrumbs/QBreadcrumbsEl.test.js +564 -0
  290. package/src/components/btn/QBtn.js +12 -6
  291. package/src/components/btn/QBtn.json +3 -2
  292. package/src/components/btn/QBtn.test.js +1529 -0
  293. package/src/components/btn/use-btn.js +8 -6
  294. package/src/components/btn/use-btn.json +14 -14
  295. package/src/components/btn/use-btn.test.js +134 -0
  296. package/src/components/btn-dropdown/QBtnDropdown.js +9 -10
  297. package/src/components/btn-dropdown/QBtnDropdown.json +16 -16
  298. package/src/components/btn-group/QBtnGroup.js +2 -2
  299. package/src/components/btn-toggle/QBtnToggle.js +3 -3
  300. package/src/components/btn-toggle/QBtnToggle.json +8 -8
  301. package/src/components/card/QCard.js +3 -3
  302. package/src/components/card/QCard.json +2 -2
  303. package/src/components/card/QCardActions.js +3 -3
  304. package/src/components/card/QCardActions.json +3 -3
  305. package/src/components/card/QCardSection.js +2 -2
  306. package/src/components/card/QCardSection.json +2 -2
  307. package/src/components/carousel/QCarousel.js +6 -6
  308. package/src/components/carousel/QCarousel.json +10 -10
  309. package/src/components/carousel/QCarouselControl.js +2 -2
  310. package/src/components/carousel/QCarouselControl.json +6 -6
  311. package/src/components/carousel/QCarouselSlide.js +3 -3
  312. package/src/components/carousel/QCarouselSlide.json +5 -8
  313. package/src/components/chat/QChatMessage.js +2 -2
  314. package/src/components/chat/QChatMessage.json +9 -9
  315. package/src/components/checkbox/QCheckbox.js +1 -1
  316. package/src/components/checkbox/use-checkbox.js +8 -8
  317. package/src/components/checkbox/use-checkbox.json +18 -16
  318. package/src/components/chip/QChip.js +7 -6
  319. package/src/components/chip/QChip.json +10 -8
  320. package/src/components/chip/QChip.test.js +902 -0
  321. package/src/components/circular-progress/QCircularProgress.js +5 -5
  322. package/src/components/circular-progress/QCircularProgress.json +9 -9
  323. package/src/components/circular-progress/{use-circular-progress.js → circular-progress.js} +1 -1
  324. package/src/components/circular-progress/circular-progress.test.js +14 -0
  325. package/src/components/color/QColor.js +10 -10
  326. package/src/components/color/QColor.json +9 -11
  327. package/src/components/date/QDate.js +9 -9
  328. package/src/components/date/QDate.json +42 -35
  329. package/src/components/date/use-datetime.js +2 -2
  330. package/src/components/date/use-datetime.json +8 -8
  331. package/src/components/dialog/QDialog.js +33 -22
  332. package/src/components/dialog/QDialog.json +18 -16
  333. package/src/components/dialog/QDialog.test.js +1264 -0
  334. package/src/components/dialog/test/DialogWrapper.vue +17 -0
  335. package/src/components/drawer/QDrawer.js +12 -12
  336. package/src/components/drawer/QDrawer.json +15 -16
  337. package/src/components/editor/QEditor.js +9 -9
  338. package/src/components/editor/QEditor.json +41 -49
  339. package/src/components/editor/editor-caret.js +1 -1
  340. package/src/components/editor/editor-utils.js +3 -3
  341. package/src/components/expansion-item/QExpansionItem.js +9 -9
  342. package/src/components/expansion-item/QExpansionItem.json +15 -15
  343. package/src/components/fab/QFab.js +5 -5
  344. package/src/components/fab/QFab.json +5 -5
  345. package/src/components/fab/QFabAction.js +4 -4
  346. package/src/components/fab/QFabAction.json +5 -6
  347. package/src/components/fab/use-fab.json +10 -12
  348. package/src/components/field/QField.js +2 -2
  349. package/src/components/field/QField.json +12 -8
  350. package/src/components/file/QFile.js +9 -9
  351. package/src/components/file/QFile.json +19 -14
  352. package/src/components/footer/QFooter.js +4 -4
  353. package/src/components/footer/QFooter.json +3 -5
  354. package/src/components/form/QForm.js +6 -6
  355. package/src/components/form/QForm.json +12 -7
  356. package/src/components/form/QFormChildMixin.js +2 -2
  357. package/src/components/form/QFormChildMixin.json +5 -4
  358. package/src/components/header/QHeader.js +3 -3
  359. package/src/components/header/QHeader.json +4 -6
  360. package/src/components/icon/QIcon.js +3 -3
  361. package/src/components/icon/QIcon.json +3 -3
  362. package/src/components/img/QImg.js +6 -6
  363. package/src/components/img/QImg.json +46 -60
  364. package/src/components/infinite-scroll/QInfiniteScroll.js +6 -6
  365. package/src/components/infinite-scroll/QInfiniteScroll.json +23 -10
  366. package/src/components/inner-loading/QInnerLoading.js +3 -3
  367. package/src/components/inner-loading/QInnerLoading.json +6 -8
  368. package/src/components/input/QInput.js +9 -9
  369. package/src/components/input/QInput.json +25 -14
  370. package/src/components/input/use-mask.js +1 -1
  371. package/src/components/input/use-mask.json +1 -1
  372. package/src/components/intersection/QIntersection.js +4 -4
  373. package/src/components/intersection/QIntersection.json +7 -7
  374. package/src/components/item/QItem.js +6 -6
  375. package/src/components/item/QItem.json +6 -6
  376. package/src/components/item/QItemLabel.js +2 -2
  377. package/src/components/item/QItemSection.js +2 -2
  378. package/src/components/item/QList.js +3 -3
  379. package/src/components/item/QList.json +2 -2
  380. package/src/components/knob/QKnob.js +7 -7
  381. package/src/components/knob/QKnob.json +7 -7
  382. package/src/components/layout/QLayout.js +5 -5
  383. package/src/components/layout/QLayout.json +3 -5
  384. package/src/components/linear-progress/QLinearProgress.js +4 -4
  385. package/src/components/linear-progress/QLinearProgress.json +3 -3
  386. package/src/components/markup-table/QMarkupTable.js +3 -3
  387. package/src/components/markup-table/QMarkupTable.json +3 -3
  388. package/src/components/menu/QMenu.js +20 -20
  389. package/src/components/menu/QMenu.json +16 -12
  390. package/src/components/no-ssr/QNoSsr.js +3 -3
  391. package/src/components/no-ssr/QNoSsr.json +3 -3
  392. package/src/components/option-group/QOptionGroup.js +2 -2
  393. package/src/components/option-group/QOptionGroup.json +15 -17
  394. package/src/components/page/QPage.js +3 -3
  395. package/src/components/page/QPage.json +2 -2
  396. package/src/components/page/QPageContainer.js +3 -3
  397. package/src/components/page-scroller/QPageScroller.js +2 -2
  398. package/src/components/page-scroller/QPageScroller.json +3 -3
  399. package/src/components/page-sticky/QPageSticky.js +1 -1
  400. package/src/components/page-sticky/QPageSticky.json +5 -5
  401. package/src/components/page-sticky/use-page-sticky.js +2 -2
  402. package/src/components/pagination/QPagination.js +4 -4
  403. package/src/components/pagination/QPagination.json +24 -22
  404. package/src/components/parallax/QParallax.js +6 -6
  405. package/src/components/parallax/QParallax.json +5 -5
  406. package/src/components/popup-edit/QPopupEdit.js +4 -4
  407. package/src/components/popup-edit/QPopupEdit.json +47 -33
  408. package/src/components/popup-proxy/QPopupProxy.js +3 -3
  409. package/src/components/popup-proxy/QPopupProxy.json +11 -7
  410. package/src/components/pull-to-refresh/QPullToRefresh.js +6 -6
  411. package/src/components/pull-to-refresh/QPullToRefresh.json +6 -2
  412. package/src/components/radio/QRadio.js +9 -9
  413. package/src/components/radio/QRadio.json +9 -7
  414. package/src/components/range/QRange.js +3 -3
  415. package/src/components/range/QRange.json +3 -7
  416. package/src/components/rating/QRating.js +6 -6
  417. package/src/components/rating/QRating.json +17 -20
  418. package/src/components/resize-observer/QResizeObserver.js +3 -3
  419. package/src/components/resize-observer/QResizeObserver.json +4 -3
  420. package/src/components/responsive/QResponsive.js +3 -3
  421. package/src/components/responsive/QResponsive.json +1 -1
  422. package/src/components/scroll-area/QScrollArea.js +7 -7
  423. package/src/components/scroll-area/QScrollArea.json +20 -14
  424. package/src/components/scroll-observer/QScrollObserver.js +3 -3
  425. package/src/components/scroll-observer/QScrollObserver.json +9 -6
  426. package/src/components/select/QSelect.js +10 -10
  427. package/src/components/select/QSelect.json +89 -72
  428. package/src/components/select/__tests__/QSelect.cy.js +21 -1
  429. package/src/components/separator/QSeparator.js +2 -2
  430. package/src/components/separator/QSeparator.json +3 -5
  431. package/src/components/skeleton/QSkeleton.js +3 -3
  432. package/src/components/skeleton/QSkeleton.json +14 -16
  433. package/src/components/slide-item/QSlideItem.js +5 -5
  434. package/src/components/slide-item/QSlideItem.json +5 -3
  435. package/src/components/slide-transition/QSlideTransition.js +1 -1
  436. package/src/components/slide-transition/QSlideTransition.json +1 -1
  437. package/src/components/slider/QSlider.js +4 -4
  438. package/src/components/slider/QSlider.json +2 -4
  439. package/src/components/slider/use-slider.js +7 -7
  440. package/src/components/slider/use-slider.json +19 -23
  441. package/src/components/space/QSpace.js +1 -1
  442. package/src/components/space/QSpace.test.js +17 -0
  443. package/src/components/spinner/QSpinner.js +1 -1
  444. package/src/components/spinner/QSpinner.json +2 -2
  445. package/src/components/spinner/QSpinnerAudio.js +1 -1
  446. package/src/components/spinner/QSpinnerAudio.json +1 -1
  447. package/src/components/spinner/QSpinnerBall.js +1 -1
  448. package/src/components/spinner/QSpinnerBall.json +1 -1
  449. package/src/components/spinner/QSpinnerBars.js +1 -1
  450. package/src/components/spinner/QSpinnerBars.json +1 -1
  451. package/src/components/spinner/QSpinnerBox.js +1 -1
  452. package/src/components/spinner/QSpinnerBox.json +1 -1
  453. package/src/components/spinner/QSpinnerClock.js +1 -1
  454. package/src/components/spinner/QSpinnerClock.json +1 -1
  455. package/src/components/spinner/QSpinnerComment.js +1 -1
  456. package/src/components/spinner/QSpinnerComment.json +1 -1
  457. package/src/components/spinner/QSpinnerCube.js +1 -1
  458. package/src/components/spinner/QSpinnerCube.json +1 -1
  459. package/src/components/spinner/QSpinnerDots.js +1 -1
  460. package/src/components/spinner/QSpinnerDots.json +1 -1
  461. package/src/components/spinner/QSpinnerFacebook.js +1 -1
  462. package/src/components/spinner/QSpinnerFacebook.json +1 -1
  463. package/src/components/spinner/QSpinnerGears.js +1 -1
  464. package/src/components/spinner/QSpinnerGears.json +1 -1
  465. package/src/components/spinner/QSpinnerGrid.js +1 -1
  466. package/src/components/spinner/QSpinnerGrid.json +1 -1
  467. package/src/components/spinner/QSpinnerHearts.js +1 -1
  468. package/src/components/spinner/QSpinnerHearts.json +1 -1
  469. package/src/components/spinner/QSpinnerHourglass.js +1 -1
  470. package/src/components/spinner/QSpinnerHourglass.json +1 -1
  471. package/src/components/spinner/QSpinnerInfinity.js +1 -1
  472. package/src/components/spinner/QSpinnerInfinity.json +1 -1
  473. package/src/components/spinner/QSpinnerIos.js +1 -1
  474. package/src/components/spinner/QSpinnerIos.json +1 -1
  475. package/src/components/spinner/QSpinnerOrbit.js +1 -1
  476. package/src/components/spinner/QSpinnerOrbit.json +1 -1
  477. package/src/components/spinner/QSpinnerOval.js +1 -1
  478. package/src/components/spinner/QSpinnerOval.json +1 -1
  479. package/src/components/spinner/QSpinnerPie.js +1 -1
  480. package/src/components/spinner/QSpinnerPie.json +1 -1
  481. package/src/components/spinner/QSpinnerPuff.js +1 -1
  482. package/src/components/spinner/QSpinnerPuff.json +1 -1
  483. package/src/components/spinner/QSpinnerRadio.js +1 -1
  484. package/src/components/spinner/QSpinnerRadio.json +1 -1
  485. package/src/components/spinner/QSpinnerRings.js +1 -1
  486. package/src/components/spinner/QSpinnerRings.json +1 -1
  487. package/src/components/spinner/QSpinnerTail.js +1 -1
  488. package/src/components/spinner/QSpinnerTail.json +1 -1
  489. package/src/components/spinner/{__spinner-mixin.json → spinner.json} +1 -1
  490. package/src/components/spinner/use-spinner.js +1 -1
  491. package/src/components/splitter/QSplitter.js +4 -4
  492. package/src/components/splitter/QSplitter.json +14 -14
  493. package/src/components/stepper/QStep.js +5 -5
  494. package/src/components/stepper/QStep.json +5 -11
  495. package/src/components/stepper/QStepper.js +5 -5
  496. package/src/components/stepper/QStepper.json +2 -4
  497. package/src/components/stepper/QStepperNavigation.js +2 -2
  498. package/src/components/stepper/StepHeader.js +2 -2
  499. package/src/components/tab-panels/QTabPanel.js +3 -3
  500. package/src/components/tab-panels/QTabPanel.json +1 -7
  501. package/src/components/tab-panels/QTabPanels.js +4 -4
  502. package/src/components/tab-panels/QTabPanels.json +1 -1
  503. package/src/components/table/QTable.js +8 -8
  504. package/src/components/table/QTable.json +148 -142
  505. package/src/components/table/QTd.js +2 -2
  506. package/src/components/table/QTd.json +1 -1
  507. package/src/components/table/QTh.js +2 -2
  508. package/src/components/table/QTh.json +1 -1
  509. package/src/components/table/QTr.js +2 -2
  510. package/src/components/table/QTr.json +1 -1
  511. package/src/components/table/table-column-selection.js +1 -1
  512. package/src/components/table/table-sort.js +2 -2
  513. package/src/components/tabs/QRouteTab.js +2 -2
  514. package/src/components/tabs/QRouteTab.json +2 -2
  515. package/src/components/tabs/QTab.js +1 -1
  516. package/src/components/tabs/QTab.json +6 -13
  517. package/src/components/tabs/QTabs.js +6 -6
  518. package/src/components/tabs/QTabs.json +8 -8
  519. package/src/components/tabs/use-tab.js +8 -8
  520. package/src/components/time/QTime.js +9 -9
  521. package/src/components/time/QTime.json +13 -23
  522. package/src/components/timeline/QTimeline.js +4 -4
  523. package/src/components/timeline/QTimeline.json +4 -4
  524. package/src/components/timeline/QTimelineEntry.js +3 -3
  525. package/src/components/timeline/QTimelineEntry.json +11 -11
  526. package/src/components/toggle/QToggle.js +1 -1
  527. package/src/components/toolbar/QToolbar.js +2 -2
  528. package/src/components/toolbar/QToolbarTitle.js +2 -2
  529. package/src/components/tooltip/QTooltip.js +15 -15
  530. package/src/components/tooltip/QTooltip.json +22 -24
  531. package/src/components/tree/QTree.js +5 -5
  532. package/src/components/tree/QTree.json +38 -30
  533. package/src/components/uploader/QUploader.js +1 -1
  534. package/src/components/uploader/QUploader.json +29 -14
  535. package/src/components/uploader/QUploaderAddTrigger.js +2 -2
  536. package/src/components/uploader/uploader-core.js +8 -8
  537. package/src/components/uploader/xhr-uploader-plugin.js +3 -1
  538. package/src/components/uploader/xhr-uploader-plugin.json +19 -19
  539. package/src/components/video/QVideo.js +2 -2
  540. package/src/components/video/QVideo.json +16 -20
  541. package/src/components/video/QVideo.test.js +183 -0
  542. package/src/components/virtual-scroll/QVirtualScroll.js +4 -4
  543. package/src/components/virtual-scroll/QVirtualScroll.json +8 -10
  544. package/src/components/virtual-scroll/use-virtual-scroll.js +3 -3
  545. package/src/components/virtual-scroll/use-virtual-scroll.json +16 -11
  546. package/src/composables/private.use-align/use-align.test.js +62 -0
  547. package/src/composables/{private → private.use-anchor}/use-anchor.js +3 -3
  548. package/src/composables/{private → private.use-anchor}/use-anchor.json +5 -6
  549. package/src/composables/private.use-dark/use-dark.test.js +68 -0
  550. package/src/composables/{private → private.use-field}/use-field.js +8 -8
  551. package/src/composables/{private → private.use-field}/use-field.json +14 -20
  552. package/src/composables/{private → private.use-file}/use-file.js +2 -2
  553. package/src/composables/{private → private.use-file}/use-file.json +10 -10
  554. package/src/composables/{private → private.use-fullscreen}/use-fullscreen.js +2 -2
  555. package/src/composables/{private → private.use-fullscreen}/use-fullscreen.json +10 -6
  556. package/src/composables/{private → private.use-history}/use-history.js +1 -1
  557. package/src/composables/private.use-history/use-history.test.js +116 -0
  558. package/src/composables/{private → private.use-key-composition}/use-key-composition.js +1 -1
  559. package/src/composables/{private → private.use-model-toggle}/use-model-toggle.js +1 -1
  560. package/src/composables/{private → private.use-panel}/use-panel.child.json +1 -3
  561. package/src/composables/{private → private.use-panel}/use-panel.js +4 -4
  562. package/src/composables/{private → private.use-panel}/use-panel.json +20 -15
  563. package/src/composables/{private → private.use-portal}/use-portal.js +21 -6
  564. package/src/composables/{private → private.use-prevent-scroll}/use-prevent-scroll.js +1 -1
  565. package/src/composables/{private → private.use-ratio}/use-ratio.json +4 -3
  566. package/src/composables/private.use-ratio/use-ratio.test.js +40 -0
  567. package/src/composables/{private → private.use-router-link}/use-router-link.js +1 -1
  568. package/src/composables/{private → private.use-router-link}/use-router-link.json +6 -6
  569. package/src/composables/{private → private.use-scroll-target}/use-scroll-target.js +2 -5
  570. package/src/composables/{private → private.use-size}/use-size.json +1 -1
  571. package/src/composables/private.use-size/use-size.test.js +40 -0
  572. package/src/composables/{private → private.use-transition}/use-transition.json +3 -3
  573. package/src/composables/private.use-transition/use-transition.test.js +118 -0
  574. package/src/composables/{private → private.use-validate}/use-validate.js +4 -4
  575. package/src/composables/{private → private.use-validate}/use-validate.json +9 -7
  576. package/src/composables/{use-dialog-plugin-component.js → use-dialog-plugin-component/use-dialog-plugin-component.js} +2 -4
  577. package/src/composables/{private/use-form.json → use-form/private.use-form.json} +1 -1
  578. package/src/composables/use-form/private.use-form.test.js +107 -0
  579. package/src/composables/{use-form-child.js → use-form/use-form-child.js} +1 -1
  580. package/src/composables/{use-hydration.js → use-hydration/use-hydration.js} +1 -1
  581. package/src/composables/use-hydration/use-hydration.test.js +27 -0
  582. package/src/composables/{use-id.js → use-id/use-id.js} +2 -2
  583. package/src/composables/use-id/use-id.test.js +72 -0
  584. package/src/composables/{use-interval.js → use-interval/use-interval.js} +1 -1
  585. package/src/composables/{use-meta.js → use-meta/use-meta.js} +1 -1
  586. package/src/composables/{use-quasar.js → use-quasar/use-quasar.js} +2 -1
  587. package/src/composables/use-quasar/use-quasar.test.js +35 -0
  588. package/src/composables/{use-tick.js → use-tick/use-tick.js} +1 -1
  589. package/src/composables/{use-timeout.js → use-timeout/use-timeout.js} +1 -1
  590. package/src/composables.js +12 -10
  591. package/src/css/index.sass +7 -7
  592. package/src/directives/{ClosePopup.js → close-popup/ClosePopup.js} +4 -4
  593. package/src/directives/{ClosePopup.json → close-popup/ClosePopup.json} +5 -5
  594. package/src/directives/{Intersection.js → intersection/Intersection.js} +3 -3
  595. package/src/directives/{Intersection.json → intersection/Intersection.json} +4 -6
  596. package/src/directives/{Morph.js → morph/Morph.js} +2 -2
  597. package/src/directives/{Morph.json → morph/Morph.json} +21 -21
  598. package/src/directives/{Mutation.js → mutation/Mutation.js} +2 -2
  599. package/src/directives/{Mutation.json → mutation/Mutation.json} +10 -12
  600. package/src/directives/{Ripple.js → ripple/Ripple.js} +6 -6
  601. package/src/directives/{Ripple.json → ripple/Ripple.json} +9 -15
  602. package/src/directives/ripple/Ripple.test.js +340 -0
  603. package/src/directives/{Scroll.js → scroll/Scroll.js} +4 -4
  604. package/src/directives/{Scroll.json → scroll/Scroll.json} +2 -2
  605. package/src/directives/{ScrollFire.js → scroll-fire/ScrollFire.js} +6 -6
  606. package/src/directives/{ScrollFire.json → scroll-fire/ScrollFire.json} +1 -1
  607. package/src/directives/{TouchHold.js → touch-hold/TouchHold.js} +5 -5
  608. package/src/directives/{TouchHold.json → touch-hold/TouchHold.json} +6 -6
  609. package/src/directives/{TouchPan.js → touch-pan/TouchPan.js} +6 -6
  610. package/src/directives/{TouchPan.json → touch-pan/TouchPan.json} +4 -4
  611. package/src/directives/{TouchRepeat.js → touch-repeat/TouchRepeat.js} +6 -6
  612. package/src/directives/{TouchRepeat.json → touch-repeat/TouchRepeat.json} +4 -4
  613. package/src/directives/{TouchSwipe.js → touch-swipe/TouchSwipe.js} +6 -6
  614. package/src/directives/{TouchSwipe.json → touch-swipe/TouchSwipe.json} +4 -4
  615. package/src/directives.js +11 -11
  616. package/src/index.dev.js +10 -4
  617. package/src/index.prod.js +11 -4
  618. package/src/index.ssr.js +11 -4
  619. package/src/index.umd.js +12 -4
  620. package/src/install-quasar.js +17 -12
  621. package/src/plugins/{AddressbarColor.js → addressbar/AddressbarColor.js} +3 -3
  622. package/src/plugins/{AddressbarColor.json → addressbar/AddressbarColor.json} +3 -2
  623. package/src/plugins/{AppFullscreen.js → app-fullscreen/AppFullscreen.js} +3 -3
  624. package/src/plugins/{AppFullscreen.json → app-fullscreen/AppFullscreen.json} +1 -0
  625. package/src/plugins/{AppVisibility.js → app-visibility/AppVisibility.js} +3 -3
  626. package/src/plugins/bottom-sheet/BottomSheet.js +8 -0
  627. package/src/plugins/{BottomSheet.json → bottom-sheet/BottomSheet.json} +11 -11
  628. package/src/{components/dialog-bottom-sheet/BottomSheet.js → plugins/bottom-sheet/component/BottomSheetComponent.js} +10 -10
  629. package/src/plugins/{Cookies.json → cookies/Cookies.json} +19 -18
  630. package/src/plugins/{Dark.js → dark/Dark.js} +2 -2
  631. package/src/plugins/{Dark.json → dark/Dark.json} +8 -5
  632. package/src/plugins/dialog/Dialog.js +8 -0
  633. package/src/plugins/{Dialog.json → dialog/Dialog.json} +17 -17
  634. package/src/{components/dialog-plugin/DialogPlugin.js → plugins/dialog/component/DialogPluginComponent.js} +14 -14
  635. package/src/{icon-set.js → plugins/icon-set/IconSet.js} +29 -10
  636. package/src/plugins/icon-set/IconSet.json +1417 -0
  637. package/src/plugins/icon-set/IconSet.test.js +346 -0
  638. package/src/{lang.js → plugins/lang/Lang.js} +25 -15
  639. package/src/plugins/lang/Lang.json +1100 -0
  640. package/src/plugins/lang/Lang.test.js +267 -0
  641. package/src/plugins/{Loading.js → loading/Loading.js} +8 -7
  642. package/src/plugins/{Loading.json → loading/Loading.json} +19 -17
  643. package/src/plugins/{LoadingBar.js → loading-bar/LoadingBar.js} +7 -7
  644. package/src/plugins/{LoadingBar.json → loading-bar/LoadingBar.json} +10 -5
  645. package/src/plugins/{Meta.js → meta/Meta.js} +2 -2
  646. package/src/plugins/{Notify.js → notify/Notify.js} +11 -10
  647. package/src/plugins/{Notify.json → notify/Notify.json} +60 -74
  648. package/src/plugins/{Platform.js → platform/Platform.js} +5 -12
  649. package/src/plugins/{Platform.json → platform/Platform.json} +12 -10
  650. package/src/plugins/platform/Platform.test.js +104 -0
  651. package/src/{body.js → plugins/private.body/Body.js} +5 -4
  652. package/src/{history.js → plugins/private.history/History.js} +2 -2
  653. package/src/plugins/{Screen.js → screen/Screen.js} +5 -5
  654. package/src/plugins/{Screen.json → screen/Screen.json} +10 -14
  655. package/src/plugins/{LocalStorage.js → storage/LocalStorage.js} +2 -2
  656. package/src/plugins/storage/LocalStorage.json +5 -0
  657. package/src/plugins/storage/LocalStorage.test.js +323 -0
  658. package/src/plugins/{SessionStorage.js → storage/SessionStorage.js} +2 -2
  659. package/src/plugins/storage/SessionStorage.json +5 -0
  660. package/src/plugins/storage/SessionStorage.test.js +323 -0
  661. package/src/{utils/private → plugins/storage/engine}/web-storage.js +21 -10
  662. package/src/{utils/private → plugins/storage/engine}/web-storage.json +29 -20
  663. package/src/plugins/storage/engine/web-storage.test.js +43 -0
  664. package/src/plugins.js +20 -16
  665. package/src/utils/EventBus/EventBus.test.js +108 -0
  666. package/src/utils/clone/clone.test.js +111 -0
  667. package/src/utils/colors/colors.test.js +459 -0
  668. package/src/utils/{copy-to-clipboard.js → copy-to-clipboard/copy-to-clipboard.js} +1 -1
  669. package/src/utils/{create-meta-mixin.js → create-meta-mixin/create-meta-mixin.js} +1 -1
  670. package/src/utils/{create-uploader-component.js → create-uploader-component/create-uploader-component.js} +4 -4
  671. package/src/utils/css-var/get-css-var.test.js +32 -0
  672. package/src/utils/css-var/set-css-var.test.js +36 -0
  673. package/src/utils/{date.js → date/date.js} +6 -6
  674. package/src/utils/debounce/debounce.test.js +188 -0
  675. package/src/utils/extend/extend.test.js +93 -0
  676. package/src/utils/{format.js → format/format.js} +2 -2
  677. package/src/utils/format/format.test.js +107 -0
  678. package/src/utils/{frame-debounce.js → frame-debounce/frame-debounce.js} +1 -1
  679. package/src/utils/frame-debounce/frame-debounce.test.js +127 -0
  680. package/src/utils/is/is.test.js +125 -0
  681. package/src/utils/{morph.js → morph/morph.js} +1 -1
  682. package/src/utils/{open-url.js → open-url/open-url.js} +3 -3
  683. package/src/utils/patterns/patterns.test.js +403 -0
  684. package/src/utils/{private → private.click-outside}/click-outside.js +2 -2
  685. package/src/utils/{private/define-reactive-plugin.js → private.create/create.js} +6 -3
  686. package/src/utils/private.create/create.test.js +58 -0
  687. package/src/utils/private.focus/focus-manager.test.js +190 -0
  688. package/src/utils/{private → private.focus}/focusout.js +1 -1
  689. package/src/utils/private.focus/focusout.test.js +114 -0
  690. package/src/utils/private.get-emits-object/get-emits-object.test.js +29 -0
  691. package/src/utils/private.global/global-config.test.js +54 -0
  692. package/src/utils/{private → private.global}/global-dialog.js +1 -1
  693. package/src/utils/{private → private.global}/global-dialog.json +3 -3
  694. package/src/utils/{private → private.global}/global-nodes.js +1 -1
  695. package/src/utils/private.global/global-nodes.test.js +110 -0
  696. package/src/utils/private.inject-obj-prop/inject-obj-prop.test.js +104 -0
  697. package/src/utils/{private → private.keyboard}/escape-key.js +2 -2
  698. package/src/utils/private.keyboard/escape-key.test.js +117 -0
  699. package/src/utils/private.noop-ssr-directive-transform/noop-ssr-directive-transform.test.js +14 -0
  700. package/src/utils/{private → private.portal}/portal.js +1 -1
  701. package/src/utils/{private → private.position-engine}/position-engine.js +2 -2
  702. package/src/utils/private.rtl/rtl.test.js +13 -0
  703. package/src/utils/{private → private.selection}/selection.js +1 -1
  704. package/src/utils/private.sort/sort.test.js +25 -0
  705. package/src/utils/{private → private.symbols}/symbols.js +1 -1
  706. package/src/utils/private.touch/touch.test.js +102 -0
  707. package/src/utils/{prevent-scroll.js → scroll/prevent-scroll.js} +3 -3
  708. package/src/utils/{scroll.js → scroll/scroll.js} +1 -1
  709. package/src/utils/throttle/throttle.test.js +146 -0
  710. package/src/utils/uid/uid.test.js +17 -0
  711. package/src/utils.js +24 -24
  712. package/src/vue-plugin.js +12 -4
  713. package/src/Lang.json +0 -19
  714. package/src/api-file-example.json +0 -94
  715. package/src/components/avatar/__tests__/QAvatar.cy.js +0 -120
  716. package/src/components/badge/__tests__/QBadge.cy.js +0 -148
  717. package/src/components/banner/__tests__/QBanner.cy.js +0 -106
  718. package/src/components/bar/__tests__/QBar.cy.js +0 -45
  719. package/src/components/breadcrumbs/__tests__/QBreadcrumbs.cy.js +0 -111
  720. package/src/components/breadcrumbs/__tests__/QBreadcrumbsEl.cy.js +0 -87
  721. package/src/components/btn/__tests__/QBtn.cy.js +0 -128
  722. package/src/components/btn/__tests__/use-btn.cy.js +0 -517
  723. package/src/components/chip/__tests__/QChip.cy.js +0 -480
  724. package/src/components/dialog/__tests__/DialogWrapper.vue +0 -33
  725. package/src/components/dialog/__tests__/QDialog.cy.js +0 -543
  726. package/src/components/tabs/__tests__/QRouteTab.cy.js +0 -9
  727. package/src/composables/private/__tests__/use-form.cy.js +0 -11
  728. package/src/composables/private/__tests__/use-size.cy.js +0 -36
  729. package/src/composables/private/__tests__/use-transition.cy.js +0 -111
  730. package/src/plugins/BottomSheet.js +0 -11
  731. package/src/plugins/Dialog.js +0 -11
  732. package/src/plugins/LocalStorage.json +0 -5
  733. package/src/plugins/SessionStorage.json +0 -5
  734. package/src/utils/private/create.js +0 -4
  735. /package/src/components/breadcrumbs/{__tests__ → test}/BasicBreadcrumbs.vue +0 -0
  736. /package/src/components/breadcrumbs/{__tests__ → test}/BreadcrumbWithSeparatorSlot.vue +0 -0
  737. /package/src/composables/{private/__tests__ → __tests__}/FieldWrapper.vue +0 -0
  738. /package/src/composables/{private/__tests__ → __tests__}/use-anchor.cy.js +0 -0
  739. /package/src/composables/{private/__tests__ → __tests__}/use-field.cy.js +0 -0
  740. /package/src/composables/{private/__tests__ → __tests__}/use-file.cy.js +0 -0
  741. /package/src/composables/{private/__tests__ → __tests__}/use-fullscreen.cy.js +0 -0
  742. /package/src/composables/{private/__tests__ → __tests__}/use-model-toggle.cy.js +0 -0
  743. /package/src/composables/{private/__tests__ → __tests__}/use-portal.cy.js +0 -0
  744. /package/src/composables/{private/__tests__ → __tests__}/use-router-link.cy.js +0 -0
  745. /package/src/composables/{private/__tests__ → __tests__}/use-validate.cy.js +0 -0
  746. /package/src/composables/{private → private.use-align}/use-align.js +0 -0
  747. /package/src/composables/{private → private.use-dark}/use-dark.js +0 -0
  748. /package/src/composables/{private → private.use-file}/use-file-dom-props.js +0 -0
  749. /package/src/composables/{private → private.use-model-toggle}/use-model-toggle.json +0 -0
  750. /package/src/composables/{private → private.use-panel}/use-panel.sass +0 -0
  751. /package/src/composables/{private → private.use-portal}/use-portal.json +0 -0
  752. /package/src/composables/{private → private.use-ratio}/use-ratio.js +0 -0
  753. /package/src/composables/{private → private.use-refocus-target}/use-refocus-target.js +0 -0
  754. /package/src/composables/{private → private.use-size}/use-size.js +0 -0
  755. /package/src/composables/{private → private.use-transition}/use-transition.js +0 -0
  756. /package/src/composables/{private/use-form.js → use-form/private.use-form.js} +0 -0
  757. /package/src/composables/{use-render-cache.js → use-render-cache/use-render-cache.js} +0 -0
  758. /package/src/composables/{use-split-attrs.js → use-split-attrs/use-split-attrs.js} +0 -0
  759. /package/src/directives/{Morph.sass → morph/Morph.sass} +0 -0
  760. /package/src/directives/{Ripple.sass → ripple/Ripple.sass} +0 -0
  761. /package/src/plugins/{AppVisibility.json → app-visibility/AppVisibility.json} +0 -0
  762. /package/src/{components/dialog-bottom-sheet/BottomSheet.sass → plugins/bottom-sheet/component/BottomSheetComponent.sass} +0 -0
  763. /package/src/plugins/{Cookies.js → cookies/Cookies.js} +0 -0
  764. /package/src/{components/dialog-plugin/DialogPlugin.sass → plugins/dialog/component/DialogPluginComponent.sass} +0 -0
  765. /package/src/plugins/{Loading.sass → loading/Loading.sass} +0 -0
  766. /package/src/plugins/{Meta.json → meta/Meta.json} +0 -0
  767. /package/src/plugins/{Notify.sass → notify/Notify.sass} +0 -0
  768. /package/src/utils/{EventBus.js → EventBus/EventBus.js} +0 -0
  769. /package/src/utils/{clone.js → clone/clone.js} +0 -0
  770. /package/src/utils/{colors.js → colors/colors.js} +0 -0
  771. /package/src/utils/{get-css-var.js → css-var/get-css-var.js} +0 -0
  772. /package/src/utils/{set-css-var.js → css-var/set-css-var.js} +0 -0
  773. /package/src/utils/{private/date-persian.js → date/private.persian.js} +0 -0
  774. /package/src/utils/{debounce.js → debounce/debounce.js} +0 -0
  775. /package/src/utils/{dom.js → dom/dom.js} +0 -0
  776. /package/src/utils/{event.js → event/event.js} +0 -0
  777. /package/src/utils/{export-file.js → export-file/export-file.js} +0 -0
  778. /package/src/utils/{extend.js → extend/extend.js} +0 -0
  779. /package/src/utils/{is.js → is/is.js} +0 -0
  780. /package/src/utils/{patterns.js → patterns/patterns.js} +0 -0
  781. /package/src/utils/{private → private.focus}/focus-manager.js +0 -0
  782. /package/src/utils/{private → private.get-emits-object}/get-emits-object.js +0 -0
  783. /package/src/utils/{private → private.global}/global-config.js +0 -0
  784. /package/src/utils/{private → private.inject-obj-prop}/inject-obj-prop.js +0 -0
  785. /package/src/utils/{private → private.keyboard}/key-composition.js +0 -0
  786. /package/src/utils/{private → private.noop-ssr-directive-transform}/noop-ssr-directive-transform.js +0 -0
  787. /package/src/utils/{private → private.option-sizes}/option-sizes.js +0 -0
  788. /package/src/utils/{private → private.render}/render.js +0 -0
  789. /package/src/utils/{private → private.rtl}/rtl.js +0 -0
  790. /package/src/utils/{private → private.sort}/sort.js +0 -0
  791. /package/src/utils/{private → private.touch}/touch.js +0 -0
  792. /package/src/utils/{private → private.vm}/vm.js +0 -0
  793. /package/src/utils/{run-sequential-promises.js → run-sequential-promises/run-sequential-promises.js} +0 -0
  794. /package/src/utils/{throttle.js → throttle/throttle.js} +0 -0
  795. /package/src/utils/{uid.js → uid/uid.js} +0 -0
@@ -0,0 +1,902 @@
1
+ import { mount, flushPromises } from '@vue/test-utils'
2
+ import { describe, test, expect } from 'vitest'
3
+
4
+ import QChip, { defaultSizes } from './QChip.js'
5
+
6
+ describe('[QChip API]', () => {
7
+ describe('[Props]', () => {
8
+ describe('[(prop)dense]', () => {
9
+ test('is defined correctly', () => {
10
+ expect(QChip.props.dense).toBeDefined()
11
+ })
12
+
13
+ test('type Boolean has effect', async () => {
14
+ const wrapper = mount(QChip)
15
+ const target = wrapper.get('.q-chip')
16
+
17
+ expect(
18
+ target.classes()
19
+ ).not.toContain('q-chip--dense')
20
+
21
+ await wrapper.setProps({ dense: true })
22
+ await flushPromises()
23
+
24
+ expect(
25
+ target.classes()
26
+ ).toContain('q-chip--dense')
27
+ })
28
+ })
29
+
30
+ describe('[(prop)size]', () => {
31
+ test('is defined correctly', () => {
32
+ expect(QChip.props.size).toBeDefined()
33
+ })
34
+
35
+ test('type String has effect', async () => {
36
+ const wrapper = mount(QChip)
37
+ const target = wrapper.get('.q-chip')
38
+
39
+ expect(
40
+ target.$style('font-size')
41
+ ).not.toBe('100px')
42
+
43
+ await wrapper.setProps({ size: '100px' })
44
+ await flushPromises()
45
+
46
+ expect(
47
+ target.$style('font-size')
48
+ ).toBe('100px')
49
+
50
+ await wrapper.setProps({ size: 'sm' })
51
+
52
+ expect(
53
+ target.$style('font-size')
54
+ ).toBe(`${ defaultSizes.sm }px`)
55
+ })
56
+ })
57
+
58
+ describe('[(prop)dark]', () => {
59
+ test('is defined correctly', () => {
60
+ expect(QChip.props.dark).toBeDefined()
61
+ })
62
+
63
+ test('type Boolean has effect', async () => {
64
+ const wrapper = mount(QChip)
65
+ const target = wrapper.get('.q-chip')
66
+
67
+ expect(
68
+ target.classes()
69
+ ).not.toContain('q-chip--dark')
70
+
71
+ await wrapper.setProps({ dark: true })
72
+ await flushPromises()
73
+
74
+ expect(
75
+ target.classes()
76
+ ).toContain('q-chip--dark')
77
+ })
78
+
79
+ test('type null has effect', async () => {
80
+ const wrapper = mount(QChip)
81
+ const target = wrapper.get('.q-chip')
82
+
83
+ expect(
84
+ target.classes()
85
+ ).not.toContain('q-chip--dense')
86
+
87
+ await wrapper.setProps({ dark: null })
88
+ await flushPromises()
89
+
90
+ expect(
91
+ target.classes()
92
+ ).not.toContain('q-chip--dense')
93
+ })
94
+ })
95
+
96
+ describe('[(prop)icon]', () => {
97
+ test('is defined correctly', () => {
98
+ expect(QChip.props.icon).toBeDefined()
99
+ })
100
+
101
+ test('type String has effect', async () => {
102
+ const propVal = 'map'
103
+ const wrapper = mount(QChip)
104
+
105
+ expect(
106
+ wrapper.find('.q-icon').exists()
107
+ ).toBe(false)
108
+
109
+ await wrapper.setProps({ icon: propVal })
110
+ await flushPromises()
111
+
112
+ expect(
113
+ wrapper.get('.q-icon').text()
114
+ ).toContain(propVal)
115
+ })
116
+ })
117
+
118
+ describe('[(prop)icon-right]', () => {
119
+ test('is defined correctly', () => {
120
+ expect(QChip.props.iconRight).toBeDefined()
121
+ })
122
+
123
+ test('type String has effect', async () => {
124
+ const propVal = 'map'
125
+ const wrapper = mount(QChip)
126
+
127
+ expect(
128
+ wrapper.find('.q-icon').exists()
129
+ ).toBe(false)
130
+
131
+ await wrapper.setProps({ iconRight: propVal })
132
+ await flushPromises()
133
+
134
+ expect(
135
+ wrapper.get('.q-icon').text()
136
+ ).toContain(propVal)
137
+ })
138
+ })
139
+
140
+ describe('[(prop)icon-remove]', () => {
141
+ test('is defined correctly', () => {
142
+ expect(QChip.props.iconRemove).toBeDefined()
143
+ })
144
+
145
+ test('type String has effect', async () => {
146
+ const propVal = 'map'
147
+ const wrapper = mount(QChip)
148
+
149
+ expect(
150
+ wrapper.find('.q-icon').exists()
151
+ ).toBe(false)
152
+
153
+ await wrapper.setProps({
154
+ removable: true,
155
+ iconRemove: propVal
156
+ })
157
+ await flushPromises()
158
+
159
+ expect(
160
+ wrapper.get('.q-icon.q-chip__icon--remove')
161
+ .text()
162
+ ).toBe(propVal)
163
+ })
164
+ })
165
+
166
+ describe('[(prop)icon-selected]', () => {
167
+ test('is defined correctly', () => {
168
+ expect(QChip.props.iconSelected).toBeDefined()
169
+ })
170
+
171
+ test('type String has effect', async () => {
172
+ const propVal = 'map'
173
+ const wrapper = mount(QChip)
174
+
175
+ expect(
176
+ wrapper.find('.q-icon').exists()
177
+ ).toBe(false)
178
+
179
+ await wrapper.setProps({
180
+ selected: true,
181
+ iconSelected: propVal
182
+ })
183
+ await flushPromises()
184
+
185
+ expect(
186
+ wrapper.get('.q-chip.q-chip--selected')
187
+ .get('.q-icon')
188
+ .text()
189
+ ).toBe(propVal)
190
+ })
191
+ })
192
+
193
+ describe('[(prop)label]', () => {
194
+ test('is defined correctly', () => {
195
+ expect(QChip.props.label).toBeDefined()
196
+ })
197
+
198
+ test.each([
199
+ [ 'String', 'John Doe' ],
200
+ [ 'Number', 22 ]
201
+ ])('type %s has effect', async (_, propVal) => {
202
+ const wrapper = mount(QChip)
203
+
204
+ expect(
205
+ wrapper.get('.q-chip__content')
206
+ .text()
207
+ ).not.toBe('' + propVal)
208
+
209
+ await wrapper.setProps({ label: propVal })
210
+ await flushPromises()
211
+
212
+ expect(
213
+ wrapper.get('.q-chip__content')
214
+ .text()
215
+ ).toBe('' + propVal)
216
+ })
217
+ })
218
+
219
+ describe('[(prop)color]', () => {
220
+ test('is defined correctly', () => {
221
+ expect(QChip.props.color).toBeDefined()
222
+ })
223
+
224
+ test('with default design', async () => {
225
+ const propVal = 'red'
226
+ const wrapper = mount(QChip)
227
+ const target = wrapper.get('.q-chip')
228
+
229
+ let cls = target.classes()
230
+ expect(cls).not.toContain('text-red')
231
+ expect(cls).not.toContain('bg-red')
232
+
233
+ await wrapper.setProps({ color: propVal })
234
+ await flushPromises()
235
+
236
+ cls = target.classes()
237
+ expect(cls).not.toContain('text-red')
238
+ expect(cls).toContain('bg-red')
239
+ })
240
+
241
+ test('with outline design', async () => {
242
+ const propVal = 'red'
243
+ const wrapper = mount(QChip, {
244
+ props: {
245
+ outline: true
246
+ }
247
+ })
248
+
249
+ const target = wrapper.get('.q-chip')
250
+
251
+ let cls = target.classes()
252
+ expect(cls).not.toContain('text-red')
253
+ expect(cls).not.toContain('bg-red')
254
+
255
+ await wrapper.setProps({ color: propVal })
256
+ await flushPromises()
257
+
258
+ cls = target.classes()
259
+ expect(cls).toContain('text-red')
260
+ expect(cls).not.toContain('bg-red')
261
+ })
262
+ })
263
+
264
+ describe('[(prop)text-color]', () => {
265
+ test('is defined correctly', () => {
266
+ expect(QChip.props.textColor).toBeDefined()
267
+ })
268
+
269
+ test('with default design', async () => {
270
+ const propVal = 'red'
271
+ const wrapper = mount(QChip)
272
+ const target = wrapper.get('.q-chip')
273
+
274
+ let cls = target.classes()
275
+ expect(cls).not.toContain('text-red')
276
+ expect(cls).not.toContain('bg-red')
277
+ expect(cls).not.toContain('q-chip--colored')
278
+
279
+ await wrapper.setProps({ textColor: propVal })
280
+ await flushPromises()
281
+
282
+ cls = target.classes()
283
+ expect(cls).toContain('text-red')
284
+ expect(cls).not.toContain('bg-red')
285
+ expect(cls).toContain('q-chip--colored')
286
+ })
287
+
288
+ test('with default design + color', async () => {
289
+ const propVal = 'red'
290
+ const wrapper = mount(QChip, {
291
+ props: {
292
+ color: 'blue'
293
+ }
294
+ })
295
+
296
+ const target = wrapper.get('.q-chip')
297
+
298
+ let cls = target.classes()
299
+ expect(cls).not.toContain('text-blue')
300
+ expect(cls).toContain('bg-blue')
301
+ expect(cls).not.toContain('text-red')
302
+ expect(cls).not.toContain('bg-red')
303
+ expect(cls).not.toContain('q-chip--colored')
304
+
305
+ await wrapper.setProps({ textColor: propVal })
306
+ await flushPromises()
307
+
308
+ cls = target.classes()
309
+ expect(cls).not.toContain('text-blue')
310
+ expect(cls).toContain('bg-blue')
311
+ expect(cls).toContain('text-red')
312
+ expect(cls).not.toContain('bg-red')
313
+ expect(cls).toContain('q-chip--colored')
314
+ })
315
+
316
+ test('with outline design', async () => {
317
+ const propVal = 'red'
318
+ const wrapper = mount(QChip, {
319
+ props: {
320
+ outline: true
321
+ }
322
+ })
323
+
324
+ const target = wrapper.get('.q-chip')
325
+
326
+ let cls = target.classes()
327
+ expect(cls).not.toContain('text-red')
328
+ expect(cls).not.toContain('bg-red')
329
+ expect(cls).not.toContain('q-chip--colored')
330
+
331
+ await wrapper.setProps({ textColor: propVal })
332
+ await flushPromises()
333
+
334
+ cls = target.classes()
335
+ expect(cls).toContain('text-red')
336
+ expect(cls).not.toContain('bg-red')
337
+ expect(cls).toContain('q-chip--colored')
338
+ })
339
+
340
+ test('with outline design + color', async () => {
341
+ const propVal = 'red'
342
+ const wrapper = mount(QChip, {
343
+ props: {
344
+ color: 'blue',
345
+ outline: true
346
+ }
347
+ })
348
+
349
+ const target = wrapper.get('.q-chip')
350
+
351
+ let cls = target.classes()
352
+ expect(cls).not.toContain('text-red')
353
+ expect(cls).not.toContain('bg-red')
354
+ expect(cls).toContain('text-blue')
355
+ expect(cls).not.toContain('bg-blue')
356
+ expect(cls).toContain('q-chip--colored')
357
+
358
+ await wrapper.setProps({ textColor: propVal })
359
+ await flushPromises()
360
+
361
+ cls = target.classes()
362
+ expect(cls).toContain('text-blue')
363
+ expect(cls).not.toContain('bg-blue')
364
+ expect(cls).not.toContain('text-red')
365
+ expect(cls).not.toContain('bg-red')
366
+ expect(cls).toContain('q-chip--colored')
367
+ })
368
+ })
369
+
370
+ describe('[(prop)model-value]', () => {
371
+ test('is defined correctly', () => {
372
+ expect(QChip.props.modelValue).toBeDefined()
373
+ })
374
+
375
+ test('type Boolean has effect', async () => {
376
+ const wrapper = mount(QChip, {
377
+ props: {
378
+ modelValue: true
379
+ }
380
+ })
381
+
382
+ expect(
383
+ wrapper.find('.q-chip').exists()
384
+ ).toBe(true)
385
+
386
+ await wrapper.setProps({ modelValue: false })
387
+ await flushPromises()
388
+
389
+ expect(
390
+ wrapper.find('.q-chip')
391
+ .exists()
392
+ ).toBe(false)
393
+ })
394
+ })
395
+
396
+ describe('[(prop)selected]', () => {
397
+ test('is defined correctly', () => {
398
+ expect(QChip.props.selected).toBeDefined()
399
+ })
400
+
401
+ test('type Boolean has effect', async () => {
402
+ const wrapper = mount(QChip)
403
+ const target = wrapper.get('.q-chip')
404
+
405
+ expect(
406
+ target.classes()
407
+ ).not.toContain('q-chip--selected')
408
+
409
+ await wrapper.setProps({
410
+ selected: true,
411
+ 'onUpdate:selected': val => { wrapper.setProps({ selected: val }) }
412
+ })
413
+ await flushPromises()
414
+
415
+ expect(
416
+ target.classes()
417
+ ).toContain('q-chip--selected')
418
+ })
419
+
420
+ test('type null has effect', async () => {
421
+ const wrapper = mount(QChip)
422
+ const target = wrapper.get('.q-chip')
423
+
424
+ expect(
425
+ target.classes()
426
+ ).not.toContain('q-chip--selected')
427
+
428
+ await wrapper.setProps({
429
+ selected: null,
430
+ 'onUpdate:selected': val => { wrapper.setProps({ selected: val }) }
431
+ })
432
+ await flushPromises()
433
+
434
+ expect(
435
+ target.classes()
436
+ ).not.toContain('q-chip--selected')
437
+ })
438
+ })
439
+
440
+ describe('[(prop)square]', () => {
441
+ test('is defined correctly', () => {
442
+ expect(QChip.props.square).toBeDefined()
443
+ })
444
+
445
+ test('type Boolean has effect', async () => {
446
+ const wrapper = mount(QChip)
447
+ const target = wrapper.get('.q-chip')
448
+
449
+ expect(
450
+ target.classes()
451
+ ).not.toContain('q-chip--square')
452
+
453
+ await wrapper.setProps({ square: true })
454
+ await flushPromises()
455
+
456
+ expect(
457
+ target.classes()
458
+ ).toContain('q-chip--square')
459
+
460
+ expect(
461
+ target.$computedStyle('border-radius')
462
+ ).toBe('4px')
463
+ })
464
+ })
465
+
466
+ describe('[(prop)outline]', () => {
467
+ test('is defined correctly', () => {
468
+ expect(QChip.props.outline).toBeDefined()
469
+ })
470
+
471
+ test('type Boolean has effect', async () => {
472
+ const wrapper = mount(QChip)
473
+ const target = wrapper.get('.q-chip')
474
+
475
+ expect(
476
+ target.classes()
477
+ ).not.toContain('q-chip--outline')
478
+
479
+ await wrapper.setProps({ outline: true })
480
+ await flushPromises()
481
+
482
+ expect(
483
+ target.classes()
484
+ ).toContain('q-chip--outline')
485
+ })
486
+ })
487
+
488
+ describe('[(prop)clickable]', () => {
489
+ test('is defined correctly', () => {
490
+ expect(QChip.props.clickable).toBeDefined()
491
+ })
492
+
493
+ test('type Boolean has effect', async () => {
494
+ const wrapper = mount(QChip)
495
+ const target = wrapper.get('.q-chip')
496
+
497
+ expect(
498
+ target.attributes('tabindex')
499
+ ).toBeUndefined()
500
+
501
+ await wrapper.setProps({ clickable: true })
502
+ await flushPromises()
503
+
504
+ expect(
505
+ target.attributes('tabindex')
506
+ ).toBe('0')
507
+
508
+ expect(
509
+ target.$computedStyle('cursor')
510
+ ).toBe('pointer')
511
+ })
512
+ })
513
+
514
+ describe('[(prop)removable]', () => {
515
+ test('is defined correctly', () => {
516
+ expect(QChip.props.removable).toBeDefined()
517
+ })
518
+
519
+ test('type Boolean has effect', async () => {
520
+ const wrapper = mount(QChip)
521
+
522
+ expect(
523
+ wrapper.find('.q-icon.q-chip__icon--remove')
524
+ .exists()
525
+ ).not.toBe(true)
526
+
527
+ await wrapper.setProps({ removable: true })
528
+ await flushPromises()
529
+
530
+ expect(
531
+ wrapper.find('.q-icon.q-chip__icon--remove')
532
+ .exists()
533
+ ).toBe(true)
534
+ })
535
+ })
536
+
537
+ describe('[(prop)ripple]', () => {
538
+ test('is defined correctly', () => {
539
+ expect(QChip.props.ripple).toBeDefined()
540
+ })
541
+
542
+ test('type Boolean has effect', async () => {
543
+ const wrapper = mount(QChip)
544
+
545
+ expect(
546
+ wrapper.find('.q-ripple')
547
+ .exists()
548
+ ).toBe(false)
549
+
550
+ await wrapper.setProps({ ripple: true })
551
+ await flushPromises()
552
+
553
+ await wrapper.trigger('click')
554
+
555
+ expect(
556
+ wrapper.find('.q-ripple')
557
+ .exists()
558
+ ).toBe(true)
559
+ })
560
+
561
+ test('type Object has effect', async () => {
562
+ const propVal = { center: true, color: 'teal', keyCodes: [] }
563
+ const wrapper = mount(QChip)
564
+
565
+ expect(
566
+ wrapper.find('.q-ripple')
567
+ .exists()
568
+ ).toBe(false)
569
+
570
+ await wrapper.setProps({ ripple: propVal })
571
+ await flushPromises()
572
+
573
+ await wrapper.trigger('click')
574
+
575
+ expect(
576
+ wrapper.find('.q-ripple')
577
+ .exists()
578
+ ).toBe(true)
579
+ })
580
+ })
581
+
582
+ describe('[(prop)remove-aria-label]', () => {
583
+ test('is defined correctly', () => {
584
+ expect(QChip.props.removeAriaLabel).toBeDefined()
585
+ })
586
+
587
+ test('type String has effect', async () => {
588
+ const propVal = 'Remove item'
589
+ const wrapper = mount(QChip, {
590
+ props: {
591
+ removable: true
592
+ }
593
+ })
594
+
595
+ const removeIcon = wrapper.get('.q-chip__icon--remove')
596
+
597
+ expect(
598
+ removeIcon.attributes('aria-label')
599
+ ).not.toBe(propVal)
600
+
601
+ await wrapper.setProps({ removeAriaLabel: propVal })
602
+ await flushPromises()
603
+
604
+ expect(
605
+ removeIcon.attributes('aria-label')
606
+ ).toBe(propVal)
607
+
608
+ expect(
609
+ removeIcon.attributes('tabindex')
610
+ ).toBe('0')
611
+ })
612
+ })
613
+
614
+ describe('[(prop)tabindex]', () => {
615
+ test('is defined correctly', () => {
616
+ expect(QChip.props.tabindex).toBeDefined()
617
+ })
618
+
619
+ test.each([
620
+ [ 'Number', 100 ],
621
+ [ 'String', '100' ]
622
+ ])('type %s has effect', async (_, propVal) => {
623
+ const wrapper = mount(QChip, {
624
+ props: {
625
+ clickable: true,
626
+ tabindex: propVal
627
+ }
628
+ })
629
+
630
+ expect(
631
+ wrapper.attributes('tabindex')
632
+ ).toBe('' + propVal)
633
+
634
+ // we'll test clickable + disable
635
+ await wrapper.setProps({ disable: true })
636
+ await flushPromises()
637
+
638
+ expect(
639
+ wrapper.attributes('tabindex')
640
+ ).toBeUndefined()
641
+
642
+ expect(
643
+ wrapper.attributes('aria-disabled')
644
+ ).toBeUndefined()
645
+
646
+ // we'll now test removable + disable
647
+ await wrapper.setProps({
648
+ clickable: false,
649
+ removable: true
650
+ })
651
+ await flushPromises()
652
+
653
+ let removeIcon = wrapper.get('.q-chip__icon--remove')
654
+
655
+ expect(
656
+ removeIcon.attributes('tabindex')
657
+ ).toBe('-1')
658
+
659
+ expect(
660
+ removeIcon.attributes('aria-disabled')
661
+ ).toBe('true')
662
+
663
+ // we'll now test removable
664
+ await wrapper.setProps({ disable: false })
665
+ await flushPromises()
666
+
667
+ removeIcon = wrapper.get('.q-chip__icon--remove')
668
+
669
+ expect(
670
+ removeIcon.attributes('tabindex')
671
+ ).toBe('' + propVal)
672
+
673
+ expect(
674
+ removeIcon.attributes('aria-disabled')
675
+ ).toBeUndefined()
676
+ })
677
+ })
678
+
679
+ describe('[(prop)disable]', () => {
680
+ test('is defined correctly', () => {
681
+ expect(QChip.props.disable).toBeDefined()
682
+ })
683
+
684
+ test('type Boolean has effect', async () => {
685
+ const wrapper = mount(QChip)
686
+
687
+ expect(
688
+ wrapper.get('.q-chip').classes()
689
+ ).not.toContain('disabled')
690
+
691
+ await wrapper.setProps({ disable: true })
692
+ await flushPromises()
693
+
694
+ expect(
695
+ wrapper.get('.q-chip').classes()
696
+ ).toContain('disabled')
697
+ })
698
+ })
699
+ })
700
+
701
+ describe('[Slots]', () => {
702
+ describe('[(slot)default]', () => {
703
+ test('renders the content', () => {
704
+ const slotContent = 'some-slot-content'
705
+ const wrapper = mount(QChip, {
706
+ slots: {
707
+ default: () => slotContent
708
+ }
709
+ })
710
+
711
+ expect(wrapper.text()).toContain(slotContent)
712
+ })
713
+ })
714
+ })
715
+
716
+ describe('[Events]', () => {
717
+ describe('[(event)click]', () => {
718
+ test('is defined correctly', () => {
719
+ expect(
720
+ QChip.emits?.includes('click')
721
+ ^ (QChip.props?.onClick !== void 0)
722
+ ).toBe(1)
723
+ })
724
+
725
+ test('is emitting when clickable', async () => {
726
+ const wrapper = mount(QChip, {
727
+ props: {
728
+ clickable: true
729
+ }
730
+ })
731
+
732
+ await wrapper.trigger('click')
733
+
734
+ const eventList = wrapper.emitted()
735
+ expect(eventList).toHaveProperty('click')
736
+ expect(eventList.click).toHaveLength(1)
737
+
738
+ const [ evt ] = eventList.click[ 0 ]
739
+ expect(evt).toBeInstanceOf(Event)
740
+ })
741
+
742
+ test('is emitting when selected', async () => {
743
+ const wrapper = mount(QChip, {
744
+ props: {
745
+ selected: true
746
+ }
747
+ })
748
+
749
+ await wrapper.trigger('click')
750
+
751
+ const eventList = wrapper.emitted()
752
+ expect(eventList).toHaveProperty('click')
753
+ expect(eventList.click).toHaveLength(1)
754
+
755
+ const [ evt ] = eventList.click[ 0 ]
756
+ expect(evt).toBeInstanceOf(Event)
757
+ })
758
+
759
+ test('is NOT emitting when not clickable or removable', async () => {
760
+ const wrapper = mount(QChip)
761
+
762
+ await wrapper.trigger('click')
763
+
764
+ const eventList = wrapper.emitted()
765
+ expect(eventList).not.toHaveProperty('click')
766
+ })
767
+
768
+ test('is NOT emitting when disable + clickable', async () => {
769
+ const wrapper = mount(QChip, {
770
+ props: {
771
+ clickable: true,
772
+ disable: true
773
+ }
774
+ })
775
+
776
+ await wrapper.trigger('click')
777
+
778
+ const eventList = wrapper.emitted()
779
+ expect(eventList).not.toHaveProperty('click')
780
+ })
781
+
782
+ test('is NOT emitting when disable + selected', async () => {
783
+ const wrapper = mount(QChip, {
784
+ props: {
785
+ selected: true,
786
+ disable: true
787
+ }
788
+ })
789
+
790
+ await wrapper.trigger('click')
791
+
792
+ const eventList = wrapper.emitted()
793
+ expect(eventList).not.toHaveProperty('click')
794
+ })
795
+ })
796
+
797
+ describe('[(event)update:selected]', () => {
798
+ test('is defined correctly', () => {
799
+ expect(
800
+ QChip.emits?.includes('update:selected')
801
+ ^ (QChip.props?.[ 'onUpdate:selected' ] !== void 0)
802
+ ).toBe(1)
803
+ })
804
+
805
+ test('is emitting', async () => {
806
+ const wrapper = mount(QChip, {
807
+ props: {
808
+ selected: false,
809
+ 'onUpdate:selected': val => {
810
+ wrapper.setProps({ selected: val })
811
+ }
812
+ }
813
+ })
814
+
815
+ await wrapper.trigger('click')
816
+ await flushPromises()
817
+
818
+ const eventList = wrapper.emitted()
819
+ expect(eventList).toHaveProperty('update:selected')
820
+ expect(eventList[ 'update:selected' ]).toHaveLength(1)
821
+
822
+ const [ state ] = eventList[ 'update:selected' ][ 0 ]
823
+ expect(state).toBeTypeOf('boolean')
824
+ })
825
+
826
+ test('is NOT emitting when disable', async () => {
827
+ const wrapper = mount(QChip, {
828
+ props: {
829
+ disable: true,
830
+ selected: false,
831
+ 'onUpdate:selected': val => {
832
+ wrapper.setProps({ selected: val })
833
+ }
834
+ }
835
+ })
836
+
837
+ await wrapper.trigger('click')
838
+ await flushPromises()
839
+
840
+ const eventList = wrapper.emitted()
841
+ expect(eventList).not.toHaveProperty('update:selected')
842
+ })
843
+ })
844
+
845
+ describe('[(event)remove]', () => {
846
+ test('is defined correctly', () => {
847
+ expect(
848
+ QChip.emits?.includes('remove')
849
+ ^ (QChip.props?.onRemove !== void 0)
850
+ ).toBe(1)
851
+ })
852
+
853
+ test('is emitting', async () => {
854
+ const wrapper = mount(QChip, {
855
+ props: {
856
+ removable: true
857
+ }
858
+ })
859
+
860
+ await wrapper.get('.q-chip__icon--remove')
861
+ .trigger('click')
862
+
863
+ const eventList = wrapper.emitted()
864
+ expect(eventList).toHaveProperty('remove')
865
+ expect(eventList.remove).toHaveLength(1)
866
+
867
+ expect(eventList.remove[ 0 ]).toHaveLength(0)
868
+ })
869
+ })
870
+
871
+ describe('[(event)update:model-value]', () => {
872
+ test('is defined correctly', () => {
873
+ expect(
874
+ QChip.emits?.includes('update:modelValue')
875
+ ^ (QChip.props?.[ 'onUpdate:modelValue' ] !== void 0)
876
+ ).toBe(1)
877
+ })
878
+
879
+ test('is emitting', async () => {
880
+ const wrapper = mount(QChip, {
881
+ props: {
882
+ removable: true,
883
+ modelValue: true,
884
+ 'onUpdate:modelValue': val => {
885
+ wrapper.setProps({ modelValue: val })
886
+ }
887
+ }
888
+ })
889
+
890
+ await wrapper.get('.q-chip__icon--remove')
891
+ .trigger('click')
892
+
893
+ const eventList = wrapper.emitted()
894
+ expect(eventList).toHaveProperty('update:modelValue')
895
+ expect(eventList[ 'update:modelValue' ]).toHaveLength(1)
896
+
897
+ const [ value ] = eventList[ 'update:modelValue' ][ 0 ]
898
+ expect(value).toBe(false)
899
+ })
900
+ })
901
+ })
902
+ })