@jobber/components 4.90.2 → 4.90.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AnimatedPresence/{index.js → index.cjs} +1 -3
- package/dist/AnimatedPresence/index.mjs +4 -0
- package/dist/{AnimatedPresence-20a02aaa.js → AnimatedPresence-CNNu0y2V.js} +3 -7
- package/dist/AnimatedPresence-Cp8tOatE.js +98 -0
- package/dist/AnimatedSwitcher/index.cjs +11 -0
- package/dist/AnimatedSwitcher/index.mjs +5 -0
- package/dist/{AnimatedSwitcher-3d45ec5d.js → AnimatedSwitcher-CXKNa7td.js} +4 -8
- package/dist/AnimatedSwitcher-DJqwc2sj.js +90 -0
- package/dist/AtlantisContext/{index.js → index.cjs} +1 -3
- package/dist/AtlantisContext/index.mjs +2 -0
- package/dist/AtlantisContext-B2cWxzkp.js +18 -0
- package/dist/Autocomplete/index.cjs +33 -0
- package/dist/Autocomplete/index.mjs +27 -0
- package/dist/Autocomplete-CHcTq0Do.js +192 -0
- package/dist/Autocomplete-CswBpc7U.js +190 -0
- package/dist/Avatar/index.cjs +12 -0
- package/dist/Avatar/index.mjs +6 -0
- package/dist/Avatar-NVE7Yqd4.js +69 -0
- package/dist/Avatar-Q8rB73I2.js +67 -0
- package/dist/Banner/components/BannerIcon/index.cjs +13 -0
- package/dist/Banner/components/BannerIcon/index.mjs +7 -0
- package/dist/Banner/index.cjs +23 -0
- package/dist/Banner/index.mjs +17 -0
- package/dist/Banner-AzSFwco8.js +79 -0
- package/dist/Banner-DH176e7P.js +81 -0
- package/dist/BannerIcon-BDM1qFzc.js +19 -0
- package/dist/BannerIcon-Dg3SkxI7.js +22 -0
- package/dist/Body-ChUi3aq5.js +54 -0
- package/dist/Body-D1DdNQ7t.js +45 -0
- package/dist/Button/index.cjs +13 -0
- package/dist/Button/index.mjs +7 -0
- package/dist/Button-C6SHw1kI.js +49 -0
- package/dist/Button-Cfp4SFrN.js +47 -0
- package/dist/ButtonDismiss/index.cjs +14 -0
- package/dist/ButtonDismiss/index.mjs +8 -0
- package/dist/ButtonDismiss-Cf-2rvG0.js +8 -0
- package/dist/ButtonDismiss-DVALYLmq.js +10 -0
- package/dist/Card/index.cjs +21 -0
- package/dist/Card/index.mjs +15 -0
- package/dist/Card-DE7aMoA7.js +83 -0
- package/dist/Card-DXsK_SD7.js +81 -0
- package/dist/Checkbox/index.cjs +15 -0
- package/dist/Checkbox/index.mjs +9 -0
- package/dist/Checkbox-BXh_wazi.js +55 -0
- package/dist/Checkbox-DxC81YWi.js +53 -0
- package/dist/Chip/hooks/index.cjs +8 -0
- package/dist/Chip/hooks/index.mjs +2 -0
- package/dist/Chip/index.cjs +26 -0
- package/dist/Chip/index.mjs +18 -0
- package/dist/Chip-DDl2lMHv.js +70 -0
- package/dist/Chip-DhTvoOnl.js +67 -0
- package/dist/ChipDismissible-S-txJuLF.js +19 -0
- package/dist/ChipDismissible-dx2J1n-C.js +22 -0
- package/dist/Chips/InternalChipDismissible/hooks/index.cjs +23 -0
- package/dist/Chips/InternalChipDismissible/hooks/index.mjs +13 -0
- package/dist/Chips/InternalChipDismissible/index.cjs +35 -0
- package/dist/Chips/InternalChipDismissible/index.mjs +29 -0
- package/dist/Chips/index.cjs +48 -0
- package/dist/Chips/index.mjs +44 -0
- package/dist/Chips-BBnCrPul.js +93 -0
- package/dist/Chips-KPKpzxUx.js +91 -0
- package/dist/Combobox/components/ComboboxAction/index.cjs +12 -0
- package/dist/Combobox/components/ComboboxAction/index.mjs +6 -0
- package/dist/Combobox/components/ComboboxActivator/index.cjs +27 -0
- package/dist/Combobox/components/ComboboxActivator/index.mjs +21 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentHeader/index.cjs +14 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentHeader/index.mjs +8 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentList/index.cjs +24 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentList/index.mjs +18 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentSearch/index.cjs +10 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentSearch/index.mjs +4 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxLoadMore/index.cjs +9 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxLoadMore/index.mjs +3 -0
- package/dist/Combobox/components/ComboboxContent/index.cjs +34 -0
- package/dist/Combobox/components/ComboboxContent/index.mjs +28 -0
- package/dist/Combobox/components/ComboboxOption/index.cjs +14 -0
- package/dist/Combobox/components/ComboboxOption/index.mjs +8 -0
- package/dist/Combobox/components/ComboboxTrigger/index.cjs +25 -0
- package/dist/Combobox/components/ComboboxTrigger/index.mjs +19 -0
- package/dist/Combobox/index.cjs +53 -0
- package/dist/Combobox/index.mjs +46 -0
- package/dist/Combobox-DL8grBGD.js +119 -0
- package/dist/Combobox-DkiMKBIq.js +117 -0
- package/dist/ComboboxAction-BZcUzPiS.js +22 -0
- package/dist/ComboboxAction-BrphUdTc.js +24 -0
- package/dist/ComboboxActivator-B-hbPIvc.js +28 -0
- package/dist/ComboboxActivator-GbDe5-gd.js +26 -0
- package/dist/ComboboxContent-PbGOqYiy.js +145 -0
- package/dist/ComboboxContent-Y7XnpDxG.js +143 -0
- package/dist/ComboboxContentHeader-CXeTEKPJ.js +29 -0
- package/dist/ComboboxContentHeader-R33IqVfI.js +27 -0
- package/dist/ComboboxContentList-BcRD6OP7.js +75 -0
- package/dist/ComboboxContentList-QdY3v22O.js +77 -0
- package/dist/ComboboxContentSearch-BQoi8eST.js +32 -0
- package/dist/ComboboxContentSearch-BYHUi0_0.js +34 -0
- package/dist/ComboboxLoadMore-CTue6Ccg.js +16 -0
- package/dist/ComboboxLoadMore-Dwov5fXg.js +14 -0
- package/dist/ComboboxOption-BQAcmD8S.js +20 -0
- package/dist/ComboboxOption-CEM44lR4.js +22 -0
- package/dist/ComboboxProvider-BfK8pUar.js +13 -0
- package/dist/ComboboxProvider-CnooL3he.js +10 -0
- package/dist/ComboboxTrigger-BPoUI5Eo.js +24 -0
- package/dist/ComboboxTrigger-CUU6Np4P.js +22 -0
- package/dist/ConfirmationModal/index.cjs +31 -0
- package/dist/ConfirmationModal/index.mjs +25 -0
- package/dist/{ConfirmationModal-b44e302f.js → ConfirmationModal-BJRisSRI.js} +8 -12
- package/dist/ConfirmationModal-DWSRaZne.js +94 -0
- package/dist/Content/index.cjs +9 -0
- package/dist/Content/index.mjs +3 -0
- package/dist/Content-BfbXarkv.js +15 -0
- package/dist/Content-DcpJaJjo.js +13 -0
- package/dist/Countdown/index.cjs +11 -0
- package/dist/Countdown/index.mjs +5 -0
- package/dist/Countdown-B1qWObYf.js +659 -0
- package/dist/Countdown-BcPHGeXW.js +657 -0
- package/dist/DataDump/index.cjs +24 -0
- package/dist/DataDump/index.mjs +18 -0
- package/dist/DataDump-CVjjQmzE.js +17 -0
- package/dist/DataDump-IdZ5dfe5.js +15 -0
- package/dist/DataList/components/DataListAction/index.cjs +13 -0
- package/dist/DataList/components/DataListAction/index.mjs +7 -0
- package/dist/DataList/components/DataListActions/index.cjs +43 -0
- package/dist/DataList/components/DataListActions/index.mjs +37 -0
- package/dist/DataList/components/DataListActionsMenu/index.cjs +17 -0
- package/dist/DataList/components/DataListActionsMenu/index.mjs +11 -0
- package/dist/DataList/components/DataListBulkActions/index.cjs +46 -0
- package/dist/DataList/components/DataListBulkActions/index.mjs +39 -0
- package/dist/DataList/components/DataListEmptyState/index.cjs +20 -0
- package/dist/DataList/components/DataListEmptyState/index.mjs +13 -0
- package/dist/DataList/components/DataListFilters/components/DataListSort/index.cjs +54 -0
- package/dist/DataList/components/DataListFilters/components/DataListSort/index.mjs +48 -0
- package/dist/DataList/components/DataListFilters/index.cjs +68 -0
- package/dist/DataList/components/DataListFilters/index.mjs +61 -0
- package/dist/DataList/components/DataListHeader/index.cjs +53 -0
- package/dist/DataList/components/DataListHeader/index.mjs +47 -0
- package/dist/DataList/components/DataListHeaderTile/components/index.cjs +12 -0
- package/dist/DataList/components/DataListHeaderTile/components/index.mjs +6 -0
- package/dist/DataList/components/DataListHeaderTile/index.cjs +20 -0
- package/dist/DataList/components/DataListHeaderTile/index.mjs +14 -0
- package/dist/DataList/components/DataListItem/components/DataListItemClickable/index.cjs +14 -0
- package/dist/DataList/components/DataListItem/components/DataListItemClickable/index.mjs +8 -0
- package/dist/DataList/components/DataListItem/index.cjs +52 -0
- package/dist/DataList/components/DataListItem/index.mjs +46 -0
- package/dist/DataList/components/DataListItemActions/index.cjs +45 -0
- package/dist/DataList/components/DataListItemActions/index.mjs +38 -0
- package/dist/DataList/components/DataListItemActionsOverflow/index.cjs +25 -0
- package/dist/DataList/components/DataListItemActionsOverflow/index.mjs +19 -0
- package/dist/DataList/components/DataListItems/index.cjs +53 -0
- package/dist/DataList/components/DataListItems/index.mjs +47 -0
- package/dist/DataList/components/DataListLayout/index.cjs +56 -0
- package/dist/DataList/components/DataListLayout/index.mjs +50 -0
- package/dist/DataList/components/DataListLayoutActions/DataListLayoutContext/index.cjs +9 -0
- package/dist/DataList/components/DataListLayoutActions/DataListLayoutContext/index.mjs +2 -0
- package/dist/DataList/components/DataListLayoutActions/index.cjs +33 -0
- package/dist/DataList/components/DataListLayoutActions/index.mjs +27 -0
- package/dist/DataList/components/DataListLoadMore/index.cjs +21 -0
- package/dist/DataList/components/DataListLoadMore/index.mjs +14 -0
- package/dist/DataList/components/DataListLoadingState/index.cjs +21 -0
- package/dist/DataList/components/DataListLoadingState/index.mjs +13 -0
- package/dist/DataList/components/DataListOverflowFade/index.cjs +11 -0
- package/dist/DataList/components/DataListOverflowFade/index.mjs +4 -0
- package/dist/DataList/components/DataListSearch/index.cjs +33 -0
- package/dist/DataList/components/DataListSearch/index.mjs +25 -0
- package/dist/DataList/components/DataListStatusBar/index.cjs +32 -0
- package/dist/DataList/components/DataListStatusBar/index.mjs +25 -0
- package/dist/DataList/components/DataListStickyHeader/index.cjs +11 -0
- package/dist/DataList/components/DataListStickyHeader/index.mjs +5 -0
- package/dist/DataList/components/DataListTags/index.cjs +12 -0
- package/dist/DataList/components/DataListTags/index.mjs +6 -0
- package/dist/DataList/components/DataListTotalCount/index.cjs +15 -0
- package/dist/DataList/components/DataListTotalCount/index.mjs +8 -0
- package/dist/DataList/context/DataListContext/index.cjs +12 -0
- package/dist/DataList/context/DataListContext/index.mjs +4 -0
- package/dist/DataList/context/DataListLayoutContext/index.cjs +12 -0
- package/dist/DataList/context/DataListLayoutContext/index.mjs +4 -0
- package/dist/DataList/index.cjs +98 -0
- package/dist/DataList/index.mjs +92 -0
- package/dist/DataList-BNFt3ksk.js +139 -0
- package/dist/DataList-Cr9VCHIX.js +5 -0
- package/dist/DataList-DHFR_-wI.js +141 -0
- package/dist/DataList-Dz5NINSZ.js +3 -0
- package/dist/DataList.const-D7NaHwv2.js +25 -0
- package/dist/DataList.const-DD8VmZp1.js +38 -0
- package/dist/DataList.utils-DhJ6Bzfb.js +161 -0
- package/dist/DataList.utils-nlVavDa-.js +168 -0
- package/dist/DataListAction-BLmcBkv3.js +39 -0
- package/dist/DataListAction-z0r8dyGZ.js +37 -0
- package/dist/DataListActions-4k1qQRcL.js +43 -0
- package/dist/DataListActions-DNsv1N2R.js +45 -0
- package/dist/DataListActionsMenu-4y3C6RwI.js +55 -0
- package/dist/DataListActionsMenu-D7LvCqEb.js +57 -0
- package/dist/DataListBulkActions-By-GrAPp.js +29 -0
- package/dist/DataListBulkActions-Ck89g6ye.js +26 -0
- package/dist/DataListContext-54s0cQ2-.js +29 -0
- package/dist/DataListContext-BQjPQQPp.js +25 -0
- package/dist/DataListEmptyState-5-J-3X4D.js +53 -0
- package/dist/DataListEmptyState-BtuGoNX6.js +50 -0
- package/dist/DataListFilters-sd7jBhQE.js +46 -0
- package/dist/DataListFilters-vylASUtC.js +43 -0
- package/dist/DataListHeader-Bkxr7WIZ.js +95 -0
- package/dist/DataListHeader-PvjsNn2I.js +93 -0
- package/dist/DataListHeaderTile-BybGOG6C.js +81 -0
- package/dist/DataListHeaderTile-KJ8Eae63.js +79 -0
- package/dist/DataListItem-BqNp3Eqq.js +112 -0
- package/dist/DataListItem-CCbOb4ts.js +114 -0
- package/dist/DataListItemActions-C25oc6Y-.js +29 -0
- package/dist/DataListItemActions-DPiWyGS1.js +32 -0
- package/dist/DataListItemActionsOverflow-Dy8lheES.js +33 -0
- package/dist/DataListItemActionsOverflow-ul1diZ44.js +35 -0
- package/dist/DataListItemClickable-BuMjNn5E.js +47 -0
- package/dist/DataListItemClickable-DQ5Sq-4_.js +45 -0
- package/dist/DataListItems--_6Rb8Jq.js +19 -0
- package/dist/DataListItems-DwAPcNSD.js +21 -0
- package/dist/DataListLayout-DWQ3LcOJ.js +21 -0
- package/dist/DataListLayout-DYcpl2hP.js +19 -0
- package/dist/DataListLayoutActions-B1EVoxK2.js +36 -0
- package/dist/DataListLayoutActions-DLj3XiZ5.js +38 -0
- package/dist/DataListLayoutContext-Dl1JtgLH.js +11 -0
- package/dist/DataListLayoutContext-DwmprXbf.js +18 -0
- package/dist/DataListLayoutContext-Il_5jPik.js +14 -0
- package/dist/DataListLayoutContext-TpQb0Nj2.js +8 -0
- package/dist/DataListLoadMore-FkGD7vHM.js +34 -0
- package/dist/DataListLoadMore-ZmJj5-i9.js +31 -0
- package/dist/DataListLoadingState-CR1Z1_AR.js +26 -0
- package/dist/DataListLoadingState-xQup12W4.js +22 -0
- package/dist/DataListOverflowFade-10aOxr8Q.js +25 -0
- package/dist/DataListOverflowFade-D0Nqey5v.js +22 -0
- package/dist/DataListSearch-DyYTAMCq.js +59 -0
- package/dist/DataListSearch-I4HkoS-h.js +63 -0
- package/dist/DataListSort-DWwMojZr.js +94 -0
- package/dist/DataListSort-GHDVPJ_E.js +92 -0
- package/dist/DataListSortingOptions-DpPwd-YR.js +35 -0
- package/dist/DataListSortingOptions-nk9dclSJ.js +37 -0
- package/dist/DataListStatusBar-Cq2c6T6R.js +22 -0
- package/dist/DataListStatusBar-DoDXKGHi.js +25 -0
- package/dist/DataListStickyHeader-6xUwJJD7.js +23 -0
- package/dist/DataListStickyHeader-xrbxWP2I.js +25 -0
- package/dist/DataListTags-69zAArZ2.js +64 -0
- package/dist/DataListTags-Ck_VOCzy.js +62 -0
- package/dist/DataListTotalCount-CJZ9FD36.js +27 -0
- package/dist/DataListTotalCount-Cns_GwAL.js +24 -0
- package/dist/DataTable/index.cjs +36 -0
- package/dist/DataTable/index.mjs +25 -0
- package/dist/DataTable/test-utilities/index.cjs +246 -0
- package/dist/DataTable/test-utilities/index.mjs +238 -0
- package/dist/DataTable-Bt0NOwH4.js +236 -0
- package/dist/DataTable-CNVDhnqd.js +238 -0
- package/dist/DatePicker/index.cjs +26 -0
- package/dist/DatePicker/index.mjs +20 -0
- package/dist/DatePicker-BRUF_5jL.js +8554 -0
- package/dist/DatePicker-Ck4FVQQS.js +8551 -0
- package/dist/DayOfMonthSelect-BdCBk0Fz.js +130 -0
- package/dist/DayOfMonthSelect-CmghghbK.js +137 -0
- package/dist/DescriptionList/index.cjs +10 -0
- package/dist/DescriptionList/index.mjs +4 -0
- package/dist/DescriptionList-BHllIrT9.js +14 -0
- package/dist/DescriptionList-BX86_iJ-.js +12 -0
- package/dist/Disclosure/index.cjs +17 -0
- package/dist/Disclosure/index.mjs +11 -0
- package/dist/Disclosure-BOotfD-_.js +33 -0
- package/dist/Disclosure-CwDEaUmN.js +35 -0
- package/dist/Divider/index.cjs +9 -0
- package/dist/Divider/index.mjs +3 -0
- package/dist/Divider-CGLchhDF.js +17 -0
- package/dist/Divider-yff7rtIo.js +19 -0
- package/dist/Drawer/index.cjs +19 -0
- package/dist/Drawer/index.mjs +12 -0
- package/dist/DrawerGrid-Csj6IRXw.js +28 -0
- package/dist/DrawerGrid-Dhe6uh-8.js +31 -0
- package/dist/Emphasis/index.cjs +10 -0
- package/dist/Emphasis/index.mjs +4 -0
- package/dist/Emphasis-RZbI_yDN.js +15 -0
- package/dist/Emphasis-ieWWb3pq.js +13 -0
- package/dist/FeatureSwitch/index.cjs +26 -0
- package/dist/FeatureSwitch/index.mjs +20 -0
- package/dist/FeatureSwitch-BcLRihpc.js +52 -0
- package/dist/FeatureSwitch-DKsr91OR.js +54 -0
- package/dist/Flex/index.cjs +9 -0
- package/dist/Flex/index.mjs +3 -0
- package/dist/Flex-CloUiW2f.js +28 -0
- package/dist/Flex-mRkBGC1G.js +30 -0
- package/dist/Form/index.cjs +10 -0
- package/dist/Form/index.mjs +4 -0
- package/dist/Form-Brm98BxU.js +48 -0
- package/dist/{Form/index.js → Form-C1OZbkgH.js} +3 -9
- package/dist/FormField/index.cjs +20 -0
- package/dist/FormField/index.mjs +14 -0
- package/dist/FormField-CevGrDGm.js +261 -0
- package/dist/FormField-DgvKr2RR.js +263 -0
- package/dist/FormatDate/{index.js → index.cjs} +1 -3
- package/dist/FormatDate/index.mjs +2 -0
- package/dist/FormatDate-Cuu1uyX_.js +27 -0
- package/dist/{FormatDate-70ea5b43.js → FormatDate-F_hdjag1.js} +1 -5
- package/dist/FormatEmail/index.cjs +9 -0
- package/dist/FormatEmail/index.mjs +3 -0
- package/dist/FormatEmail-BL75oJKz.js +11 -0
- package/dist/FormatEmail-FWzV4fL2.js +13 -0
- package/dist/FormatFile/index.cjs +36 -0
- package/dist/FormatFile/index.mjs +30 -0
- package/dist/FormatFile-CaULPATZ.js +149 -0
- package/dist/FormatFile-Dkkpc4RO.js +147 -0
- package/dist/FormatRelativeDateTime/index.cjs +8 -0
- package/dist/FormatRelativeDateTime/index.mjs +2 -0
- package/dist/{FormatRelativeDateTime/index.js → FormatRelativeDateTime-DJIQHUEo.js} +5 -11
- package/dist/FormatRelativeDateTime-SwQGKFKx.js +64 -0
- package/dist/FormatTime/index.cjs +8 -0
- package/dist/FormatTime/index.mjs +2 -0
- package/dist/FormatTime-BUp8wKYB.js +29 -0
- package/dist/{FormatTime/index.js → FormatTime-Bf1p46AK.js} +1 -7
- package/dist/Gallery/index.cjs +42 -0
- package/dist/Gallery/index.mjs +36 -0
- package/dist/Gallery-iRUMatk_.js +65 -0
- package/dist/Gallery-ondjCKOu.js +63 -0
- package/dist/Glimmer/index.cjs +12 -0
- package/dist/Glimmer/index.mjs +5 -0
- package/dist/Glimmer-CVTrhX52.js +60 -0
- package/dist/Glimmer-CnsLTogn.js +63 -0
- package/dist/Grid/InternalGridCell/index.cjs +9 -0
- package/dist/Grid/InternalGridCell/index.mjs +2 -0
- package/dist/Grid/index.cjs +14 -0
- package/dist/Grid/index.mjs +7 -0
- package/dist/Grid-DC7GAarU.js +29 -0
- package/dist/Grid-c8FgrzP7.js +32 -0
- package/dist/Heading/index.cjs +12 -0
- package/dist/Heading/index.mjs +6 -0
- package/dist/{Heading-23d382a1.js → Heading-CCFoOnua.js} +3 -7
- package/dist/Heading-Cik7AvDW.js +49 -0
- package/dist/Icon/index.cjs +9 -0
- package/dist/Icon/index.mjs +3 -0
- package/dist/Icon-Cprfa6DH.js +34 -0
- package/dist/Icon-DN6zZdoZ.js +36 -0
- package/dist/InlineLabel/index.cjs +10 -0
- package/dist/InlineLabel/index.mjs +4 -0
- package/dist/InlineLabel-DjcM6md2.js +18 -0
- package/dist/InlineLabel-DpGHWyZ1.js +20 -0
- package/dist/InputAvatar/index.cjs +26 -0
- package/dist/InputAvatar/index.mjs +20 -0
- package/dist/InputAvatar-0CRsukeF.js +49 -0
- package/dist/InputAvatar-BR9CNN8N.js +47 -0
- package/dist/InputDate/index.cjs +34 -0
- package/dist/InputDate/index.mjs +28 -0
- package/dist/{InputDate/index.js → InputDate-ChvqCIwy.js} +6 -31
- package/dist/InputDate-Di1ilUDK.js +48 -0
- package/dist/InputEmail/index.cjs +22 -0
- package/dist/InputEmail/index.mjs +15 -0
- package/dist/InputEmail-2iUVN3lX.js +23 -0
- package/dist/InputEmail-DIaAL1Fj.js +20 -0
- package/dist/InputFile/index.cjs +23 -0
- package/dist/InputFile/index.mjs +16 -0
- package/dist/InputFile-CQcJalUx.js +1611 -0
- package/dist/InputFile-DrLKxOEw.js +1608 -0
- package/dist/InputGroup/index.cjs +9 -0
- package/dist/InputGroup/index.mjs +3 -0
- package/dist/InputGroup-CDAggb3R.js +25 -0
- package/dist/InputGroup-CqwRtrCP.js +23 -0
- package/dist/InputNumber/index.cjs +21 -0
- package/dist/InputNumber/index.mjs +15 -0
- package/dist/{InputNumber-e15cc1a3.js → InputNumber-B1xScmfR.js} +2 -6
- package/dist/InputNumber-CJabx_OX.js +56 -0
- package/dist/InputPassword/index.cjs +21 -0
- package/dist/InputPassword/index.mjs +15 -0
- package/dist/InputPassword-558tvE1p.js +21 -0
- package/dist/InputPassword-DIzD-pX3.js +19 -0
- package/dist/InputPhoneNumber/index.cjs +21 -0
- package/dist/InputPhoneNumber/index.mjs +15 -0
- package/dist/InputPhoneNumber-DRdIU41q.js +94 -0
- package/dist/{InputPhoneNumber/index.js → InputPhoneNumber-DWdXIF84.js} +7 -27
- package/dist/InputText/index.cjs +22 -0
- package/dist/InputText/index.mjs +16 -0
- package/dist/{InputText-130b0440.js → InputText-Br2K1C4M.js} +4 -8
- package/dist/InputText-CyGO_Jef.js +96 -0
- package/dist/InputTime/index.cjs +26 -0
- package/dist/InputTime/index.mjs +20 -0
- package/dist/{InputTime/index.js → InputTime-CpoUMFJT.js} +5 -25
- package/dist/InputTime-kqDNzoYY.js +190 -0
- package/dist/InputValidation/index.cjs +14 -0
- package/dist/InputValidation/index.mjs +8 -0
- package/dist/InputValidation-CA3D4HMZ.js +22 -0
- package/dist/InputValidation-D4MvsPKI.js +20 -0
- package/dist/InternalChipDismissible-B7LrCyb7.js +152 -0
- package/dist/InternalChipDismissible-C52ZoCE0.js +157 -0
- package/dist/InternalGridCell-DqEoIvP9.js +34 -0
- package/dist/InternalGridCell-zig0sMW5.js +37 -0
- package/dist/LightBox/index.cjs +26 -0
- package/dist/LightBox/index.mjs +20 -0
- package/dist/LightBox-BMcZ0zUE.js +112 -0
- package/dist/LightBox-DdN2Kv2x.js +110 -0
- package/dist/Link/index.cjs +8 -0
- package/dist/Link/index.mjs +2 -0
- package/dist/Link-BXg1N0uc.js +7 -0
- package/dist/Link-D4vsUc4Q.js +9 -0
- package/dist/List/index.cjs +29 -0
- package/dist/List/index.mjs +22 -0
- package/dist/List-DEIH9jaA.js +189 -0
- package/dist/List-Dh-L_8Vd.js +186 -0
- package/dist/Markdown/index.cjs +19 -0
- package/dist/Markdown/index.mjs +13 -0
- package/dist/Markdown-DIOh2S0u.js +19011 -0
- package/dist/Markdown-GR9F9CIO.js +19013 -0
- package/dist/Menu/index.cjs +18 -0
- package/dist/Menu/index.mjs +12 -0
- package/dist/Menu-D4apJOhh.js +131 -0
- package/dist/Menu-IjuAzGId.js +129 -0
- package/dist/Modal/index.cjs +23 -0
- package/dist/Modal/index.mjs +17 -0
- package/dist/Modal-Dr-Y4-gf.js +62 -0
- package/dist/Modal-aGXkiuSS.js +60 -0
- package/dist/MultiSelect/index.cjs +16 -0
- package/dist/MultiSelect/index.mjs +10 -0
- package/dist/MultiSelect-1LkHc-4a.js +166 -0
- package/dist/MultiSelect-CIFWIwY6.js +164 -0
- package/dist/Option-DLsUvwdO.js +12 -0
- package/dist/Option-c12Y1Noe.js +15 -0
- package/dist/Page/index.cjs +32 -0
- package/dist/Page/index.mjs +26 -0
- package/dist/Page-CakXCvoE.js +58 -0
- package/dist/Page-DwQymzZk.js +56 -0
- package/dist/Popover/index.cjs +17 -0
- package/dist/Popover/index.mjs +11 -0
- package/dist/Popover-BY0EW6zV.js +48 -0
- package/dist/Popover-ByVk1LqF.js +50 -0
- package/dist/ProgressBar/index.cjs +9 -0
- package/dist/ProgressBar/index.mjs +3 -0
- package/dist/ProgressBar-52i53SJE.js +33 -0
- package/dist/ProgressBar-BaSkqP8J.js +31 -0
- package/dist/RadioGroup/index.cjs +12 -0
- package/dist/RadioGroup/index.mjs +5 -0
- package/dist/RadioGroup-CRwAZq63.js +36 -0
- package/dist/RadioGroup-TNqC7foh.js +39 -0
- package/dist/RecurringSelect/components/index.cjs +15 -0
- package/dist/RecurringSelect/components/index.mjs +6 -0
- package/dist/RecurringSelect/index.cjs +35 -0
- package/dist/RecurringSelect/index.mjs +21 -0
- package/dist/RecurringSelect-VBGk4Lt2.js +71 -0
- package/dist/RecurringSelect-cwPdAc_S.js +69 -0
- package/dist/Select/index.cjs +22 -0
- package/dist/Select/index.mjs +15 -0
- package/dist/Spinner/index.cjs +9 -0
- package/dist/Spinner/index.mjs +3 -0
- package/dist/Spinner-L0bWOO6S.js +16 -0
- package/dist/Spinner-gZOK7Pbk.js +14 -0
- package/dist/StatusIndicator/index.cjs +8 -0
- package/dist/StatusIndicator/index.mjs +2 -0
- package/dist/StatusIndicator-CQ4BuDSG.js +9 -0
- package/dist/StatusIndicator-CQu-mhiP.js +11 -0
- package/dist/StatusLabel/index.cjs +11 -0
- package/dist/StatusLabel/index.mjs +5 -0
- package/dist/StatusLabel-C8xAbAuq.js +18 -0
- package/dist/StatusLabel-O-4M1wUA.js +16 -0
- package/dist/Switch/index.cjs +10 -0
- package/dist/Switch/index.mjs +4 -0
- package/dist/Switch-DMYTNJjq.js +48 -0
- package/dist/Switch-DqzUCyHn.js +46 -0
- package/dist/Table/index.cjs +17 -0
- package/dist/Table/index.mjs +4 -0
- package/dist/Tabs/index.cjs +11 -0
- package/dist/Tabs/index.mjs +4 -0
- package/dist/Tabs-C3qMIs1F.js +67 -0
- package/dist/Tabs-CRY_vyNW.js +70 -0
- package/dist/Text/index.cjs +10 -0
- package/dist/Text/index.mjs +4 -0
- package/dist/{Text-fbeaaca6.js → Text-Bopx9dUr.js} +2 -6
- package/dist/Text-DALHhxHl.js +25 -0
- package/dist/Toast/index.cjs +16 -0
- package/dist/Toast/index.mjs +10 -0
- package/dist/Tooltip/index.cjs +14 -0
- package/dist/Tooltip/index.mjs +8 -0
- package/dist/Tooltip-B2DBKrJM.js +103 -0
- package/dist/Tooltip-VHTRuZ4Y.js +105 -0
- package/dist/Typography/index.cjs +9 -0
- package/dist/Typography/index.mjs +3 -0
- package/dist/Typography-D6YoQOGF.js +36 -0
- package/dist/Typography-WLLQxuNl.js +38 -0
- package/dist/_baseAssignValue-BthOhxdo.js +29 -0
- package/dist/_baseAssignValue-Dt4F7vTV.js +31 -0
- package/dist/_baseEach-BECef8ru.js +1069 -0
- package/dist/_baseEach-Dze5I6UM.js +1073 -0
- package/dist/_commonjsHelpers-COf7qtKz.js +32 -0
- package/dist/_commonjsHelpers-vq2WA-uE.js +36 -0
- package/dist/_defineProperty-2TBZHj_H.js +1306 -0
- package/dist/_defineProperty-DxuhV38S.js +1326 -0
- package/dist/_getTag-BhVE5Z9s.js +733 -0
- package/dist/_getTag-Z6aLseUE.js +718 -0
- package/dist/_polyfill-node.process-e5fcXoUk.js +255 -0
- package/dist/_polyfill-node.process-mCRQTL4d.js +258 -0
- package/dist/_setToString-CFGrPYbk.js +230 -0
- package/dist/_setToString-D9q1MBnP.js +234 -0
- package/dist/debounce-DNEaQL1N.js +332 -0
- package/dist/debounce-DgeBwtKp.js +329 -0
- package/dist/helpers-QJ7YD42d.js +17 -0
- package/dist/helpers-cJmOwx3u.js +15 -0
- package/dist/index-C4SneFNu.js +1186 -0
- package/dist/index-yqmGqwFM.js +1189 -0
- package/dist/index.cjs +275 -0
- package/dist/index.d.mts +74 -0
- package/dist/index.d.ts +74 -0
- package/dist/index.mjs +162 -0
- package/dist/isObjectLike-BLBufvwS.js +197 -0
- package/dist/isObjectLike-CqUyaiWM.js +190 -0
- package/dist/isSymbol-MYvz4htB.js +35 -0
- package/dist/isSymbol-_Iyy_jRJ.js +33 -0
- package/dist/noop-C8qh6oDm.js +26 -0
- package/dist/noop-CNfu_5-L.js +24 -0
- package/dist/showToast-BB8OsmX0.js +97 -0
- package/dist/showToast-DNc6Ghvi.js +99 -0
- package/dist/styles.css +8762 -0
- package/dist/tslib.es6-CQnq_FvL.js +97 -0
- package/dist/tslib.es6-v7P0Y776.js +102 -0
- package/dist/useActiveLayout-C0_CiH6w.js +16 -0
- package/dist/useActiveLayout-CpgnILog.js +14 -0
- package/dist/useAssert--FSFxEub.js +27 -0
- package/dist/useAssert-BRTg70rg.js +27 -0
- package/dist/{useAtlantisConfig-ed0bee66.js → useAtlantisConfig-BbG41OXr.js} +2 -2
- package/dist/useAtlantisConfig-ClMTcI5f.js +14 -0
- package/dist/useBatchSelect-CTMzNd5R.js +36 -0
- package/dist/useBatchSelect-nB5zKoLG.js +38 -0
- package/dist/useChildComponent-2LnkmIw0.js +15 -0
- package/dist/useChildComponent-Dv0rjZs2.js +17 -0
- package/dist/useFocusTrap-DDVdHPLP.js +74 -0
- package/dist/useFocusTrap-J4nqJhkL.js +74 -0
- package/dist/useInView-D7JiU6w9.js +25 -0
- package/dist/useInView-DRRNAygj.js +25 -0
- package/dist/useIsMounted-Ds9qZzhJ.js +47 -0
- package/dist/useIsMounted-sw4iFcH2.js +47 -0
- package/dist/useOnKeyDown-BBUzTpsM.js +40 -0
- package/dist/useOnKeyDown-ClBoAl9o.js +40 -0
- package/dist/useRefocusOnActivator-DhXYZbJ2.js +32 -0
- package/dist/useRefocusOnActivator-JhjmSWbr.js +32 -0
- package/dist/useResizeObserver-Bt-giwIv.js +1192 -0
- package/dist/useResizeObserver-D7zJHmH-.js +1189 -0
- package/dist/useResponsiveSizing-CaFHa0P8.js +49 -0
- package/dist/useResponsiveSizing-X79bu1Sd.js +51 -0
- package/dist/useSafeLayoutEffect-87KYIon5.js +14 -0
- package/dist/useSafeLayoutEffect-IMNHxeSN.js +12 -0
- package/dist/useScrollToActive-AgUIt0XS.js +591 -0
- package/dist/useScrollToActive-D4MUBncA.js +597 -0
- package/package.json +394 -8
- package/{rollup.config.js → rollup.config.mjs} +50 -17
- package/dist/AnimatedSwitcher/index.js +0 -13
- package/dist/Autocomplete/index.js +0 -214
- package/dist/Avatar/index.js +0 -15
- package/dist/Avatar-76a799fa.js +0 -78
- package/dist/Banner/index.js +0 -111
- package/dist/Button/index.js +0 -16
- package/dist/Button-6b922fc1.js +0 -57
- package/dist/ButtonDismiss/index.js +0 -17
- package/dist/ButtonDismiss-a3ba1de2.js +0 -14
- package/dist/Card/index.js +0 -24
- package/dist/Card-01d6ba19.js +0 -93
- package/dist/Checkbox/index.js +0 -18
- package/dist/Checkbox-e481a4b1.js +0 -63
- package/dist/Chip/index.js +0 -42
- package/dist/Chip-76f18555.js +0 -89
- package/dist/Chips/index.js +0 -525
- package/dist/Combobox/index.js +0 -41
- package/dist/Combobox-6d864202.js +0 -481
- package/dist/ConfirmationModal/index.js +0 -32
- package/dist/Content/index.js +0 -12
- package/dist/Content-e3f7b6fc.js +0 -24
- package/dist/Countdown/index.js +0 -72
- package/dist/DataDump/index.js +0 -37
- package/dist/DataList/index.js +0 -1346
- package/dist/DataTable/index.js +0 -301
- package/dist/DatePicker/index.js +0 -21
- package/dist/DatePicker-305a5b82.js +0 -144
- package/dist/DescriptionList/index.js +0 -24
- package/dist/Disclosure/index.js +0 -46
- package/dist/Divider/index.js +0 -29
- package/dist/Drawer/index.js +0 -50
- package/dist/Emphasis/index.js +0 -13
- package/dist/Emphasis-a77d8ee9.js +0 -19
- package/dist/FeatureSwitch/index.js +0 -71
- package/dist/Flex/index.js +0 -12
- package/dist/Flex-d490c4db.js +0 -38
- package/dist/FormField/index.js +0 -24
- package/dist/FormField-f6fadff2.js +0 -253
- package/dist/FormatEmail/index.js +0 -23
- package/dist/FormatFile/index.js +0 -37
- package/dist/FormatFile-32228107.js +0 -162
- package/dist/Gallery/index.js +0 -101
- package/dist/Glimmer/index.js +0 -15
- package/dist/Glimmer-84dee1ed.js +0 -77
- package/dist/Grid/index.js +0 -76
- package/dist/Heading/index.js +0 -15
- package/dist/Icon/index.js +0 -11
- package/dist/Icon-405a216c.js +0 -40
- package/dist/InlineLabel/index.js +0 -13
- package/dist/InlineLabel-c8fc28f0.js +0 -28
- package/dist/InputAvatar/index.js +0 -70
- package/dist/InputEmail/index.js +0 -43
- package/dist/InputFile/index.js +0 -25
- package/dist/InputFile-20b9074a.js +0 -190
- package/dist/InputGroup/index.js +0 -12
- package/dist/InputGroup-8d4fd4eb.js +0 -33
- package/dist/InputNumber/index.js +0 -25
- package/dist/InputPassword/index.js +0 -41
- package/dist/InputText/index.js +0 -26
- package/dist/InputValidation/index.js +0 -17
- package/dist/InputValidation-a92bb519.js +0 -29
- package/dist/LightBox/index.js +0 -25
- package/dist/LightBox-7efe8932.js +0 -121
- package/dist/Link/index.js +0 -15
- package/dist/List/index.js +0 -94
- package/dist/Markdown/index.js +0 -20
- package/dist/Markdown-0f24de70.js +0 -62
- package/dist/Menu/index.js +0 -21
- package/dist/Menu-d6dd673e.js +0 -139
- package/dist/Modal/index.js +0 -26
- package/dist/Modal-067becad.js +0 -73
- package/dist/MultiSelect/index.js +0 -182
- package/dist/Option-a1dbc08a.js +0 -19
- package/dist/Page/index.js +0 -78
- package/dist/Popover/index.js +0 -65
- package/dist/ProgressBar/index.js +0 -12
- package/dist/ProgressBar-b68edc8f.js +0 -43
- package/dist/RadioGroup/index.js +0 -15
- package/dist/RadioGroup-678f4932.js +0 -46
- package/dist/RecurringSelect/index.js +0 -227
- package/dist/Select/index.js +0 -26
- package/dist/Spinner/index.js +0 -12
- package/dist/Spinner-9d8fc7ff.js +0 -24
- package/dist/StatusIndicator/index.js +0 -11
- package/dist/StatusIndicator-7b5258ea.js +0 -18
- package/dist/StatusLabel/index.js +0 -28
- package/dist/Switch/index.js +0 -13
- package/dist/Switch-eac89586.js +0 -56
- package/dist/Table/index.js +0 -66
- package/dist/Tabs/index.js +0 -80
- package/dist/Text/index.js +0 -13
- package/dist/Toast/index.js +0 -111
- package/dist/Tooltip/index.js +0 -17
- package/dist/Tooltip-b9de6e57.js +0 -114
- package/dist/Typography/index.js +0 -12
- package/dist/Typography-e2a23b7e.js +0 -62
- package/dist/style-inject.es-9d2f5f4e.js +0 -30
- package/dist/tslib.es6-754e2961.js +0 -46
- /package/{.eslintrc.js → .eslintrc.cjs} +0 -0
- /package/dist/{AtlantisContext-64608897.js → AtlantisContext-kZu_c9Er.js} +0 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export { I as InputTime } from '../InputTime-kqDNzoYY.js';
|
|
2
|
+
import '../tslib.es6-CQnq_FvL.js';
|
|
3
|
+
import 'react';
|
|
4
|
+
import '@std-proposal/temporal';
|
|
5
|
+
import '../debounce-DgeBwtKp.js';
|
|
6
|
+
import '../_commonjsHelpers-COf7qtKz.js';
|
|
7
|
+
import '../isObjectLike-CqUyaiWM.js';
|
|
8
|
+
import '../isSymbol-_Iyy_jRJ.js';
|
|
9
|
+
import '../FormField-CevGrDGm.js';
|
|
10
|
+
import 'react-hook-form';
|
|
11
|
+
import 'classnames';
|
|
12
|
+
import '../Button-Cfp4SFrN.js';
|
|
13
|
+
import 'react-router-dom';
|
|
14
|
+
import '../Icon-Cprfa6DH.js';
|
|
15
|
+
import '@jobber/design';
|
|
16
|
+
import '../Typography-D6YoQOGF.js';
|
|
17
|
+
import '../Text-DALHhxHl.js';
|
|
18
|
+
import '../InputValidation-D4MvsPKI.js';
|
|
19
|
+
import 'framer-motion';
|
|
20
|
+
import '../Spinner-gZOK7Pbk.js';
|
|
@@ -1,30 +1,10 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
var tslib_es6 = require('../tslib.es6-754e2961.js');
|
|
3
|
+
var tslib_es6 = require('./tslib.es6-v7P0Y776.js');
|
|
6
4
|
var React = require('react');
|
|
7
5
|
var temporal = require('@std-proposal/temporal');
|
|
8
|
-
var debounce = require('
|
|
9
|
-
var FormField = require('
|
|
10
|
-
require('react-hook-form');
|
|
11
|
-
require('../style-inject.es-9d2f5f4e.js');
|
|
12
|
-
require('classnames');
|
|
13
|
-
require('@jobber/hooks/useShowClear');
|
|
14
|
-
require('../Button-6b922fc1.js');
|
|
15
|
-
require('react-router-dom');
|
|
16
|
-
require('../Icon-405a216c.js');
|
|
17
|
-
require('@jobber/design');
|
|
18
|
-
require('../Typography-e2a23b7e.js');
|
|
19
|
-
require('../Text-fbeaaca6.js');
|
|
20
|
-
require('../InputValidation-a92bb519.js');
|
|
21
|
-
require('framer-motion');
|
|
22
|
-
require('../Spinner-9d8fc7ff.js');
|
|
23
|
-
|
|
24
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
25
|
-
|
|
26
|
-
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
27
|
-
var debounce__default = /*#__PURE__*/_interopDefaultLegacy(debounce);
|
|
6
|
+
var debounce = require('./debounce-DNEaQL1N.js');
|
|
7
|
+
var FormField = require('./FormField-DgvKr2RR.js');
|
|
28
8
|
|
|
29
9
|
function civilTimeToHTMLTime(civilTime) {
|
|
30
10
|
if (civilTime == undefined) {
|
|
@@ -46,7 +26,7 @@ const DEBOUNCE_TIME = 300;
|
|
|
46
26
|
function useTimePredict({ value, handleChange }) {
|
|
47
27
|
const [IS_12_HOUR_FORMAT, set12HourFormat] = React.useState(false);
|
|
48
28
|
const [typedTime, setTypedTime] = React.useState("");
|
|
49
|
-
const predictTime = React.useCallback(
|
|
29
|
+
const predictTime = React.useCallback(debounce.debounce(() => {
|
|
50
30
|
if (value)
|
|
51
31
|
return;
|
|
52
32
|
handleChange(predictHours(typedTime, IS_12_HOUR_FORMAT));
|
|
@@ -188,7 +168,7 @@ function InputTime(_a) {
|
|
|
188
168
|
const ref = React.useRef(null);
|
|
189
169
|
const { setTypedTime } = useTimePredict({ value, handleChange });
|
|
190
170
|
const fieldProps = Object.assign(Object.assign(Object.assign({ onChange: handleChange }, (defaultValue && { defaultValue: civilTimeToHTMLTime(defaultValue) })), (!defaultValue && { value: civilTimeToHTMLTime(value) })), params);
|
|
191
|
-
return (
|
|
171
|
+
return (React.createElement(FormField.FormField, Object.assign({ inputRef: ref, type: "time" }, fieldProps, { onBlur: handleBlur, onKeyUp: e => {
|
|
192
172
|
var _a;
|
|
193
173
|
(_a = fieldProps.onKeyUp) === null || _a === void 0 ? void 0 : _a.call(fieldProps, e);
|
|
194
174
|
!isNaN(parseInt(e.key, 10)) && setTypedTime(prev => prev + e.key);
|
|
@@ -0,0 +1,190 @@
|
|
|
1
|
+
import { _ as __rest } from './tslib.es6-CQnq_FvL.js';
|
|
2
|
+
import React, { useState, useCallback, useEffect, useRef } from 'react';
|
|
3
|
+
import { CivilTime } from '@std-proposal/temporal';
|
|
4
|
+
import { d as debounce } from './debounce-DgeBwtKp.js';
|
|
5
|
+
import { F as FormField } from './FormField-CevGrDGm.js';
|
|
6
|
+
|
|
7
|
+
function civilTimeToHTMLTime(civilTime) {
|
|
8
|
+
if (civilTime == undefined) {
|
|
9
|
+
return "";
|
|
10
|
+
}
|
|
11
|
+
const timeString = civilTime.toString();
|
|
12
|
+
return timeString.slice(0, 5);
|
|
13
|
+
}
|
|
14
|
+
function htmlTimeToCivilTime(timeString) {
|
|
15
|
+
try {
|
|
16
|
+
return CivilTime.fromString(timeString + ":00.000000000");
|
|
17
|
+
}
|
|
18
|
+
catch (_a) {
|
|
19
|
+
return undefined;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const DEBOUNCE_TIME = 300;
|
|
24
|
+
function useTimePredict({ value, handleChange }) {
|
|
25
|
+
const [IS_12_HOUR_FORMAT, set12HourFormat] = useState(false);
|
|
26
|
+
const [typedTime, setTypedTime] = useState("");
|
|
27
|
+
const predictTime = useCallback(debounce(() => {
|
|
28
|
+
if (value)
|
|
29
|
+
return;
|
|
30
|
+
handleChange(predictHours(typedTime, IS_12_HOUR_FORMAT));
|
|
31
|
+
}, DEBOUNCE_TIME), [typedTime, value, handleChange, IS_12_HOUR_FORMAT]);
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
set12HourFormat(Boolean(Intl.DateTimeFormat(navigator.language, {
|
|
34
|
+
hour: "numeric",
|
|
35
|
+
}).resolvedOptions().hour12));
|
|
36
|
+
}, []);
|
|
37
|
+
/**
|
|
38
|
+
* Predict the hour when user types a number
|
|
39
|
+
*/
|
|
40
|
+
useEffect(() => {
|
|
41
|
+
/**
|
|
42
|
+
* Don't try to predict if the user types 0 as the user would almost always
|
|
43
|
+
* type another number after 0.
|
|
44
|
+
*/
|
|
45
|
+
if (typedTime && typedTime !== "0") {
|
|
46
|
+
predictTime();
|
|
47
|
+
if ((IS_12_HOUR_FORMAT && typedTime !== "1") || typedTime.length === 2) {
|
|
48
|
+
// Immediately predict the hour
|
|
49
|
+
predictTime.flush();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return predictTime.cancel;
|
|
53
|
+
}, [typedTime]);
|
|
54
|
+
/**
|
|
55
|
+
* Reset typed time when the value changed
|
|
56
|
+
*/
|
|
57
|
+
useEffect(() => {
|
|
58
|
+
setTypedTime("");
|
|
59
|
+
}, [value]);
|
|
60
|
+
return {
|
|
61
|
+
setTypedTime,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
function predictHours(time, is12HourFormat = false) {
|
|
65
|
+
const today = new Date();
|
|
66
|
+
const currentHour = today.getHours();
|
|
67
|
+
const parsedTime = parseInt(time, 10);
|
|
68
|
+
let predictedTime;
|
|
69
|
+
if (is12HourFormat) {
|
|
70
|
+
predictedTime = predict12Hours(parsedTime, currentHour);
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
predictedTime = predict24Hours(time, parsedTime, currentHour);
|
|
74
|
+
}
|
|
75
|
+
return formatHour(predictedTime);
|
|
76
|
+
}
|
|
77
|
+
function predict12Hours(parsedTime, currentHour) {
|
|
78
|
+
/**
|
|
79
|
+
* We need to predict what the user wants when they type 1 since it could be
|
|
80
|
+
* 10, 11, 12, or 1.
|
|
81
|
+
*
|
|
82
|
+
* If the current hour is over 12PM, we can skip this and go to the next logic.
|
|
83
|
+
*/
|
|
84
|
+
if (parsedTime === 1 && currentHour < 12) {
|
|
85
|
+
if (currentHour < 10) {
|
|
86
|
+
return 10;
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
return currentHour + 1;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Typing 1-5 predicts that the user want that exact hour on the afternoon.
|
|
94
|
+
*/
|
|
95
|
+
if (parsedTime <= 5) {
|
|
96
|
+
return parsedTime + 12;
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Typing 13-15 predicts that the user want the 2nd number as the minute interval.
|
|
100
|
+
*/
|
|
101
|
+
if (parsedTime > 12 && parsedTime <= 15) {
|
|
102
|
+
const timeArray = parsedTime.toString().split("").map(Number); // 13 -> [1, 3]
|
|
103
|
+
const convertToHoursAndMinutes = timeArray.map((time, i) => {
|
|
104
|
+
if (i === 0)
|
|
105
|
+
return time + 12; // 1 -> 13 as 1PM
|
|
106
|
+
if (i === 1)
|
|
107
|
+
return time * 10; // 3 -> 30 as 30 minutes
|
|
108
|
+
});
|
|
109
|
+
return Number(convertToHoursAndMinutes.join("")); // [13, 30] -> 1330
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Anything after 5 will be predicted to be set as AM.
|
|
113
|
+
*/
|
|
114
|
+
return parsedTime;
|
|
115
|
+
}
|
|
116
|
+
function predict24Hours(time, parsedTime, currentHour) {
|
|
117
|
+
/**
|
|
118
|
+
* Typing 1 could be predicted from 10 to 19.
|
|
119
|
+
* Typing 01 skips this logic and sets the time to 01:00.
|
|
120
|
+
*/
|
|
121
|
+
if (parsedTime === 1 && time !== "01") {
|
|
122
|
+
if (currentHour < 10 || currentHour > 19) {
|
|
123
|
+
return 10;
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
return currentHour + 1;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Typing 2 could be predicted from 20 to 24.
|
|
131
|
+
* Typing 02 skips this logic and sets the time to 02:00.
|
|
132
|
+
*/
|
|
133
|
+
if (parsedTime === 2 && time !== "02") {
|
|
134
|
+
if (currentHour < 20) {
|
|
135
|
+
return 20;
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
return currentHour + 1;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Typing 24 or 00 is set to midnight. This ensures the time doesn't get set
|
|
143
|
+
* to 24 as that would be invalid.
|
|
144
|
+
*/
|
|
145
|
+
if (parsedTime === 24 || time === "00") {
|
|
146
|
+
return 0;
|
|
147
|
+
}
|
|
148
|
+
return parsedTime;
|
|
149
|
+
}
|
|
150
|
+
function formatHour(time) {
|
|
151
|
+
if (time > 99) {
|
|
152
|
+
const splitTime = time.toString().split("");
|
|
153
|
+
if (splitTime.length === 3)
|
|
154
|
+
splitTime.unshift("0"); // 130 -> 0130
|
|
155
|
+
splitTime.splice(2, 0, ":"); // 0130 -> 01:30
|
|
156
|
+
return splitTime.join("");
|
|
157
|
+
}
|
|
158
|
+
if (time < 10) {
|
|
159
|
+
return `0${time}:00`;
|
|
160
|
+
}
|
|
161
|
+
return `${time}:00`;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
function InputTime(_a) {
|
|
165
|
+
var { defaultValue, value, onChange } = _a, params = __rest(_a, ["defaultValue", "value", "onChange"]);
|
|
166
|
+
const ref = useRef(null);
|
|
167
|
+
const { setTypedTime } = useTimePredict({ value, handleChange });
|
|
168
|
+
const fieldProps = Object.assign(Object.assign(Object.assign({ onChange: handleChange }, (defaultValue && { defaultValue: civilTimeToHTMLTime(defaultValue) })), (!defaultValue && { value: civilTimeToHTMLTime(value) })), params);
|
|
169
|
+
return (React.createElement(FormField, Object.assign({ inputRef: ref, type: "time" }, fieldProps, { onBlur: handleBlur, onKeyUp: e => {
|
|
170
|
+
var _a;
|
|
171
|
+
(_a = fieldProps.onKeyUp) === null || _a === void 0 ? void 0 : _a.call(fieldProps, e);
|
|
172
|
+
!isNaN(parseInt(e.key, 10)) && setTypedTime(prev => prev + e.key);
|
|
173
|
+
} })));
|
|
174
|
+
function handleChange(newValue) {
|
|
175
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(htmlTimeToCivilTime(newValue));
|
|
176
|
+
}
|
|
177
|
+
function handleBlur() {
|
|
178
|
+
var _a;
|
|
179
|
+
(_a = params.onBlur) === null || _a === void 0 ? void 0 : _a.call(params);
|
|
180
|
+
// Time inputs doesn't clear the typed value when it's invalid. This should
|
|
181
|
+
// force it to reset the input value when the typed value is invalid.
|
|
182
|
+
if (ref.current) {
|
|
183
|
+
if (!ref.current.checkValidity()) {
|
|
184
|
+
ref.current.value = "";
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
export { InputTime as I };
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var InputValidation = require('../InputValidation-CA3D4HMZ.js');
|
|
4
|
+
require('react');
|
|
5
|
+
require('framer-motion');
|
|
6
|
+
require('../Text-Bopx9dUr.js');
|
|
7
|
+
require('../Typography-WLLQxuNl.js');
|
|
8
|
+
require('classnames');
|
|
9
|
+
require('../Icon-DN6zZdoZ.js');
|
|
10
|
+
require('@jobber/design');
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
exports.InputValidation = InputValidation.InputValidation;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { I as InputValidation } from '../InputValidation-D4MvsPKI.js';
|
|
2
|
+
import 'react';
|
|
3
|
+
import 'framer-motion';
|
|
4
|
+
import '../Text-DALHhxHl.js';
|
|
5
|
+
import '../Typography-D6YoQOGF.js';
|
|
6
|
+
import 'classnames';
|
|
7
|
+
import '../Icon-Cprfa6DH.js';
|
|
8
|
+
import '@jobber/design';
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var framerMotion = require('framer-motion');
|
|
5
|
+
var Text = require('./Text-Bopx9dUr.js');
|
|
6
|
+
var Icon = require('./Icon-DN6zZdoZ.js');
|
|
7
|
+
|
|
8
|
+
var styles = {"hasValidationMessage":"sc-bFJieXBA-","message":"xybhC5Y6mk4-"};
|
|
9
|
+
|
|
10
|
+
function InputValidation({ message }) {
|
|
11
|
+
const messages = [message];
|
|
12
|
+
const variants = {
|
|
13
|
+
slideOut: { y: "5%", opacity: 0 },
|
|
14
|
+
slideIn: { y: 0, opacity: 1 },
|
|
15
|
+
};
|
|
16
|
+
return (React.createElement(React.Fragment, null, messages && messages.length > 0 && (React.createElement(framerMotion.AnimatePresence, { mode: "wait" }, messages.map(msg => (React.createElement(framerMotion.motion.div, { key: `validation-${msg}`, variants: variants, initial: "slideOut", animate: "slideIn", exit: "slideOut", transition: { duration: 0.2 } },
|
|
17
|
+
React.createElement("div", { className: styles.message, "aria-live": "assertive", role: "alert", tabIndex: 0 },
|
|
18
|
+
React.createElement(Icon.Icon, { name: "alert", size: "small", color: "critical" }),
|
|
19
|
+
React.createElement(Text.Text, { size: "small", variation: "error" }, msg)))))))));
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
exports.InputValidation = InputValidation;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { AnimatePresence, motion } from 'framer-motion';
|
|
3
|
+
import { T as Text } from './Text-DALHhxHl.js';
|
|
4
|
+
import { I as Icon } from './Icon-Cprfa6DH.js';
|
|
5
|
+
|
|
6
|
+
var styles = {"hasValidationMessage":"sc-bFJieXBA-","message":"xybhC5Y6mk4-"};
|
|
7
|
+
|
|
8
|
+
function InputValidation({ message }) {
|
|
9
|
+
const messages = [message];
|
|
10
|
+
const variants = {
|
|
11
|
+
slideOut: { y: "5%", opacity: 0 },
|
|
12
|
+
slideIn: { y: 0, opacity: 1 },
|
|
13
|
+
};
|
|
14
|
+
return (React.createElement(React.Fragment, null, messages && messages.length > 0 && (React.createElement(AnimatePresence, { mode: "wait" }, messages.map(msg => (React.createElement(motion.div, { key: `validation-${msg}`, variants: variants, initial: "slideOut", animate: "slideIn", exit: "slideOut", transition: { duration: 0.2 } },
|
|
15
|
+
React.createElement("div", { className: styles.message, "aria-live": "assertive", role: "alert", tabIndex: 0 },
|
|
16
|
+
React.createElement(Icon, { name: "alert", size: "small", color: "critical" }),
|
|
17
|
+
React.createElement(Text, { size: "small", variation: "error" }, msg)))))))));
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export { InputValidation as I };
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import React, { useRef, useState, useEffect } from 'react';
|
|
2
|
+
import { a as useInternalChipDismissibleInput, d as useScrollToActive, b as useInView, c as useRepositionMenu, u as useInternalChipDismissible } from './useScrollToActive-AgUIt0XS.js';
|
|
3
|
+
import './isObjectLike-CqUyaiWM.js';
|
|
4
|
+
import '@jobber/design';
|
|
5
|
+
import 'react-popper';
|
|
6
|
+
import { d as debounce } from './debounce-DgeBwtKp.js';
|
|
7
|
+
import classnames from 'classnames';
|
|
8
|
+
import { T as Text } from './Text-DALHhxHl.js';
|
|
9
|
+
import { B as Button } from './Button-Cfp4SFrN.js';
|
|
10
|
+
import { S as Spinner } from './Spinner-gZOK7Pbk.js';
|
|
11
|
+
import { u as useAssert_2 } from './useAssert-BRTg70rg.js';
|
|
12
|
+
import { I as Icon } from './Icon-Cprfa6DH.js';
|
|
13
|
+
import { A as Avatar } from './Avatar-Q8rB73I2.js';
|
|
14
|
+
import { T as Typography } from './Typography-D6YoQOGF.js';
|
|
15
|
+
import { T as Tooltip } from './Tooltip-B2DBKrJM.js';
|
|
16
|
+
|
|
17
|
+
var styles$1 = {"wrapper":"zn6onyiQVmA-","chip":"PEnZzMEgbhU-","hasPrefix":"dtysUhwYdG4-","hasSuffix":"xGaMCAYsdwA-","clickable":"SNT7gGV-h-o-","input":"W4D98cvEth4-","active":"_0hEzaTXK9M0-","invalid":"JApS2787BU8-","disabled":"Kg0c8WVgMpg-","button":"_0-ZWexS4Gfg-","icon":"DQPnZP4UZpw-"};
|
|
18
|
+
|
|
19
|
+
function InternalChipButton({ icon, invalid, disabled, label, onClick, }) {
|
|
20
|
+
const buttonRef = useRef();
|
|
21
|
+
return (React.createElement("div", { ref: buttonRef, className: styles$1.button, tabIndex: 0, onKeyUp: handleKeyUp, onKeyDown: handleKeyDown, onClick: handleClick, role: "button", "aria-label": `Remove ${label}`, "aria-hidden": true, "aria-disabled": disabled, "data-testid": "remove-chip-button" },
|
|
22
|
+
React.createElement(Icon, { name: icon, color: getColor() })));
|
|
23
|
+
function handleKeyUp(event) {
|
|
24
|
+
if (document.activeElement === buttonRef.current &&
|
|
25
|
+
(event.key === " " || event.key === "Enter")) {
|
|
26
|
+
event.stopPropagation();
|
|
27
|
+
buttonRef.current.click();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
function handleKeyDown(event) {
|
|
31
|
+
if (document.activeElement === buttonRef.current && event.key === " ") {
|
|
32
|
+
// Don't scroll down
|
|
33
|
+
event.preventDefault();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
function getColor() {
|
|
37
|
+
if (disabled)
|
|
38
|
+
return "disabled";
|
|
39
|
+
if (invalid)
|
|
40
|
+
return "critical";
|
|
41
|
+
return "greyBlue";
|
|
42
|
+
}
|
|
43
|
+
function handleClick(event) {
|
|
44
|
+
event.stopPropagation();
|
|
45
|
+
onClick === null || onClick === void 0 ? void 0 : onClick(event);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
function InternalChipAffix({ affix, active, invalid, disabled, }) {
|
|
50
|
+
assertProps();
|
|
51
|
+
if ((affix === null || affix === void 0 ? void 0 : affix.type) === Avatar) {
|
|
52
|
+
return React.createElement(Avatar, Object.assign({}, affix.props, { size: "small" }));
|
|
53
|
+
}
|
|
54
|
+
if ((affix === null || affix === void 0 ? void 0 : affix.type) === Icon) {
|
|
55
|
+
return renderChipIcon(affix);
|
|
56
|
+
}
|
|
57
|
+
if ((affix === null || affix === void 0 ? void 0 : affix.type) === InternalChipButton) {
|
|
58
|
+
return React.createElement(InternalChipButton, Object.assign({}, affix.props));
|
|
59
|
+
}
|
|
60
|
+
return React.createElement(React.Fragment, null);
|
|
61
|
+
function renderChipIcon(icon) {
|
|
62
|
+
const color = getIconColor();
|
|
63
|
+
return (React.createElement("div", { className: styles$1.icon }, React.cloneElement(icon, Object.assign({ size: "base" }, (color && { color: color })))));
|
|
64
|
+
}
|
|
65
|
+
function getIconColor() {
|
|
66
|
+
if (disabled && !active)
|
|
67
|
+
return "disabled";
|
|
68
|
+
if (invalid && !disabled)
|
|
69
|
+
return "critical";
|
|
70
|
+
if (active)
|
|
71
|
+
return "white";
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
function assertProps() {
|
|
75
|
+
const isAvatar = (affix === null || affix === void 0 ? void 0 : affix.type) === Avatar || false;
|
|
76
|
+
const isIcon = (affix === null || affix === void 0 ? void 0 : affix.type) === Icon || false;
|
|
77
|
+
const isChipButton = (affix === null || affix === void 0 ? void 0 : affix.type) === InternalChipButton || false;
|
|
78
|
+
useAssert_2(!!affix && !(isAvatar || isIcon || isChipButton), `Prefix prop only accepts "<Avatar />" or "<Icon />" component. You have "${affix === null || affix === void 0 ? void 0 : affix.type}".`);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
function InternalChip({ label, active = false, disabled = false, invalid = false, prefix, suffix, tabIndex, ariaLabel, onClick, onKeyDown, }) {
|
|
83
|
+
const [truncateRef, setTruncateRef] = useState();
|
|
84
|
+
const isClickable = onClick && !disabled;
|
|
85
|
+
const classNames = classnames(styles$1.chip, {
|
|
86
|
+
[styles$1.clickable]: isClickable,
|
|
87
|
+
[styles$1.active]: active,
|
|
88
|
+
[styles$1.disabled]: disabled,
|
|
89
|
+
[styles$1.invalid]: invalid,
|
|
90
|
+
[styles$1.hasPrefix]: prefix,
|
|
91
|
+
[styles$1.hasSuffix]: suffix,
|
|
92
|
+
});
|
|
93
|
+
const affixProps = { active, invalid, disabled };
|
|
94
|
+
const Tag = onClick ? "button" : "div";
|
|
95
|
+
const chip = (React.createElement(Tag, Object.assign({ className: classNames }, (isClickable && { onClick, disabled }), { onKeyDown: onKeyDown, "data-testid": "chip-wrapper", "aria-label": ariaLabel, tabIndex: tabIndex, role: tabIndex !== undefined ? "option" : undefined }),
|
|
96
|
+
React.createElement(InternalChipAffix, Object.assign({ affix: prefix }, affixProps)),
|
|
97
|
+
React.createElement(Typography, { element: "span", numberOfLines: 1, size: "base" },
|
|
98
|
+
React.createElement("span", { ref: setTruncateRef }, label)),
|
|
99
|
+
React.createElement(InternalChipAffix, Object.assign({ affix: suffix }, affixProps))));
|
|
100
|
+
return isTruncated() ? React.createElement(Tooltip, { message: label }, chip) : chip;
|
|
101
|
+
function isTruncated() {
|
|
102
|
+
var _a;
|
|
103
|
+
const truncateParentHeight = ((_a = truncateRef === null || truncateRef === void 0 ? void 0 : truncateRef.parentElement) === null || _a === void 0 ? void 0 : _a.offsetHeight) || 0;
|
|
104
|
+
const truncateChildHeight = (truncateRef === null || truncateRef === void 0 ? void 0 : truncateRef.offsetHeight) || 0;
|
|
105
|
+
return truncateChildHeight >= truncateParentHeight * 2;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
var styles = {"wrapper":"sCNIjluCskc-","input":"MFUlz1WQLdk-","menu":"V9eYJdjPAeY-","menuList":"LdytkOeCU9c-","menuListOption":"y7Cz2u8BuNE-","loadingIndicator":"_-7bmao8Q9As-","activeOption":"iCwWdcmtInc-"};
|
|
110
|
+
|
|
111
|
+
function InternalChipDismissibleInput(props) {
|
|
112
|
+
const { activator = React.createElement(Button, { icon: "add", type: "secondary", ariaLabel: "Add" }), attachTo, isLoadingMore = false, onLoadMore, } = props;
|
|
113
|
+
const { activeIndex, allOptions, hasAvailableOptions, inputRef, menuId, menuOpen, searchValue, generateDescendantId, handleBlur, handleOpenMenu, handleSearchChange, handleCancelBlur, handleEnableBlur, handleSetActiveOnMouseOver, handleKeyDown, handleSelectOption, handleDebouncedSearch, } = useInternalChipDismissibleInput(props);
|
|
114
|
+
const menuRef = useScrollToActive(activeIndex);
|
|
115
|
+
const { ref: visibleChildRef, isInView } = useInView();
|
|
116
|
+
const { styles: popperStyles, attributes, update, setPositionedElementRef, } = useRepositionMenu(attachTo);
|
|
117
|
+
useEffect(() => {
|
|
118
|
+
if (menuOpen && update)
|
|
119
|
+
update();
|
|
120
|
+
}, [allOptions]);
|
|
121
|
+
useEffect(() => {
|
|
122
|
+
handleDebouncedSearch();
|
|
123
|
+
return handleDebouncedSearch.cancel;
|
|
124
|
+
}, [searchValue]);
|
|
125
|
+
useEffect(() => {
|
|
126
|
+
isInView && onLoadMore && onLoadMore(searchValue);
|
|
127
|
+
}, [isInView]);
|
|
128
|
+
if (!menuOpen) {
|
|
129
|
+
return React.cloneElement(activator, { onClick: handleOpenMenu });
|
|
130
|
+
}
|
|
131
|
+
return (React.createElement(React.Fragment, null,
|
|
132
|
+
React.createElement("input", { ref: inputRef, className: styles.input, type: "text", role: "combobox", "aria-label": "Press up and down arrow to cycle through the options or type to narrow down the results", "aria-autocomplete": "list", "aria-owns": menuId, "aria-expanded": hasAvailableOptions, "aria-activedescendant": generateDescendantId(activeIndex), value: searchValue, onChange: handleSearchChange, onKeyDown: handleKeyDown, onBlur: debounce(handleBlur, 200), onFocus: handleOpenMenu, autoFocus: true }),
|
|
133
|
+
(hasAvailableOptions || isLoadingMore) && (React.createElement("div", Object.assign({ ref: setPositionedElementRef, className: styles.menu, style: popperStyles.popper }, attributes.popper),
|
|
134
|
+
React.createElement("div", { ref: menuRef, role: "listbox", id: menuId, className: styles.menuList, "data-testid": "chip-menu" },
|
|
135
|
+
allOptions.map((option, i) => (React.createElement("button", { key: option.value, role: "option", type: "button", id: generateDescendantId(i), className: classnames(styles.menuListOption, {
|
|
136
|
+
[styles.activeOption]: activeIndex === i,
|
|
137
|
+
}), onClick: () => handleSelectOption(option), onMouseEnter: handleSetActiveOnMouseOver(i), onMouseDown: handleCancelBlur, onMouseUp: handleEnableBlur },
|
|
138
|
+
React.createElement("span", { "aria-hidden": true }, option.prefix),
|
|
139
|
+
React.createElement(Text, null, option.label)))),
|
|
140
|
+
React.createElement("div", { ref: visibleChildRef }),
|
|
141
|
+
isLoadingMore && (React.createElement("div", { className: styles.loadingIndicator },
|
|
142
|
+
React.createElement(Spinner, { size: "small", inline: true }))))))));
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
function InternalChipDismissible(props) {
|
|
146
|
+
const { availableChipOptions, ref: wrapperRef, sortedVisibleChipOptions, handleChipAdd, handleChipClick, handleChipKeyDown, handleChipRemove, handleCustomAdd, handleWrapperKeyDown, } = useInternalChipDismissible(props);
|
|
147
|
+
return (React.createElement("div", { ref: wrapperRef, className: styles.wrapper, "data-testid": "dismissible-chips", onKeyDown: handleWrapperKeyDown, role: "listbox" },
|
|
148
|
+
sortedVisibleChipOptions.map(chip => (React.createElement(InternalChip, Object.assign({ key: chip.value }, chip, { onKeyDown: handleChipKeyDown(chip.value), onClick: handleChipClick(chip.value), ariaLabel: `${chip.label}. Press delete or backspace to remove ${chip.label}`, tabIndex: 0, suffix: React.createElement(InternalChipButton, { icon: "remove", invalid: chip.invalid, disabled: chip.disabled, label: chip.label, onClick: handleChipRemove(chip.value) }) })))),
|
|
149
|
+
React.createElement(InternalChipDismissibleInput, { activator: props.activator, attachTo: wrapperRef, isLoadingMore: props.isLoadingMore, options: availableChipOptions, onOptionSelect: handleChipAdd, onCustomOptionSelect: handleCustomAdd, onSearch: props.onSearch, onLoadMore: props.onLoadMore })));
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
export { InternalChipDismissible as I, InternalChip as a, InternalChipButton as b, styles$1 as s };
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var useScrollToActive = require('./useScrollToActive-D4MUBncA.js');
|
|
5
|
+
require('./isObjectLike-BLBufvwS.js');
|
|
6
|
+
require('@jobber/design');
|
|
7
|
+
require('react-popper');
|
|
8
|
+
var debounce = require('./debounce-DNEaQL1N.js');
|
|
9
|
+
var classnames = require('classnames');
|
|
10
|
+
var Text = require('./Text-Bopx9dUr.js');
|
|
11
|
+
var Button = require('./Button-C6SHw1kI.js');
|
|
12
|
+
var Spinner = require('./Spinner-L0bWOO6S.js');
|
|
13
|
+
var useAssert = require('./useAssert--FSFxEub.js');
|
|
14
|
+
var Icon = require('./Icon-DN6zZdoZ.js');
|
|
15
|
+
var Avatar = require('./Avatar-NVE7Yqd4.js');
|
|
16
|
+
var Typography = require('./Typography-WLLQxuNl.js');
|
|
17
|
+
var Tooltip = require('./Tooltip-VHTRuZ4Y.js');
|
|
18
|
+
|
|
19
|
+
var styles$1 = {"wrapper":"zn6onyiQVmA-","chip":"PEnZzMEgbhU-","hasPrefix":"dtysUhwYdG4-","hasSuffix":"xGaMCAYsdwA-","clickable":"SNT7gGV-h-o-","input":"W4D98cvEth4-","active":"_0hEzaTXK9M0-","invalid":"JApS2787BU8-","disabled":"Kg0c8WVgMpg-","button":"_0-ZWexS4Gfg-","icon":"DQPnZP4UZpw-"};
|
|
20
|
+
|
|
21
|
+
function InternalChipButton({ icon, invalid, disabled, label, onClick, }) {
|
|
22
|
+
const buttonRef = React.useRef();
|
|
23
|
+
return (React.createElement("div", { ref: buttonRef, className: styles$1.button, tabIndex: 0, onKeyUp: handleKeyUp, onKeyDown: handleKeyDown, onClick: handleClick, role: "button", "aria-label": `Remove ${label}`, "aria-hidden": true, "aria-disabled": disabled, "data-testid": "remove-chip-button" },
|
|
24
|
+
React.createElement(Icon.Icon, { name: icon, color: getColor() })));
|
|
25
|
+
function handleKeyUp(event) {
|
|
26
|
+
if (document.activeElement === buttonRef.current &&
|
|
27
|
+
(event.key === " " || event.key === "Enter")) {
|
|
28
|
+
event.stopPropagation();
|
|
29
|
+
buttonRef.current.click();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
function handleKeyDown(event) {
|
|
33
|
+
if (document.activeElement === buttonRef.current && event.key === " ") {
|
|
34
|
+
// Don't scroll down
|
|
35
|
+
event.preventDefault();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
function getColor() {
|
|
39
|
+
if (disabled)
|
|
40
|
+
return "disabled";
|
|
41
|
+
if (invalid)
|
|
42
|
+
return "critical";
|
|
43
|
+
return "greyBlue";
|
|
44
|
+
}
|
|
45
|
+
function handleClick(event) {
|
|
46
|
+
event.stopPropagation();
|
|
47
|
+
onClick === null || onClick === void 0 ? void 0 : onClick(event);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function InternalChipAffix({ affix, active, invalid, disabled, }) {
|
|
52
|
+
assertProps();
|
|
53
|
+
if ((affix === null || affix === void 0 ? void 0 : affix.type) === Avatar.Avatar) {
|
|
54
|
+
return React.createElement(Avatar.Avatar, Object.assign({}, affix.props, { size: "small" }));
|
|
55
|
+
}
|
|
56
|
+
if ((affix === null || affix === void 0 ? void 0 : affix.type) === Icon.Icon) {
|
|
57
|
+
return renderChipIcon(affix);
|
|
58
|
+
}
|
|
59
|
+
if ((affix === null || affix === void 0 ? void 0 : affix.type) === InternalChipButton) {
|
|
60
|
+
return React.createElement(InternalChipButton, Object.assign({}, affix.props));
|
|
61
|
+
}
|
|
62
|
+
return React.createElement(React.Fragment, null);
|
|
63
|
+
function renderChipIcon(icon) {
|
|
64
|
+
const color = getIconColor();
|
|
65
|
+
return (React.createElement("div", { className: styles$1.icon }, React.cloneElement(icon, Object.assign({ size: "base" }, (color && { color: color })))));
|
|
66
|
+
}
|
|
67
|
+
function getIconColor() {
|
|
68
|
+
if (disabled && !active)
|
|
69
|
+
return "disabled";
|
|
70
|
+
if (invalid && !disabled)
|
|
71
|
+
return "critical";
|
|
72
|
+
if (active)
|
|
73
|
+
return "white";
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
function assertProps() {
|
|
77
|
+
const isAvatar = (affix === null || affix === void 0 ? void 0 : affix.type) === Avatar.Avatar || false;
|
|
78
|
+
const isIcon = (affix === null || affix === void 0 ? void 0 : affix.type) === Icon.Icon || false;
|
|
79
|
+
const isChipButton = (affix === null || affix === void 0 ? void 0 : affix.type) === InternalChipButton || false;
|
|
80
|
+
useAssert.useAssert_2(!!affix && !(isAvatar || isIcon || isChipButton), `Prefix prop only accepts "<Avatar />" or "<Icon />" component. You have "${affix === null || affix === void 0 ? void 0 : affix.type}".`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
function InternalChip({ label, active = false, disabled = false, invalid = false, prefix, suffix, tabIndex, ariaLabel, onClick, onKeyDown, }) {
|
|
85
|
+
const [truncateRef, setTruncateRef] = React.useState();
|
|
86
|
+
const isClickable = onClick && !disabled;
|
|
87
|
+
const classNames = classnames(styles$1.chip, {
|
|
88
|
+
[styles$1.clickable]: isClickable,
|
|
89
|
+
[styles$1.active]: active,
|
|
90
|
+
[styles$1.disabled]: disabled,
|
|
91
|
+
[styles$1.invalid]: invalid,
|
|
92
|
+
[styles$1.hasPrefix]: prefix,
|
|
93
|
+
[styles$1.hasSuffix]: suffix,
|
|
94
|
+
});
|
|
95
|
+
const affixProps = { active, invalid, disabled };
|
|
96
|
+
const Tag = onClick ? "button" : "div";
|
|
97
|
+
const chip = (React.createElement(Tag, Object.assign({ className: classNames }, (isClickable && { onClick, disabled }), { onKeyDown: onKeyDown, "data-testid": "chip-wrapper", "aria-label": ariaLabel, tabIndex: tabIndex, role: tabIndex !== undefined ? "option" : undefined }),
|
|
98
|
+
React.createElement(InternalChipAffix, Object.assign({ affix: prefix }, affixProps)),
|
|
99
|
+
React.createElement(Typography.Typography, { element: "span", numberOfLines: 1, size: "base" },
|
|
100
|
+
React.createElement("span", { ref: setTruncateRef }, label)),
|
|
101
|
+
React.createElement(InternalChipAffix, Object.assign({ affix: suffix }, affixProps))));
|
|
102
|
+
return isTruncated() ? React.createElement(Tooltip.Tooltip, { message: label }, chip) : chip;
|
|
103
|
+
function isTruncated() {
|
|
104
|
+
var _a;
|
|
105
|
+
const truncateParentHeight = ((_a = truncateRef === null || truncateRef === void 0 ? void 0 : truncateRef.parentElement) === null || _a === void 0 ? void 0 : _a.offsetHeight) || 0;
|
|
106
|
+
const truncateChildHeight = (truncateRef === null || truncateRef === void 0 ? void 0 : truncateRef.offsetHeight) || 0;
|
|
107
|
+
return truncateChildHeight >= truncateParentHeight * 2;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
var styles = {"wrapper":"sCNIjluCskc-","input":"MFUlz1WQLdk-","menu":"V9eYJdjPAeY-","menuList":"LdytkOeCU9c-","menuListOption":"y7Cz2u8BuNE-","loadingIndicator":"_-7bmao8Q9As-","activeOption":"iCwWdcmtInc-"};
|
|
112
|
+
|
|
113
|
+
function InternalChipDismissibleInput(props) {
|
|
114
|
+
const { activator = React.createElement(Button.Button, { icon: "add", type: "secondary", ariaLabel: "Add" }), attachTo, isLoadingMore = false, onLoadMore, } = props;
|
|
115
|
+
const { activeIndex, allOptions, hasAvailableOptions, inputRef, menuId, menuOpen, searchValue, generateDescendantId, handleBlur, handleOpenMenu, handleSearchChange, handleCancelBlur, handleEnableBlur, handleSetActiveOnMouseOver, handleKeyDown, handleSelectOption, handleDebouncedSearch, } = useScrollToActive.useInternalChipDismissibleInput(props);
|
|
116
|
+
const menuRef = useScrollToActive.useScrollToActive(activeIndex);
|
|
117
|
+
const { ref: visibleChildRef, isInView } = useScrollToActive.useInView();
|
|
118
|
+
const { styles: popperStyles, attributes, update, setPositionedElementRef, } = useScrollToActive.useRepositionMenu(attachTo);
|
|
119
|
+
React.useEffect(() => {
|
|
120
|
+
if (menuOpen && update)
|
|
121
|
+
update();
|
|
122
|
+
}, [allOptions]);
|
|
123
|
+
React.useEffect(() => {
|
|
124
|
+
handleDebouncedSearch();
|
|
125
|
+
return handleDebouncedSearch.cancel;
|
|
126
|
+
}, [searchValue]);
|
|
127
|
+
React.useEffect(() => {
|
|
128
|
+
isInView && onLoadMore && onLoadMore(searchValue);
|
|
129
|
+
}, [isInView]);
|
|
130
|
+
if (!menuOpen) {
|
|
131
|
+
return React.cloneElement(activator, { onClick: handleOpenMenu });
|
|
132
|
+
}
|
|
133
|
+
return (React.createElement(React.Fragment, null,
|
|
134
|
+
React.createElement("input", { ref: inputRef, className: styles.input, type: "text", role: "combobox", "aria-label": "Press up and down arrow to cycle through the options or type to narrow down the results", "aria-autocomplete": "list", "aria-owns": menuId, "aria-expanded": hasAvailableOptions, "aria-activedescendant": generateDescendantId(activeIndex), value: searchValue, onChange: handleSearchChange, onKeyDown: handleKeyDown, onBlur: debounce.debounce(handleBlur, 200), onFocus: handleOpenMenu, autoFocus: true }),
|
|
135
|
+
(hasAvailableOptions || isLoadingMore) && (React.createElement("div", Object.assign({ ref: setPositionedElementRef, className: styles.menu, style: popperStyles.popper }, attributes.popper),
|
|
136
|
+
React.createElement("div", { ref: menuRef, role: "listbox", id: menuId, className: styles.menuList, "data-testid": "chip-menu" },
|
|
137
|
+
allOptions.map((option, i) => (React.createElement("button", { key: option.value, role: "option", type: "button", id: generateDescendantId(i), className: classnames(styles.menuListOption, {
|
|
138
|
+
[styles.activeOption]: activeIndex === i,
|
|
139
|
+
}), onClick: () => handleSelectOption(option), onMouseEnter: handleSetActiveOnMouseOver(i), onMouseDown: handleCancelBlur, onMouseUp: handleEnableBlur },
|
|
140
|
+
React.createElement("span", { "aria-hidden": true }, option.prefix),
|
|
141
|
+
React.createElement(Text.Text, null, option.label)))),
|
|
142
|
+
React.createElement("div", { ref: visibleChildRef }),
|
|
143
|
+
isLoadingMore && (React.createElement("div", { className: styles.loadingIndicator },
|
|
144
|
+
React.createElement(Spinner.Spinner, { size: "small", inline: true }))))))));
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
function InternalChipDismissible(props) {
|
|
148
|
+
const { availableChipOptions, ref: wrapperRef, sortedVisibleChipOptions, handleChipAdd, handleChipClick, handleChipKeyDown, handleChipRemove, handleCustomAdd, handleWrapperKeyDown, } = useScrollToActive.useInternalChipDismissible(props);
|
|
149
|
+
return (React.createElement("div", { ref: wrapperRef, className: styles.wrapper, "data-testid": "dismissible-chips", onKeyDown: handleWrapperKeyDown, role: "listbox" },
|
|
150
|
+
sortedVisibleChipOptions.map(chip => (React.createElement(InternalChip, Object.assign({ key: chip.value }, chip, { onKeyDown: handleChipKeyDown(chip.value), onClick: handleChipClick(chip.value), ariaLabel: `${chip.label}. Press delete or backspace to remove ${chip.label}`, tabIndex: 0, suffix: React.createElement(InternalChipButton, { icon: "remove", invalid: chip.invalid, disabled: chip.disabled, label: chip.label, onClick: handleChipRemove(chip.value) }) })))),
|
|
151
|
+
React.createElement(InternalChipDismissibleInput, { activator: props.activator, attachTo: wrapperRef, isLoadingMore: props.isLoadingMore, options: availableChipOptions, onOptionSelect: handleChipAdd, onCustomOptionSelect: handleCustomAdd, onSearch: props.onSearch, onLoadMore: props.onLoadMore })));
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
exports.InternalChip = InternalChip;
|
|
155
|
+
exports.InternalChipButton = InternalChipButton;
|
|
156
|
+
exports.InternalChipDismissible = InternalChipDismissible;
|
|
157
|
+
exports.styles = styles$1;
|