quasar 2.19.2 → 2.20.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/Lang.json +1 -1
- package/dist/api/QCarouselSlide.json +1 -1
- package/dist/api/QChatMessage.json +1 -1
- package/dist/api/QImg.json +1 -1
- package/dist/api/QParallax.json +1 -1
- package/dist/api/QRange.json +1 -1
- package/dist/api/QSlider.json +1 -1
- package/dist/api/QTimelineEntry.json +1 -1
- package/dist/api/QTree.json +1 -1
- package/dist/icon-set/bootstrap-icons.umd.prod.js +1 -1
- package/dist/icon-set/eva-icons.umd.prod.js +2 -2
- package/dist/icon-set/fontawesome-v5-pro.umd.prod.js +5 -5
- package/dist/icon-set/fontawesome-v5.umd.prod.js +5 -5
- package/dist/icon-set/fontawesome-v6-pro.umd.prod.js +5 -5
- package/dist/icon-set/fontawesome-v6.umd.prod.js +5 -5
- package/dist/icon-set/fontawesome-v7-pro.umd.prod.js +6 -0
- package/dist/icon-set/fontawesome-v7.umd.prod.js +6 -0
- package/dist/icon-set/ionicons-v4.umd.prod.js +2 -2
- 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 +5 -5
- package/dist/icon-set/mdi-v4.umd.prod.js +5 -5
- package/dist/icon-set/mdi-v5.umd.prod.js +5 -5
- package/dist/icon-set/mdi-v6.umd.prod.js +5 -5
- 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 +2 -2
- package/dist/icon-set/svg-fontawesome-v5.umd.prod.js +5 -5
- package/dist/icon-set/svg-fontawesome-v6.umd.prod.js +5 -5
- package/dist/icon-set/svg-fontawesome-v7.umd.prod.js +6 -0
- package/dist/icon-set/svg-ionicons-v4.umd.prod.js +2 -2
- package/dist/icon-set/svg-ionicons-v5.umd.prod.js +5 -5
- package/dist/icon-set/svg-ionicons-v6.umd.prod.js +5 -5
- package/dist/icon-set/svg-ionicons-v7.umd.prod.js +6 -0
- package/dist/icon-set/svg-ionicons-v8.umd.prod.js +6 -0
- 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 +2 -2
- package/dist/icon-set/svg-material-symbols-rounded.umd.prod.js +2 -2
- package/dist/icon-set/svg-material-symbols-sharp.umd.prod.js +2 -2
- package/dist/icon-set/svg-mdi-v6.umd.prod.js +5 -5
- package/dist/icon-set/svg-mdi-v7.umd.prod.js +1 -1
- package/dist/icon-set/svg-themify.umd.prod.js +2 -2
- package/dist/icon-set/themify.umd.prod.js +2 -2
- package/dist/lang/ar-TN.umd.prod.js +2 -2
- package/dist/lang/ar.umd.prod.js +2 -2
- package/dist/lang/az-Latn.umd.prod.js +2 -2
- package/dist/lang/bg.umd.prod.js +2 -2
- package/dist/lang/bn.umd.prod.js +2 -2
- package/dist/lang/bs-BA.umd.prod.js +2 -2
- package/dist/lang/ca.umd.prod.js +2 -2
- package/dist/lang/cs.umd.prod.js +2 -2
- package/dist/lang/da.umd.prod.js +2 -2
- package/dist/lang/de-CH.umd.prod.js +2 -2
- package/dist/lang/de-DE.umd.prod.js +2 -2
- package/dist/lang/de.umd.prod.js +2 -2
- package/dist/lang/el.umd.prod.js +2 -2
- package/dist/lang/en-GB.umd.prod.js +2 -2
- package/dist/lang/en-US.umd.prod.js +2 -2
- package/dist/lang/eo.umd.prod.js +2 -2
- package/dist/lang/es.umd.prod.js +2 -2
- package/dist/lang/et.umd.prod.js +2 -2
- package/dist/lang/eu.umd.prod.js +2 -2
- package/dist/lang/fa-IR.umd.prod.js +2 -2
- package/dist/lang/fa.umd.prod.js +2 -2
- package/dist/lang/fi.umd.prod.js +2 -2
- package/dist/lang/fr.umd.prod.js +2 -2
- package/dist/lang/gn.umd.prod.js +2 -2
- package/dist/lang/he.umd.prod.js +2 -2
- package/dist/lang/hi.umd.prod.js +2 -2
- package/dist/lang/hr.umd.prod.js +2 -2
- package/dist/lang/hu.umd.prod.js +2 -2
- package/dist/lang/id.umd.prod.js +2 -2
- package/dist/lang/is.umd.prod.js +2 -2
- package/dist/lang/it.umd.prod.js +2 -2
- package/dist/lang/ja.umd.prod.js +2 -2
- package/dist/lang/kk.umd.prod.js +2 -2
- package/dist/lang/km.umd.prod.js +2 -2
- package/dist/lang/ko-KR.umd.prod.js +1 -1
- package/dist/lang/kur-CKB.umd.prod.js +2 -2
- package/dist/lang/lt.umd.prod.js +2 -2
- package/dist/lang/lu.umd.prod.js +2 -2
- package/dist/lang/lv.umd.prod.js +2 -2
- package/dist/lang/mk.umd.prod.js +2 -2
- package/dist/lang/ml.umd.prod.js +2 -2
- package/dist/lang/mm.umd.prod.js +2 -2
- package/dist/lang/ms-MY.umd.prod.js +2 -2
- package/dist/lang/ms.umd.prod.js +2 -2
- package/dist/lang/my.umd.prod.js +2 -2
- package/dist/lang/nb-NO.umd.prod.js +2 -2
- package/dist/lang/nl.umd.prod.js +2 -2
- package/dist/lang/pl.umd.prod.js +2 -2
- package/dist/lang/pt-BR.umd.prod.js +2 -2
- package/dist/lang/pt.umd.prod.js +2 -2
- package/dist/lang/ro.umd.prod.js +2 -2
- package/dist/lang/ru.umd.prod.js +2 -2
- package/dist/lang/sk.umd.prod.js +2 -2
- package/dist/lang/sl.umd.prod.js +2 -2
- package/dist/lang/sm.umd.prod.js +2 -2
- package/dist/lang/sq.umd.prod.js +2 -2
- package/dist/lang/sr-CYR.umd.prod.js +2 -2
- package/dist/lang/sr.umd.prod.js +2 -2
- package/dist/lang/sv.umd.prod.js +2 -2
- package/dist/lang/ta.umd.prod.js +2 -2
- package/dist/lang/th.umd.prod.js +2 -2
- package/dist/lang/tl.umd.prod.js +2 -2
- package/dist/lang/tr.umd.prod.js +2 -2
- package/dist/lang/ug.umd.prod.js +2 -2
- package/dist/lang/uk.umd.prod.js +2 -2
- package/dist/lang/ur-PK.umd.prod.js +2 -2
- package/dist/lang/uz-Cyrl.umd.prod.js +2 -2
- package/dist/lang/uz-Latn.umd.prod.js +2 -2
- package/dist/lang/vi.umd.prod.js +2 -2
- package/dist/lang/zh-CN.umd.prod.js +2 -2
- package/dist/lang/zh-TW.umd.prod.js +2 -2
- package/dist/quasar.client.js +2615 -2603
- package/dist/quasar.sass +1 -1
- package/dist/quasar.server.prod.cjs +11 -11
- package/dist/quasar.server.prod.js +25 -25
- package/dist/quasar.umd.js +2610 -2598
- package/dist/quasar.umd.prod.js +23 -23
- package/dist/types/api/dialog.d.ts +1 -1
- package/dist/types/api/qnotify.d.ts +1 -1
- package/dist/types/api/qpopupproxy.d.ts +1 -1
- package/dist/types/feature-flag.d.ts +2 -2
- package/dist/types/globals.d.ts +3 -3
- package/dist/types/{extras/icon-set.d.ts → icon-set.d.ts} +21 -16
- package/dist/types/index.d.ts +1 -1
- package/dist/types/plugin.d.ts +1 -1
- package/dist/types/shim-icon-set.d.ts +1 -2
- package/dist/types/shim-lang.d.ts +1 -2
- package/dist/types/ts-helpers.d.ts +3 -3
- package/dist/types/tsconfig.json +1 -1
- package/dist/types/utils/scroll.d.ts +1 -1
- package/dist/types/utils.d.ts +2 -2
- package/dist/web-types/web-types.json +1 -1
- package/icon-set/bootstrap-icons.js +1 -1
- package/icon-set/eva-icons.js +23 -23
- package/icon-set/fontawesome-v7-pro.js +128 -0
- package/icon-set/fontawesome-v7.js +128 -0
- package/icon-set/ionicons-v4.js +17 -17
- package/icon-set/svg-bootstrap-icons.js +1 -1
- package/icon-set/svg-eva-icons.js +23 -23
- package/icon-set/svg-fontawesome-v5.js +1 -1
- package/icon-set/svg-fontawesome-v7.js +197 -0
- package/icon-set/svg-ionicons-v4.js +17 -17
- package/icon-set/svg-ionicons-v5.js +1 -1
- package/icon-set/svg-ionicons-v6.js +1 -1
- package/icon-set/svg-ionicons-v7.js +224 -0
- package/icon-set/svg-ionicons-v8.js +224 -0
- package/icon-set/svg-themify.js +7 -7
- package/icon-set/themify.js +7 -7
- package/lang/ar-TN.js +1 -1
- package/lang/ar.js +1 -1
- package/lang/az-Latn.js +1 -1
- package/lang/bg.js +1 -1
- package/lang/bn.js +1 -1
- package/lang/bs-BA.js +1 -1
- package/lang/ca.js +1 -1
- package/lang/cs.js +11 -6
- package/lang/da.js +1 -1
- package/lang/de-CH.js +1 -1
- package/lang/de-DE.js +1 -1
- package/lang/de.js +1 -1
- package/lang/el.js +1 -1
- package/lang/en-GB.js +1 -1
- package/lang/en-US.js +1 -1
- package/lang/eo.js +1 -1
- package/lang/es.js +1 -1
- package/lang/et.js +1 -1
- package/lang/eu.js +1 -1
- package/lang/fa-IR.js +1 -1
- package/lang/fa.js +1 -1
- package/lang/fi.js +1 -1
- package/lang/fr.js +1 -1
- package/lang/gn.js +1 -1
- package/lang/he.js +1 -1
- package/lang/hi.js +1 -1
- package/lang/hr.js +1 -1
- package/lang/hu.js +1 -1
- package/lang/id.js +1 -1
- package/lang/is.js +1 -1
- package/lang/it.js +9 -9
- package/lang/ja.js +1 -1
- package/lang/kk.js +1 -1
- package/lang/km.js +1 -1
- package/lang/kur-CKB.js +1 -1
- package/lang/lt.js +2 -2
- package/lang/lu.js +1 -1
- package/lang/lv.js +1 -1
- package/lang/mk.js +1 -1
- package/lang/ml.js +1 -1
- package/lang/mm.js +1 -1
- package/lang/ms-MY.js +1 -1
- package/lang/ms.js +1 -1
- package/lang/my.js +1 -1
- package/lang/nb-NO.js +1 -1
- package/lang/nl.js +1 -1
- package/lang/pl.js +1 -1
- package/lang/pt-BR.js +1 -1
- package/lang/pt.js +1 -1
- package/lang/ro.js +1 -1
- package/lang/ru.js +1 -1
- package/lang/sk.js +1 -1
- package/lang/sl.js +1 -1
- package/lang/sm.js +1 -1
- package/lang/sq.js +1 -1
- package/lang/sr-CYR.js +1 -1
- package/lang/sr.js +1 -1
- package/lang/sv.js +1 -1
- package/lang/ta.js +1 -1
- package/lang/th.js +1 -1
- package/lang/tl.js +1 -1
- package/lang/tr.js +1 -1
- package/lang/ug.js +1 -1
- package/lang/uk.js +1 -1
- package/lang/ur-PK.js +1 -1
- package/lang/uz-Cyrl.js +1 -1
- package/lang/uz-Latn.js +1 -1
- package/lang/vi.js +1 -1
- package/lang/zh-CN.js +1 -1
- package/lang/zh-TW.js +1 -1
- package/package.json +13 -17
- package/src/components/ajax-bar/QAjaxBar.js +22 -25
- package/src/components/avatar/QAvatar.js +3 -3
- package/src/components/avatar/QAvatar.test.js +2 -2
- package/src/components/badge/QBadge.js +9 -10
- package/src/components/badge/QBadge.test.js +2 -2
- package/src/components/banner/QBanner.js +6 -6
- package/src/components/banner/QBanner.test.js +2 -2
- package/src/components/bar/QBar.js +3 -3
- package/src/components/bar/QBar.test.js +2 -2
- package/src/components/breadcrumbs/QBreadcrumbs.js +5 -4
- package/src/components/breadcrumbs/QBreadcrumbs.test.js +3 -3
- package/src/components/breadcrumbs/QBreadcrumbsEl.js +4 -4
- package/src/components/breadcrumbs/QBreadcrumbsEl.test.js +2 -2
- package/src/components/btn/QBtn.js +39 -44
- package/src/components/btn/QBtn.test.js +2 -2
- package/src/components/btn/use-btn.js +34 -47
- package/src/components/btn/use-btn.test.js +5 -5
- package/src/components/btn-dropdown/QBtnDropdown.js +15 -16
- package/src/components/btn-group/QBtnGroup.js +3 -3
- package/src/components/btn-toggle/QBtnToggle.js +5 -9
- package/src/components/card/QCard.js +5 -5
- package/src/components/card/QCardActions.js +2 -2
- package/src/components/card/QCardSection.js +2 -2
- package/src/components/carousel/QCarousel.js +32 -38
- package/src/components/carousel/QCarouselControl.js +1 -1
- package/src/components/carousel/QCarouselSlide.js +1 -1
- package/src/components/carousel/QCarouselSlide.json +1 -1
- package/src/components/chat/QChatMessage.js +13 -14
- package/src/components/chat/QChatMessage.json +1 -1
- package/src/components/checkbox/QCheckbox.js +5 -5
- package/src/components/checkbox/use-checkbox.js +38 -50
- package/src/components/chip/QChip.js +26 -34
- package/src/components/chip/QChip.test.js +2 -2
- package/src/components/circular-progress/QCircularProgress.js +8 -11
- package/src/components/circular-progress/circular-progress.test.js +1 -1
- package/src/components/color/QColor.js +75 -98
- package/src/components/date/QDate.js +128 -140
- package/src/components/date/use-datetime.js +3 -6
- package/src/components/dialog/QDialog.js +44 -50
- package/src/components/dialog/QDialog.test.js +7 -7
- package/src/components/drawer/QDrawer.js +110 -152
- package/src/components/editor/QEditor.js +44 -37
- package/src/components/editor/editor-caret.js +27 -31
- package/src/components/editor/editor-utils.js +9 -5
- package/src/components/expansion-item/QExpansionItem.js +36 -48
- package/src/components/fab/QFab.js +11 -11
- package/src/components/fab/QFabAction.js +2 -4
- package/src/components/fab/use-fab.js +6 -7
- package/src/components/field/QField.js +2 -2
- package/src/components/file/QFile.js +26 -33
- package/src/components/footer/QFooter.js +40 -53
- package/src/components/form/QForm.js +37 -43
- package/src/components/form/QFormChildMixin.js +3 -3
- package/src/components/header/QHeader.js +35 -47
- package/src/components/icon/QIcon.js +19 -19
- package/src/components/img/QImg.js +24 -24
- package/src/components/img/QImg.json +3 -3
- package/src/components/infinite-scroll/QInfiniteScroll.js +38 -52
- package/src/components/inner-loading/QInnerLoading.js +3 -3
- package/src/components/input/QInput.js +52 -52
- package/src/components/input/use-mask.js +56 -54
- package/src/components/intersection/QIntersection.js +6 -8
- package/src/components/item/QItem.js +20 -30
- package/src/components/item/QItemLabel.js +5 -7
- package/src/components/item/QItemSection.js +6 -6
- package/src/components/item/QList.js +6 -6
- package/src/components/item/QList.test.js +2 -2
- package/src/components/knob/QKnob.js +39 -44
- package/src/components/layout/QLayout.js +30 -34
- package/src/components/linear-progress/QLinearProgress.js +14 -23
- package/src/components/markup-table/QMarkupTable.js +7 -9
- package/src/components/menu/QMenu.js +36 -37
- package/src/components/no-ssr/QNoSsr.js +1 -1
- package/src/components/option-group/QOptionGroup.js +5 -5
- package/src/components/page/QPage.js +16 -18
- package/src/components/page/QPageContainer.js +9 -9
- package/src/components/page-scroller/QPageScroller.js +11 -13
- package/src/components/page-sticky/use-page-sticky.js +18 -18
- package/src/components/pagination/QPagination.js +24 -26
- package/src/components/parallax/QParallax.js +15 -9
- package/src/components/parallax/QParallax.json +1 -1
- package/src/components/popup-edit/QPopupEdit.js +10 -13
- package/src/components/popup-proxy/QPopupProxy.js +5 -7
- package/src/components/pull-to-refresh/QPullToRefresh.js +15 -17
- package/src/components/radio/QRadio.js +24 -29
- package/src/components/range/QRange.js +33 -37
- package/src/components/rating/QRating.js +59 -61
- package/src/components/resize-observer/QResizeObserver.js +55 -62
- package/src/components/scroll-area/QScrollArea.js +32 -36
- package/src/components/scroll-observer/QScrollObserver.js +3 -3
- package/src/components/select/QSelect.js +208 -269
- package/src/components/separator/QSeparator.js +7 -10
- package/src/components/skeleton/QSkeleton.js +4 -4
- package/src/components/slide-item/QSlideItem.js +7 -7
- package/src/components/slide-transition/QSlideTransition.js +4 -4
- package/src/components/slider/QSlider.js +13 -16
- package/src/components/slider/use-slider.js +53 -81
- package/src/components/slider/use-slider.json +3 -3
- package/src/components/space/QSpace.test.js +1 -1
- package/src/components/spinner/QSpinner.test.js +2 -2
- package/src/components/spinner/QSpinnerAudio.test.js +2 -2
- package/src/components/spinner/QSpinnerBall.test.js +2 -2
- package/src/components/spinner/QSpinnerBars.test.js +2 -2
- package/src/components/spinner/QSpinnerBox.test.js +2 -2
- package/src/components/spinner/QSpinnerClock.test.js +2 -2
- package/src/components/spinner/QSpinnerComment.test.js +2 -2
- package/src/components/spinner/QSpinnerCube.test.js +2 -2
- package/src/components/spinner/QSpinnerDots.test.js +2 -2
- package/src/components/spinner/QSpinnerFacebook.test.js +2 -2
- package/src/components/spinner/QSpinnerGears.test.js +2 -2
- package/src/components/spinner/QSpinnerGrid.test.js +2 -2
- package/src/components/spinner/QSpinnerHearts.test.js +2 -2
- package/src/components/spinner/QSpinnerHourglass.test.js +2 -2
- package/src/components/spinner/QSpinnerInfinity.test.js +2 -2
- package/src/components/spinner/QSpinnerIos.test.js +2 -2
- package/src/components/spinner/QSpinnerOrbit.test.js +2 -2
- package/src/components/spinner/QSpinnerOval.test.js +2 -2
- package/src/components/spinner/QSpinnerPie.test.js +2 -2
- package/src/components/spinner/QSpinnerPuff.test.js +2 -2
- package/src/components/spinner/QSpinnerRadio.test.js +2 -2
- package/src/components/spinner/QSpinnerRings.test.js +2 -2
- package/src/components/spinner/QSpinnerTail.test.js +2 -2
- package/src/components/spinner/use-spinner.test.js +1 -1
- package/src/components/splitter/QSplitter.js +19 -21
- package/src/components/stepper/QStep.js +12 -14
- package/src/components/stepper/QStepper.js +13 -14
- package/src/components/stepper/StepHeader.js +34 -35
- package/src/components/tab-panels/QTabPanels.js +3 -3
- package/src/components/table/QTable.js +82 -100
- package/src/components/table/QTd.js +3 -3
- package/src/components/table/QTh.js +5 -6
- package/src/components/table/QTr.js +3 -3
- package/src/components/table/table-column-selection.js +4 -6
- package/src/components/table/table-filter.js +2 -2
- package/src/components/table/table-pagination.js +14 -20
- package/src/components/table/table-row-expand.js +3 -3
- package/src/components/table/table-row-selection.js +10 -20
- package/src/components/table/table-sort.js +7 -7
- package/src/components/tabs/QRouteTab.js +1 -1
- package/src/components/tabs/QTab.js +1 -1
- package/src/components/tabs/QTabs.js +82 -109
- package/src/components/tabs/use-tab.js +36 -38
- package/src/components/time/QTime.js +109 -132
- package/src/components/timeline/QTimeline.js +7 -4
- package/src/components/timeline/QTimelineEntry.js +7 -6
- package/src/components/timeline/QTimelineEntry.json +1 -1
- package/src/components/toggle/QToggle.js +6 -8
- package/src/components/toolbar/QToolbar.js +2 -2
- package/src/components/toolbar/QToolbar.test.js +2 -2
- package/src/components/toolbar/QToolbarTitle.js +2 -4
- package/src/components/toolbar/QToolbarTitle.test.js +2 -2
- package/src/components/tooltip/QTooltip.js +27 -28
- package/src/components/tree/QTree.js +96 -114
- package/src/components/tree/QTree.json +1 -1
- package/src/components/uploader/QUploaderAddTrigger.js +2 -2
- package/src/components/uploader/uploader-core.js +44 -51
- package/src/components/uploader/xhr-uploader-plugin.js +13 -17
- package/src/components/video/QVideo.js +1 -1
- package/src/components/video/QVideo.test.js +2 -2
- package/src/components/virtual-scroll/QVirtualScroll.js +9 -10
- package/src/components/virtual-scroll/use-virtual-scroll.js +42 -50
- package/src/composables/private.use-align/use-align.js +2 -2
- package/src/composables/private.use-align/use-align.test.js +1 -1
- package/src/composables/private.use-anchor/use-anchor.js +23 -32
- package/src/composables/private.use-dark/use-dark.test.js +1 -1
- package/src/composables/private.use-field/use-field.js +79 -99
- package/src/composables/private.use-file/use-file-dom-props.js +2 -2
- package/src/composables/private.use-file/use-file.js +27 -27
- package/src/composables/private.use-fullscreen/use-fullscreen.js +15 -20
- package/src/composables/private.use-history/use-history.js +2 -2
- package/src/composables/private.use-history/use-history.test.js +1 -1
- package/src/composables/private.use-key-composition/use-key-composition.js +11 -12
- package/src/composables/private.use-model-toggle/use-model-toggle.js +16 -25
- package/src/composables/private.use-panel/use-panel.js +25 -27
- package/src/composables/private.use-portal/use-portal.js +11 -9
- package/src/composables/private.use-prevent-scroll/use-prevent-scroll.js +1 -4
- package/src/composables/private.use-ratio/use-ratio.js +6 -5
- package/src/composables/private.use-ratio/use-ratio.test.js +1 -1
- package/src/composables/private.use-refocus-target/use-refocus-target.js +2 -4
- package/src/composables/private.use-router-link/use-router-link.js +44 -55
- package/src/composables/private.use-scroll-target/use-scroll-target.js +1 -1
- package/src/composables/private.use-size/use-size.test.js +1 -1
- package/src/composables/private.use-transition/use-transition.test.js +1 -1
- package/src/composables/private.use-validate/use-validate.js +23 -36
- package/src/composables/use-dialog-plugin-component/use-dialog-plugin-component.js +1 -1
- package/src/composables/use-form/private.use-form.js +1 -1
- package/src/composables/use-form/private.use-form.test.js +3 -3
- package/src/composables/use-form/use-form-child.js +7 -7
- package/src/composables/use-hydration/use-hydration.js +2 -2
- package/src/composables/use-hydration/use-hydration.test.js +1 -1
- package/src/composables/use-id/use-id.js +4 -8
- package/src/composables/use-id/use-id.test.js +1 -1
- package/src/composables/use-interval/use-interval.js +3 -3
- package/src/composables/use-interval/use-interval.test.js +1 -1
- package/src/composables/use-meta/use-meta.js +3 -3
- package/src/composables/use-quasar/use-quasar.test.js +1 -1
- package/src/composables/use-render-cache/use-render-cache.js +1 -1
- package/src/composables/use-render-cache/use-render-cache.test.js +1 -1
- package/src/composables/use-split-attrs/use-split-attrs.js +3 -7
- package/src/composables/use-split-attrs/use-split-attrs.test.js +1 -1
- package/src/composables/use-tick/use-tick.js +3 -3
- package/src/composables/use-tick/use-tick.test.js +2 -2
- package/src/composables/use-timeout/use-timeout.js +2 -2
- package/src/composables/use-timeout/use-timeout.test.js +1 -1
- package/src/directives/close-popup/ClosePopup.js +4 -9
- package/src/directives/intersection/Intersection.js +5 -8
- package/src/directives/morph/Morph.js +12 -18
- package/src/directives/ripple/Ripple.js +19 -26
- package/src/directives/ripple/Ripple.test.js +2 -2
- package/src/directives/scroll/Scroll.js +2 -2
- package/src/directives/touch-hold/TouchHold.js +22 -28
- package/src/directives/touch-pan/TouchPan.js +68 -84
- package/src/directives/touch-repeat/TouchRepeat.js +28 -39
- package/src/directives/touch-swipe/TouchSwipe.js +30 -33
- package/src/index.ssr.js +2 -0
- package/src/index.umd.js +2 -0
- package/src/install-quasar.js +9 -9
- package/src/plugins/addressbar/AddressbarColor.js +9 -9
- package/src/plugins/addressbar/AddressbarColor.test.js +2 -2
- package/src/plugins/app-fullscreen/AppFullscreen.js +11 -10
- package/src/plugins/app-fullscreen/AppFullscreen.test.js +2 -2
- package/src/plugins/app-fullscreen/test/mock-fullscreen.js +2 -2
- package/src/plugins/app-visibility/AppVisibility.js +5 -5
- package/src/plugins/app-visibility/AppVisibility.test.js +2 -2
- package/src/plugins/bottom-sheet/BottomSheet.js +2 -2
- package/src/plugins/bottom-sheet/component/BottomSheetComponent.js +4 -4
- package/src/plugins/cookies/Cookies.js +50 -62
- package/src/plugins/dark/Dark.js +3 -5
- package/src/plugins/dark/Dark.test.js +1 -1
- package/src/plugins/dialog/Dialog.js +2 -2
- package/src/plugins/dialog/component/DialogPluginComponent.js +17 -20
- package/src/plugins/icon-set/IconSet.js +2 -4
- package/src/plugins/icon-set/IconSet.test.js +1 -1
- package/src/plugins/lang/Lang.js +7 -10
- package/src/plugins/lang/Lang.json +2 -2
- package/src/plugins/lang/Lang.test.js +2 -2
- package/src/plugins/loading/Loading.js +10 -12
- package/src/plugins/loading-bar/LoadingBar.js +4 -4
- package/src/plugins/meta/Meta.js +10 -11
- package/src/plugins/notify/Notify.js +67 -72
- package/src/plugins/platform/Platform.js +19 -21
- package/src/plugins/platform/Platform.test.js +1 -1
- package/src/plugins/private.body/Body.js +23 -29
- package/src/plugins/private.body/Body.test.js +1 -1
- package/src/plugins/private.history/History.js +17 -25
- package/src/plugins/private.history/History.test.js +1 -1
- package/src/plugins/screen/Screen.js +16 -16
- package/src/plugins/screen/Screen.test.js +1 -1
- package/src/plugins/storage/LocalStorage.js +3 -4
- package/src/plugins/storage/LocalStorage.test.js +2 -2
- package/src/plugins/storage/SessionStorage.js +3 -4
- package/src/plugins/storage/SessionStorage.test.js +2 -2
- package/src/plugins/storage/engine/web-storage.js +30 -23
- package/src/plugins/storage/engine/web-storage.test.js +1 -1
- package/src/utils/EventBus/EventBus.js +3 -4
- package/src/utils/EventBus/EventBus.test.js +1 -1
- package/src/utils/clone/clone.test.js +4 -8
- package/src/utils/colors/colors.js +38 -29
- package/src/utils/colors/colors.test.js +2 -2
- package/src/utils/copy-to-clipboard/copy-to-clipboard.js +6 -11
- package/src/utils/create-meta-mixin/create-meta-mixin.js +2 -2
- package/src/utils/create-uploader-component/create-uploader-component.js +12 -7
- package/src/utils/css-var/get-css-var.test.js +2 -2
- package/src/utils/css-var/set-css-var.test.js +2 -2
- package/src/utils/date/date.js +229 -172
- package/src/utils/date/private.persian.js +11 -11
- package/src/utils/debounce/debounce.js +3 -7
- package/src/utils/debounce/debounce.test.js +1 -1
- package/src/utils/dom/dom.js +2 -4
- package/src/utils/dom/dom.test.js +4 -4
- package/src/utils/event/event.js +21 -23
- package/src/utils/export-file/export-file.js +3 -3
- package/src/utils/extend/extend.js +15 -14
- package/src/utils/extend/extend.test.js +2 -2
- package/src/utils/format/format.js +4 -10
- package/src/utils/format/format.test.js +1 -1
- package/src/utils/frame-debounce/frame-debounce.js +23 -12
- package/src/utils/frame-debounce/frame-debounce.test.js +1 -1
- package/src/utils/is/is.js +15 -26
- package/src/utils/is/is.test.js +8 -7
- package/src/utils/morph/morph.js +57 -48
- package/src/utils/open-url/open-url.js +7 -7
- package/src/utils/patterns/patterns.js +26 -23
- package/src/utils/patterns/patterns.test.js +1 -1
- package/src/utils/private.click-outside/click-outside.js +5 -5
- package/src/utils/private.config/instance-config.js +2 -0
- package/src/utils/private.config/instance-config.test.js +4 -4
- package/src/utils/private.config/nodes.js +5 -5
- package/src/utils/private.config/nodes.test.js +4 -4
- package/src/utils/private.create/create.test.js +1 -1
- package/src/utils/private.dialog/create-dialog.js +9 -12
- package/src/utils/private.focus/focus-manager.js +1 -1
- package/src/utils/private.focus/focus-manager.test.js +4 -4
- package/src/utils/private.focus/focusout.js +2 -2
- package/src/utils/private.focus/focusout.test.js +1 -1
- package/src/utils/private.get-emits-object/get-emits-object.test.js +1 -1
- package/src/utils/private.inject-obj-prop/inject-obj-prop.test.js +2 -2
- package/src/utils/private.keyboard/escape-key.js +5 -5
- package/src/utils/private.keyboard/escape-key.test.js +1 -1
- package/src/utils/private.keyboard/key-composition.js +4 -6
- package/src/utils/private.noop-ssr-directive-transform/noop-ssr-directive-transform.js +3 -1
- package/src/utils/private.noop-ssr-directive-transform/noop-ssr-directive-transform.test.js +1 -1
- package/src/utils/private.portal/portal.js +5 -5
- package/src/utils/private.position-engine/position-engine.js +20 -22
- package/src/utils/private.render/render.js +5 -7
- package/src/utils/private.render/render.test.js +5 -5
- package/src/utils/private.rtl/rtl.js +3 -2
- package/src/utils/private.rtl/rtl.test.js +1 -1
- package/src/utils/private.selection/selection.js +1 -1
- package/src/utils/private.selection/selection.test.js +2 -2
- package/src/utils/private.sort/sort.test.js +2 -2
- package/src/utils/private.touch/touch.js +10 -14
- package/src/utils/private.touch/touch.test.js +1 -1
- package/src/utils/private.vm/vm.js +2 -2
- package/src/utils/private.vm/vm.test.js +4 -4
- package/src/utils/run-sequential-promises/run-sequential-promises.js +44 -54
- package/src/utils/run-sequential-promises/run-sequential-promises.test.js +183 -0
- package/src/utils/scroll/prevent-scroll.js +9 -9
- package/src/utils/scroll/scroll.js +11 -12
- package/src/utils/throttle/throttle.js +4 -3
- package/src/utils/throttle/throttle.test.js +1 -1
- package/src/utils/uid/uid.js +51 -77
- package/src/utils/uid/uid.test.js +3 -3
- package/wrappers/index.cjs +2 -2
- package/wrappers/index.js +2 -2
- package/dist/types/extras/animations.d.ts +0 -106
- package/dist/types/extras/fonts.d.ts +0 -1
- package/dist/types/extras.d.ts +0 -3
- package/dist/vetur/quasar-attributes.json +0 -1
- package/dist/vetur/quasar-tags.json +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { client, isRuntimeSsrPreHydration } from '../platform/Platform.js'
|
|
2
2
|
|
|
3
3
|
import { createReactivePlugin } from '../../utils/private.create/create.js'
|
|
4
4
|
import { listenOpts, noop } from '../../utils/event/event.js'
|
|
@@ -48,9 +48,9 @@ export default createReactivePlugin(
|
|
|
48
48
|
|
|
49
49
|
if (__QUASAR_SSR_SERVER__) return
|
|
50
50
|
|
|
51
|
-
if (this.__installed
|
|
51
|
+
if (this.__installed) {
|
|
52
52
|
if ($q.config.screen !== void 0) {
|
|
53
|
-
if (
|
|
53
|
+
if (!$q.config.screen.bodyClasses) {
|
|
54
54
|
document.body.classList.remove(`screen--${this.name}`)
|
|
55
55
|
} else {
|
|
56
56
|
this.__update(true)
|
|
@@ -64,7 +64,7 @@ export default createReactivePlugin(
|
|
|
64
64
|
const scrollingElement =
|
|
65
65
|
document.scrollingElement || document.documentElement
|
|
66
66
|
const getSize =
|
|
67
|
-
visualViewport === void 0 || client.is.mobile
|
|
67
|
+
visualViewport === void 0 || client.is.mobile
|
|
68
68
|
? () => [
|
|
69
69
|
Math.max(window.innerWidth, scrollingElement.clientWidth),
|
|
70
70
|
Math.max(window.innerHeight, scrollingElement.clientHeight)
|
|
@@ -78,7 +78,7 @@ export default createReactivePlugin(
|
|
|
78
78
|
scrollingElement.clientHeight
|
|
79
79
|
]
|
|
80
80
|
|
|
81
|
-
const
|
|
81
|
+
const useBodyClasses = $q.config.screen?.bodyClasses === true
|
|
82
82
|
|
|
83
83
|
this.__update = force => {
|
|
84
84
|
const [w, h] = getSize()
|
|
@@ -104,20 +104,20 @@ export default createReactivePlugin(
|
|
|
104
104
|
this.lt.lg = w < s.lg
|
|
105
105
|
this.lt.xl = w < s.xl
|
|
106
106
|
this.xs = this.lt.sm
|
|
107
|
-
this.sm = this.gt.xs
|
|
108
|
-
this.md = this.gt.sm
|
|
109
|
-
this.lg = this.gt.md
|
|
107
|
+
this.sm = this.gt.xs && this.lt.md
|
|
108
|
+
this.md = this.gt.sm && this.lt.lg
|
|
109
|
+
this.lg = this.gt.md && this.lt.xl
|
|
110
110
|
this.xl = this.gt.lg
|
|
111
111
|
|
|
112
112
|
s =
|
|
113
|
-
(this.xs
|
|
114
|
-
(this.sm
|
|
115
|
-
(this.md
|
|
116
|
-
(this.lg
|
|
113
|
+
(this.xs && 'xs') ||
|
|
114
|
+
(this.sm && 'sm') ||
|
|
115
|
+
(this.md && 'md') ||
|
|
116
|
+
(this.lg && 'lg') ||
|
|
117
117
|
'xl'
|
|
118
118
|
|
|
119
119
|
if (s !== this.name) {
|
|
120
|
-
if (
|
|
120
|
+
if (useBodyClasses) {
|
|
121
121
|
document.body.classList.remove(`screen--${this.name}`)
|
|
122
122
|
document.body.classList.add(`screen--${s}`)
|
|
123
123
|
}
|
|
@@ -146,7 +146,7 @@ export default createReactivePlugin(
|
|
|
146
146
|
// if css props available
|
|
147
147
|
if (style.getPropertyValue('--q-size-sm')) {
|
|
148
148
|
SIZE_LIST.forEach(name => {
|
|
149
|
-
this.sizes[name] = parseInt(
|
|
149
|
+
this.sizes[name] = Number.parseInt(
|
|
150
150
|
style.getPropertyValue(`--q-size-${name}`),
|
|
151
151
|
10
|
|
152
152
|
)
|
|
@@ -181,12 +181,12 @@ export default createReactivePlugin(
|
|
|
181
181
|
}
|
|
182
182
|
|
|
183
183
|
// due to optimizations, this would be left out otherwise
|
|
184
|
-
if (
|
|
184
|
+
if (useBodyClasses && this.name === 'xs') {
|
|
185
185
|
document.body.classList.add('screen--xs')
|
|
186
186
|
}
|
|
187
187
|
}
|
|
188
188
|
|
|
189
|
-
if (isRuntimeSsrPreHydration.value
|
|
189
|
+
if (isRuntimeSsrPreHydration.value) {
|
|
190
190
|
onSSRHydrated.push(start)
|
|
191
191
|
} else {
|
|
192
192
|
start()
|
|
@@ -2,16 +2,15 @@ import { client } from '../platform/Platform.js'
|
|
|
2
2
|
import { getEmptyStorage, getStorage } from './engine/web-storage.js'
|
|
3
3
|
|
|
4
4
|
const storage =
|
|
5
|
-
__QUASAR_SSR_SERVER__ || client.has.webStorage
|
|
5
|
+
__QUASAR_SSR_SERVER__ || !client.has.webStorage
|
|
6
6
|
? getEmptyStorage()
|
|
7
7
|
: getStorage('local')
|
|
8
8
|
|
|
9
9
|
const Plugin = {
|
|
10
10
|
install({ $q }) {
|
|
11
11
|
$q.localStorage = storage
|
|
12
|
-
}
|
|
12
|
+
},
|
|
13
|
+
...storage
|
|
13
14
|
}
|
|
14
15
|
|
|
15
|
-
Object.assign(Plugin, storage)
|
|
16
|
-
|
|
17
16
|
export default Plugin
|
|
@@ -2,16 +2,15 @@ import { client } from '../platform/Platform.js'
|
|
|
2
2
|
import { getEmptyStorage, getStorage } from './engine/web-storage.js'
|
|
3
3
|
|
|
4
4
|
const storage =
|
|
5
|
-
__QUASAR_SSR_SERVER__ || client.has.webStorage
|
|
5
|
+
__QUASAR_SSR_SERVER__ || !client.has.webStorage
|
|
6
6
|
? getEmptyStorage()
|
|
7
7
|
: getStorage('session')
|
|
8
8
|
|
|
9
9
|
const Plugin = {
|
|
10
10
|
install({ $q }) {
|
|
11
11
|
$q.sessionStorage = storage
|
|
12
|
-
}
|
|
12
|
+
},
|
|
13
|
+
...storage
|
|
13
14
|
}
|
|
14
15
|
|
|
15
|
-
Object.assign(Plugin, storage)
|
|
16
|
-
|
|
17
16
|
export default Plugin
|
|
@@ -2,10 +2,10 @@ import { noop } from '../../../utils/event/event.js'
|
|
|
2
2
|
import { isDate, isRegexp } from '../../../utils/is/is.js'
|
|
3
3
|
|
|
4
4
|
function encode(value) {
|
|
5
|
-
if (isDate(value)
|
|
5
|
+
if (isDate(value)) {
|
|
6
6
|
return '__q_date|' + value.getTime()
|
|
7
7
|
}
|
|
8
|
-
if (isRegexp(value)
|
|
8
|
+
if (isRegexp(value)) {
|
|
9
9
|
return '__q_expr|' + value.source
|
|
10
10
|
}
|
|
11
11
|
if (typeof value === 'number') {
|
|
@@ -29,55 +29,62 @@ function encode(value) {
|
|
|
29
29
|
return value
|
|
30
30
|
}
|
|
31
31
|
|
|
32
|
+
const numberRE = /^-?\d+$/
|
|
33
|
+
|
|
32
34
|
function decode(value) {
|
|
33
35
|
const length = value.length
|
|
34
|
-
if (length < 9) {
|
|
35
|
-
// then it wasn't encoded by us
|
|
36
|
-
return value
|
|
37
|
-
}
|
|
38
36
|
|
|
39
|
-
|
|
40
|
-
|
|
37
|
+
// if it wasn't encoded by us
|
|
38
|
+
if (length < 9) return value
|
|
39
|
+
|
|
40
|
+
const type = value.slice(0, 8)
|
|
41
|
+
const source = value.slice(9)
|
|
41
42
|
|
|
42
43
|
switch (type) {
|
|
43
|
-
case '__q_date':
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
case '__q_date': {
|
|
45
|
+
return new Date(
|
|
46
|
+
numberRE.test(source) ? Number.parseInt(source, 10) : source
|
|
47
|
+
)
|
|
48
|
+
}
|
|
46
49
|
|
|
47
|
-
case '__q_expr':
|
|
50
|
+
case '__q_expr': {
|
|
48
51
|
return new RegExp(source)
|
|
52
|
+
}
|
|
49
53
|
|
|
50
|
-
case '__q_numb':
|
|
54
|
+
case '__q_numb': {
|
|
51
55
|
return Number(source)
|
|
56
|
+
}
|
|
52
57
|
|
|
53
|
-
case '__q_bool':
|
|
58
|
+
case '__q_bool': {
|
|
54
59
|
return Boolean(source === '1')
|
|
60
|
+
}
|
|
55
61
|
|
|
56
|
-
case '__q_strn':
|
|
62
|
+
case '__q_strn': {
|
|
57
63
|
return String(source)
|
|
64
|
+
}
|
|
58
65
|
|
|
59
|
-
case '__q_objt':
|
|
66
|
+
case '__q_objt': {
|
|
60
67
|
return JSON.parse(source)
|
|
68
|
+
}
|
|
61
69
|
|
|
62
|
-
default:
|
|
70
|
+
default: {
|
|
63
71
|
// hmm, we reached here, we don't know the type,
|
|
64
72
|
// then it means it wasn't encoded by us, so just
|
|
65
73
|
// return whatever value it is
|
|
66
74
|
return value
|
|
75
|
+
}
|
|
67
76
|
}
|
|
68
77
|
}
|
|
69
78
|
|
|
70
79
|
export function getEmptyStorage() {
|
|
71
|
-
const getVal = () => null
|
|
72
|
-
|
|
73
80
|
return {
|
|
74
81
|
has: () => false, // alias for hasItem; TODO: remove in Qv3
|
|
75
82
|
hasItem: () => false,
|
|
76
83
|
getLength: () => 0,
|
|
77
|
-
getItem:
|
|
78
|
-
getIndex:
|
|
79
|
-
getKey:
|
|
80
|
-
getAll: () => {},
|
|
84
|
+
getItem: () => null,
|
|
85
|
+
getIndex: () => null,
|
|
86
|
+
getKey: () => null,
|
|
87
|
+
getAll: () => ({}),
|
|
81
88
|
getAllKeys: () => [],
|
|
82
89
|
set: noop, // alias for setItem; TODO: remove in Qv3
|
|
83
90
|
setItem: noop,
|
|
@@ -9,7 +9,7 @@ export default class EventBus {
|
|
|
9
9
|
}
|
|
10
10
|
|
|
11
11
|
on(name, callback, ctx) {
|
|
12
|
-
;(this.__stack[name]
|
|
12
|
+
;(this.__stack[name] ||= []).push({
|
|
13
13
|
fn: callback,
|
|
14
14
|
ctx
|
|
15
15
|
})
|
|
@@ -27,13 +27,12 @@ export default class EventBus {
|
|
|
27
27
|
return this.on(name, listener, ctx) // chainable
|
|
28
28
|
}
|
|
29
29
|
|
|
30
|
-
emit(name) {
|
|
30
|
+
emit(name, ...args) {
|
|
31
31
|
const list = this.__stack[name]
|
|
32
32
|
|
|
33
33
|
if (list !== void 0) {
|
|
34
|
-
const params = [].slice.call(arguments, 1)
|
|
35
34
|
list.forEach(entry => {
|
|
36
|
-
entry.fn.apply(entry.ctx,
|
|
35
|
+
entry.fn.apply(entry.ctx, args)
|
|
37
36
|
})
|
|
38
37
|
}
|
|
39
38
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { describe,
|
|
1
|
+
import { describe, expect, test } from 'vitest'
|
|
2
2
|
|
|
3
3
|
import clone from './clone.js'
|
|
4
4
|
|
|
@@ -11,7 +11,7 @@ describe('[clone API]', () => {
|
|
|
11
11
|
['Boolean', true],
|
|
12
12
|
['Null', null],
|
|
13
13
|
['Undefined', void 0],
|
|
14
|
-
['NaN', NaN],
|
|
14
|
+
['NaN', Number.NaN],
|
|
15
15
|
['Infinity', Infinity]
|
|
16
16
|
])('clone(%s)', (_, value) => {
|
|
17
17
|
const result = clone(value)
|
|
@@ -61,9 +61,7 @@ describe('[clone API]', () => {
|
|
|
61
61
|
const set = new Set([1, 2, 3])
|
|
62
62
|
const result = clone(set)
|
|
63
63
|
|
|
64
|
-
expect(
|
|
65
|
-
Array.from(set.values())
|
|
66
|
-
)
|
|
64
|
+
expect([...result.values()]).toStrictEqual([...set.values()])
|
|
67
65
|
|
|
68
66
|
expect(result).not.toBe(set)
|
|
69
67
|
})
|
|
@@ -75,9 +73,7 @@ describe('[clone API]', () => {
|
|
|
75
73
|
])
|
|
76
74
|
const result = clone(map)
|
|
77
75
|
|
|
78
|
-
expect(
|
|
79
|
-
Array.from(map.entries())
|
|
80
|
-
)
|
|
76
|
+
expect([...result.entries()]).toStrictEqual([...map.entries()])
|
|
81
77
|
|
|
82
78
|
expect(result).not.toBe(map)
|
|
83
79
|
})
|
|
@@ -37,7 +37,7 @@ export function hexToRgb(hex) {
|
|
|
37
37
|
hex = hex[0] + hex[0] + hex[1] + hex[1] + hex[2] + hex[2] + hex[3] + hex[3]
|
|
38
38
|
}
|
|
39
39
|
|
|
40
|
-
const num = parseInt(hex, 16)
|
|
40
|
+
const num = Number.parseInt(hex, 16)
|
|
41
41
|
|
|
42
42
|
return hex.length > 6
|
|
43
43
|
? {
|
|
@@ -62,36 +62,42 @@ export function hsvToRgb({ h, s, v, a }) {
|
|
|
62
62
|
t = v * (1 - (1 - f) * s)
|
|
63
63
|
|
|
64
64
|
switch (i % 6) {
|
|
65
|
-
case 0:
|
|
65
|
+
case 0: {
|
|
66
66
|
r = v
|
|
67
67
|
g = t
|
|
68
68
|
b = p
|
|
69
69
|
break
|
|
70
|
-
|
|
70
|
+
}
|
|
71
|
+
case 1: {
|
|
71
72
|
r = q
|
|
72
73
|
g = v
|
|
73
74
|
b = p
|
|
74
75
|
break
|
|
75
|
-
|
|
76
|
+
}
|
|
77
|
+
case 2: {
|
|
76
78
|
r = p
|
|
77
79
|
g = v
|
|
78
80
|
b = t
|
|
79
81
|
break
|
|
80
|
-
|
|
82
|
+
}
|
|
83
|
+
case 3: {
|
|
81
84
|
r = p
|
|
82
85
|
g = q
|
|
83
86
|
b = v
|
|
84
87
|
break
|
|
85
|
-
|
|
88
|
+
}
|
|
89
|
+
case 4: {
|
|
86
90
|
r = t
|
|
87
91
|
g = p
|
|
88
92
|
b = v
|
|
89
93
|
break
|
|
90
|
-
|
|
94
|
+
}
|
|
95
|
+
case 5: {
|
|
91
96
|
r = v
|
|
92
97
|
g = p
|
|
93
98
|
b = q
|
|
94
99
|
break
|
|
100
|
+
}
|
|
95
101
|
}
|
|
96
102
|
|
|
97
103
|
return {
|
|
@@ -111,21 +117,25 @@ export function rgbToHsv({ r, g, b, a }) {
|
|
|
111
117
|
let h
|
|
112
118
|
|
|
113
119
|
switch (max) {
|
|
114
|
-
case min:
|
|
120
|
+
case min: {
|
|
115
121
|
h = 0
|
|
116
122
|
break
|
|
117
|
-
|
|
123
|
+
}
|
|
124
|
+
case r: {
|
|
118
125
|
h = g - b + d * (g < b ? 6 : 0)
|
|
119
126
|
h /= 6 * d
|
|
120
127
|
break
|
|
121
|
-
|
|
128
|
+
}
|
|
129
|
+
case g: {
|
|
122
130
|
h = b - r + d * 2
|
|
123
131
|
h /= 6 * d
|
|
124
132
|
break
|
|
125
|
-
|
|
133
|
+
}
|
|
134
|
+
case b: {
|
|
126
135
|
h = r - g + d * 4
|
|
127
136
|
h /= 6 * d
|
|
128
137
|
break
|
|
138
|
+
}
|
|
129
139
|
}
|
|
130
140
|
|
|
131
141
|
return {
|
|
@@ -141,23 +151,22 @@ export function textToRgb(str) {
|
|
|
141
151
|
throw new TypeError('Expected a string')
|
|
142
152
|
}
|
|
143
153
|
|
|
144
|
-
const color = str.
|
|
145
|
-
|
|
154
|
+
const color = str.replaceAll(' ', '')
|
|
146
155
|
const m = reRGBA.exec(color)
|
|
147
|
-
|
|
148
|
-
if (m === null) {
|
|
149
|
-
return hexToRgb(color)
|
|
150
|
-
}
|
|
156
|
+
if (m === null) return hexToRgb(color)
|
|
151
157
|
|
|
152
158
|
const rgb = {
|
|
153
|
-
r: Math.min(255, parseInt(m[2], 10)),
|
|
154
|
-
g: Math.min(255, parseInt(m[3], 10)),
|
|
155
|
-
b: Math.min(255, parseInt(m[4], 10))
|
|
159
|
+
r: Math.min(255, Math.max(0, Number.parseInt(m[2], 10))),
|
|
160
|
+
g: Math.min(255, Math.max(0, Number.parseInt(m[3], 10))),
|
|
161
|
+
b: Math.min(255, Math.max(0, Number.parseInt(m[4], 10)))
|
|
156
162
|
}
|
|
157
163
|
|
|
158
164
|
if (m[1]) {
|
|
159
|
-
const alpha = parseFloat(m[5])
|
|
160
|
-
|
|
165
|
+
const alpha = Number.parseFloat(m[5])
|
|
166
|
+
const safeAlpha = Number.isFinite(alpha)
|
|
167
|
+
? Math.max(0, Math.min(1, alpha))
|
|
168
|
+
: 1
|
|
169
|
+
rgb.a = Math.round(safeAlpha * 100)
|
|
161
170
|
}
|
|
162
171
|
|
|
163
172
|
return rgb
|
|
@@ -182,9 +191,9 @@ export function lighten(color, percent) {
|
|
|
182
191
|
return (
|
|
183
192
|
'#' +
|
|
184
193
|
(
|
|
185
|
-
|
|
186
|
-
(Math.round((t - R) * p) + R) *
|
|
187
|
-
(Math.round((t - G) * p) + G) *
|
|
194
|
+
0x1_00_00_00 +
|
|
195
|
+
(Math.round((t - R) * p) + R) * 0x1_00_00 +
|
|
196
|
+
(Math.round((t - G) * p) + G) * 0x1_00 +
|
|
188
197
|
(Math.round((t - B) * p) + B)
|
|
189
198
|
)
|
|
190
199
|
.toString(16)
|
|
@@ -201,9 +210,9 @@ export function luminosity(color) {
|
|
|
201
210
|
r = rgb.r / 255,
|
|
202
211
|
g = rgb.g / 255,
|
|
203
212
|
b = rgb.b / 255,
|
|
204
|
-
R = r <= 0.
|
|
205
|
-
G = g <= 0.
|
|
206
|
-
B = b <= 0.
|
|
213
|
+
R = r <= 0.039_28 ? r / 12.92 : ((r + 0.055) / 1.055) ** 2.4,
|
|
214
|
+
G = g <= 0.039_28 ? g / 12.92 : ((g + 0.055) / 1.055) ** 2.4,
|
|
215
|
+
B = b <= 0.039_28 ? b / 12.92 : ((b + 0.055) / 1.055) ** 2.4
|
|
207
216
|
return 0.2126 * R + 0.7152 * G + 0.0722 * B
|
|
208
217
|
}
|
|
209
218
|
|
|
@@ -277,7 +286,7 @@ export function getPaletteColor(colorName) {
|
|
|
277
286
|
const el = document.createElement('div')
|
|
278
287
|
|
|
279
288
|
el.className = `text-${colorName} invisible fixed no-pointer-events`
|
|
280
|
-
document.body.
|
|
289
|
+
document.body.append(el)
|
|
281
290
|
|
|
282
291
|
const result = getComputedStyle(el).getPropertyValue('color')
|
|
283
292
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// oxlint-disable import/no-named-as-default-member
|
|
2
2
|
|
|
3
|
-
import { describe,
|
|
3
|
+
import { describe, expect, test } from 'vitest'
|
|
4
4
|
|
|
5
5
|
import colors, { rgbToString } from './colors.js'
|
|
6
6
|
|
|
@@ -249,7 +249,7 @@ describe('[colors API]', () => {
|
|
|
249
249
|
['yellow', { r: 255, g: 255, b: 0 }, 0.9278],
|
|
250
250
|
['cyan', { r: 0, g: 255, b: 255 }, 0.7874],
|
|
251
251
|
['magenta', { r: 255, g: 0, b: 255 }, 0.2848],
|
|
252
|
-
['gray', { r: 128, g: 128, b: 128 }, 0.
|
|
252
|
+
['gray', { r: 128, g: 128, b: 128 }, 0.215_859_375]
|
|
253
253
|
])('luminosity(%s)', (_, value, expected) => {
|
|
254
254
|
expect(colors.luminosity(value)).toBeCloseTo(expected)
|
|
255
255
|
})
|
|
@@ -6,10 +6,11 @@ function fallback(text) {
|
|
|
6
6
|
area.contentEditable = 'true'
|
|
7
7
|
area.style.position = 'fixed' // avoid scrolling to bottom
|
|
8
8
|
|
|
9
|
+
// oxlint-disable-next-line unicorn/consistent-function-scoping
|
|
9
10
|
const fn = () => {}
|
|
10
11
|
addFocusout(fn)
|
|
11
12
|
|
|
12
|
-
document.body.
|
|
13
|
+
document.body.append(area)
|
|
13
14
|
area.focus()
|
|
14
15
|
area.select()
|
|
15
16
|
|
|
@@ -22,14 +23,8 @@ function fallback(text) {
|
|
|
22
23
|
}
|
|
23
24
|
|
|
24
25
|
export default function copyToClipboard(text) {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
if (res) {
|
|
30
|
-
resolve(true)
|
|
31
|
-
} else {
|
|
32
|
-
reject(res)
|
|
33
|
-
}
|
|
34
|
-
})
|
|
26
|
+
if (navigator.clipboard) return navigator.clipboard.writeText(text)
|
|
27
|
+
|
|
28
|
+
const res = fallback(text)
|
|
29
|
+
return res ? Promise.resolve(true) : Promise.reject(res)
|
|
35
30
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { clientList, planClientUpdate } from '../../plugins/meta/Meta.js'
|
|
2
2
|
|
|
3
|
-
export default metaOptions
|
|
3
|
+
export default function createMetaMixin(metaOptions) {
|
|
4
4
|
if (__QUASAR_SSR_SERVER__) {
|
|
5
5
|
return {
|
|
6
6
|
created:
|
|
@@ -43,7 +43,7 @@ export default metaOptions => {
|
|
|
43
43
|
watch: {
|
|
44
44
|
__qMetaOptions(val) {
|
|
45
45
|
this.__qMeta.val = val
|
|
46
|
-
if (this.__qMeta.active
|
|
46
|
+
if (this.__qMeta.active) planClientUpdate()
|
|
47
47
|
}
|
|
48
48
|
},
|
|
49
49
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
|
-
coreProps,
|
|
3
2
|
coreEmits,
|
|
3
|
+
coreProps,
|
|
4
4
|
getRenderer
|
|
5
5
|
} from '../../components/uploader/uploader-core.js'
|
|
6
6
|
|
|
@@ -10,8 +10,13 @@ import { isObject } from '../is/is.js'
|
|
|
10
10
|
|
|
11
11
|
const coreEmitsObject = getEmitsObject(coreEmits)
|
|
12
12
|
|
|
13
|
-
export default ({
|
|
14
|
-
|
|
13
|
+
export default function createUploaderComponent({
|
|
14
|
+
name,
|
|
15
|
+
props,
|
|
16
|
+
emits,
|
|
17
|
+
injectPlugin
|
|
18
|
+
}) {
|
|
19
|
+
return createComponent({
|
|
15
20
|
name,
|
|
16
21
|
|
|
17
22
|
props: {
|
|
@@ -19,12 +24,12 @@ export default ({ name, props, emits, injectPlugin }) =>
|
|
|
19
24
|
...props
|
|
20
25
|
},
|
|
21
26
|
|
|
22
|
-
emits:
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
: [...coreEmits, ...emits],
|
|
27
|
+
emits: isObject(emits)
|
|
28
|
+
? { ...coreEmitsObject, ...emits }
|
|
29
|
+
: [...coreEmits, ...emits],
|
|
26
30
|
|
|
27
31
|
setup(_, { expose }) {
|
|
28
32
|
return getRenderer(injectPlugin, expose)
|
|
29
33
|
}
|
|
30
34
|
})
|
|
35
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { describe,
|
|
1
|
+
import { describe, expect, test } from 'vitest'
|
|
2
2
|
|
|
3
3
|
import getCssVar from './get-css-var.js'
|
|
4
4
|
|
|
@@ -13,7 +13,7 @@ describe('[getCssVar API]', () => {
|
|
|
13
13
|
|
|
14
14
|
test('getCssVar(prop, el)', () => {
|
|
15
15
|
const el = document.createElement('div')
|
|
16
|
-
document.body.
|
|
16
|
+
document.body.append(el)
|
|
17
17
|
el.style.setProperty('--q-my-prop', 'some-value')
|
|
18
18
|
|
|
19
19
|
expect.soft(getCssVar('my-prop', el)).toBe('some-value')
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { describe,
|
|
1
|
+
import { describe, expect, test } from 'vitest'
|
|
2
2
|
|
|
3
3
|
import setCssVar from './set-css-var.js'
|
|
4
4
|
|
|
@@ -15,7 +15,7 @@ describe('[setCssVar API]', () => {
|
|
|
15
15
|
|
|
16
16
|
test('setCss(prop, el)', () => {
|
|
17
17
|
const el = document.createElement('div')
|
|
18
|
-
document.body.
|
|
18
|
+
document.body.append(el)
|
|
19
19
|
|
|
20
20
|
expect.soft(setCssVar('my-prop', 'cool', el)).toBeUndefined()
|
|
21
21
|
|