quasar 2.15.3 → 2.16.0
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.
- package/dist/api/AppFullscreen.json +1 -1
- package/dist/api/Brand.json +1 -1
- package/dist/api/QBreadcrumbs.json +1 -1
- package/dist/api/QBreadcrumbsEl.json +1 -1
- package/dist/api/QBtnDropdown.json +1 -1
- package/dist/api/QCarousel.json +1 -1
- package/dist/api/QCheckbox.json +1 -1
- package/dist/api/QCircularProgress.json +1 -1
- package/dist/api/QDialog.json +1 -1
- package/dist/api/QDrawer.json +1 -1
- package/dist/api/QEditor.json +1 -1
- package/dist/api/QExpansionItem.json +1 -1
- package/dist/api/QFab.json +1 -1
- package/dist/api/QFabAction.json +1 -1
- package/dist/api/QField.json +1 -1
- package/dist/api/QFile.json +1 -1
- package/dist/api/QImg.json +1 -1
- package/dist/api/QInnerLoading.json +1 -1
- package/dist/api/QInput.json +1 -1
- package/dist/api/QIntersection.json +1 -1
- package/dist/api/QItem.json +1 -1
- package/dist/api/QKnob.json +1 -1
- package/dist/api/QMenu.json +1 -1
- package/dist/api/QPage.json +1 -1
- package/dist/api/QPagination.json +1 -1
- package/dist/api/QParallax.json +1 -1
- package/dist/api/QPopupEdit.json +1 -1
- package/dist/api/QRadio.json +1 -1
- package/dist/api/QRange.json +1 -1
- package/dist/api/QRouteTab.json +1 -1
- package/dist/api/QSelect.json +1 -1
- package/dist/api/QSeparator.json +1 -1
- package/dist/api/QSkeleton.json +1 -1
- package/dist/api/QSlider.json +1 -1
- package/dist/api/QSpinner.json +1 -1
- package/dist/api/QSpinnerAudio.json +1 -1
- package/dist/api/QSpinnerBall.json +1 -1
- package/dist/api/QSpinnerBars.json +1 -1
- package/dist/api/QSpinnerBox.json +1 -1
- package/dist/api/QSpinnerClock.json +1 -1
- package/dist/api/QSpinnerComment.json +1 -1
- package/dist/api/QSpinnerCube.json +1 -1
- package/dist/api/QSpinnerDots.json +1 -1
- package/dist/api/QSpinnerFacebook.json +1 -1
- package/dist/api/QSpinnerGears.json +1 -1
- package/dist/api/QSpinnerGrid.json +1 -1
- package/dist/api/QSpinnerHearts.json +1 -1
- package/dist/api/QSpinnerHourglass.json +1 -1
- package/dist/api/QSpinnerInfinity.json +1 -1
- package/dist/api/QSpinnerIos.json +1 -1
- package/dist/api/QSpinnerOrbit.json +1 -1
- package/dist/api/QSpinnerOval.json +1 -1
- package/dist/api/QSpinnerPie.json +1 -1
- package/dist/api/QSpinnerPuff.json +1 -1
- package/dist/api/QSpinnerRadio.json +1 -1
- package/dist/api/QSpinnerRings.json +1 -1
- package/dist/api/QSpinnerTail.json +1 -1
- package/dist/api/QSplitter.json +1 -1
- package/dist/api/QStepper.json +1 -1
- package/dist/api/QTabPanels.json +1 -1
- package/dist/api/QTable.json +1 -1
- package/dist/api/QTimeline.json +1 -1
- package/dist/api/QToggle.json +1 -1
- package/dist/api/QTooltip.json +1 -1
- package/dist/api/QTree.json +1 -1
- package/dist/api/QVirtualScroll.json +1 -1
- package/dist/icon-set/bootstrap-icons.umd.prod.js +1 -1
- package/dist/icon-set/eva-icons.umd.prod.js +1 -1
- package/dist/icon-set/fontawesome-v5-pro.umd.prod.js +1 -1
- package/dist/icon-set/fontawesome-v5.umd.prod.js +1 -1
- package/dist/icon-set/fontawesome-v6-pro.umd.prod.js +1 -1
- package/dist/icon-set/fontawesome-v6.umd.prod.js +1 -1
- package/dist/icon-set/ionicons-v4.umd.prod.js +1 -1
- package/dist/icon-set/line-awesome.umd.prod.js +1 -1
- package/dist/icon-set/material-icons-outlined.umd.prod.js +1 -1
- package/dist/icon-set/material-icons-round.umd.prod.js +1 -1
- package/dist/icon-set/material-icons-sharp.umd.prod.js +1 -1
- package/dist/icon-set/material-icons.umd.prod.js +1 -1
- package/dist/icon-set/material-symbols-outlined.umd.prod.js +1 -1
- package/dist/icon-set/material-symbols-rounded.umd.prod.js +1 -1
- package/dist/icon-set/material-symbols-sharp.umd.prod.js +1 -1
- package/dist/icon-set/mdi-v3.umd.prod.js +1 -1
- package/dist/icon-set/mdi-v4.umd.prod.js +1 -1
- package/dist/icon-set/mdi-v5.umd.prod.js +1 -1
- package/dist/icon-set/mdi-v6.umd.prod.js +1 -1
- package/dist/icon-set/mdi-v7.umd.prod.js +1 -1
- package/dist/icon-set/svg-bootstrap-icons.umd.prod.js +1 -1
- package/dist/icon-set/svg-eva-icons.umd.prod.js +1 -1
- package/dist/icon-set/svg-fontawesome-v5.umd.prod.js +1 -1
- package/dist/icon-set/svg-fontawesome-v6.umd.prod.js +1 -1
- package/dist/icon-set/svg-ionicons-v4.umd.prod.js +1 -1
- package/dist/icon-set/svg-ionicons-v5.umd.prod.js +1 -1
- package/dist/icon-set/svg-ionicons-v6.umd.prod.js +1 -1
- package/dist/icon-set/svg-line-awesome.umd.prod.js +1 -1
- package/dist/icon-set/svg-material-icons-outlined.umd.prod.js +1 -1
- package/dist/icon-set/svg-material-icons-round.umd.prod.js +1 -1
- package/dist/icon-set/svg-material-icons-sharp.umd.prod.js +1 -1
- package/dist/icon-set/svg-material-icons.umd.prod.js +1 -1
- package/dist/icon-set/svg-material-symbols-outlined.umd.prod.js +1 -1
- package/dist/icon-set/svg-material-symbols-rounded.umd.prod.js +1 -1
- package/dist/icon-set/svg-material-symbols-sharp.umd.prod.js +1 -1
- package/dist/icon-set/svg-mdi-v6.umd.prod.js +1 -1
- package/dist/icon-set/svg-mdi-v7.umd.prod.js +1 -1
- package/dist/icon-set/svg-themify.umd.prod.js +1 -1
- package/dist/icon-set/themify.umd.prod.js +1 -1
- package/dist/lang/ar-TN.umd.prod.js +1 -1
- package/dist/lang/ar.umd.prod.js +1 -1
- package/dist/lang/az-Latn.umd.prod.js +1 -1
- package/dist/lang/bg.umd.prod.js +1 -1
- package/dist/lang/bn.umd.prod.js +1 -1
- package/dist/lang/ca.umd.prod.js +1 -1
- package/dist/lang/cs.umd.prod.js +1 -1
- package/dist/lang/da.umd.prod.js +1 -1
- package/dist/lang/de-CH.umd.prod.js +1 -1
- package/dist/lang/de-DE.umd.prod.js +1 -1
- package/dist/lang/de.umd.prod.js +1 -1
- package/dist/lang/el.umd.prod.js +1 -1
- package/dist/lang/en-GB.umd.prod.js +1 -1
- package/dist/lang/en-US.umd.prod.js +1 -1
- package/dist/lang/eo.umd.prod.js +1 -1
- package/dist/lang/es.umd.prod.js +1 -1
- package/dist/lang/et.umd.prod.js +1 -1
- package/dist/lang/eu.umd.prod.js +1 -1
- package/dist/lang/fa-IR.umd.prod.js +1 -1
- package/dist/lang/fa.umd.prod.js +1 -1
- package/dist/lang/fi.umd.prod.js +1 -1
- package/dist/lang/fr.umd.prod.js +1 -1
- package/dist/lang/gn.umd.prod.js +1 -1
- package/dist/lang/he.umd.prod.js +1 -1
- package/dist/lang/hi.umd.prod.js +1 -1
- package/dist/lang/hr.umd.prod.js +1 -1
- package/dist/lang/hu.umd.prod.js +1 -1
- package/dist/lang/id.umd.prod.js +1 -1
- package/dist/lang/is.umd.prod.js +1 -1
- package/dist/lang/it.umd.prod.js +1 -1
- package/dist/lang/ja.umd.prod.js +1 -1
- package/dist/lang/kk.umd.prod.js +1 -1
- package/dist/lang/km.umd.prod.js +1 -1
- package/dist/lang/ko-KR.umd.prod.js +1 -1
- package/dist/lang/kur-CKB.umd.prod.js +1 -1
- package/dist/lang/lt.umd.prod.js +1 -1
- package/dist/lang/lu.umd.prod.js +1 -1
- package/dist/lang/lv.umd.prod.js +1 -1
- package/dist/lang/mk.umd.prod.js +1 -1
- package/dist/lang/ml.umd.prod.js +1 -1
- package/dist/lang/mm.umd.prod.js +1 -1
- package/dist/lang/ms-MY.umd.prod.js +1 -1
- package/dist/lang/ms.umd.prod.js +1 -1
- package/dist/lang/my.umd.prod.js +1 -1
- package/dist/lang/nb-NO.umd.prod.js +1 -1
- package/dist/lang/nl.umd.prod.js +1 -1
- package/dist/lang/pl.umd.prod.js +1 -1
- package/dist/lang/pt-BR.umd.prod.js +1 -1
- package/dist/lang/pt.umd.prod.js +1 -1
- package/dist/lang/ro.umd.prod.js +1 -1
- package/dist/lang/ru.umd.prod.js +1 -1
- package/dist/lang/sk.umd.prod.js +1 -1
- package/dist/lang/sl.umd.prod.js +1 -1
- package/dist/lang/sm.umd.prod.js +1 -1
- package/dist/lang/sr-CYR.umd.prod.js +1 -1
- package/dist/lang/sr.umd.prod.js +1 -1
- package/dist/lang/sv.umd.prod.js +1 -1
- package/dist/lang/ta.umd.prod.js +1 -1
- package/dist/lang/th.umd.prod.js +1 -1
- package/dist/lang/tl.umd.prod.js +1 -1
- package/dist/lang/tr.umd.prod.js +1 -1
- package/dist/lang/ug.umd.prod.js +1 -1
- package/dist/lang/uk.umd.prod.js +1 -1
- package/dist/lang/uz-Cyrl.umd.prod.js +1 -1
- package/dist/lang/uz-Latn.umd.prod.js +1 -1
- package/dist/lang/vi.umd.prod.js +1 -1
- package/dist/lang/zh-CN.umd.prod.js +1 -1
- package/dist/lang/zh-TW.umd.prod.js +1 -1
- package/dist/{quasar.esm.js → quasar.client.js} +337 -364
- package/dist/quasar.sass +1 -1
- package/dist/quasar.server.prod.cjs +127 -0
- package/dist/quasar.server.prod.js +127 -0
- package/dist/quasar.umd.js +337 -363
- package/dist/quasar.umd.prod.js +8 -8
- package/dist/transforms/api-list.json +1 -1
- package/dist/types/index.d.ts +191 -93
- package/dist/vetur/quasar-attributes.json +1 -1
- package/dist/vetur/quasar-tags.json +1 -1
- package/dist/web-types/web-types.json +1 -1
- package/icon-set/bootstrap-icons.js +3 -8
- package/icon-set/eva-icons.js +3 -8
- package/icon-set/fontawesome-v5-pro.js +1 -6
- package/icon-set/fontawesome-v5.js +1 -6
- package/icon-set/fontawesome-v6-pro.js +1 -6
- package/icon-set/fontawesome-v6.js +1 -6
- package/icon-set/ionicons-v4.js +3 -8
- package/icon-set/line-awesome.js +1 -6
- package/icon-set/material-icons-outlined.js +1 -6
- package/icon-set/material-icons-round.js +1 -6
- package/icon-set/material-icons-sharp.js +1 -6
- package/icon-set/material-icons.js +1 -6
- package/icon-set/material-symbols-outlined.js +1 -6
- package/icon-set/material-symbols-rounded.js +1 -6
- package/icon-set/material-symbols-sharp.js +1 -6
- package/icon-set/mdi-v3.js +1 -6
- package/icon-set/mdi-v4.js +1 -6
- package/icon-set/mdi-v5.js +1 -6
- package/icon-set/mdi-v6.js +1 -6
- package/icon-set/mdi-v7.js +1 -6
- package/icon-set/svg-bootstrap-icons.js +6 -6
- package/icon-set/svg-eva-icons.js +6 -6
- package/icon-set/svg-fontawesome-v5.js +3 -3
- package/icon-set/svg-fontawesome-v6.js +4 -5
- package/icon-set/svg-ionicons-v4.js +6 -6
- package/icon-set/svg-ionicons-v5.js +5 -5
- package/icon-set/svg-ionicons-v6.js +5 -5
- package/icon-set/svg-line-awesome.js +4 -5
- package/icon-set/svg-material-icons-outlined.js +4 -5
- package/icon-set/svg-material-icons-round.js +4 -5
- package/icon-set/svg-material-icons-sharp.js +4 -5
- package/icon-set/svg-material-icons.js +4 -5
- package/icon-set/svg-material-symbols-outlined.js +4 -4
- package/icon-set/svg-material-symbols-rounded.js +4 -4
- package/icon-set/svg-material-symbols-sharp.js +4 -4
- package/icon-set/svg-mdi-v6.js +4 -5
- package/icon-set/svg-mdi-v7.js +4 -4
- package/icon-set/svg-themify.js +6 -6
- package/icon-set/themify.js +3 -8
- package/lang/ar-TN.js +1 -6
- package/lang/ar.js +1 -6
- package/lang/az-Latn.js +1 -6
- package/lang/bg.js +1 -6
- package/lang/bn.js +1 -6
- package/lang/ca.js +1 -6
- package/lang/cs.js +1 -6
- package/lang/da.js +1 -6
- package/lang/de-CH.js +1 -6
- package/lang/de-DE.js +1 -6
- package/lang/de.js +1 -6
- package/lang/el.js +1 -6
- package/lang/en-GB.js +1 -6
- package/lang/en-US.js +1 -6
- package/lang/eo.js +1 -6
- package/lang/es.js +1 -6
- package/lang/et.js +1 -6
- package/lang/eu.js +1 -6
- package/lang/fa-IR.js +1 -6
- package/lang/fa.js +1 -6
- package/lang/fi.js +1 -6
- package/lang/fr.js +1 -6
- package/lang/gn.js +1 -6
- package/lang/he.js +1 -6
- package/lang/hi.js +1 -6
- package/lang/hr.js +1 -6
- package/lang/hu.js +1 -6
- package/lang/id.js +1 -6
- package/lang/is.js +1 -6
- package/lang/it.js +1 -6
- package/lang/ja.js +1 -6
- package/lang/kk.js +1 -6
- package/lang/km.js +1 -6
- package/lang/ko-KR.js +1 -6
- package/lang/kur-CKB.js +1 -6
- package/lang/lt.js +1 -6
- package/lang/lu.js +1 -6
- package/lang/lv.js +1 -6
- package/lang/mk.js +1 -6
- package/lang/ml.js +1 -6
- package/lang/mm.js +1 -6
- package/lang/ms-MY.js +1 -6
- package/lang/ms.js +1 -6
- package/lang/my.js +1 -6
- package/lang/nb-NO.js +1 -6
- package/lang/nl.js +1 -6
- package/lang/pl.js +1 -6
- package/lang/pt-BR.js +1 -6
- package/lang/pt.js +1 -6
- package/lang/ro.js +1 -6
- package/lang/ru.js +1 -6
- package/lang/sk.js +1 -6
- package/lang/sl.js +1 -6
- package/lang/sm.js +1 -6
- package/lang/sr-CYR.js +1 -6
- package/lang/sr.js +1 -6
- package/lang/sv.js +1 -6
- package/lang/ta.js +1 -6
- package/lang/th.js +1 -6
- package/lang/tl.js +1 -6
- package/lang/tr.js +1 -6
- package/lang/ug.js +1 -6
- package/lang/uk.js +1 -6
- package/lang/uz-Cyrl.js +1 -6
- package/lang/uz-Latn.js +1 -6
- package/lang/vi.js +1 -6
- package/lang/zh-CN.js +1 -6
- package/lang/zh-TW.js +1 -6
- package/package.json +20 -9
- package/src/components/avatar/QAvatar.test.js +0 -28
- package/src/components/badge/QBadge.test.js +0 -36
- package/src/components/banner/QBanner.test.js +0 -16
- package/src/components/bar/QBar.test.js +0 -8
- package/src/components/breadcrumbs/QBreadcrumbs.json +2 -1
- package/src/components/breadcrumbs/QBreadcrumbs.test.js +1 -21
- package/src/components/breadcrumbs/QBreadcrumbsEl.test.js +0 -51
- package/src/components/btn/QBtn.json +6 -1
- package/src/components/btn/QBtn.test.js +0 -143
- package/src/components/btn/use-btn.js +8 -4
- package/src/components/btn/use-btn.test.js +9 -1
- package/src/components/btn-dropdown/QBtnDropdown.js +3 -3
- package/src/components/btn-dropdown/QBtnDropdown.json +1 -4
- package/src/components/btn-toggle/QBtnToggle.json +3 -1
- package/src/components/card/QCardActions.json +1 -0
- package/src/components/carousel/QCarousel.js +4 -3
- package/src/components/carousel/QCarousel.json +6 -3
- package/src/components/checkbox/use-checkbox.json +1 -1
- package/src/components/chip/QChip.test.js +0 -108
- package/src/components/circular-progress/QCircularProgress.json +0 -1
- package/src/components/color/QColor.json +1 -0
- package/src/components/date/QDate.js +8 -2
- package/src/components/date/QDate.json +1 -0
- package/src/components/date/use-datetime.js +1 -3
- package/src/components/dialog/QDialog.js +1 -2
- package/src/components/dialog/QDialog.json +11 -1
- package/src/components/dialog/QDialog.test.js +38 -160
- package/src/components/drawer/QDrawer.json +2 -2
- package/src/components/editor/QEditor.js +3 -8
- package/src/components/editor/QEditor.json +9 -2
- package/src/components/expansion-item/QExpansionItem.js +1 -1
- package/src/components/expansion-item/QExpansionItem.json +5 -6
- package/src/components/fab/QFab.js +1 -0
- package/src/components/fab/QFab.json +5 -4
- package/src/components/fab/QFabAction.json +2 -1
- package/src/components/fab/use-fab.json +2 -1
- package/src/components/field/QField.json +0 -39
- package/src/components/file/QFile.js +2 -2
- package/src/components/file/QFile.json +2 -7
- package/src/components/footer/QFooter.json +3 -1
- package/src/components/form/QForm.js +1 -1
- package/src/components/header/QHeader.json +3 -1
- package/src/components/img/QImg.json +1 -1
- package/src/components/infinite-scroll/QInfiniteScroll.js +7 -6
- package/src/components/inner-loading/QInnerLoading.js +1 -1
- package/src/components/inner-loading/QInnerLoading.json +1 -0
- package/src/components/input/QInput.js +2 -1
- package/src/components/input/QInput.json +7 -24
- package/src/components/intersection/QIntersection.json +1 -1
- package/src/components/item/QItem.json +3 -1
- package/src/components/knob/QKnob.json +11 -2
- package/src/components/menu/QMenu.js +2 -4
- package/src/components/menu/QMenu.json +3 -1
- package/src/components/option-group/QOptionGroup.js +1 -0
- package/src/components/page/QPage.json +1 -2
- package/src/components/page-scroller/QPageScroller.js +1 -0
- package/src/components/page-scroller/QPageScroller.json +4 -0
- package/src/components/page-sticky/QPageSticky.js +1 -1
- package/src/components/pagination/QPagination.json +7 -2
- package/src/components/parallax/QParallax.js +2 -4
- package/src/components/parallax/QParallax.json +1 -0
- package/src/components/popup-edit/QPopupEdit.json +2 -1
- package/src/components/pull-to-refresh/QPullToRefresh.js +2 -4
- package/src/components/radio/QRadio.json +2 -2
- package/src/components/range/QRange.json +1 -0
- package/src/components/scroll-observer/QScrollObserver.js +2 -4
- package/src/components/select/QSelect.js +7 -7
- package/src/components/select/QSelect.json +27 -16
- package/src/components/separator/QSeparator.json +0 -1
- package/src/components/skeleton/QSkeleton.json +1 -1
- package/src/components/slider/QSlider.json +1 -0
- package/src/components/slider/use-slider.js +0 -2
- package/src/components/spinner/QSpinner.json +1 -5
- package/src/components/spinner/QSpinner.test.js +79 -0
- package/src/components/spinner/QSpinnerAudio.test.js +59 -0
- package/src/components/spinner/QSpinnerBall.test.js +59 -0
- package/src/components/spinner/QSpinnerBars.test.js +59 -0
- package/src/components/spinner/QSpinnerBox.test.js +59 -0
- package/src/components/spinner/QSpinnerClock.test.js +59 -0
- package/src/components/spinner/QSpinnerComment.test.js +59 -0
- package/src/components/spinner/QSpinnerCube.test.js +59 -0
- package/src/components/spinner/QSpinnerDots.test.js +59 -0
- package/src/components/spinner/QSpinnerFacebook.test.js +59 -0
- package/src/components/spinner/QSpinnerGears.test.js +59 -0
- package/src/components/spinner/QSpinnerGrid.test.js +59 -0
- package/src/components/spinner/QSpinnerHearts.test.js +59 -0
- package/src/components/spinner/QSpinnerHourglass.test.js +59 -0
- package/src/components/spinner/QSpinnerInfinity.test.js +59 -0
- package/src/components/spinner/QSpinnerIos.test.js +59 -0
- package/src/components/spinner/QSpinnerOrbit.test.js +59 -0
- package/src/components/spinner/QSpinnerOval.test.js +59 -0
- package/src/components/spinner/QSpinnerPie.test.js +59 -0
- package/src/components/spinner/QSpinnerPuff.test.js +59 -0
- package/src/components/spinner/QSpinnerRadio.test.js +59 -0
- package/src/components/spinner/QSpinnerRings.test.js +59 -0
- package/src/components/spinner/QSpinnerTail.test.js +59 -0
- package/src/components/spinner/spinner.json +5 -0
- package/src/components/spinner/use-spinner.js +1 -1
- package/src/components/spinner/use-spinner.test.js +59 -0
- package/src/components/splitter/QSplitter.json +3 -3
- package/src/components/stepper/QStep.json +6 -0
- package/src/components/tab-panels/QTabPanels.json +6 -0
- package/src/components/table/QTable.js +6 -8
- package/src/components/table/QTable.json +13 -8
- package/src/components/table/QTh.json +4 -0
- package/src/components/tabs/QRouteTab.json +3 -2
- package/src/components/tabs/QTab.json +1 -65
- package/src/components/tabs/use-tab.json +72 -0
- package/src/components/time/QTime.js +6 -0
- package/src/components/time/QTime.json +2 -0
- package/src/components/timeline/QTimeline.json +2 -1
- package/src/components/toolbar/QToolbar.test.js +41 -0
- package/src/components/toolbar/QToolbarTitle.test.js +41 -0
- package/src/components/tooltip/QTooltip.js +6 -6
- package/src/components/tooltip/QTooltip.json +6 -15
- package/src/components/tree/QTree.js +1 -1
- package/src/components/tree/QTree.json +2 -1
- package/src/components/uploader/xhr-uploader-plugin.js +1 -3
- package/src/components/video/QVideo.test.js +0 -24
- package/src/components/virtual-scroll/QVirtualScroll.js +2 -4
- package/src/components/virtual-scroll/QVirtualScroll.json +0 -1
- package/src/components/virtual-scroll/use-virtual-scroll.js +2 -2
- package/src/components/virtual-scroll/use-virtual-scroll.json +1 -1
- package/src/composables/private.use-anchor/use-anchor-static.json +22 -0
- package/src/composables/private.use-anchor/use-anchor.js +13 -4
- package/src/composables/private.use-anchor/use-anchor.json +2 -19
- package/src/composables/private.use-field/use-field.js +6 -3
- package/src/composables/private.use-field/use-field.json +22 -0
- package/src/composables/private.use-fullscreen/use-fullscreen.json +10 -0
- package/src/composables/private.use-model-toggle/use-model-toggle.json +4 -2
- package/src/composables/private.use-panel/use-panel.json +3 -0
- package/src/composables/private.use-portal/use-portal.js +1 -1
- package/src/composables/private.use-router-link/use-router-link.js +15 -9
- package/src/composables/private.use-router-link/use-router-link.json +2 -0
- package/src/composables/private.use-validate/use-validate.json +1 -0
- package/src/composables/use-id/use-id.test.js +0 -1
- package/src/composables/use-interval/use-interval.test.js +173 -0
- package/src/composables/use-render-cache/use-render-cache.js +2 -2
- package/src/composables/use-render-cache/use-render-cache.test.js +73 -0
- package/src/composables/use-split-attrs/use-split-attrs.test.js +55 -0
- package/src/composables/use-tick/use-tick.test.js +118 -0
- package/src/composables/use-timeout/use-timeout.test.js +169 -0
- package/src/install-quasar.js +1 -1
- package/src/plugins/addressbar/AddressbarColor.test.js +53 -0
- package/src/plugins/app-fullscreen/AppFullscreen.js +1 -1
- package/src/plugins/app-fullscreen/AppFullscreen.json +3 -1
- package/src/plugins/app-fullscreen/AppFullscreen.test.js +206 -0
- package/src/plugins/app-fullscreen/test/mock-fullscreen.js +43 -0
- package/src/plugins/app-visibility/AppVisibility.test.js +45 -0
- package/src/plugins/bottom-sheet/BottomSheet.js +1 -1
- package/src/plugins/bottom-sheet/BottomSheet.json +1 -1
- package/src/plugins/dark/Dark.test.js +158 -0
- package/src/plugins/dialog/Dialog.js +1 -1
- package/src/plugins/dialog/Dialog.json +1 -1
- package/src/plugins/icon-set/IconSet.js +1 -2
- package/src/plugins/icon-set/IconSet.test.js +2 -2
- package/src/plugins/lang/Lang.js +1 -2
- package/src/plugins/lang/Lang.test.js +2 -2
- package/src/plugins/loading/Loading.js +1 -1
- package/src/plugins/loading-bar/LoadingBar.js +1 -1
- package/src/plugins/notify/Notify.js +1 -1
- package/src/plugins/platform/Platform.js +2 -1
- package/src/plugins/private.body/Body.test.js +28 -0
- package/src/plugins/private.history/History.test.js +38 -0
- package/src/plugins/screen/Screen.test.js +453 -0
- package/src/utils/css-var/get-css-var.test.js +12 -0
- package/src/utils/css-var/set-css-var.test.js +18 -0
- package/src/utils/dom/dom.test.js +222 -0
- package/src/utils/{private.global/global-config.test.js → private.config/instance-config.test.js} +2 -2
- package/src/utils/{private.global/global-nodes.js → private.config/nodes.js} +1 -1
- package/src/utils/{private.global/global-nodes.test.js → private.config/nodes.test.js} +3 -3
- package/src/utils/{private.global/global-dialog.js → private.dialog/create-dialog.js} +1 -1
- package/src/utils/private.render/render.test.js +187 -0
- package/src/utils/private.selection/selection.test.js +40 -0
- package/src/utils/private.vm/vm.test.js +175 -0
- package/src/utils/scroll/scroll.js +4 -0
- package/wrappers/{index.mjs → index.cjs} +15 -15
- package/wrappers/index.js +15 -15
- package/dist/quasar.cjs.prod.js +0 -127
- package/dist/quasar.esm.prod.js +0 -127
- package/dist/transforms/import-transformation.js +0 -9
- package/icon-set/bootstrap-icons.mjs +0 -136
- package/icon-set/eva-icons.mjs +0 -186
- package/icon-set/fontawesome-v5-pro.mjs +0 -128
- package/icon-set/fontawesome-v5.mjs +0 -128
- package/icon-set/fontawesome-v6-pro.mjs +0 -128
- package/icon-set/fontawesome-v6.mjs +0 -128
- package/icon-set/ionicons-v4.mjs +0 -180
- package/icon-set/line-awesome.mjs +0 -128
- package/icon-set/material-icons-outlined.mjs +0 -128
- package/icon-set/material-icons-round.mjs +0 -128
- package/icon-set/material-icons-sharp.mjs +0 -128
- package/icon-set/material-icons.mjs +0 -128
- package/icon-set/material-symbols-outlined.mjs +0 -128
- package/icon-set/material-symbols-rounded.mjs +0 -128
- package/icon-set/material-symbols-sharp.mjs +0 -128
- package/icon-set/mdi-v3.mjs +0 -141
- package/icon-set/mdi-v4.mjs +0 -141
- package/icon-set/mdi-v5.mjs +0 -141
- package/icon-set/mdi-v6.mjs +0 -141
- package/icon-set/mdi-v7.mjs +0 -141
- package/icon-set/svg-bootstrap-icons.mjs +0 -210
- package/icon-set/svg-eva-icons.mjs +0 -233
- package/icon-set/svg-fontawesome-v5.mjs +0 -197
- package/icon-set/svg-fontawesome-v6.mjs +0 -198
- package/icon-set/svg-ionicons-v4.mjs +0 -234
- package/icon-set/svg-ionicons-v5.mjs +0 -225
- package/icon-set/svg-ionicons-v6.mjs +0 -224
- package/icon-set/svg-line-awesome.mjs +0 -198
- package/icon-set/svg-material-icons-outlined.mjs +0 -203
- package/icon-set/svg-material-icons-round.mjs +0 -203
- package/icon-set/svg-material-icons-sharp.mjs +0 -203
- package/icon-set/svg-material-icons.mjs +0 -203
- package/icon-set/svg-material-symbols-outlined.mjs +0 -201
- package/icon-set/svg-material-symbols-rounded.mjs +0 -201
- package/icon-set/svg-material-symbols-sharp.mjs +0 -201
- package/icon-set/svg-mdi-v6.mjs +0 -225
- package/icon-set/svg-mdi-v7.mjs +0 -224
- package/icon-set/svg-themify.mjs +0 -231
- package/icon-set/themify.mjs +0 -169
- package/lang/ar-TN.mjs +0 -98
- package/lang/ar.mjs +0 -98
- package/lang/az-Latn.mjs +0 -93
- package/lang/bg.mjs +0 -93
- package/lang/bn.mjs +0 -93
- package/lang/ca.mjs +0 -93
- package/lang/cs.mjs +0 -104
- package/lang/da.mjs +0 -93
- package/lang/de-CH.mjs +0 -93
- package/lang/de-DE.mjs +0 -93
- package/lang/de.mjs +0 -93
- package/lang/el.mjs +0 -93
- package/lang/en-GB.mjs +0 -93
- package/lang/en-US.mjs +0 -93
- package/lang/eo.mjs +0 -93
- package/lang/es.mjs +0 -93
- package/lang/et.mjs +0 -93
- package/lang/eu.mjs +0 -93
- package/lang/fa-IR.mjs +0 -94
- package/lang/fa.mjs +0 -94
- package/lang/fi.mjs +0 -94
- package/lang/fr.mjs +0 -96
- package/lang/gn.mjs +0 -93
- package/lang/he.mjs +0 -94
- package/lang/hi.mjs +0 -93
- package/lang/hr.mjs +0 -93
- package/lang/hu.mjs +0 -93
- package/lang/id.mjs +0 -93
- package/lang/is.mjs +0 -93
- package/lang/it.mjs +0 -93
- package/lang/ja.mjs +0 -92
- package/lang/kk.mjs +0 -97
- package/lang/km.mjs +0 -93
- package/lang/ko-KR.mjs +0 -93
- package/lang/kur-CKB.mjs +0 -103
- package/lang/lt.mjs +0 -105
- package/lang/lu.mjs +0 -93
- package/lang/lv.mjs +0 -93
- package/lang/mk.mjs +0 -93
- package/lang/ml.mjs +0 -97
- package/lang/mm.mjs +0 -94
- package/lang/ms-MY.mjs +0 -96
- package/lang/ms.mjs +0 -93
- package/lang/my.mjs +0 -92
- package/lang/nb-NO.mjs +0 -94
- package/lang/nl.mjs +0 -93
- package/lang/pl.mjs +0 -93
- package/lang/pt-BR.mjs +0 -93
- package/lang/pt.mjs +0 -93
- package/lang/ro.mjs +0 -93
- package/lang/ru.mjs +0 -97
- package/lang/sk.mjs +0 -93
- package/lang/sl.mjs +0 -93
- package/lang/sm.mjs +0 -93
- package/lang/sr-CYR.mjs +0 -93
- package/lang/sr.mjs +0 -93
- package/lang/sv.mjs +0 -93
- package/lang/ta.mjs +0 -93
- package/lang/th.mjs +0 -93
- package/lang/tl.mjs +0 -93
- package/lang/tr.mjs +0 -89
- package/lang/ug.mjs +0 -93
- package/lang/uk.mjs +0 -97
- package/lang/uz-Cyrl.mjs +0 -95
- package/lang/uz-Latn.mjs +0 -99
- package/lang/vi.mjs +0 -93
- package/lang/zh-CN.mjs +0 -92
- package/lang/zh-TW.mjs +0 -92
- /package/src/utils/{private.global/global-config.js → private.config/instance-config.js} +0 -0
- /package/src/utils/{private.global/global-dialog.json → private.dialog/create-dialog.json} +0 -0
|
@@ -1,15 +1,11 @@
|
|
|
1
1
|
{
|
|
2
|
-
"mixins": [ "
|
|
2
|
+
"mixins": [ "components/spinner/spinner" ],
|
|
3
3
|
|
|
4
4
|
"meta": {
|
|
5
5
|
"docsUrl": "https://v2.quasar.dev/vue-components/spinners"
|
|
6
6
|
},
|
|
7
7
|
|
|
8
8
|
"props": {
|
|
9
|
-
"color": {
|
|
10
|
-
"extends": "color"
|
|
11
|
-
},
|
|
12
|
-
|
|
13
9
|
"thickness": {
|
|
14
10
|
"type": "Number",
|
|
15
11
|
"desc": "Override value to use for stroke-width",
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinner from './QSpinner.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinner API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinner)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinner)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
|
|
59
|
+
describe('[(prop)thickness]', () => {
|
|
60
|
+
test('type Number has effect', async () => {
|
|
61
|
+
const propVal = 50
|
|
62
|
+
const wrapper = mount(QSpinner)
|
|
63
|
+
|
|
64
|
+
const target = wrapper.get('.q-spinner circle')
|
|
65
|
+
|
|
66
|
+
expect(
|
|
67
|
+
target.attributes('stroke-width')
|
|
68
|
+
).not.toBe('' + propVal)
|
|
69
|
+
|
|
70
|
+
await wrapper.setProps({ thickness: propVal })
|
|
71
|
+
await flushPromises()
|
|
72
|
+
|
|
73
|
+
expect(
|
|
74
|
+
target.attributes('stroke-width')
|
|
75
|
+
).toBe('' + propVal)
|
|
76
|
+
})
|
|
77
|
+
})
|
|
78
|
+
})
|
|
79
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerAudio from './QSpinnerAudio.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerAudio API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerAudio)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerAudio)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerBall from './QSpinnerBall.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerBall API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerBall)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerBall)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerBars from './QSpinnerBars.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerBars API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerBars)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerBars)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerBox from './QSpinnerBox.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerBox API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerBox)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerBox)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerClock from './QSpinnerClock.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerClock API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerClock)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerClock)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerComment from './QSpinnerComment.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerComment API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerComment)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerComment)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerCube from './QSpinnerCube.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerCube API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerCube)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerCube)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerDots from './QSpinnerDots.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerDots API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerDots)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerDots)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerFacebook from './QSpinnerFacebook.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerFacebook API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerFacebook)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerFacebook)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { mount, flushPromises } from '@vue/test-utils'
|
|
2
|
+
import { describe, test, expect } from 'vitest'
|
|
3
|
+
|
|
4
|
+
import QSpinnerGears from './QSpinnerGears.js'
|
|
5
|
+
|
|
6
|
+
describe('[QSpinnerGears API]', () => {
|
|
7
|
+
describe('[Props]', () => {
|
|
8
|
+
describe('[(prop)size]', () => {
|
|
9
|
+
test.each([
|
|
10
|
+
[ 'String', '100px' ],
|
|
11
|
+
[ 'Number', 100 ]
|
|
12
|
+
])('type %s has effect', async (_, propVal) => {
|
|
13
|
+
const expectedValue = '' + propVal
|
|
14
|
+
const wrapper = mount(QSpinnerGears)
|
|
15
|
+
|
|
16
|
+
const target = wrapper.get('.q-spinner')
|
|
17
|
+
|
|
18
|
+
expect(
|
|
19
|
+
target.attributes('width')
|
|
20
|
+
).not.toBe(expectedValue)
|
|
21
|
+
|
|
22
|
+
expect(
|
|
23
|
+
target.attributes('height')
|
|
24
|
+
).not.toBe(expectedValue)
|
|
25
|
+
|
|
26
|
+
await wrapper.setProps({ size: propVal })
|
|
27
|
+
await flushPromises()
|
|
28
|
+
|
|
29
|
+
expect(
|
|
30
|
+
target.attributes('width')
|
|
31
|
+
).toBe(expectedValue)
|
|
32
|
+
|
|
33
|
+
expect(
|
|
34
|
+
target.attributes('height')
|
|
35
|
+
).toBe(expectedValue)
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
describe('[(prop)color]', () => {
|
|
40
|
+
test('type String has effect', async () => {
|
|
41
|
+
const propVal = 'red'
|
|
42
|
+
const wrapper = mount(QSpinnerGears)
|
|
43
|
+
|
|
44
|
+
const target = wrapper.get('.q-spinner')
|
|
45
|
+
|
|
46
|
+
expect(
|
|
47
|
+
target.classes()
|
|
48
|
+
).not.toContain('text-red')
|
|
49
|
+
|
|
50
|
+
await wrapper.setProps({ color: propVal })
|
|
51
|
+
await flushPromises()
|
|
52
|
+
|
|
53
|
+
expect(
|
|
54
|
+
target.classes()
|
|
55
|
+
).toContain('text-red')
|
|
56
|
+
})
|
|
57
|
+
})
|
|
58
|
+
})
|
|
59
|
+
})
|