@jobber/components 4.90.4 → 4.90.5
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-BWePg1sL.js} +3 -7
- package/dist/AnimatedPresence-CzXm0q2a.js +98 -0
- package/dist/AnimatedSwitcher/index.cjs +11 -0
- package/dist/AnimatedSwitcher/index.mjs +5 -0
- package/dist/AnimatedSwitcher--j45gdP1.js +90 -0
- package/dist/{AnimatedSwitcher-3d45ec5d.js → AnimatedSwitcher-D_Qj_hx5.js} +4 -8
- package/dist/AtlantisContext/{index.js → index.cjs} +1 -3
- package/dist/AtlantisContext/index.mjs +2 -0
- package/dist/AtlantisContext-B0Zo5l8l.js +18 -0
- package/dist/Autocomplete/index.cjs +33 -0
- package/dist/Autocomplete/index.mjs +27 -0
- package/dist/Autocomplete-DQ9t1vLy.js +190 -0
- package/dist/Autocomplete-W9xb3p2A.js +192 -0
- package/dist/Avatar/index.cjs +12 -0
- package/dist/Avatar/index.mjs +6 -0
- package/dist/Avatar-BPd8t6BU.js +67 -0
- package/dist/Avatar-DTFS2kFm.js +69 -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-Dpwk3NK9.js +79 -0
- package/dist/Banner-DzeDUJLs.js +81 -0
- package/dist/BannerIcon-Co45J70u.js +19 -0
- package/dist/BannerIcon-CzBZbMVi.js +22 -0
- package/dist/Body-4eoS-dUC.js +45 -0
- package/dist/Body-CwY_QyVF.js +54 -0
- package/dist/Button/index.cjs +13 -0
- package/dist/Button/index.mjs +7 -0
- package/dist/Button-BH4Hhr2S.js +47 -0
- package/dist/Button-BPYGeGx2.js +49 -0
- package/dist/ButtonDismiss/index.cjs +14 -0
- package/dist/ButtonDismiss/index.mjs +8 -0
- package/dist/ButtonDismiss-BajTLHia.js +10 -0
- package/dist/ButtonDismiss-Dwe1QljB.js +8 -0
- package/dist/Card/index.cjs +21 -0
- package/dist/Card/index.mjs +15 -0
- package/dist/Card-DG7RIZdT.js +83 -0
- package/dist/Card-DWjfc534.js +81 -0
- package/dist/Checkbox/index.cjs +15 -0
- package/dist/Checkbox/index.mjs +9 -0
- package/dist/Checkbox-BDVwj5E8.js +53 -0
- package/dist/Checkbox-DDDvFfUJ.js +55 -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-Br7-JkgN.js +70 -0
- package/dist/Chip-CGMUQ-V-.js +67 -0
- package/dist/ChipDismissible-DETPCXth.js +19 -0
- package/dist/ChipDismissible-DyMHTSQ9.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-B1RCrN1F.js +93 -0
- package/dist/Chips-DXbRgMUE.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-D0Qo3yYu.js +117 -0
- package/dist/Combobox-DxPzrwcK.js +119 -0
- package/dist/ComboboxAction-Ct0ao84E.js +24 -0
- package/dist/ComboboxAction-I7TT2mVE.js +22 -0
- package/dist/ComboboxActivator-BOGk012k.js +26 -0
- package/dist/ComboboxActivator-uU5VaZqF.js +28 -0
- package/dist/ComboboxContent-miRfjhNV.js +145 -0
- package/dist/ComboboxContent-u1C3PXKH.js +143 -0
- package/dist/ComboboxContentHeader-BF43vAXl.js +27 -0
- package/dist/ComboboxContentHeader-Cirx9k9L.js +29 -0
- package/dist/ComboboxContentList-DFv7m0NQ.js +77 -0
- package/dist/ComboboxContentList-nxCsc_XU.js +75 -0
- package/dist/ComboboxContentSearch-C2RHQNXR.js +34 -0
- package/dist/ComboboxContentSearch-DX-BiYTa.js +32 -0
- package/dist/ComboboxLoadMore-CUK0n3WY.js +16 -0
- package/dist/ComboboxLoadMore-t_s_eVDp.js +14 -0
- package/dist/ComboboxOption-BMg1O_Br.js +20 -0
- package/dist/ComboboxOption-DSzlMoup.js +22 -0
- package/dist/ComboboxProvider-GdvooWYJ.js +10 -0
- package/dist/ComboboxProvider-ku2HdEkO.js +13 -0
- package/dist/ComboboxTrigger-1KuifQvl.js +24 -0
- package/dist/ComboboxTrigger-CvcB6ptJ.js +22 -0
- package/dist/ConfirmationModal/index.cjs +31 -0
- package/dist/ConfirmationModal/index.mjs +25 -0
- package/dist/{ConfirmationModal-b44e302f.js → ConfirmationModal-AtuPSZb4.js} +8 -12
- package/dist/ConfirmationModal-DrQ-Nm1m.js +94 -0
- package/dist/Content/index.cjs +9 -0
- package/dist/Content/index.mjs +3 -0
- package/dist/Content-CobtdYug.js +13 -0
- package/dist/Content-D5eJgx6J.js +15 -0
- package/dist/Countdown/index.cjs +11 -0
- package/dist/Countdown/index.mjs +5 -0
- package/dist/Countdown-CXuL7Gh7.js +659 -0
- package/dist/Countdown-CnIjUABD.js +657 -0
- package/dist/DataDump/index.cjs +24 -0
- package/dist/DataDump/index.mjs +18 -0
- package/dist/DataDump-CXh_x55J.js +15 -0
- package/dist/DataDump-R0kwoLVp.js +17 -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-BRPBlIVp.js +3 -0
- package/dist/DataList-C_diEjjb.js +5 -0
- package/dist/DataList-DyUX97mL.js +141 -0
- package/dist/DataList-DzXNiSs1.js +139 -0
- package/dist/DataList.const-Bqcfo3vs.js +38 -0
- package/dist/DataList.const-z084v3KH.js +25 -0
- package/dist/DataList.utils-BjG-otvz.js +168 -0
- package/dist/DataList.utils-RcG6TvB4.js +161 -0
- package/dist/DataListAction-3U8gJcpE.js +37 -0
- package/dist/DataListAction-BN0qp_ae.js +39 -0
- package/dist/DataListActions-D1r_3WQD.js +43 -0
- package/dist/DataListActions-DV-03b5h.js +45 -0
- package/dist/DataListActionsMenu-Cg-ZZ0LI.js +55 -0
- package/dist/DataListActionsMenu-D9iOGk3i.js +57 -0
- package/dist/DataListBulkActions-BEFyOkWd.js +29 -0
- package/dist/DataListBulkActions-C2E5e2oE.js +26 -0
- package/dist/DataListContext-DTtBXteA.js +25 -0
- package/dist/DataListContext-qFN5DiHI.js +29 -0
- package/dist/DataListEmptyState-DTsqkHng.js +50 -0
- package/dist/DataListEmptyState-DfaWzs71.js +53 -0
- package/dist/DataListFilters-35MxtHUo.js +43 -0
- package/dist/DataListFilters-BjC9kPSD.js +46 -0
- package/dist/DataListHeader-CI-p6m7K.js +93 -0
- package/dist/DataListHeader-D5iNjhk1.js +95 -0
- package/dist/DataListHeaderTile-DwHOJPOJ.js +81 -0
- package/dist/DataListHeaderTile-K_UG9NgG.js +79 -0
- package/dist/DataListItem-BpD1kRWd.js +112 -0
- package/dist/DataListItem-CK9nQ-II.js +114 -0
- package/dist/DataListItemActions-B7Pbbv7U.js +29 -0
- package/dist/DataListItemActions-DDdszYpl.js +32 -0
- package/dist/DataListItemActionsOverflow-CmBtR4CV.js +33 -0
- package/dist/DataListItemActionsOverflow-D83sgU_z.js +35 -0
- package/dist/DataListItemClickable-BBVDmF_w.js +45 -0
- package/dist/DataListItemClickable-DluGOyKl.js +47 -0
- package/dist/DataListItems-DHSJSPeG.js +21 -0
- package/dist/DataListItems-hAiXRicl.js +19 -0
- package/dist/DataListLayout-CVVR8T7f.js +21 -0
- package/dist/DataListLayout-CiKR3P98.js +19 -0
- package/dist/DataListLayoutActions-BiR49Hjb.js +36 -0
- package/dist/DataListLayoutActions-CUWi8Fxy.js +38 -0
- package/dist/DataListLayoutContext-B3szPGTf.js +8 -0
- package/dist/DataListLayoutContext-CjAT05BI.js +11 -0
- package/dist/DataListLayoutContext-lF5Zk-jV.js +18 -0
- package/dist/DataListLayoutContext-p48sRC9i.js +14 -0
- package/dist/DataListLoadMore-CixukWAA.js +31 -0
- package/dist/DataListLoadMore-Cu32AbMo.js +34 -0
- package/dist/DataListLoadingState-CBsAzSFk.js +22 -0
- package/dist/DataListLoadingState-DFRSjdMI.js +26 -0
- package/dist/DataListOverflowFade-BGAt4dqm.js +25 -0
- package/dist/DataListOverflowFade-DU0y9j-T.js +22 -0
- package/dist/DataListSearch-C1PpW3kQ.js +59 -0
- package/dist/DataListSearch-uEaN0YJ7.js +63 -0
- package/dist/DataListSort-BrRFvXG5.js +92 -0
- package/dist/DataListSort-Dx6POURf.js +94 -0
- package/dist/DataListSortingOptions-BndDkYtw.js +37 -0
- package/dist/DataListSortingOptions-wYjmZSp4.js +35 -0
- package/dist/DataListStatusBar-B_NpGiAA.js +22 -0
- package/dist/DataListStatusBar-VdGpFaWQ.js +25 -0
- package/dist/DataListStickyHeader-CScdFohW.js +25 -0
- package/dist/DataListStickyHeader-YssmrZlM.js +23 -0
- package/dist/DataListTags-B4e8t5VV.js +62 -0
- package/dist/DataListTags-xHDVW7r1.js +64 -0
- package/dist/DataListTotalCount-FvMJCJV4.js +27 -0
- package/dist/DataListTotalCount-TVna906A.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-BhmuLCau.js +236 -0
- package/dist/DataTable-DRXABYeP.js +238 -0
- package/dist/DatePicker/index.cjs +26 -0
- package/dist/DatePicker/index.mjs +20 -0
- package/dist/DatePicker-BzXdyAsQ.js +8554 -0
- package/dist/DatePicker-CZnbHBrf.js +8551 -0
- package/dist/DayOfMonthSelect-GTME6B8V.js +130 -0
- package/dist/DayOfMonthSelect-Rxeaskdx.js +137 -0
- package/dist/DescriptionList/index.cjs +10 -0
- package/dist/DescriptionList/index.mjs +4 -0
- package/dist/DescriptionList-CMHhotQz.js +12 -0
- package/dist/DescriptionList-D4V2AGoH.js +14 -0
- package/dist/Disclosure/index.cjs +17 -0
- package/dist/Disclosure/index.mjs +11 -0
- package/dist/Disclosure-B_Ndy93n.js +33 -0
- package/dist/Disclosure-iwknokMb.js +35 -0
- package/dist/Divider/index.cjs +9 -0
- package/dist/Divider/index.mjs +3 -0
- package/dist/Divider-CQwVNie1.js +17 -0
- package/dist/Divider-aDM-8IiX.js +19 -0
- package/dist/Drawer/index.cjs +19 -0
- package/dist/Drawer/index.mjs +12 -0
- package/dist/DrawerGrid-Cy6jFIEj.js +28 -0
- package/dist/DrawerGrid-D-xjQAGo.js +31 -0
- package/dist/Emphasis/index.cjs +10 -0
- package/dist/Emphasis/index.mjs +4 -0
- package/dist/Emphasis-DIJAlzt-.js +13 -0
- package/dist/Emphasis-ZgoNe2R5.js +15 -0
- package/dist/FeatureSwitch/index.cjs +26 -0
- package/dist/FeatureSwitch/index.mjs +20 -0
- package/dist/FeatureSwitch-BKO31OVK.js +52 -0
- package/dist/FeatureSwitch-C4S0awPY.js +54 -0
- package/dist/Flex/index.cjs +9 -0
- package/dist/Flex/index.mjs +3 -0
- package/dist/Flex-Bfl-vL64.js +28 -0
- package/dist/Flex-Dh0WNozY.js +30 -0
- package/dist/Form/index.cjs +10 -0
- package/dist/Form/index.mjs +4 -0
- package/dist/{Form/index.js → Form-5myjIaNx.js} +3 -9
- package/dist/Form-fdEPa2Di.js +48 -0
- package/dist/FormField/index.cjs +20 -0
- package/dist/FormField/index.mjs +14 -0
- package/dist/FormField-DY5JDjdc.js +261 -0
- package/dist/FormField-RMjW742D.js +263 -0
- package/dist/FormatDate/{index.js → index.cjs} +1 -3
- package/dist/FormatDate/index.mjs +2 -0
- package/dist/{FormatDate-70ea5b43.js → FormatDate-CcycFjAL.js} +1 -5
- package/dist/FormatDate-YUbeta27.js +27 -0
- package/dist/FormatEmail/index.cjs +9 -0
- package/dist/FormatEmail/index.mjs +3 -0
- package/dist/FormatEmail-B7cAlIQY.js +11 -0
- package/dist/FormatEmail-DJLlhpQr.js +13 -0
- package/dist/FormatFile/index.cjs +36 -0
- package/dist/FormatFile/index.mjs +30 -0
- package/dist/FormatFile-BAZqq1p8.js +149 -0
- package/dist/FormatFile-CRPcqK86.js +147 -0
- package/dist/FormatRelativeDateTime/index.cjs +8 -0
- package/dist/FormatRelativeDateTime/index.mjs +2 -0
- package/dist/FormatRelativeDateTime-Ca1DyZ7Z.js +64 -0
- package/dist/{FormatRelativeDateTime/index.js → FormatRelativeDateTime-hdrEQWhy.js} +5 -11
- package/dist/FormatTime/index.cjs +8 -0
- package/dist/FormatTime/index.mjs +2 -0
- package/dist/FormatTime-DcIV5E6n.js +29 -0
- package/dist/{FormatTime/index.js → FormatTime-DrHluWW3.js} +1 -7
- package/dist/Gallery/index.cjs +42 -0
- package/dist/Gallery/index.mjs +36 -0
- package/dist/Gallery-D9AVJQTM.js +65 -0
- package/dist/Gallery-Duiow0xg.js +63 -0
- package/dist/Glimmer/index.cjs +12 -0
- package/dist/Glimmer/index.mjs +5 -0
- package/dist/Glimmer-CG9tFCHs.js +63 -0
- package/dist/Glimmer-IWgpoHGI.js +60 -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-DzRYkCwi.js +29 -0
- package/dist/Grid-VQ3fN1ko.js +32 -0
- package/dist/Heading/index.cjs +12 -0
- package/dist/Heading/index.mjs +6 -0
- package/dist/Heading-D_ylbFzI.js +49 -0
- package/dist/{Heading-23d382a1.js → Heading-Y2BrFvzY.js} +3 -7
- package/dist/Icon/index.cjs +9 -0
- package/dist/Icon/index.mjs +3 -0
- package/dist/Icon-C05AQvkv.js +36 -0
- package/dist/Icon-Dic5myD3.js +34 -0
- package/dist/InlineLabel/index.cjs +10 -0
- package/dist/InlineLabel/index.mjs +4 -0
- package/dist/InlineLabel-A3tenwf6.js +20 -0
- package/dist/InlineLabel-BLt0Q3bb.js +18 -0
- package/dist/InputAvatar/index.cjs +26 -0
- package/dist/InputAvatar/index.mjs +20 -0
- package/dist/InputAvatar-BdLo0JDy.js +49 -0
- package/dist/InputAvatar-Dqd68eBU.js +47 -0
- package/dist/InputDate/index.cjs +34 -0
- package/dist/InputDate/index.mjs +28 -0
- package/dist/InputDate-CEk7YABR.js +48 -0
- package/dist/{InputDate/index.js → InputDate-kNxwMqkc.js} +6 -31
- package/dist/InputEmail/index.cjs +22 -0
- package/dist/InputEmail/index.mjs +15 -0
- package/dist/InputEmail-C-EyDCxm.js +20 -0
- package/dist/InputEmail-wUgCu5JW.js +23 -0
- package/dist/InputFile/index.cjs +23 -0
- package/dist/InputFile/index.mjs +16 -0
- package/dist/InputFile-B4DD55KU.js +1608 -0
- package/dist/InputFile-D5DGGfOB.js +1611 -0
- package/dist/InputGroup/index.cjs +9 -0
- package/dist/InputGroup/index.mjs +3 -0
- package/dist/InputGroup-DeQx7ud8.js +25 -0
- package/dist/InputGroup-hh3QBfdL.js +23 -0
- package/dist/InputNumber/index.cjs +21 -0
- package/dist/InputNumber/index.mjs +15 -0
- package/dist/InputNumber-BveQrPyO.js +56 -0
- package/dist/{InputNumber-e15cc1a3.js → InputNumber-CW4ttUb0.js} +2 -6
- package/dist/InputPassword/index.cjs +21 -0
- package/dist/InputPassword/index.mjs +15 -0
- package/dist/InputPassword-C8V7VR78.js +21 -0
- package/dist/InputPassword-Dw7Go90j.js +19 -0
- package/dist/InputPhoneNumber/index.cjs +21 -0
- package/dist/InputPhoneNumber/index.mjs +15 -0
- package/dist/{InputPhoneNumber/index.js → InputPhoneNumber-DHO2lp-T.js} +7 -27
- package/dist/InputPhoneNumber-DVscxVqU.js +94 -0
- package/dist/InputText/index.cjs +22 -0
- package/dist/InputText/index.mjs +16 -0
- package/dist/InputText-COr1oIHK.js +96 -0
- package/dist/{InputText-130b0440.js → InputText-C_iZe7xf.js} +4 -8
- package/dist/InputTime/index.cjs +26 -0
- package/dist/InputTime/index.mjs +20 -0
- package/dist/{InputTime/index.js → InputTime-DemVybcJ.js} +5 -25
- package/dist/InputTime-_Oc4Hp9L.js +190 -0
- package/dist/InputValidation/index.cjs +14 -0
- package/dist/InputValidation/index.mjs +8 -0
- package/dist/InputValidation-BiJTp0aC.js +22 -0
- package/dist/InputValidation-CCkTBcxQ.js +20 -0
- package/dist/InternalChipDismissible-D8UrPjJC.js +152 -0
- package/dist/InternalChipDismissible-DUluzwH6.js +157 -0
- package/dist/InternalGridCell-Bi4IFFO8.js +37 -0
- package/dist/InternalGridCell-CE9IQZwO.js +34 -0
- package/dist/LightBox/index.cjs +26 -0
- package/dist/LightBox/index.mjs +20 -0
- package/dist/LightBox-CIWrYTaA.js +110 -0
- package/dist/LightBox-D-gmMO7L.js +112 -0
- package/dist/Link/index.cjs +8 -0
- package/dist/Link/index.mjs +2 -0
- package/dist/Link-_423xhjb.js +7 -0
- package/dist/Link-j486eamd.js +9 -0
- package/dist/List/index.cjs +29 -0
- package/dist/List/index.mjs +22 -0
- package/dist/List-BcQDY2Rj.js +186 -0
- package/dist/List-Dgwp7JmK.js +189 -0
- package/dist/Markdown/index.cjs +19 -0
- package/dist/Markdown/index.mjs +13 -0
- package/dist/Markdown-BfxzpIEM.js +19011 -0
- package/dist/Markdown-BhG7kPFl.js +19013 -0
- package/dist/Menu/index.cjs +18 -0
- package/dist/Menu/index.mjs +12 -0
- package/dist/Menu-CuPp5MtV.js +129 -0
- package/dist/Menu-DNImsnBT.js +131 -0
- package/dist/Modal/index.cjs +23 -0
- package/dist/Modal/index.mjs +17 -0
- package/dist/Modal-Cgz6UlsK.js +62 -0
- package/dist/Modal-DQHFlXp5.js +60 -0
- package/dist/MultiSelect/index.cjs +16 -0
- package/dist/MultiSelect/index.mjs +10 -0
- package/dist/MultiSelect-BxtKPK3-.js +166 -0
- package/dist/MultiSelect-DFR0vsTw.js +164 -0
- package/dist/Option-C87IriRr.js +12 -0
- package/dist/Option-X8lh2w6I.js +15 -0
- package/dist/Page/index.cjs +32 -0
- package/dist/Page/index.mjs +26 -0
- package/dist/Page-BgG3_7DX.js +56 -0
- package/dist/Page-BowBp8rI.js +58 -0
- package/dist/Popover/index.cjs +17 -0
- package/dist/Popover/index.mjs +11 -0
- package/dist/Popover-BwG9WBGX.js +50 -0
- package/dist/Popover-o9pOjTMP.js +48 -0
- package/dist/ProgressBar/index.cjs +9 -0
- package/dist/ProgressBar/index.mjs +3 -0
- package/dist/ProgressBar-CUTebo_k.js +33 -0
- package/dist/ProgressBar-OBLHnKRF.js +31 -0
- package/dist/RadioGroup/index.cjs +12 -0
- package/dist/RadioGroup/index.mjs +5 -0
- package/dist/RadioGroup-CxguJ9E7.js +39 -0
- package/dist/RadioGroup-Dt9_WguN.js +36 -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-BB2D2awE.js +69 -0
- package/dist/RecurringSelect-Dqle4F6a.js +71 -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-CjTb3xIl.js +16 -0
- package/dist/Spinner-DGO8_Jsa.js +14 -0
- package/dist/StatusIndicator/index.cjs +8 -0
- package/dist/StatusIndicator/index.mjs +2 -0
- package/dist/StatusIndicator-CNH13isn.js +11 -0
- package/dist/StatusIndicator-DaWtSIUm.js +9 -0
- package/dist/StatusLabel/index.cjs +11 -0
- package/dist/StatusLabel/index.mjs +5 -0
- package/dist/StatusLabel-DuJzG65D.js +18 -0
- package/dist/StatusLabel-YebFZkcB.js +16 -0
- package/dist/Switch/index.cjs +10 -0
- package/dist/Switch/index.mjs +4 -0
- package/dist/Switch-CUBASre6.js +46 -0
- package/dist/Switch-KKEqlvTp.js +48 -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-AoDyVJHh.js +70 -0
- package/dist/Tabs-CmCuGGLm.js +67 -0
- package/dist/Text/index.cjs +10 -0
- package/dist/Text/index.mjs +4 -0
- package/dist/{Text-fbeaaca6.js → Text-BKFV1Z0j.js} +2 -6
- package/dist/Text-CfxmOdM-.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-BrnUcSMD.js +103 -0
- package/dist/Tooltip-PbQMMMXT.js +105 -0
- package/dist/Typography/index.cjs +9 -0
- package/dist/Typography/index.mjs +3 -0
- package/dist/Typography-BiJhpsiL.js +38 -0
- package/dist/Typography-DscVWtp8.js +36 -0
- package/dist/_baseAssignValue-Byqm0l-g.js +29 -0
- package/dist/_baseAssignValue-ph7A7Tyf.js +31 -0
- package/dist/_baseEach-2sgXrDWN.js +1073 -0
- package/dist/_baseEach-DbUzYrtE.js +1069 -0
- package/dist/_commonjsHelpers-BHq9dk6I.js +36 -0
- package/dist/_commonjsHelpers-Dw5gAsMR.js +32 -0
- package/dist/_defineProperty-PEG-eSOB.js +1326 -0
- package/dist/_defineProperty-fDNRMxz-.js +1306 -0
- package/dist/_getTag-BBi2mXSK.js +718 -0
- package/dist/_getTag-CtczKdF2.js +733 -0
- package/dist/_polyfill-node.process-7AsFqJce.js +258 -0
- package/dist/_polyfill-node.process-B3Zw2Wh0.js +255 -0
- package/dist/_setToString-BEt-Msu3.js +230 -0
- package/dist/_setToString-BXD3rooF.js +234 -0
- package/dist/debounce-DHeCta_M.js +329 -0
- package/dist/debounce-DtVkjvKH.js +332 -0
- package/dist/helpers-BX_7EKw7.js +15 -0
- package/dist/helpers-BpmnB4Qy.js +17 -0
- package/dist/index-BE4KkyL_.js +1186 -0
- package/dist/index-dKBcvdAq.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-53d8VfgU.js +190 -0
- package/dist/isObjectLike-zrq0mtNG.js +197 -0
- package/dist/isSymbol-B7o505jx.js +35 -0
- package/dist/isSymbol-Co3-vUC1.js +33 -0
- package/dist/noop-B8ZS2J9q.js +24 -0
- package/dist/noop-mF8IIYWw.js +26 -0
- package/dist/showToast-C4Fxtv_O.js +97 -0
- package/dist/showToast-Ckq11MSy.js +99 -0
- package/dist/styles.css +8762 -0
- package/dist/tslib.es6-5nrZ19JS.js +97 -0
- package/dist/tslib.es6-BBH1pS30.js +102 -0
- package/dist/useActiveLayout-BSipZn9t.js +16 -0
- package/dist/useActiveLayout-BqE7ZQY7.js +14 -0
- package/dist/useAssert-BTe43jaI.js +27 -0
- package/dist/useAssert-CSmf3rDf.js +27 -0
- package/dist/{useAtlantisConfig-ed0bee66.js → useAtlantisConfig-Ckfr55qY.js} +2 -2
- package/dist/useAtlantisConfig-DC3Ppo_R.js +14 -0
- package/dist/useBatchSelect-KPnTra4u.js +36 -0
- package/dist/useBatchSelect-rQ55uZ7U.js +38 -0
- package/dist/useChildComponent-CwlKwCml.js +15 -0
- package/dist/useChildComponent-D7PbyArU.js +17 -0
- package/dist/useFocusTrap-B-xOQ79p.js +74 -0
- package/dist/useFocusTrap-D0gOZaSx.js +74 -0
- package/dist/useInView-CjeNEvX0.js +25 -0
- package/dist/useInView-DGjydyXL.js +25 -0
- package/dist/useIsMounted-BxDu0lnY.js +47 -0
- package/dist/useIsMounted-DfJrPzyU.js +47 -0
- package/dist/useOnKeyDown-07RktdgP.js +40 -0
- package/dist/useOnKeyDown-W2x-4HSi.js +40 -0
- package/dist/useRefocusOnActivator-BAub7L-i.js +32 -0
- package/dist/useRefocusOnActivator-BnM3unqN.js +32 -0
- package/dist/useResizeObserver-B4Vfml7U.js +1192 -0
- package/dist/useResizeObserver-DzMx2b66.js +1189 -0
- package/dist/useResponsiveSizing-DB6K2Viw.js +51 -0
- package/dist/useResponsiveSizing-DVb-nBuX.js +49 -0
- package/dist/useSafeLayoutEffect-BW_VIS6-.js +12 -0
- package/dist/useSafeLayoutEffect-juh5vdFE.js +14 -0
- package/dist/useScrollToActive-CQdgd_Dw.js +591 -0
- package/dist/useScrollToActive-DP9nvfrv.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-AiJSmYGH.js} +0 -0
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var Tooltip = require('./Tooltip-PbQMMMXT.js');
|
|
5
|
+
var Button = require('./Button-BPYGeGx2.js');
|
|
6
|
+
var DataListOverflowFade = require('./DataListOverflowFade-BGAt4dqm.js');
|
|
7
|
+
var DataList_utils = require('./DataList.utils-BjG-otvz.js');
|
|
8
|
+
var DataListLayoutContext = require('./DataListLayoutContext-CjAT05BI.js');
|
|
9
|
+
var DataListItemActionsOverflow = require('./DataListItemActionsOverflow-D83sgU_z.js');
|
|
10
|
+
|
|
11
|
+
function DataListActions({ children, itemsToExpose = 2, }) {
|
|
12
|
+
const { activeItem } = DataListLayoutContext.useDataListLayoutActionsContext();
|
|
13
|
+
const childrenArray = React.Children.toArray(children).filter(React.isValidElement);
|
|
14
|
+
const exposedActions = DataList_utils.getExposedActions(childrenArray, itemsToExpose);
|
|
15
|
+
childrenArray.splice(0, exposedActions.length);
|
|
16
|
+
return (React.createElement(DataListOverflowFade.DataListOverflowFade, null,
|
|
17
|
+
exposedActions.map(({ props }) => {
|
|
18
|
+
if (props.visible && !props.visible(activeItem))
|
|
19
|
+
return null;
|
|
20
|
+
if (!props.icon)
|
|
21
|
+
return null;
|
|
22
|
+
function getActionLabel() {
|
|
23
|
+
if (typeof props.label === "string") {
|
|
24
|
+
return props.label;
|
|
25
|
+
}
|
|
26
|
+
if (activeItem) {
|
|
27
|
+
return props.label(activeItem);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
const actionLabel = getActionLabel();
|
|
31
|
+
return (React.createElement(Tooltip.Tooltip, { key: actionLabel, message: actionLabel },
|
|
32
|
+
React.createElement(Button.Button, { icon: props.icon, ariaLabel: actionLabel, onClick: () => {
|
|
33
|
+
var _a, _b;
|
|
34
|
+
if (activeItem) {
|
|
35
|
+
(_a = props.onClick) === null || _a === void 0 ? void 0 : _a.call(props, activeItem);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
(_b = props.onClick) === null || _b === void 0 ? void 0 : _b.call(props);
|
|
39
|
+
}
|
|
40
|
+
}, type: "secondary", variation: "subtle" })));
|
|
41
|
+
}),
|
|
42
|
+
React.createElement(DataListItemActionsOverflow.DataListItemActionsOverflow, { actions: childrenArray })));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
exports.DataListActions = DataListActions;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import React, { useState } from 'react';
|
|
2
|
+
import { AnimatePresence, motion } from 'framer-motion';
|
|
3
|
+
import { u as useFocusTrap_2 } from './useFocusTrap-D0gOZaSx.js';
|
|
4
|
+
import { u as useRefocusOnActivator_2 } from './useRefocusOnActivator-BAub7L-i.js';
|
|
5
|
+
import { u as useOnKeyDown_2 } from './useOnKeyDown-07RktdgP.js';
|
|
6
|
+
import { createPortal } from 'react-dom';
|
|
7
|
+
import { tokens } from '@jobber/design';
|
|
8
|
+
import { u as useIsMounted_2 } from './useIsMounted-BxDu0lnY.js';
|
|
9
|
+
import { d as TRANSITION_DELAY_IN_SECONDS } from './DataList.const-z084v3KH.js';
|
|
10
|
+
|
|
11
|
+
var styles = {"menu":"aokwZU8jbWU-","overlay":"XtVRP97TVSE-"};
|
|
12
|
+
|
|
13
|
+
const variants = {
|
|
14
|
+
hidden: { opacity: 0, y: -10 },
|
|
15
|
+
visible: { opacity: 1, y: 0 },
|
|
16
|
+
};
|
|
17
|
+
function DataListActionsMenu({ visible = false, position, onRequestClose, children, }) {
|
|
18
|
+
const [ref, setRef] = useState();
|
|
19
|
+
const mounted = useIsMounted_2();
|
|
20
|
+
useRefocusOnActivator_2(visible);
|
|
21
|
+
const focusTrapRef = useFocusTrap_2(visible);
|
|
22
|
+
useOnKeyDown_2(onRequestClose, "Escape");
|
|
23
|
+
const actionsMenu = (React.createElement(AnimatePresence, null, visible && (React.createElement("div", { ref: focusTrapRef, onClick: handleClick },
|
|
24
|
+
React.createElement(motion.div, { role: "menu", ref: setRef, variants: variants, initial: "hidden", animate: "visible", exit: "hidden", transition: { duration: TRANSITION_DELAY_IN_SECONDS }, className: styles.menu, style: getPositionCssVars(), onClick: onRequestClose }, children),
|
|
25
|
+
React.createElement("button", { type: "button", className: styles.overlay, onClick: onRequestClose, "aria-label": "Close menu" })))));
|
|
26
|
+
return mounted.current
|
|
27
|
+
? createPortal(actionsMenu, document.body)
|
|
28
|
+
: actionsMenu;
|
|
29
|
+
function handleClick(event) {
|
|
30
|
+
// Prevent menu from firing the parent's onClick event when it is nested
|
|
31
|
+
// within a clickable list item
|
|
32
|
+
event.stopPropagation();
|
|
33
|
+
}
|
|
34
|
+
function getPositionCssVars() {
|
|
35
|
+
const { posX, posY } = getPosition();
|
|
36
|
+
return {
|
|
37
|
+
"--actions-menu-x": `${posX}px`,
|
|
38
|
+
"--actions-menu-y": `${posY}px`,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
function getPosition() {
|
|
42
|
+
const rect = ref === null || ref === void 0 ? void 0 : ref.getBoundingClientRect();
|
|
43
|
+
const { width = 0, height = 0 } = rect || {};
|
|
44
|
+
const { x, y } = position;
|
|
45
|
+
const xIsOffScreen = x + width > window.innerWidth;
|
|
46
|
+
const yIsOffScreen = y + height > window.innerHeight;
|
|
47
|
+
const xOffSet = x + width - window.innerWidth + tokens["space-base"];
|
|
48
|
+
const yOffSet = y + height - window.innerHeight;
|
|
49
|
+
const newPosX = Math.floor(xIsOffScreen ? x - xOffSet : x);
|
|
50
|
+
const newPosY = Math.floor(yIsOffScreen ? y - yOffSet : y);
|
|
51
|
+
return { posX: newPosX, posY: newPosY };
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export { DataListActionsMenu as D };
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var framerMotion = require('framer-motion');
|
|
5
|
+
var useFocusTrap = require('./useFocusTrap-B-xOQ79p.js');
|
|
6
|
+
var useRefocusOnActivator = require('./useRefocusOnActivator-BnM3unqN.js');
|
|
7
|
+
var useOnKeyDown = require('./useOnKeyDown-W2x-4HSi.js');
|
|
8
|
+
var ReactDOM = require('react-dom');
|
|
9
|
+
var design = require('@jobber/design');
|
|
10
|
+
var useIsMounted = require('./useIsMounted-DfJrPzyU.js');
|
|
11
|
+
var DataList_const = require('./DataList.const-Bqcfo3vs.js');
|
|
12
|
+
|
|
13
|
+
var styles = {"menu":"aokwZU8jbWU-","overlay":"XtVRP97TVSE-"};
|
|
14
|
+
|
|
15
|
+
const variants = {
|
|
16
|
+
hidden: { opacity: 0, y: -10 },
|
|
17
|
+
visible: { opacity: 1, y: 0 },
|
|
18
|
+
};
|
|
19
|
+
function DataListActionsMenu({ visible = false, position, onRequestClose, children, }) {
|
|
20
|
+
const [ref, setRef] = React.useState();
|
|
21
|
+
const mounted = useIsMounted.useIsMounted_2();
|
|
22
|
+
useRefocusOnActivator.useRefocusOnActivator_2(visible);
|
|
23
|
+
const focusTrapRef = useFocusTrap.useFocusTrap_2(visible);
|
|
24
|
+
useOnKeyDown.useOnKeyDown_2(onRequestClose, "Escape");
|
|
25
|
+
const actionsMenu = (React.createElement(framerMotion.AnimatePresence, null, visible && (React.createElement("div", { ref: focusTrapRef, onClick: handleClick },
|
|
26
|
+
React.createElement(framerMotion.motion.div, { role: "menu", ref: setRef, variants: variants, initial: "hidden", animate: "visible", exit: "hidden", transition: { duration: DataList_const.TRANSITION_DELAY_IN_SECONDS }, className: styles.menu, style: getPositionCssVars(), onClick: onRequestClose }, children),
|
|
27
|
+
React.createElement("button", { type: "button", className: styles.overlay, onClick: onRequestClose, "aria-label": "Close menu" })))));
|
|
28
|
+
return mounted.current
|
|
29
|
+
? ReactDOM.createPortal(actionsMenu, document.body)
|
|
30
|
+
: actionsMenu;
|
|
31
|
+
function handleClick(event) {
|
|
32
|
+
// Prevent menu from firing the parent's onClick event when it is nested
|
|
33
|
+
// within a clickable list item
|
|
34
|
+
event.stopPropagation();
|
|
35
|
+
}
|
|
36
|
+
function getPositionCssVars() {
|
|
37
|
+
const { posX, posY } = getPosition();
|
|
38
|
+
return {
|
|
39
|
+
"--actions-menu-x": `${posX}px`,
|
|
40
|
+
"--actions-menu-y": `${posY}px`,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
function getPosition() {
|
|
44
|
+
const rect = ref === null || ref === void 0 ? void 0 : ref.getBoundingClientRect();
|
|
45
|
+
const { width = 0, height = 0 } = rect || {};
|
|
46
|
+
const { x, y } = position;
|
|
47
|
+
const xIsOffScreen = x + width > window.innerWidth;
|
|
48
|
+
const yIsOffScreen = y + height > window.innerHeight;
|
|
49
|
+
const xOffSet = x + width - window.innerWidth + design.tokens["space-base"];
|
|
50
|
+
const yOffSet = y + height - window.innerHeight;
|
|
51
|
+
const newPosX = Math.floor(xIsOffScreen ? x - xOffSet : x);
|
|
52
|
+
const newPosY = Math.floor(yIsOffScreen ? y - yOffSet : y);
|
|
53
|
+
return { posX: newPosX, posY: newPosY };
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
exports.DataListActionsMenu = DataListActionsMenu;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var DataListContext = require('./DataListContext-qFN5DiHI.js');
|
|
5
|
+
var DataListActions = require('./DataListActions-DV-03b5h.js');
|
|
6
|
+
var useResponsiveSizing = require('./useResponsiveSizing-DB6K2Viw.js');
|
|
7
|
+
|
|
8
|
+
var styles = {"bulkActions":"v-GrdlFpBLk-"};
|
|
9
|
+
|
|
10
|
+
// This component is meant to capture the props of the DataList.BulkActions
|
|
11
|
+
function DataListBulkActions(
|
|
12
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
13
|
+
_) {
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
function InternalDataListBulkActions() {
|
|
17
|
+
const { bulkActionsComponent } = DataListContext.useDataListContext();
|
|
18
|
+
if (!bulkActionsComponent)
|
|
19
|
+
return null;
|
|
20
|
+
const { children } = bulkActionsComponent.props;
|
|
21
|
+
const { sm } = useResponsiveSizing.useResponsiveSizing();
|
|
22
|
+
// Collapse all actions under "More actions" when breakpoint is smaller than sm
|
|
23
|
+
const itemsToExpose = sm ? 3 : 0;
|
|
24
|
+
return (React.createElement("div", { className: styles.bulkActions },
|
|
25
|
+
React.createElement(DataListActions.DataListActions, { itemsToExpose: itemsToExpose }, children)));
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
exports.DataListBulkActions = DataListBulkActions;
|
|
29
|
+
exports.InternalDataListBulkActions = InternalDataListBulkActions;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { u as useDataListContext } from './DataListContext-DTtBXteA.js';
|
|
3
|
+
import { D as DataListActions } from './DataListActions-D1r_3WQD.js';
|
|
4
|
+
import { u as useResponsiveSizing } from './useResponsiveSizing-DVb-nBuX.js';
|
|
5
|
+
|
|
6
|
+
var styles = {"bulkActions":"v-GrdlFpBLk-"};
|
|
7
|
+
|
|
8
|
+
// This component is meant to capture the props of the DataList.BulkActions
|
|
9
|
+
function DataListBulkActions(
|
|
10
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
11
|
+
_) {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
function InternalDataListBulkActions() {
|
|
15
|
+
const { bulkActionsComponent } = useDataListContext();
|
|
16
|
+
if (!bulkActionsComponent)
|
|
17
|
+
return null;
|
|
18
|
+
const { children } = bulkActionsComponent.props;
|
|
19
|
+
const { sm } = useResponsiveSizing();
|
|
20
|
+
// Collapse all actions under "More actions" when breakpoint is smaller than sm
|
|
21
|
+
const itemsToExpose = sm ? 3 : 0;
|
|
22
|
+
return (React.createElement("div", { className: styles.bulkActions },
|
|
23
|
+
React.createElement(DataListActions, { itemsToExpose: itemsToExpose }, children)));
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export { DataListBulkActions as D, InternalDataListBulkActions as I };
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import React, { createContext, useContext } from 'react';
|
|
2
|
+
import { n as noop } from './noop-B8ZS2J9q.js';
|
|
3
|
+
|
|
4
|
+
const defaultValues = {
|
|
5
|
+
title: "",
|
|
6
|
+
data: [],
|
|
7
|
+
headers: {},
|
|
8
|
+
children: [],
|
|
9
|
+
selected: [],
|
|
10
|
+
layoutBreakpoints: [],
|
|
11
|
+
layouts: {
|
|
12
|
+
xs: children => React.createElement(React.Fragment, null, children),
|
|
13
|
+
sm: children => React.createElement(React.Fragment, null, children),
|
|
14
|
+
md: children => React.createElement(React.Fragment, null, children),
|
|
15
|
+
lg: children => React.createElement(React.Fragment, null, children),
|
|
16
|
+
xl: children => React.createElement(React.Fragment, null, children),
|
|
17
|
+
},
|
|
18
|
+
registerLayout: noop,
|
|
19
|
+
};
|
|
20
|
+
const DataListContext = createContext(defaultValues);
|
|
21
|
+
function useDataListContext() {
|
|
22
|
+
return useContext(DataListContext);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
export { DataListContext as D, defaultValues as d, useDataListContext as u };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var noop = require('./noop-mF8IIYWw.js');
|
|
5
|
+
|
|
6
|
+
const defaultValues = {
|
|
7
|
+
title: "",
|
|
8
|
+
data: [],
|
|
9
|
+
headers: {},
|
|
10
|
+
children: [],
|
|
11
|
+
selected: [],
|
|
12
|
+
layoutBreakpoints: [],
|
|
13
|
+
layouts: {
|
|
14
|
+
xs: children => React.createElement(React.Fragment, null, children),
|
|
15
|
+
sm: children => React.createElement(React.Fragment, null, children),
|
|
16
|
+
md: children => React.createElement(React.Fragment, null, children),
|
|
17
|
+
lg: children => React.createElement(React.Fragment, null, children),
|
|
18
|
+
xl: children => React.createElement(React.Fragment, null, children),
|
|
19
|
+
},
|
|
20
|
+
registerLayout: noop.noop,
|
|
21
|
+
};
|
|
22
|
+
const DataListContext = React.createContext(defaultValues);
|
|
23
|
+
function useDataListContext() {
|
|
24
|
+
return React.useContext(DataListContext);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
exports.DataListContext = DataListContext;
|
|
28
|
+
exports.defaultValues = defaultValues;
|
|
29
|
+
exports.useDataListContext = useDataListContext;
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import React, { useContext, cloneElement } from 'react';
|
|
2
|
+
import { D as DataListContext } from './DataListContext-DTtBXteA.js';
|
|
3
|
+
import { T as Text } from './Text-CfxmOdM-.js';
|
|
4
|
+
import { B as Button } from './Button-BH4Hhr2S.js';
|
|
5
|
+
import { E as EMPTY_FILTER_RESULTS_MESSAGE, b as EMPTY_RESULTS_MESSAGE, c as EMPTY_STATE_ACTION_BUTTON_ONLY_ERROR } from './DataList.const-z084v3KH.js';
|
|
6
|
+
|
|
7
|
+
var styles = {"emptyStateWrapper":"zg3w9nQga-M-"};
|
|
8
|
+
|
|
9
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
10
|
+
function DataListEmptyState(_) {
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
function InternalDataListEmptyState() {
|
|
14
|
+
const { emptyStateComponents: components, filtered } = useContext(DataListContext);
|
|
15
|
+
const { message, action } = getMessages();
|
|
16
|
+
return (React.createElement("div", { className: styles.emptyStateWrapper },
|
|
17
|
+
React.createElement(Text, { align: "center" }, message),
|
|
18
|
+
renderButton(action)));
|
|
19
|
+
function getMessages() {
|
|
20
|
+
const { defaultEmptyState, filteredEmptyState } = getEmptyStates(components);
|
|
21
|
+
if (filtered) {
|
|
22
|
+
return {
|
|
23
|
+
message: (filteredEmptyState === null || filteredEmptyState === void 0 ? void 0 : filteredEmptyState.props.message) || EMPTY_FILTER_RESULTS_MESSAGE,
|
|
24
|
+
action: filteredEmptyState === null || filteredEmptyState === void 0 ? void 0 : filteredEmptyState.props.action,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
return {
|
|
28
|
+
message: (defaultEmptyState === null || defaultEmptyState === void 0 ? void 0 : defaultEmptyState.props.message) || EMPTY_RESULTS_MESSAGE,
|
|
29
|
+
action: defaultEmptyState === null || defaultEmptyState === void 0 ? void 0 : defaultEmptyState.props.action,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
function renderButton(action) {
|
|
34
|
+
if (action) {
|
|
35
|
+
if (action.type === Button) {
|
|
36
|
+
return cloneElement(action, {
|
|
37
|
+
variation: action.props.variation || "subtle",
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
throw new Error(EMPTY_STATE_ACTION_BUTTON_ONLY_ERROR);
|
|
41
|
+
}
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
function getEmptyStates(components) {
|
|
45
|
+
const defaultEmptyState = components === null || components === void 0 ? void 0 : components.find(es => es.props.type === "empty" || es.props.type === undefined);
|
|
46
|
+
const filteredEmptyState = components === null || components === void 0 ? void 0 : components.find(es => es.props.type === "filtered");
|
|
47
|
+
return { defaultEmptyState, filteredEmptyState };
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export { DataListEmptyState as D, InternalDataListEmptyState as I };
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var DataListContext = require('./DataListContext-qFN5DiHI.js');
|
|
5
|
+
var Text = require('./Text-BKFV1Z0j.js');
|
|
6
|
+
var Button = require('./Button-BPYGeGx2.js');
|
|
7
|
+
var DataList_const = require('./DataList.const-Bqcfo3vs.js');
|
|
8
|
+
|
|
9
|
+
var styles = {"emptyStateWrapper":"zg3w9nQga-M-"};
|
|
10
|
+
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
12
|
+
function DataListEmptyState(_) {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
function InternalDataListEmptyState() {
|
|
16
|
+
const { emptyStateComponents: components, filtered } = React.useContext(DataListContext.DataListContext);
|
|
17
|
+
const { message, action } = getMessages();
|
|
18
|
+
return (React.createElement("div", { className: styles.emptyStateWrapper },
|
|
19
|
+
React.createElement(Text.Text, { align: "center" }, message),
|
|
20
|
+
renderButton(action)));
|
|
21
|
+
function getMessages() {
|
|
22
|
+
const { defaultEmptyState, filteredEmptyState } = getEmptyStates(components);
|
|
23
|
+
if (filtered) {
|
|
24
|
+
return {
|
|
25
|
+
message: (filteredEmptyState === null || filteredEmptyState === void 0 ? void 0 : filteredEmptyState.props.message) || DataList_const.EMPTY_FILTER_RESULTS_MESSAGE,
|
|
26
|
+
action: filteredEmptyState === null || filteredEmptyState === void 0 ? void 0 : filteredEmptyState.props.action,
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
return {
|
|
30
|
+
message: (defaultEmptyState === null || defaultEmptyState === void 0 ? void 0 : defaultEmptyState.props.message) || DataList_const.EMPTY_RESULTS_MESSAGE,
|
|
31
|
+
action: defaultEmptyState === null || defaultEmptyState === void 0 ? void 0 : defaultEmptyState.props.action,
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
function renderButton(action) {
|
|
36
|
+
if (action) {
|
|
37
|
+
if (action.type === Button.Button) {
|
|
38
|
+
return React.cloneElement(action, {
|
|
39
|
+
variation: action.props.variation || "subtle",
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
throw new Error(DataList_const.EMPTY_STATE_ACTION_BUTTON_ONLY_ERROR);
|
|
43
|
+
}
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
function getEmptyStates(components) {
|
|
47
|
+
const defaultEmptyState = components === null || components === void 0 ? void 0 : components.find(es => es.props.type === "empty" || es.props.type === undefined);
|
|
48
|
+
const filteredEmptyState = components === null || components === void 0 ? void 0 : components.find(es => es.props.type === "filtered");
|
|
49
|
+
return { defaultEmptyState, filteredEmptyState };
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
exports.DataListEmptyState = DataListEmptyState;
|
|
53
|
+
exports.InternalDataListEmptyState = InternalDataListEmptyState;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { D as DataListSort } from './DataListSort-BrRFvXG5.js';
|
|
3
|
+
import { D as DataListOverflowFade } from './DataListOverflowFade-DU0y9j-T.js';
|
|
4
|
+
import { u as useDataListContext } from './DataListContext-DTtBXteA.js';
|
|
5
|
+
import { g as getCompoundComponent } from './DataList.utils-RcG6TvB4.js';
|
|
6
|
+
import { u as useResponsiveSizing } from './useResponsiveSizing-DVb-nBuX.js';
|
|
7
|
+
|
|
8
|
+
function useShowHeader() {
|
|
9
|
+
const { headerVisibility } = useDataListContext();
|
|
10
|
+
if (headerVisibility === undefined)
|
|
11
|
+
return true;
|
|
12
|
+
const sizes = useResponsiveSizing();
|
|
13
|
+
const sizeKeys = Object.keys(sizes);
|
|
14
|
+
const showHeader = sizeKeys.reduce((previous, breakpoint) => {
|
|
15
|
+
const isHeaderVisible = headerVisibility[breakpoint] || false;
|
|
16
|
+
const isBreakpointTriggered = sizes[breakpoint];
|
|
17
|
+
return previous || (isBreakpointTriggered && isHeaderVisible);
|
|
18
|
+
}, false);
|
|
19
|
+
return showHeader;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
// This component is meant to capture the props of the DataList.Filters
|
|
23
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
24
|
+
function DataListFilters(_) {
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Renders the DataList.Filters component
|
|
29
|
+
*/
|
|
30
|
+
function InternalDataListFilters() {
|
|
31
|
+
const { children: parentChildren } = useDataListContext();
|
|
32
|
+
const showHeader = useShowHeader();
|
|
33
|
+
const showSortButton = !showHeader;
|
|
34
|
+
const component = getCompoundComponent(parentChildren, DataListFilters);
|
|
35
|
+
if (!showSortButton && !component)
|
|
36
|
+
return null;
|
|
37
|
+
const children = component === null || component === void 0 ? void 0 : component.props.children;
|
|
38
|
+
return (React.createElement(DataListOverflowFade, null,
|
|
39
|
+
children && children,
|
|
40
|
+
showSortButton && React.createElement(DataListSort, null)));
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export { DataListFilters as D, InternalDataListFilters as I };
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var DataListSort = require('./DataListSort-Dx6POURf.js');
|
|
5
|
+
var DataListOverflowFade = require('./DataListOverflowFade-BGAt4dqm.js');
|
|
6
|
+
var DataListContext = require('./DataListContext-qFN5DiHI.js');
|
|
7
|
+
var DataList_utils = require('./DataList.utils-BjG-otvz.js');
|
|
8
|
+
var useResponsiveSizing = require('./useResponsiveSizing-DB6K2Viw.js');
|
|
9
|
+
|
|
10
|
+
function useShowHeader() {
|
|
11
|
+
const { headerVisibility } = DataListContext.useDataListContext();
|
|
12
|
+
if (headerVisibility === undefined)
|
|
13
|
+
return true;
|
|
14
|
+
const sizes = useResponsiveSizing.useResponsiveSizing();
|
|
15
|
+
const sizeKeys = Object.keys(sizes);
|
|
16
|
+
const showHeader = sizeKeys.reduce((previous, breakpoint) => {
|
|
17
|
+
const isHeaderVisible = headerVisibility[breakpoint] || false;
|
|
18
|
+
const isBreakpointTriggered = sizes[breakpoint];
|
|
19
|
+
return previous || (isBreakpointTriggered && isHeaderVisible);
|
|
20
|
+
}, false);
|
|
21
|
+
return showHeader;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
// This component is meant to capture the props of the DataList.Filters
|
|
25
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
26
|
+
function DataListFilters(_) {
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Renders the DataList.Filters component
|
|
31
|
+
*/
|
|
32
|
+
function InternalDataListFilters() {
|
|
33
|
+
const { children: parentChildren } = DataListContext.useDataListContext();
|
|
34
|
+
const showHeader = useShowHeader();
|
|
35
|
+
const showSortButton = !showHeader;
|
|
36
|
+
const component = DataList_utils.getCompoundComponent(parentChildren, DataListFilters);
|
|
37
|
+
if (!showSortButton && !component)
|
|
38
|
+
return null;
|
|
39
|
+
const children = component === null || component === void 0 ? void 0 : component.props.children;
|
|
40
|
+
return (React.createElement(DataListOverflowFade.DataListOverflowFade, null,
|
|
41
|
+
children && children,
|
|
42
|
+
showSortButton && React.createElement(DataListSort.DataListSort, null)));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
exports.DataListFilters = DataListFilters;
|
|
46
|
+
exports.InternalDataListFilters = InternalDataListFilters;
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { u as useDataListContext } from './DataListContext-DTtBXteA.js';
|
|
3
|
+
import { c as generateHeaderElements, s as sortBreakpoints } from './DataList.utils-RcG6TvB4.js';
|
|
4
|
+
import { u as useResponsiveSizing } from './useResponsiveSizing-DVb-nBuX.js';
|
|
5
|
+
import classnames from 'classnames';
|
|
6
|
+
import { A as AnimatedSwitcher } from './AnimatedSwitcher--j45gdP1.js';
|
|
7
|
+
import { T as Text } from './Text-CfxmOdM-.js';
|
|
8
|
+
import { B as Button } from './Button-BH4Hhr2S.js';
|
|
9
|
+
import { C as Checkbox } from './Checkbox-BDVwj5E8.js';
|
|
10
|
+
import { s as styles } from './DataList-BRPBlIVp.js';
|
|
11
|
+
import { I as InternalDataListBulkActions } from './DataListBulkActions-C2E5e2oE.js';
|
|
12
|
+
import { u as useBatchSelect } from './useBatchSelect-KPnTra4u.js';
|
|
13
|
+
import { u as useActiveLayout } from './useActiveLayout-BqE7ZQY7.js';
|
|
14
|
+
|
|
15
|
+
function DataListHeaderCheckbox({ children }) {
|
|
16
|
+
const { sm } = useResponsiveSizing();
|
|
17
|
+
const { data, totalCount } = useDataListContext();
|
|
18
|
+
const { canSelectAll, hasAtLeastOneSelected, isSelectAll, selectedCount, selectedIDs, selected, onSelectAll, onSelect, } = useBatchSelect();
|
|
19
|
+
// If there's no onSelectAll or onSelect, we don't need to render the checkbox.
|
|
20
|
+
if (!canSelectAll)
|
|
21
|
+
return children;
|
|
22
|
+
const deselectText = sm ? "Deselect All" : "Deselect";
|
|
23
|
+
const selectedLabel = selectedCount ? `${selectedCount} selected` : "";
|
|
24
|
+
return (React.createElement("div", { className: styles.selectable },
|
|
25
|
+
React.createElement("div", { className: classnames(styles.selectAllCheckbox, {
|
|
26
|
+
[styles.visible]: canSelectAll,
|
|
27
|
+
}) },
|
|
28
|
+
React.createElement(Checkbox, { checked: isAllSelected(), indeterminate: isIndeterminate(), onChange: handleSelectAll },
|
|
29
|
+
React.createElement("div", { className: styles.srOnly }, selectedLabel))),
|
|
30
|
+
React.createElement(AnimatedSwitcher, { switched: hasAtLeastOneSelected, initialChild: children, switchTo: React.createElement("div", { className: styles.batchSelectContainer },
|
|
31
|
+
React.createElement("div", { className: styles.headerBatchSelect },
|
|
32
|
+
Boolean(selectedCount) && React.createElement(Text, null,
|
|
33
|
+
selectedCount,
|
|
34
|
+
" selected"),
|
|
35
|
+
React.createElement(Button, { label: deselectText, onClick: () => onSelect === null || onSelect === void 0 ? void 0 : onSelect([]), type: "tertiary" })),
|
|
36
|
+
React.createElement(InternalDataListBulkActions, null)) })));
|
|
37
|
+
function isIndeterminate() {
|
|
38
|
+
if (isSelectAll)
|
|
39
|
+
return selectedIDs.length > 0;
|
|
40
|
+
return selectedCount > 0 && !isAllSelected();
|
|
41
|
+
}
|
|
42
|
+
function isAllSelected() {
|
|
43
|
+
if (isSelectAll)
|
|
44
|
+
return true;
|
|
45
|
+
// If there's a totalCount, we can use that to accurately determine if the
|
|
46
|
+
// user have "selected all".
|
|
47
|
+
if (totalCount) {
|
|
48
|
+
return totalCount === selectedCount;
|
|
49
|
+
}
|
|
50
|
+
// Otherwise, we'll use the total count of data. This is not as reliable, as
|
|
51
|
+
// it's possible that the would select all loaded data while we're
|
|
52
|
+
// loading more. It's still hard to get to that state as the load more
|
|
53
|
+
// triggers before you see the last item.
|
|
54
|
+
return data.length > 0 && selectedCount >= data.length;
|
|
55
|
+
}
|
|
56
|
+
function handleSelectAll() {
|
|
57
|
+
if (isAllSelected()) {
|
|
58
|
+
return onSelectAll === null || onSelectAll === void 0 ? void 0 : onSelectAll([]);
|
|
59
|
+
}
|
|
60
|
+
onSelectAll === null || onSelectAll === void 0 ? void 0 : onSelectAll({ totalCount: getTotalCount(), unselected: [] });
|
|
61
|
+
}
|
|
62
|
+
function getTotalCount() {
|
|
63
|
+
if (selected && "totalCount" in selected)
|
|
64
|
+
return selected.totalCount;
|
|
65
|
+
if (totalCount)
|
|
66
|
+
return totalCount;
|
|
67
|
+
return 0;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
function DataListHeader() {
|
|
72
|
+
const breakpoints = useResponsiveSizing();
|
|
73
|
+
const { headerVisibility = { xs: true, sm: true, md: true, lg: true, xl: true }, headers, layoutBreakpoints, } = useDataListContext();
|
|
74
|
+
const { hasAtLeastOneSelected } = useBatchSelect();
|
|
75
|
+
const size = getVisibleSize();
|
|
76
|
+
const { layout } = useActiveLayout();
|
|
77
|
+
const visible = headerVisibility[size];
|
|
78
|
+
if ((!visible && !hasAtLeastOneSelected) || !layout)
|
|
79
|
+
return null;
|
|
80
|
+
const headerData = generateHeaderElements(headers);
|
|
81
|
+
if (!headerData)
|
|
82
|
+
return null;
|
|
83
|
+
return (React.createElement("div", { className: styles.headerTitles },
|
|
84
|
+
React.createElement(DataListHeaderCheckbox, null, layout(headerData))));
|
|
85
|
+
function getVisibleSize() {
|
|
86
|
+
const visibilityKeys = Object.keys(headerVisibility);
|
|
87
|
+
const headerBreakpoints = sortBreakpoints(visibilityKeys).reverse();
|
|
88
|
+
const visibleHeaderSize = headerBreakpoints.find(key => breakpoints[key]);
|
|
89
|
+
return visibleHeaderSize || layoutBreakpoints[0];
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
export { DataListHeader as D };
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var DataListContext = require('./DataListContext-qFN5DiHI.js');
|
|
5
|
+
var DataList_utils = require('./DataList.utils-BjG-otvz.js');
|
|
6
|
+
var useResponsiveSizing = require('./useResponsiveSizing-DB6K2Viw.js');
|
|
7
|
+
var classnames = require('classnames');
|
|
8
|
+
var AnimatedSwitcher = require('./AnimatedSwitcher-D_Qj_hx5.js');
|
|
9
|
+
var Text = require('./Text-BKFV1Z0j.js');
|
|
10
|
+
var Button = require('./Button-BPYGeGx2.js');
|
|
11
|
+
var Checkbox = require('./Checkbox-DDDvFfUJ.js');
|
|
12
|
+
var DataList = require('./DataList-C_diEjjb.js');
|
|
13
|
+
var DataListBulkActions = require('./DataListBulkActions-BEFyOkWd.js');
|
|
14
|
+
var useBatchSelect = require('./useBatchSelect-rQ55uZ7U.js');
|
|
15
|
+
var useActiveLayout = require('./useActiveLayout-BSipZn9t.js');
|
|
16
|
+
|
|
17
|
+
function DataListHeaderCheckbox({ children }) {
|
|
18
|
+
const { sm } = useResponsiveSizing.useResponsiveSizing();
|
|
19
|
+
const { data, totalCount } = DataListContext.useDataListContext();
|
|
20
|
+
const { canSelectAll, hasAtLeastOneSelected, isSelectAll, selectedCount, selectedIDs, selected, onSelectAll, onSelect, } = useBatchSelect.useBatchSelect();
|
|
21
|
+
// If there's no onSelectAll or onSelect, we don't need to render the checkbox.
|
|
22
|
+
if (!canSelectAll)
|
|
23
|
+
return children;
|
|
24
|
+
const deselectText = sm ? "Deselect All" : "Deselect";
|
|
25
|
+
const selectedLabel = selectedCount ? `${selectedCount} selected` : "";
|
|
26
|
+
return (React.createElement("div", { className: DataList.styles.selectable },
|
|
27
|
+
React.createElement("div", { className: classnames(DataList.styles.selectAllCheckbox, {
|
|
28
|
+
[DataList.styles.visible]: canSelectAll,
|
|
29
|
+
}) },
|
|
30
|
+
React.createElement(Checkbox.Checkbox, { checked: isAllSelected(), indeterminate: isIndeterminate(), onChange: handleSelectAll },
|
|
31
|
+
React.createElement("div", { className: DataList.styles.srOnly }, selectedLabel))),
|
|
32
|
+
React.createElement(AnimatedSwitcher.AnimatedSwitcher, { switched: hasAtLeastOneSelected, initialChild: children, switchTo: React.createElement("div", { className: DataList.styles.batchSelectContainer },
|
|
33
|
+
React.createElement("div", { className: DataList.styles.headerBatchSelect },
|
|
34
|
+
Boolean(selectedCount) && React.createElement(Text.Text, null,
|
|
35
|
+
selectedCount,
|
|
36
|
+
" selected"),
|
|
37
|
+
React.createElement(Button.Button, { label: deselectText, onClick: () => onSelect === null || onSelect === void 0 ? void 0 : onSelect([]), type: "tertiary" })),
|
|
38
|
+
React.createElement(DataListBulkActions.InternalDataListBulkActions, null)) })));
|
|
39
|
+
function isIndeterminate() {
|
|
40
|
+
if (isSelectAll)
|
|
41
|
+
return selectedIDs.length > 0;
|
|
42
|
+
return selectedCount > 0 && !isAllSelected();
|
|
43
|
+
}
|
|
44
|
+
function isAllSelected() {
|
|
45
|
+
if (isSelectAll)
|
|
46
|
+
return true;
|
|
47
|
+
// If there's a totalCount, we can use that to accurately determine if the
|
|
48
|
+
// user have "selected all".
|
|
49
|
+
if (totalCount) {
|
|
50
|
+
return totalCount === selectedCount;
|
|
51
|
+
}
|
|
52
|
+
// Otherwise, we'll use the total count of data. This is not as reliable, as
|
|
53
|
+
// it's possible that the would select all loaded data while we're
|
|
54
|
+
// loading more. It's still hard to get to that state as the load more
|
|
55
|
+
// triggers before you see the last item.
|
|
56
|
+
return data.length > 0 && selectedCount >= data.length;
|
|
57
|
+
}
|
|
58
|
+
function handleSelectAll() {
|
|
59
|
+
if (isAllSelected()) {
|
|
60
|
+
return onSelectAll === null || onSelectAll === void 0 ? void 0 : onSelectAll([]);
|
|
61
|
+
}
|
|
62
|
+
onSelectAll === null || onSelectAll === void 0 ? void 0 : onSelectAll({ totalCount: getTotalCount(), unselected: [] });
|
|
63
|
+
}
|
|
64
|
+
function getTotalCount() {
|
|
65
|
+
if (selected && "totalCount" in selected)
|
|
66
|
+
return selected.totalCount;
|
|
67
|
+
if (totalCount)
|
|
68
|
+
return totalCount;
|
|
69
|
+
return 0;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
function DataListHeader() {
|
|
74
|
+
const breakpoints = useResponsiveSizing.useResponsiveSizing();
|
|
75
|
+
const { headerVisibility = { xs: true, sm: true, md: true, lg: true, xl: true }, headers, layoutBreakpoints, } = DataListContext.useDataListContext();
|
|
76
|
+
const { hasAtLeastOneSelected } = useBatchSelect.useBatchSelect();
|
|
77
|
+
const size = getVisibleSize();
|
|
78
|
+
const { layout } = useActiveLayout.useActiveLayout();
|
|
79
|
+
const visible = headerVisibility[size];
|
|
80
|
+
if ((!visible && !hasAtLeastOneSelected) || !layout)
|
|
81
|
+
return null;
|
|
82
|
+
const headerData = DataList_utils.generateHeaderElements(headers);
|
|
83
|
+
if (!headerData)
|
|
84
|
+
return null;
|
|
85
|
+
return (React.createElement("div", { className: DataList.styles.headerTitles },
|
|
86
|
+
React.createElement(DataListHeaderCheckbox, null, layout(headerData))));
|
|
87
|
+
function getVisibleSize() {
|
|
88
|
+
const visibilityKeys = Object.keys(headerVisibility);
|
|
89
|
+
const headerBreakpoints = DataList_utils.sortBreakpoints(visibilityKeys).reverse();
|
|
90
|
+
const visibleHeaderSize = headerBreakpoints.find(key => breakpoints[key]);
|
|
91
|
+
return visibleHeaderSize || layoutBreakpoints[0];
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
exports.DataListHeader = DataListHeader;
|