@jobber/components 4.92.0 → 4.92.1-JOB-91143.4
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-C7_0OG8K.js} +3 -7
- package/dist/AnimatedPresence-DuP07qsR.js +98 -0
- package/dist/AnimatedSwitcher/index.cjs +11 -0
- package/dist/AnimatedSwitcher/index.mjs +5 -0
- package/dist/AnimatedSwitcher-DOQq-lwI.js +90 -0
- package/dist/{AnimatedSwitcher-3d45ec5d.js → AnimatedSwitcher-DypsdKLY.js} +4 -8
- package/dist/AtlantisContext/{index.js → index.cjs} +1 -3
- package/dist/AtlantisContext/index.mjs +2 -0
- package/dist/AtlantisContext-vajd9Fye.js +18 -0
- package/dist/Autocomplete/index.cjs +33 -0
- package/dist/Autocomplete/index.mjs +27 -0
- package/dist/Autocomplete-BG15vNs1.js +192 -0
- package/dist/Autocomplete-oDRc9WsO.js +190 -0
- package/dist/Avatar/index.cjs +12 -0
- package/dist/Avatar/index.mjs +6 -0
- package/dist/Avatar-5fBKFezP.js +67 -0
- package/dist/Avatar-CVgBcpGi.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-BIHgdvV3.js +81 -0
- package/dist/Banner-BUy2m7mr.js +79 -0
- package/dist/BannerIcon-BoW3uKD-.js +19 -0
- package/dist/BannerIcon-DWpqnHvJ.js +22 -0
- package/dist/Body-BXB4Ywng.js +45 -0
- package/dist/Body-ByAvs9el.js +54 -0
- package/dist/Button/index.cjs +13 -0
- package/dist/Button/index.mjs +7 -0
- package/dist/Button-CKxjsn8f.js +47 -0
- package/dist/Button-DE6Du5Wv.js +49 -0
- package/dist/ButtonDismiss/index.cjs +14 -0
- package/dist/ButtonDismiss/index.mjs +8 -0
- package/dist/ButtonDismiss-BIVGFM9M.js +8 -0
- package/dist/ButtonDismiss-DjOs7eO3.js +10 -0
- package/dist/Card/index.cjs +21 -0
- package/dist/Card/index.mjs +15 -0
- package/dist/Card-CW-modgy.js +83 -0
- package/dist/Card-DOzOOnY0.js +81 -0
- package/dist/Checkbox/index.cjs +15 -0
- package/dist/Checkbox/index.mjs +9 -0
- package/dist/Checkbox-3Qa3Mp4s.js +55 -0
- package/dist/Checkbox-BVH5HUy3.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-BRA8Ie1D.js +70 -0
- package/dist/Chip-D5t8gDBN.js +67 -0
- package/dist/ChipDismissible-BfodalJt.js +22 -0
- package/dist/ChipDismissible-D7vWlDtB.js +19 -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-CYDxrU8D.js +91 -0
- package/dist/Chips-ZogWZIAB.js +93 -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-4g_P-scs.js +119 -0
- package/dist/Combobox-C9lk5lGs.js +117 -0
- package/dist/ComboboxAction-CDXUQcsS.js +22 -0
- package/dist/ComboboxAction-Ci7RkWIs.js +24 -0
- package/dist/ComboboxActivator-DC7UbnAU.js +26 -0
- package/dist/ComboboxActivator-Wru82KGv.js +28 -0
- package/dist/ComboboxContent-B3t3fDTn.js +143 -0
- package/dist/ComboboxContent-FcsdPGqc.js +145 -0
- package/dist/ComboboxContentHeader-CudWca0J.js +29 -0
- package/dist/ComboboxContentHeader-CwgZyJ-n.js +27 -0
- package/dist/ComboboxContentList-B84jQ_k9.js +77 -0
- package/dist/ComboboxContentList-BlSsa2wi.js +75 -0
- package/dist/ComboboxContentSearch-B76E7yYs.js +32 -0
- package/dist/ComboboxContentSearch-DH_9gdSF.js +34 -0
- package/dist/ComboboxLoadMore-BnhP-b9N.js +16 -0
- package/dist/ComboboxLoadMore-CKnSg956.js +14 -0
- package/dist/ComboboxOption-CmhVk1Tm.js +20 -0
- package/dist/ComboboxOption-fq9MC5fv.js +22 -0
- package/dist/ComboboxProvider-B1d2SG67.js +13 -0
- package/dist/ComboboxProvider-BpcqvBBD.js +10 -0
- package/dist/ComboboxTrigger-CBviayim.js +24 -0
- package/dist/ComboboxTrigger-D6M0Glk-.js +22 -0
- package/dist/ConfirmationModal/index.cjs +31 -0
- package/dist/ConfirmationModal/index.mjs +25 -0
- package/dist/{ConfirmationModal-c0b5e893.js → ConfirmationModal-MK_2VfpM.js} +8 -12
- package/dist/ConfirmationModal-rAPd3iIk.js +94 -0
- package/dist/Content/index.cjs +9 -0
- package/dist/Content/index.mjs +3 -0
- package/dist/Content-DErBfjY3.js +15 -0
- package/dist/Content-DvE60Q2i.js +13 -0
- package/dist/Countdown/index.cjs +11 -0
- package/dist/Countdown/index.mjs +5 -0
- package/dist/Countdown-CfRvv0Ww.js +657 -0
- package/dist/Countdown-DliSLLhR.js +659 -0
- package/dist/DataDump/index.cjs +24 -0
- package/dist/DataDump/index.mjs +18 -0
- package/dist/DataDump-CyNg2_YY.js +17 -0
- package/dist/DataDump-zMz56TNi.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-B7x2oFVS.js +139 -0
- package/dist/DataList-BNQqXKIC.js +5 -0
- package/dist/DataList-Br4dFDOB.js +3 -0
- package/dist/DataList-Cu_Ae-fT.js +141 -0
- package/dist/DataList.const-Bhvz7Luy.js +38 -0
- package/dist/DataList.const-C329b2_o.js +25 -0
- package/dist/DataList.utils-C_f0XZRT.js +168 -0
- package/dist/DataList.utils-hr_HVCYl.js +161 -0
- package/dist/DataListAction-CGHgpeIN.js +39 -0
- package/dist/DataListAction-ymAGmjKg.js +37 -0
- package/dist/DataListActions-2RjU1dqb.js +45 -0
- package/dist/DataListActions-C6ZysnI5.js +43 -0
- package/dist/DataListActionsMenu-D6jGO6-B.js +57 -0
- package/dist/DataListActionsMenu-D98jRKew.js +55 -0
- package/dist/DataListBulkActions-CImnK1P5.js +29 -0
- package/dist/DataListBulkActions-DTrhDaNb.js +26 -0
- package/dist/DataListContext-DikZuZOD.js +29 -0
- package/dist/DataListContext-VbiGFkPI.js +25 -0
- package/dist/DataListEmptyState-C5r8SfIE.js +50 -0
- package/dist/DataListEmptyState-zgu3AGxu.js +53 -0
- package/dist/DataListFilters-DigCSxBy.js +43 -0
- package/dist/DataListFilters-NOmECi3p.js +46 -0
- package/dist/DataListHeader-B5iRESYw.js +95 -0
- package/dist/DataListHeader-JCeJNeuy.js +93 -0
- package/dist/DataListHeaderTile-CT3k41HG.js +80 -0
- package/dist/DataListHeaderTile-CZIjDn8L.js +82 -0
- package/dist/DataListItem-4Ix109is.js +114 -0
- package/dist/DataListItem-ChTxYoqE.js +112 -0
- package/dist/DataListItemActions-CQ8hDqYw.js +29 -0
- package/dist/DataListItemActions-D5wUuHMv.js +32 -0
- package/dist/DataListItemActionsOverflow-B_u6m2o9.js +33 -0
- package/dist/DataListItemActionsOverflow-DIzayDpq.js +35 -0
- package/dist/DataListItemClickable-Bt5Ucj0t.js +47 -0
- package/dist/DataListItemClickable-IwbswX6H.js +45 -0
- package/dist/DataListItems-BWg5lHjy.js +19 -0
- package/dist/DataListItems-Drq7j4YK.js +21 -0
- package/dist/DataListLayout-BgG0MMDj.js +19 -0
- package/dist/DataListLayout-DZynXNte.js +21 -0
- package/dist/DataListLayoutActions-AWqreR_S.js +36 -0
- package/dist/DataListLayoutActions-DeJK3JlE.js +38 -0
- package/dist/DataListLayoutContext--JcgS5I5.js +8 -0
- package/dist/DataListLayoutContext-D23XP8tN.js +11 -0
- package/dist/DataListLayoutContext-DWW2jgpD.js +18 -0
- package/dist/DataListLayoutContext-pSkER2Lr.js +14 -0
- package/dist/DataListLoadMore-CjCviC3F.js +34 -0
- package/dist/DataListLoadMore-jXRGVlFE.js +31 -0
- package/dist/DataListLoadingState-Bx7XgOwA.js +22 -0
- package/dist/DataListLoadingState-CSKfVetd.js +26 -0
- package/dist/DataListOverflowFade-DDkSdQhd.js +22 -0
- package/dist/DataListOverflowFade-DRoqry1j.js +25 -0
- package/dist/DataListSearch-CQY9fc7a.js +59 -0
- package/dist/DataListSearch-CjjEiz9Q.js +63 -0
- package/dist/DataListSort-DCNk7yyf.js +92 -0
- package/dist/DataListSort-invC98NZ.js +94 -0
- package/dist/DataListSortingOptions-CRMfOuGM.js +35 -0
- package/dist/DataListSortingOptions-sgWugbZH.js +37 -0
- package/dist/DataListStatusBar-Bc1dPDj_.js +22 -0
- package/dist/DataListStatusBar-C5HWzkA7.js +25 -0
- package/dist/DataListStickyHeader-MBgJBBb6.js +25 -0
- package/dist/DataListStickyHeader-O_e64YEP.js +23 -0
- package/dist/DataListTags-BG05pYRr.js +62 -0
- package/dist/DataListTags-DhUvQkt9.js +64 -0
- package/dist/DataListTotalCount-Ba0aAw-B.js +27 -0
- package/dist/DataListTotalCount-CKgXrXkX.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-Dl89aEOa.js +236 -0
- package/dist/DataTable-iSgYQH5p.js +238 -0
- package/dist/DatePicker/index.cjs +26 -0
- package/dist/DatePicker/index.mjs +20 -0
- package/dist/DatePicker-BpDKGmIl.js +8551 -0
- package/dist/DatePicker-CvQJ4m4F.js +8554 -0
- package/dist/DayOfMonthSelect-abrJ8VI9.js +137 -0
- package/dist/DayOfMonthSelect-t0nv438k.js +130 -0
- package/dist/DescriptionList/index.cjs +10 -0
- package/dist/DescriptionList/index.mjs +4 -0
- package/dist/DescriptionList-C2P6fxRg.js +14 -0
- package/dist/DescriptionList-DnPmrW50.js +12 -0
- package/dist/Disclosure/index.cjs +17 -0
- package/dist/Disclosure/index.mjs +11 -0
- package/dist/Disclosure-Du27Rftc.js +35 -0
- package/dist/Disclosure-DwDbK7TS.js +33 -0
- package/dist/Divider/index.cjs +9 -0
- package/dist/Divider/index.mjs +3 -0
- package/dist/Divider-02U5Br4P.js +19 -0
- package/dist/Divider-WHJnTEQ7.js +17 -0
- package/dist/Drawer/index.cjs +19 -0
- package/dist/Drawer/index.mjs +12 -0
- package/dist/DrawerGrid-BbRnqv1A.js +28 -0
- package/dist/DrawerGrid-BlhKZeYC.js +31 -0
- package/dist/Emphasis/index.cjs +10 -0
- package/dist/Emphasis/index.mjs +4 -0
- package/dist/Emphasis-ByZi7T6Z.js +13 -0
- package/dist/Emphasis-JTjJXWkg.js +15 -0
- package/dist/FeatureSwitch/index.cjs +26 -0
- package/dist/FeatureSwitch/index.mjs +20 -0
- package/dist/FeatureSwitch-BFrC78kj.js +54 -0
- package/dist/FeatureSwitch-ByeZTRwR.js +52 -0
- package/dist/Flex/index.cjs +9 -0
- package/dist/Flex/index.mjs +3 -0
- package/dist/Flex-BkRBJK0Z.js +30 -0
- package/dist/Flex-DQVyK7wo.js +28 -0
- package/dist/Form/index.cjs +10 -0
- package/dist/Form/index.mjs +4 -0
- package/dist/Form-BZeUfE2t.js +48 -0
- package/dist/{Form/index.js → Form-DUTTuYPf.js} +3 -9
- package/dist/FormField/index.cjs +20 -0
- package/dist/FormField/index.mjs +14 -0
- package/dist/FormField-D7z5-WII.js +263 -0
- package/dist/FormField-hdVpso_w.js +261 -0
- package/dist/FormatDate/{index.js → index.cjs} +1 -3
- package/dist/FormatDate/index.mjs +2 -0
- package/dist/FormatDate-Brr2_Lfu.js +27 -0
- package/dist/{FormatDate-70ea5b43.js → FormatDate-CE_p3d5L.js} +1 -5
- package/dist/FormatEmail/index.cjs +9 -0
- package/dist/FormatEmail/index.mjs +3 -0
- package/dist/FormatEmail-B326Qd3m.js +11 -0
- package/dist/FormatEmail-D6AV_2nc.js +13 -0
- package/dist/FormatFile/index.cjs +36 -0
- package/dist/FormatFile/index.mjs +30 -0
- package/dist/FormatFile-CDd5WXPj.js +149 -0
- package/dist/FormatFile-DxfGUhYm.js +147 -0
- package/dist/FormatRelativeDateTime/index.cjs +8 -0
- package/dist/FormatRelativeDateTime/index.mjs +2 -0
- package/dist/FormatRelativeDateTime-B9bjZ-eX.js +64 -0
- package/dist/{FormatRelativeDateTime/index.js → FormatRelativeDateTime-CXzEyJFr.js} +5 -11
- package/dist/FormatTime/index.cjs +8 -0
- package/dist/FormatTime/index.mjs +2 -0
- package/dist/FormatTime-B-wa4KRb.js +29 -0
- package/dist/{FormatTime/index.js → FormatTime-B91IsX-x.js} +1 -7
- package/dist/Gallery/index.cjs +42 -0
- package/dist/Gallery/index.mjs +36 -0
- package/dist/Gallery-1x8eXLka.js +63 -0
- package/dist/Gallery-DK44lD2R.js +65 -0
- package/dist/Glimmer/index.cjs +12 -0
- package/dist/Glimmer/index.mjs +5 -0
- package/dist/Glimmer-B5eYryBF.js +60 -0
- package/dist/Glimmer-D0tv78WP.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-AIrBh4rt.js +32 -0
- package/dist/Grid-C5FWfhEs.js +29 -0
- package/dist/Heading/index.cjs +12 -0
- package/dist/Heading/index.mjs +6 -0
- package/dist/{Heading-ffc87a2a.js → Heading-BhKK7vho.js} +3 -7
- package/dist/Heading-CN8xip8K.js +49 -0
- package/dist/Icon/index.cjs +9 -0
- package/dist/Icon/index.mjs +3 -0
- package/dist/Icon-BJUSeqrr.js +34 -0
- package/dist/Icon-DjU29wkY.js +36 -0
- package/dist/InlineLabel/index.cjs +10 -0
- package/dist/InlineLabel/index.mjs +4 -0
- package/dist/InlineLabel-BF3sXYgM.js +20 -0
- package/dist/InlineLabel-CdbTX3Qa.js +18 -0
- package/dist/InputAvatar/index.cjs +26 -0
- package/dist/InputAvatar/index.mjs +20 -0
- package/dist/InputAvatar-BdAiPSSn.js +49 -0
- package/dist/InputAvatar-CPLTarYo.js +47 -0
- package/dist/InputDate/index.cjs +34 -0
- package/dist/InputDate/index.mjs +28 -0
- package/dist/InputDate-BN9KkEfE.js +48 -0
- package/dist/{InputDate/index.js → InputDate-BquD5lFz.js} +6 -31
- package/dist/InputEmail/index.cjs +22 -0
- package/dist/InputEmail/index.mjs +15 -0
- package/dist/InputEmail-CpyoerVx.js +23 -0
- package/dist/InputEmail-TUmHsMNX.js +20 -0
- package/dist/InputFile/index.cjs +23 -0
- package/dist/InputFile/index.mjs +16 -0
- package/dist/InputFile-DMnF1pDx.js +1611 -0
- package/dist/InputFile-OoWKy7q9.js +1608 -0
- package/dist/InputGroup/index.cjs +9 -0
- package/dist/InputGroup/index.mjs +3 -0
- package/dist/InputGroup-BFZ64kWc.js +25 -0
- package/dist/InputGroup-t1rzSE0F.js +23 -0
- package/dist/InputNumber/index.cjs +21 -0
- package/dist/InputNumber/index.mjs +15 -0
- package/dist/{InputNumber-f1990039.js → InputNumber-DL9rK650.js} +2 -6
- package/dist/InputNumber-u7uPvLgZ.js +56 -0
- package/dist/InputPassword/index.cjs +21 -0
- package/dist/InputPassword/index.mjs +15 -0
- package/dist/InputPassword-CqBOZ112.js +19 -0
- package/dist/InputPassword-cLUOeqk-.js +21 -0
- package/dist/InputPhoneNumber/index.cjs +21 -0
- package/dist/InputPhoneNumber/index.mjs +15 -0
- package/dist/InputPhoneNumber-B2FFUWwm.js +94 -0
- package/dist/{InputPhoneNumber/index.js → InputPhoneNumber-DxMxWR2z.js} +7 -27
- package/dist/InputText/index.cjs +22 -0
- package/dist/InputText/index.mjs +16 -0
- package/dist/InputText-Qhl0INR-.js +96 -0
- package/dist/{InputText-375a415c.js → InputText-nucFL4pz.js} +4 -8
- package/dist/InputTime/index.cjs +26 -0
- package/dist/InputTime/index.mjs +20 -0
- package/dist/{InputTime/index.js → InputTime-Bj4P_56s.js} +5 -25
- package/dist/InputTime-pPxm1wr1.js +190 -0
- package/dist/InputValidation/index.cjs +14 -0
- package/dist/InputValidation/index.mjs +8 -0
- package/dist/InputValidation-BY33gA8g.js +20 -0
- package/dist/InputValidation-BvTmvsYp.js +22 -0
- package/dist/InternalChipDismissible-LAkxRtnV.js +152 -0
- package/dist/InternalChipDismissible-PISlerj_.js +157 -0
- package/dist/InternalGridCell-BprDm5Fi.js +37 -0
- package/dist/InternalGridCell-DyWZRqAY.js +34 -0
- package/dist/LightBox/index.cjs +26 -0
- package/dist/LightBox/index.mjs +20 -0
- package/dist/LightBox-BWUWUkUD.js +112 -0
- package/dist/LightBox-D6Z6s0_U.js +110 -0
- package/dist/Link/index.cjs +8 -0
- package/dist/Link/index.mjs +2 -0
- package/dist/Link-B7ix2LW9.js +7 -0
- package/dist/Link-Cl2pzeag.js +9 -0
- package/dist/List/index.cjs +29 -0
- package/dist/List/index.mjs +22 -0
- package/dist/List-C3IcqOZZ.js +186 -0
- package/dist/List-D1li09_A.js +189 -0
- package/dist/Markdown/index.cjs +19 -0
- package/dist/Markdown/index.mjs +13 -0
- package/dist/Markdown-CRBKB6xQ.js +19013 -0
- package/dist/Markdown-DroxcM3U.js +19011 -0
- package/dist/Menu/index.cjs +18 -0
- package/dist/Menu/index.mjs +12 -0
- package/dist/Menu-BKIXU731.js +131 -0
- package/dist/Menu-DbsQFQOW.js +129 -0
- package/dist/Modal/index.cjs +23 -0
- package/dist/Modal/index.mjs +17 -0
- package/dist/Modal-Dx1bOlz7.js +63 -0
- package/dist/Modal-JhusMU4D.js +61 -0
- package/dist/MultiSelect/index.cjs +16 -0
- package/dist/MultiSelect/index.mjs +10 -0
- package/dist/MultiSelect-B2vx9vLw.js +166 -0
- package/dist/MultiSelect-But9vE7v.js +164 -0
- package/dist/Option-C2vJjWfu.js +15 -0
- package/dist/Option-m08lH3jJ.js +12 -0
- package/dist/Page/index.cjs +32 -0
- package/dist/Page/index.mjs +26 -0
- package/dist/Page-BU3T-y1q.js +58 -0
- package/dist/Page-DV_XwjfX.js +56 -0
- package/dist/Popover/index.cjs +17 -0
- package/dist/Popover/index.mjs +11 -0
- package/dist/Popover-B-KE_eFI.js +48 -0
- package/dist/Popover-CHu9ozKj.js +50 -0
- package/dist/ProgressBar/index.cjs +9 -0
- package/dist/ProgressBar/index.mjs +3 -0
- package/dist/ProgressBar-B5zkI3pM.js +33 -0
- package/dist/ProgressBar-s-XzXLlQ.js +31 -0
- package/dist/RadioGroup/index.cjs +12 -0
- package/dist/RadioGroup/index.mjs +5 -0
- package/dist/RadioGroup-BjKA09z3.js +39 -0
- package/dist/RadioGroup-CaUGNOG2.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-6-wdlnln.js +71 -0
- package/dist/RecurringSelect-B0Gq9jU1.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-4_B4sbFF.js +16 -0
- package/dist/Spinner-AOCiYGuW.js +14 -0
- package/dist/StatusIndicator/index.cjs +8 -0
- package/dist/StatusIndicator/index.mjs +2 -0
- package/dist/StatusIndicator-NtKs1bnS.js +11 -0
- package/dist/StatusIndicator-vPYWY92m.js +9 -0
- package/dist/StatusLabel/index.cjs +11 -0
- package/dist/StatusLabel/index.mjs +5 -0
- package/dist/StatusLabel-B0GIHhhK.js +18 -0
- package/dist/StatusLabel-CMT-yiLl.js +16 -0
- package/dist/Switch/index.cjs +10 -0
- package/dist/Switch/index.mjs +4 -0
- package/dist/Switch-CqAWEokO.js +48 -0
- package/dist/Switch-D2ujtfce.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-CRYN2A35.js +67 -0
- package/dist/Tabs-D5jT4HLS.js +70 -0
- package/dist/Text/index.cjs +10 -0
- package/dist/Text/index.mjs +4 -0
- package/dist/Text-9Y0IeH0M.js +25 -0
- package/dist/{Text-94b5c2e5.js → Text-CqfEADu0.js} +2 -6
- 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-D2U8LSaI.js +105 -0
- package/dist/Tooltip-DeXlEfZX.js +103 -0
- package/dist/Typography/index.cjs +9 -0
- package/dist/Typography/index.mjs +3 -0
- package/dist/Typography-CBz3Bwzs.js +38 -0
- package/dist/Typography-DBA8fJ4I.js +36 -0
- package/dist/_baseAssignValue-Br3FbMzF.js +29 -0
- package/dist/_baseAssignValue-Cvm5AXvh.js +31 -0
- package/dist/_baseEach-CTax1-yy.js +1069 -0
- package/dist/_baseEach-D8SssyxZ.js +1073 -0
- package/dist/_commonjsHelpers-C-Wbr7RH.js +32 -0
- package/dist/_commonjsHelpers-xAV1A7i5.js +36 -0
- package/dist/_defineProperty-BujIpPGc.js +1326 -0
- package/dist/_defineProperty-CjkR3-BA.js +1306 -0
- package/dist/_getTag-BKCeVxsL.js +733 -0
- package/dist/_getTag-DpOqMBPJ.js +718 -0
- package/dist/_polyfill-node.process-B_9ykg-O.js +255 -0
- package/dist/_polyfill-node.process-CYhOBsNv.js +258 -0
- package/dist/_setToString-CBBLiglb.js +234 -0
- package/dist/_setToString-CZpqSjYr.js +230 -0
- package/dist/debounce-BpTvHvBt.js +332 -0
- package/dist/debounce-Dd5GxxzC.js +329 -0
- package/dist/helpers-D1m0vSul.js +17 -0
- package/dist/helpers-DwMBemop.js +15 -0
- package/dist/index-BQdnPLod.js +1189 -0
- package/dist/index-BeAq-j7t.js +1186 -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-D72TVWLW.js +190 -0
- package/dist/isObjectLike-DkE0-lSd.js +197 -0
- package/dist/isSymbol-BdlIpdew.js +33 -0
- package/dist/isSymbol-DVwHxcm6.js +35 -0
- package/dist/noop-9CHQCFDx.js +26 -0
- package/dist/noop-CiBZ2qxz.js +24 -0
- package/dist/showToast-DdjKsUjz.js +99 -0
- package/dist/showToast-kK8ISglC.js +97 -0
- package/dist/styles.css +8743 -0
- package/dist/tslib.es6-BJzo8cuE.js +97 -0
- package/dist/tslib.es6-CjmNBqgv.js +102 -0
- package/dist/useActiveLayout-Bvi4Yx0s.js +14 -0
- package/dist/useActiveLayout-DOW95mNw.js +16 -0
- package/dist/useAssert-B1i-_d5Q.js +27 -0
- package/dist/useAssert-Bk9LtVuC.js +27 -0
- package/dist/useAtlantisConfig-CVSBhQb8.js +14 -0
- package/dist/{useAtlantisConfig-ed0bee66.js → useAtlantisConfig-D-Qo7OhV.js} +2 -2
- package/dist/useBatchSelect-4-bP-nq0.js +36 -0
- package/dist/useBatchSelect-rCfKq55l.js +38 -0
- package/dist/useChildComponent-D2t-5Jky.js +15 -0
- package/dist/useChildComponent-DktVoc_0.js +17 -0
- package/dist/useFocusTrap-Bk_llzCy.js +74 -0
- package/dist/useFocusTrap-BztNbnoA.js +74 -0
- package/dist/useInView-Dk25sanP.js +25 -0
- package/dist/useInView-NIKZBawt.js +25 -0
- package/dist/useIsMounted-CEL42pGR.js +47 -0
- package/dist/useIsMounted-DZig4aFK.js +47 -0
- package/dist/useOnKeyDown-BRrGkWfQ.js +40 -0
- package/dist/useOnKeyDown-Dtenmfc9.js +40 -0
- package/dist/useRefocusOnActivator-BCZuCyZg.js +32 -0
- package/dist/useRefocusOnActivator-Nc-vAHlK.js +32 -0
- package/dist/useResizeObserver-Blt1gsn-.js +1189 -0
- package/dist/useResizeObserver-BwdGHaB_.js +1192 -0
- package/dist/useResponsiveSizing-CN6AfX4o.js +51 -0
- package/dist/useResponsiveSizing-DXaps7kG.js +49 -0
- package/dist/useSafeLayoutEffect-BNLlFJBq.js +14 -0
- package/dist/useSafeLayoutEffect-CtAU_CL9.js +12 -0
- package/dist/useScrollToActive-BCcpdtxF.js +597 -0
- package/dist/useScrollToActive-Dd4eAK3b.js +591 -0
- package/package.json +410 -10
- package/{rollup.config.js → rollup.config.mjs} +49 -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-0c831b03.js +0 -57
- package/dist/ButtonDismiss/index.js +0 -17
- package/dist/ButtonDismiss-101366b5.js +0 -14
- package/dist/Card/index.js +0 -24
- package/dist/Card-2e03b887.js +0 -93
- package/dist/Checkbox/index.js +0 -18
- package/dist/Checkbox-67a8c60f.js +0 -63
- package/dist/Chip/index.js +0 -42
- package/dist/Chip-6395df79.js +0 -89
- package/dist/Chips/index.js +0 -525
- package/dist/Combobox/index.js +0 -41
- package/dist/Combobox-2f357a96.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-3b086bf8.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-f298e0bd.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-cea3a4f7.js +0 -253
- package/dist/FormatEmail/index.js +0 -23
- package/dist/FormatFile/index.js +0 -37
- package/dist/FormatFile-9cc4c85a.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-79098f71.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-07c0c738.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-ba5f81cb.js +0 -29
- package/dist/LightBox/index.js +0 -25
- package/dist/LightBox-ec2c0094.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-bee813fc.js +0 -62
- package/dist/Menu/index.js +0 -21
- package/dist/Menu-9477e5e3.js +0 -139
- package/dist/Modal/index.js +0 -26
- package/dist/Modal-03731670.js +0 -74
- package/dist/MultiSelect/index.js +0 -182
- package/dist/Option-085a96d7.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-2a8824e9.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-e9503dbd.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-8c397b84.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-LI1uQsX5.js} +0 -0
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var Menu = require('../Menu-BKIXU731.js');
|
|
4
|
+
require('react');
|
|
5
|
+
require('classnames');
|
|
6
|
+
require('framer-motion');
|
|
7
|
+
require('../useOnKeyDown-BRrGkWfQ.js');
|
|
8
|
+
require('../useRefocusOnActivator-Nc-vAHlK.js');
|
|
9
|
+
require('../useSafeLayoutEffect-BNLlFJBq.js');
|
|
10
|
+
require('../Button-DE6Du5Wv.js');
|
|
11
|
+
require('react-router-dom');
|
|
12
|
+
require('../Icon-DjU29wkY.js');
|
|
13
|
+
require('@jobber/design');
|
|
14
|
+
require('../Typography-CBz3Bwzs.js');
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
exports.Menu = Menu.Menu;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export { M as Menu } from '../Menu-DbsQFQOW.js';
|
|
2
|
+
import 'react';
|
|
3
|
+
import 'classnames';
|
|
4
|
+
import 'framer-motion';
|
|
5
|
+
import '../useOnKeyDown-Dtenmfc9.js';
|
|
6
|
+
import '../useRefocusOnActivator-BCZuCyZg.js';
|
|
7
|
+
import '../useSafeLayoutEffect-CtAU_CL9.js';
|
|
8
|
+
import '../Button-CKxjsn8f.js';
|
|
9
|
+
import 'react-router-dom';
|
|
10
|
+
import '../Icon-BJUSeqrr.js';
|
|
11
|
+
import '@jobber/design';
|
|
12
|
+
import '../Typography-DBA8fJ4I.js';
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var classnames = require('classnames');
|
|
5
|
+
var framerMotion = require('framer-motion');
|
|
6
|
+
var useOnKeyDown = require('./useOnKeyDown-BRrGkWfQ.js');
|
|
7
|
+
var useRefocusOnActivator = require('./useRefocusOnActivator-Nc-vAHlK.js');
|
|
8
|
+
var useSafeLayoutEffect = require('./useSafeLayoutEffect-BNLlFJBq.js');
|
|
9
|
+
var Button = require('./Button-DE6Du5Wv.js');
|
|
10
|
+
var Typography = require('./Typography-CBz3Bwzs.js');
|
|
11
|
+
var Icon = require('./Icon-DjU29wkY.js');
|
|
12
|
+
|
|
13
|
+
var styles = {"wrapper":"dT6M9tp1sZc-","menu":"Qmxlsj0D3qM-","above":"QTisUfiHwL4-","below":"qsch1dlpOHc-","left":"_0xR9-oxWMOU-","right":"gaZwsdyoG0k-","section":"LaKFjYCLHZc-","sectionHeader":"_7HB7dWnqCi0-","action":"ZuceCiefKqw-","icon":"Bz8TONF8kws-","overlay":"eKnUAucwwWU-","fullWidth":"oaxefr58z-E-","screenReaderOnly":"vz9opIdwHFg-"};
|
|
14
|
+
|
|
15
|
+
const variation = {
|
|
16
|
+
overlayStartStop: { opacity: 0 },
|
|
17
|
+
startOrStop: (position) => {
|
|
18
|
+
let y = 10;
|
|
19
|
+
if (position === "below")
|
|
20
|
+
y *= -1;
|
|
21
|
+
if (window.innerWidth < 640)
|
|
22
|
+
y = 150;
|
|
23
|
+
return { opacity: 0, y };
|
|
24
|
+
},
|
|
25
|
+
done: { opacity: 1, y: 0 },
|
|
26
|
+
};
|
|
27
|
+
// eslint-disable-next-line max-statements
|
|
28
|
+
function Menu({ activator, items }) {
|
|
29
|
+
var _a;
|
|
30
|
+
const [visible, setVisible] = React.useState(false);
|
|
31
|
+
const fullWidth = ((_a = activator === null || activator === void 0 ? void 0 : activator.props) === null || _a === void 0 ? void 0 : _a.fullWidth) || false;
|
|
32
|
+
const [position, setPosition] = React.useState({
|
|
33
|
+
vertical: "below",
|
|
34
|
+
horizontal: "right",
|
|
35
|
+
});
|
|
36
|
+
const wrapperRef = React.createRef();
|
|
37
|
+
const buttonID = React.useId();
|
|
38
|
+
const menuID = React.useId();
|
|
39
|
+
useOnKeyDown.useOnKeyDown_2(handleKeyboardShortcut, ["Escape"]);
|
|
40
|
+
useSafeLayoutEffect.useSafeLayoutEffect_1(() => {
|
|
41
|
+
if (wrapperRef.current) {
|
|
42
|
+
const bounds = wrapperRef.current.getBoundingClientRect();
|
|
43
|
+
const newPosition = Object.assign({}, position);
|
|
44
|
+
if (bounds.top <= window.innerHeight / 2) {
|
|
45
|
+
newPosition.vertical = "below";
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
newPosition.vertical = "above";
|
|
49
|
+
}
|
|
50
|
+
if (bounds.left <= window.innerWidth / 2) {
|
|
51
|
+
newPosition.horizontal = "right";
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
newPosition.horizontal = "left";
|
|
55
|
+
}
|
|
56
|
+
setPosition(newPosition);
|
|
57
|
+
}
|
|
58
|
+
}, [visible, fullWidth]);
|
|
59
|
+
useRefocusOnActivator.useRefocusOnActivator_2(visible);
|
|
60
|
+
if (!activator) {
|
|
61
|
+
activator = (React.createElement(Button.Button, { fullWidth: true, label: "More Actions", icon: "more", type: "secondary" }));
|
|
62
|
+
}
|
|
63
|
+
const menuClasses = classnames(styles.menu, position.vertical === "above" && styles.above, position.vertical === "below" && styles.below, position.horizontal === "left" && styles.left, position.horizontal === "right" && styles.right);
|
|
64
|
+
const wrapperClasses = classnames(styles.wrapper, {
|
|
65
|
+
[styles.fullWidth]: fullWidth,
|
|
66
|
+
});
|
|
67
|
+
return (React.createElement("div", { className: wrapperClasses, ref: wrapperRef, onClick: handleParentClick },
|
|
68
|
+
React.cloneElement(activator, {
|
|
69
|
+
onClick: toggle(activator.props.onClick),
|
|
70
|
+
id: buttonID,
|
|
71
|
+
ariaControls: menuID,
|
|
72
|
+
ariaExpanded: visible,
|
|
73
|
+
ariaHaspopup: true,
|
|
74
|
+
}),
|
|
75
|
+
React.createElement(framerMotion.AnimatePresence, null, visible && (React.createElement(React.Fragment, null,
|
|
76
|
+
React.createElement(framerMotion.motion.div, { className: styles.overlay, onClick: toggle(), variants: variation, initial: "overlayStartStop", animate: "done", exit: "overlayStartStop", transition: {
|
|
77
|
+
type: "tween",
|
|
78
|
+
duration: 0.15,
|
|
79
|
+
} }),
|
|
80
|
+
React.createElement(framerMotion.motion.div, { className: menuClasses, role: "menu", "aria-labelledby": buttonID, id: menuID, onClick: hide, variants: variation, initial: "startOrStop", animate: "done", exit: "startOrStop", custom: position, transition: {
|
|
81
|
+
type: "tween",
|
|
82
|
+
duration: 0.25,
|
|
83
|
+
} }, items.map((item, key) => (React.createElement("div", { key: key, className: styles.section },
|
|
84
|
+
item.header && React.createElement(SectionHeader, { text: item.header }),
|
|
85
|
+
item.actions.map((action, index) => (React.createElement(Action, Object.assign({ sectionLabel: item.header, key: action.label, shouldFocus: key === 0 && index === 0 }, action)))))))))))));
|
|
86
|
+
function toggle(callbackPassthrough) {
|
|
87
|
+
return (event) => {
|
|
88
|
+
setVisible(!visible);
|
|
89
|
+
callbackPassthrough && callbackPassthrough(event);
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
function hide() {
|
|
93
|
+
setVisible(false);
|
|
94
|
+
}
|
|
95
|
+
function handleKeyboardShortcut(event) {
|
|
96
|
+
const { key } = event;
|
|
97
|
+
if (!visible)
|
|
98
|
+
return;
|
|
99
|
+
event.preventDefault();
|
|
100
|
+
event.stopPropagation();
|
|
101
|
+
key === "Escape" && hide();
|
|
102
|
+
}
|
|
103
|
+
function handleParentClick(event) {
|
|
104
|
+
// Since the menu is being rendered within the same parent as the activator,
|
|
105
|
+
// we need to stop the click event from bubbling up. If the Menu component
|
|
106
|
+
// gets added within a parent that has a click handler, any click on the
|
|
107
|
+
// menu will trigger the parent's click handler.
|
|
108
|
+
event.stopPropagation();
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
function SectionHeader({ text }) {
|
|
112
|
+
return (React.createElement("div", { className: styles.sectionHeader, "aria-hidden": true },
|
|
113
|
+
React.createElement(Typography.Typography, { element: "h6", size: "small", textCase: "uppercase", textColor: "textSecondary", fontWeight: "bold" }, text)));
|
|
114
|
+
}
|
|
115
|
+
function Action({ label, sectionLabel, icon, onClick, shouldFocus = false, }) {
|
|
116
|
+
const actionButtonRef = React.useRef();
|
|
117
|
+
React.useEffect(() => {
|
|
118
|
+
if (shouldFocus) {
|
|
119
|
+
// Focus on the next tick to allow useRefocusOnActivator to initialize
|
|
120
|
+
setTimeout(() => { var _a; return (_a = actionButtonRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, 0);
|
|
121
|
+
}
|
|
122
|
+
}, [shouldFocus]);
|
|
123
|
+
return (React.createElement("button", { role: "menuitem", type: "button", className: styles.action, key: label, onClick: onClick, ref: actionButtonRef },
|
|
124
|
+
icon && (React.createElement("span", { className: styles.icon },
|
|
125
|
+
React.createElement(Icon.Icon, { name: icon }))),
|
|
126
|
+
React.createElement(Typography.Typography, { element: "span", size: "base", textColor: "text" },
|
|
127
|
+
sectionLabel && (React.createElement("span", { className: styles.screenReaderOnly }, sectionLabel)),
|
|
128
|
+
label)));
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
exports.Menu = Menu;
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import React, { useState, createRef, useId, useRef, useEffect } from 'react';
|
|
2
|
+
import classnames from 'classnames';
|
|
3
|
+
import { AnimatePresence, motion } from 'framer-motion';
|
|
4
|
+
import { u as useOnKeyDown_2 } from './useOnKeyDown-Dtenmfc9.js';
|
|
5
|
+
import { u as useRefocusOnActivator_2 } from './useRefocusOnActivator-BCZuCyZg.js';
|
|
6
|
+
import { u as useSafeLayoutEffect_1 } from './useSafeLayoutEffect-CtAU_CL9.js';
|
|
7
|
+
import { B as Button } from './Button-CKxjsn8f.js';
|
|
8
|
+
import { T as Typography } from './Typography-DBA8fJ4I.js';
|
|
9
|
+
import { I as Icon } from './Icon-BJUSeqrr.js';
|
|
10
|
+
|
|
11
|
+
var styles = {"wrapper":"dT6M9tp1sZc-","menu":"Qmxlsj0D3qM-","above":"QTisUfiHwL4-","below":"qsch1dlpOHc-","left":"_0xR9-oxWMOU-","right":"gaZwsdyoG0k-","section":"LaKFjYCLHZc-","sectionHeader":"_7HB7dWnqCi0-","action":"ZuceCiefKqw-","icon":"Bz8TONF8kws-","overlay":"eKnUAucwwWU-","fullWidth":"oaxefr58z-E-","screenReaderOnly":"vz9opIdwHFg-"};
|
|
12
|
+
|
|
13
|
+
const variation = {
|
|
14
|
+
overlayStartStop: { opacity: 0 },
|
|
15
|
+
startOrStop: (position) => {
|
|
16
|
+
let y = 10;
|
|
17
|
+
if (position === "below")
|
|
18
|
+
y *= -1;
|
|
19
|
+
if (window.innerWidth < 640)
|
|
20
|
+
y = 150;
|
|
21
|
+
return { opacity: 0, y };
|
|
22
|
+
},
|
|
23
|
+
done: { opacity: 1, y: 0 },
|
|
24
|
+
};
|
|
25
|
+
// eslint-disable-next-line max-statements
|
|
26
|
+
function Menu({ activator, items }) {
|
|
27
|
+
var _a;
|
|
28
|
+
const [visible, setVisible] = useState(false);
|
|
29
|
+
const fullWidth = ((_a = activator === null || activator === void 0 ? void 0 : activator.props) === null || _a === void 0 ? void 0 : _a.fullWidth) || false;
|
|
30
|
+
const [position, setPosition] = useState({
|
|
31
|
+
vertical: "below",
|
|
32
|
+
horizontal: "right",
|
|
33
|
+
});
|
|
34
|
+
const wrapperRef = createRef();
|
|
35
|
+
const buttonID = useId();
|
|
36
|
+
const menuID = useId();
|
|
37
|
+
useOnKeyDown_2(handleKeyboardShortcut, ["Escape"]);
|
|
38
|
+
useSafeLayoutEffect_1(() => {
|
|
39
|
+
if (wrapperRef.current) {
|
|
40
|
+
const bounds = wrapperRef.current.getBoundingClientRect();
|
|
41
|
+
const newPosition = Object.assign({}, position);
|
|
42
|
+
if (bounds.top <= window.innerHeight / 2) {
|
|
43
|
+
newPosition.vertical = "below";
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
newPosition.vertical = "above";
|
|
47
|
+
}
|
|
48
|
+
if (bounds.left <= window.innerWidth / 2) {
|
|
49
|
+
newPosition.horizontal = "right";
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
newPosition.horizontal = "left";
|
|
53
|
+
}
|
|
54
|
+
setPosition(newPosition);
|
|
55
|
+
}
|
|
56
|
+
}, [visible, fullWidth]);
|
|
57
|
+
useRefocusOnActivator_2(visible);
|
|
58
|
+
if (!activator) {
|
|
59
|
+
activator = (React.createElement(Button, { fullWidth: true, label: "More Actions", icon: "more", type: "secondary" }));
|
|
60
|
+
}
|
|
61
|
+
const menuClasses = classnames(styles.menu, position.vertical === "above" && styles.above, position.vertical === "below" && styles.below, position.horizontal === "left" && styles.left, position.horizontal === "right" && styles.right);
|
|
62
|
+
const wrapperClasses = classnames(styles.wrapper, {
|
|
63
|
+
[styles.fullWidth]: fullWidth,
|
|
64
|
+
});
|
|
65
|
+
return (React.createElement("div", { className: wrapperClasses, ref: wrapperRef, onClick: handleParentClick },
|
|
66
|
+
React.cloneElement(activator, {
|
|
67
|
+
onClick: toggle(activator.props.onClick),
|
|
68
|
+
id: buttonID,
|
|
69
|
+
ariaControls: menuID,
|
|
70
|
+
ariaExpanded: visible,
|
|
71
|
+
ariaHaspopup: true,
|
|
72
|
+
}),
|
|
73
|
+
React.createElement(AnimatePresence, null, visible && (React.createElement(React.Fragment, null,
|
|
74
|
+
React.createElement(motion.div, { className: styles.overlay, onClick: toggle(), variants: variation, initial: "overlayStartStop", animate: "done", exit: "overlayStartStop", transition: {
|
|
75
|
+
type: "tween",
|
|
76
|
+
duration: 0.15,
|
|
77
|
+
} }),
|
|
78
|
+
React.createElement(motion.div, { className: menuClasses, role: "menu", "aria-labelledby": buttonID, id: menuID, onClick: hide, variants: variation, initial: "startOrStop", animate: "done", exit: "startOrStop", custom: position, transition: {
|
|
79
|
+
type: "tween",
|
|
80
|
+
duration: 0.25,
|
|
81
|
+
} }, items.map((item, key) => (React.createElement("div", { key: key, className: styles.section },
|
|
82
|
+
item.header && React.createElement(SectionHeader, { text: item.header }),
|
|
83
|
+
item.actions.map((action, index) => (React.createElement(Action, Object.assign({ sectionLabel: item.header, key: action.label, shouldFocus: key === 0 && index === 0 }, action)))))))))))));
|
|
84
|
+
function toggle(callbackPassthrough) {
|
|
85
|
+
return (event) => {
|
|
86
|
+
setVisible(!visible);
|
|
87
|
+
callbackPassthrough && callbackPassthrough(event);
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
function hide() {
|
|
91
|
+
setVisible(false);
|
|
92
|
+
}
|
|
93
|
+
function handleKeyboardShortcut(event) {
|
|
94
|
+
const { key } = event;
|
|
95
|
+
if (!visible)
|
|
96
|
+
return;
|
|
97
|
+
event.preventDefault();
|
|
98
|
+
event.stopPropagation();
|
|
99
|
+
key === "Escape" && hide();
|
|
100
|
+
}
|
|
101
|
+
function handleParentClick(event) {
|
|
102
|
+
// Since the menu is being rendered within the same parent as the activator,
|
|
103
|
+
// we need to stop the click event from bubbling up. If the Menu component
|
|
104
|
+
// gets added within a parent that has a click handler, any click on the
|
|
105
|
+
// menu will trigger the parent's click handler.
|
|
106
|
+
event.stopPropagation();
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
function SectionHeader({ text }) {
|
|
110
|
+
return (React.createElement("div", { className: styles.sectionHeader, "aria-hidden": true },
|
|
111
|
+
React.createElement(Typography, { element: "h6", size: "small", textCase: "uppercase", textColor: "textSecondary", fontWeight: "bold" }, text)));
|
|
112
|
+
}
|
|
113
|
+
function Action({ label, sectionLabel, icon, onClick, shouldFocus = false, }) {
|
|
114
|
+
const actionButtonRef = useRef();
|
|
115
|
+
useEffect(() => {
|
|
116
|
+
if (shouldFocus) {
|
|
117
|
+
// Focus on the next tick to allow useRefocusOnActivator to initialize
|
|
118
|
+
setTimeout(() => { var _a; return (_a = actionButtonRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, 0);
|
|
119
|
+
}
|
|
120
|
+
}, [shouldFocus]);
|
|
121
|
+
return (React.createElement("button", { role: "menuitem", type: "button", className: styles.action, key: label, onClick: onClick, ref: actionButtonRef },
|
|
122
|
+
icon && (React.createElement("span", { className: styles.icon },
|
|
123
|
+
React.createElement(Icon, { name: icon }))),
|
|
124
|
+
React.createElement(Typography, { element: "span", size: "base", textColor: "text" },
|
|
125
|
+
sectionLabel && (React.createElement("span", { className: styles.screenReaderOnly }, sectionLabel)),
|
|
126
|
+
label)));
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export { Menu as M };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var Modal = require('../Modal-Dx1bOlz7.js');
|
|
4
|
+
require('react');
|
|
5
|
+
require('react-dom');
|
|
6
|
+
require('classnames');
|
|
7
|
+
require('framer-motion');
|
|
8
|
+
require('../useRefocusOnActivator-Nc-vAHlK.js');
|
|
9
|
+
require('../useOnKeyDown-BRrGkWfQ.js');
|
|
10
|
+
require('../useFocusTrap-Bk_llzCy.js');
|
|
11
|
+
require('../Heading-BhKK7vho.js');
|
|
12
|
+
require('../Typography-CBz3Bwzs.js');
|
|
13
|
+
require('../useAtlantisConfig-D-Qo7OhV.js');
|
|
14
|
+
require('../useSafeLayoutEffect-BNLlFJBq.js');
|
|
15
|
+
require('../Button-DE6Du5Wv.js');
|
|
16
|
+
require('react-router-dom');
|
|
17
|
+
require('../Icon-DjU29wkY.js');
|
|
18
|
+
require('@jobber/design');
|
|
19
|
+
require('../ButtonDismiss-DjOs7eO3.js');
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
exports.Modal = Modal.Modal;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export { M as Modal } from '../Modal-JhusMU4D.js';
|
|
2
|
+
import 'react';
|
|
3
|
+
import 'react-dom';
|
|
4
|
+
import 'classnames';
|
|
5
|
+
import 'framer-motion';
|
|
6
|
+
import '../useRefocusOnActivator-BCZuCyZg.js';
|
|
7
|
+
import '../useOnKeyDown-Dtenmfc9.js';
|
|
8
|
+
import '../useFocusTrap-BztNbnoA.js';
|
|
9
|
+
import '../Heading-CN8xip8K.js';
|
|
10
|
+
import '../Typography-DBA8fJ4I.js';
|
|
11
|
+
import '../useAtlantisConfig-CVSBhQb8.js';
|
|
12
|
+
import '../useSafeLayoutEffect-CtAU_CL9.js';
|
|
13
|
+
import '../Button-CKxjsn8f.js';
|
|
14
|
+
import 'react-router-dom';
|
|
15
|
+
import '../Icon-BJUSeqrr.js';
|
|
16
|
+
import '@jobber/design';
|
|
17
|
+
import '../ButtonDismiss-BIVGFM9M.js';
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var ReactDOM = require('react-dom');
|
|
5
|
+
var classnames = require('classnames');
|
|
6
|
+
var framerMotion = require('framer-motion');
|
|
7
|
+
var useRefocusOnActivator = require('./useRefocusOnActivator-Nc-vAHlK.js');
|
|
8
|
+
var useOnKeyDown = require('./useOnKeyDown-BRrGkWfQ.js');
|
|
9
|
+
var useFocusTrap = require('./useFocusTrap-Bk_llzCy.js');
|
|
10
|
+
var Heading = require('./Heading-BhKK7vho.js');
|
|
11
|
+
var Button = require('./Button-DE6Du5Wv.js');
|
|
12
|
+
var ButtonDismiss = require('./ButtonDismiss-DjOs7eO3.js');
|
|
13
|
+
|
|
14
|
+
var styles = {"container":"QGRLFHPoV5E-","overlay":"_4WzGOMUGj5I-","modal":"WLId2NJBQcQ-","header":"wjrPpIUNNrk-","closeButton":"rKvigUnOyYE-","actionBar":"_62c8HLZFwvs-","leftAction":"Xl1Ptn-P9Ew-","rightAction":"p2s7GtpoZz0-"};
|
|
15
|
+
|
|
16
|
+
var sizes = {"small":"_65IpUjOZiBg-","large":"Cpwnmw65caA-"};
|
|
17
|
+
|
|
18
|
+
function Modal({ open = false, title, size, dismissible = true, children, primaryAction, secondaryAction, tertiaryAction, onRequestClose, }) {
|
|
19
|
+
const modalClassName = classnames(styles.modal, size && sizes[size]);
|
|
20
|
+
useRefocusOnActivator.useRefocusOnActivator_2(open);
|
|
21
|
+
const modalRef = useFocusTrap.useFocusTrap_2(open);
|
|
22
|
+
useOnKeyDown.useOnKeyDown_2(handleRequestClose, "Escape");
|
|
23
|
+
const template = (React.createElement(framerMotion.AnimatePresence, null, open && (React.createElement("div", { ref: modalRef, role: "dialog", className: styles.container, tabIndex: 0 },
|
|
24
|
+
React.createElement(framerMotion.motion.div, { key: styles.overlay, className: styles.overlay, onClick: onRequestClose, initial: { opacity: 0 }, animate: { opacity: 0.8 }, exit: { opacity: 0 }, transition: { duration: 0.2 } }),
|
|
25
|
+
React.createElement(framerMotion.motion.div, { key: styles.modal, className: modalClassName, initial: { scale: 0.9, opacity: 0 }, animate: { scale: 1, opacity: 1 }, exit: { scale: 0.9, opacity: 0 }, transition: {
|
|
26
|
+
duration: 0.2,
|
|
27
|
+
ease: "easeInOut",
|
|
28
|
+
} },
|
|
29
|
+
title != undefined && (React.createElement(Header, { title: title, dismissible: dismissible, onRequestClose: onRequestClose })),
|
|
30
|
+
children,
|
|
31
|
+
React.createElement(Actions, { primary: primaryAction, secondary: secondaryAction, tertiary: tertiaryAction }))))));
|
|
32
|
+
return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
|
|
33
|
+
? ReactDOM.createPortal(template, document.body)
|
|
34
|
+
: template;
|
|
35
|
+
function handleRequestClose() {
|
|
36
|
+
if (open && onRequestClose) {
|
|
37
|
+
onRequestClose();
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
function Header({ title, dismissible, onRequestClose }) {
|
|
42
|
+
return (React.createElement("div", { className: styles.header, "data-testid": "modal-header" },
|
|
43
|
+
React.createElement(Heading.Heading, { level: 2 }, title),
|
|
44
|
+
dismissible && (React.createElement("div", { className: styles.closeButton },
|
|
45
|
+
React.createElement(ButtonDismiss.ButtonDismiss, { onClick: onRequestClose, ariaLabel: "Close modal" })))));
|
|
46
|
+
}
|
|
47
|
+
function Actions({ primary, secondary, tertiary }) {
|
|
48
|
+
const shouldShow = primary != undefined || secondary != undefined || tertiary != undefined;
|
|
49
|
+
if (secondary != undefined) {
|
|
50
|
+
secondary = Object.assign({ type: "primary", variation: "subtle" }, secondary);
|
|
51
|
+
}
|
|
52
|
+
if (tertiary != undefined) {
|
|
53
|
+
tertiary = Object.assign({ type: "secondary", variation: "destructive" }, tertiary);
|
|
54
|
+
}
|
|
55
|
+
return (React.createElement(React.Fragment, null, shouldShow && (React.createElement("div", { className: styles.actionBar },
|
|
56
|
+
React.createElement("div", { className: styles.rightAction },
|
|
57
|
+
primary && React.createElement(Button.Button, Object.assign({}, primary)),
|
|
58
|
+
secondary && React.createElement(Button.Button, Object.assign({}, secondary))),
|
|
59
|
+
tertiary && (React.createElement("div", { className: styles.leftAction },
|
|
60
|
+
React.createElement(Button.Button, Object.assign({}, tertiary))))))));
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
exports.Modal = Modal;
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import ReactDOM from 'react-dom';
|
|
3
|
+
import classnames from 'classnames';
|
|
4
|
+
import { AnimatePresence, motion } from 'framer-motion';
|
|
5
|
+
import { u as useRefocusOnActivator_2 } from './useRefocusOnActivator-BCZuCyZg.js';
|
|
6
|
+
import { u as useOnKeyDown_2 } from './useOnKeyDown-Dtenmfc9.js';
|
|
7
|
+
import { u as useFocusTrap_2 } from './useFocusTrap-BztNbnoA.js';
|
|
8
|
+
import { H as Heading } from './Heading-CN8xip8K.js';
|
|
9
|
+
import { B as Button } from './Button-CKxjsn8f.js';
|
|
10
|
+
import { B as ButtonDismiss } from './ButtonDismiss-BIVGFM9M.js';
|
|
11
|
+
|
|
12
|
+
var styles = {"container":"QGRLFHPoV5E-","overlay":"_4WzGOMUGj5I-","modal":"WLId2NJBQcQ-","header":"wjrPpIUNNrk-","closeButton":"rKvigUnOyYE-","actionBar":"_62c8HLZFwvs-","leftAction":"Xl1Ptn-P9Ew-","rightAction":"p2s7GtpoZz0-"};
|
|
13
|
+
|
|
14
|
+
var sizes = {"small":"_65IpUjOZiBg-","large":"Cpwnmw65caA-"};
|
|
15
|
+
|
|
16
|
+
function Modal({ open = false, title, size, dismissible = true, children, primaryAction, secondaryAction, tertiaryAction, onRequestClose, }) {
|
|
17
|
+
const modalClassName = classnames(styles.modal, size && sizes[size]);
|
|
18
|
+
useRefocusOnActivator_2(open);
|
|
19
|
+
const modalRef = useFocusTrap_2(open);
|
|
20
|
+
useOnKeyDown_2(handleRequestClose, "Escape");
|
|
21
|
+
const template = (React.createElement(AnimatePresence, null, open && (React.createElement("div", { ref: modalRef, role: "dialog", className: styles.container, tabIndex: 0 },
|
|
22
|
+
React.createElement(motion.div, { key: styles.overlay, className: styles.overlay, onClick: onRequestClose, initial: { opacity: 0 }, animate: { opacity: 0.8 }, exit: { opacity: 0 }, transition: { duration: 0.2 } }),
|
|
23
|
+
React.createElement(motion.div, { key: styles.modal, className: modalClassName, initial: { scale: 0.9, opacity: 0 }, animate: { scale: 1, opacity: 1 }, exit: { scale: 0.9, opacity: 0 }, transition: {
|
|
24
|
+
duration: 0.2,
|
|
25
|
+
ease: "easeInOut",
|
|
26
|
+
} },
|
|
27
|
+
title != undefined && (React.createElement(Header, { title: title, dismissible: dismissible, onRequestClose: onRequestClose })),
|
|
28
|
+
children,
|
|
29
|
+
React.createElement(Actions, { primary: primaryAction, secondary: secondaryAction, tertiary: tertiaryAction }))))));
|
|
30
|
+
return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
|
|
31
|
+
? ReactDOM.createPortal(template, document.body)
|
|
32
|
+
: template;
|
|
33
|
+
function handleRequestClose() {
|
|
34
|
+
if (open && onRequestClose) {
|
|
35
|
+
onRequestClose();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
function Header({ title, dismissible, onRequestClose }) {
|
|
40
|
+
return (React.createElement("div", { className: styles.header, "data-testid": "modal-header" },
|
|
41
|
+
React.createElement(Heading, { level: 2 }, title),
|
|
42
|
+
dismissible && (React.createElement("div", { className: styles.closeButton },
|
|
43
|
+
React.createElement(ButtonDismiss, { onClick: onRequestClose, ariaLabel: "Close modal" })))));
|
|
44
|
+
}
|
|
45
|
+
function Actions({ primary, secondary, tertiary }) {
|
|
46
|
+
const shouldShow = primary != undefined || secondary != undefined || tertiary != undefined;
|
|
47
|
+
if (secondary != undefined) {
|
|
48
|
+
secondary = Object.assign({ type: "primary", variation: "subtle" }, secondary);
|
|
49
|
+
}
|
|
50
|
+
if (tertiary != undefined) {
|
|
51
|
+
tertiary = Object.assign({ type: "secondary", variation: "destructive" }, tertiary);
|
|
52
|
+
}
|
|
53
|
+
return (React.createElement(React.Fragment, null, shouldShow && (React.createElement("div", { className: styles.actionBar },
|
|
54
|
+
React.createElement("div", { className: styles.rightAction },
|
|
55
|
+
primary && React.createElement(Button, Object.assign({}, primary)),
|
|
56
|
+
secondary && React.createElement(Button, Object.assign({}, secondary))),
|
|
57
|
+
tertiary && (React.createElement("div", { className: styles.leftAction },
|
|
58
|
+
React.createElement(Button, Object.assign({}, tertiary))))))));
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export { Modal as M };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var MultiSelect = require('../MultiSelect-B2vx9vLw.js');
|
|
4
|
+
require('react');
|
|
5
|
+
require('classnames');
|
|
6
|
+
require('../Checkbox-3Qa3Mp4s.js');
|
|
7
|
+
require('../tslib.es6-CjmNBqgv.js');
|
|
8
|
+
require('react-hook-form');
|
|
9
|
+
require('../Icon-DjU29wkY.js');
|
|
10
|
+
require('@jobber/design');
|
|
11
|
+
require('../Text-CqfEADu0.js');
|
|
12
|
+
require('../Typography-CBz3Bwzs.js');
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
exports.MultiSelect = MultiSelect.MultiSelect;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export { M as MultiSelect } from '../MultiSelect-But9vE7v.js';
|
|
2
|
+
import 'react';
|
|
3
|
+
import 'classnames';
|
|
4
|
+
import '../Checkbox-BVH5HUy3.js';
|
|
5
|
+
import '../tslib.es6-BJzo8cuE.js';
|
|
6
|
+
import 'react-hook-form';
|
|
7
|
+
import '../Icon-BJUSeqrr.js';
|
|
8
|
+
import '@jobber/design';
|
|
9
|
+
import '../Text-9Y0IeH0M.js';
|
|
10
|
+
import '../Typography-DBA8fJ4I.js';
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var classnames = require('classnames');
|
|
5
|
+
var Checkbox = require('./Checkbox-3Qa3Mp4s.js');
|
|
6
|
+
var Text = require('./Text-CqfEADu0.js');
|
|
7
|
+
var Icon = require('./Icon-DjU29wkY.js');
|
|
8
|
+
|
|
9
|
+
var styles$1 = {"multiSelectContainer":"D-J03az6XL4-","multiSelect":"EzNdHgwsT40-","active":"bu7HWKRu6HI-","small":"eQ6yfQg6zLc-","large":"pM-ts4-QMZY-"};
|
|
10
|
+
|
|
11
|
+
var styles = {"dropDownMenuContainer":"_0SStdD4KRHs-","option":"mFSgwOQZJm0-","active":"SepF4gvOxq8-"};
|
|
12
|
+
|
|
13
|
+
function DropDownMenu({ options, setOptions }) {
|
|
14
|
+
const [highlightedIndex, setHighlightedIndex] = React.useState(0);
|
|
15
|
+
const menuDiv = React.useRef();
|
|
16
|
+
const handleOptionClick = React.useCallback((clickedOption) => {
|
|
17
|
+
setOptions(current => current.map(option => {
|
|
18
|
+
if (option.label == clickedOption.label) {
|
|
19
|
+
return Object.assign(Object.assign({}, option), { checked: !clickedOption.checked });
|
|
20
|
+
}
|
|
21
|
+
return option;
|
|
22
|
+
}));
|
|
23
|
+
}, []);
|
|
24
|
+
function handleOptionHover(event, index) {
|
|
25
|
+
event.preventDefault();
|
|
26
|
+
setHighlightedIndex(index);
|
|
27
|
+
}
|
|
28
|
+
function handleOptionFocus(index) {
|
|
29
|
+
setHighlightedIndex(index);
|
|
30
|
+
if (menuDiv.current) {
|
|
31
|
+
const option = menuDiv.current.children[index].querySelector("input");
|
|
32
|
+
option === null || option === void 0 ? void 0 : option.focus();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
function scrollMenuIfItemNotInView(menuDivElement, direction) {
|
|
36
|
+
const itemDiv = menuDivElement.querySelector(`:nth-child(${highlightedIndex + 1})`);
|
|
37
|
+
if (!itemDiv)
|
|
38
|
+
return;
|
|
39
|
+
const menuTop = menuDivElement.getBoundingClientRect().top;
|
|
40
|
+
const { top: itemTop, height: itemHeight, bottom: itemBottom, } = itemDiv.getBoundingClientRect();
|
|
41
|
+
const itemTrueBottom = itemBottom + itemHeight;
|
|
42
|
+
const menuBottom = menuDivElement.getBoundingClientRect().bottom;
|
|
43
|
+
if (direction == "up" && itemTop - itemHeight < menuTop) {
|
|
44
|
+
menuDivElement.scrollTop -= itemHeight;
|
|
45
|
+
}
|
|
46
|
+
else if (direction == "down" && itemTrueBottom > menuBottom) {
|
|
47
|
+
menuDivElement.scrollTop += itemHeight;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
function handleKeyDown(event) {
|
|
51
|
+
const { key, metaKey, ctrlKey } = event;
|
|
52
|
+
if (metaKey || ctrlKey)
|
|
53
|
+
return;
|
|
54
|
+
switch (key) {
|
|
55
|
+
case "Enter": {
|
|
56
|
+
if (highlightedIndex >= 0) {
|
|
57
|
+
handleOptionClick(options[highlightedIndex]);
|
|
58
|
+
}
|
|
59
|
+
break;
|
|
60
|
+
}
|
|
61
|
+
case "ArrowDown": {
|
|
62
|
+
handlePressDown(event);
|
|
63
|
+
break;
|
|
64
|
+
}
|
|
65
|
+
case "ArrowUp": {
|
|
66
|
+
handlePressUp(event);
|
|
67
|
+
break;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
React.useEffect(() => {
|
|
72
|
+
// focus first option
|
|
73
|
+
handleOptionFocus(0);
|
|
74
|
+
}, [menuDiv]);
|
|
75
|
+
return (React.createElement("ul", { "data-testid": "dropdown-menu", className: styles.dropDownMenuContainer, ref: menuDiv, onKeyDown: handleKeyDown }, options.map((option, index) => {
|
|
76
|
+
const optionClass = classnames(styles.option, {
|
|
77
|
+
[styles.active]: index === highlightedIndex,
|
|
78
|
+
});
|
|
79
|
+
return (React.createElement("li", { key: `${index}-${option.label}`, className: optionClass, onClick: event => {
|
|
80
|
+
event.stopPropagation();
|
|
81
|
+
event.preventDefault();
|
|
82
|
+
handleOptionClick(option);
|
|
83
|
+
}, onMouseOver: e => handleOptionHover(e, index) },
|
|
84
|
+
React.createElement(Checkbox.Checkbox, { label: option.label, checked: option.checked, onFocus: () => setHighlightedIndex(index) })));
|
|
85
|
+
})));
|
|
86
|
+
function handlePressUp(event) {
|
|
87
|
+
event.preventDefault();
|
|
88
|
+
const newIndex = Math.max(0, highlightedIndex - 1);
|
|
89
|
+
handleOptionFocus(newIndex);
|
|
90
|
+
scrollMenuIfItemNotInView(menuDiv.current, "up");
|
|
91
|
+
}
|
|
92
|
+
function handlePressDown(event) {
|
|
93
|
+
event.preventDefault();
|
|
94
|
+
const newIndex = Math.min(options.length - 1, highlightedIndex + 1);
|
|
95
|
+
handleOptionFocus(newIndex);
|
|
96
|
+
scrollMenuIfItemNotInView(menuDiv.current, "down");
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// eslint-disable-next-line max-statements
|
|
101
|
+
function MultiSelect({ defaultLabel, allSelectedLabel, options, onOptionsChange, size, }) {
|
|
102
|
+
const [label, setLabel] = React.useState(defaultLabel);
|
|
103
|
+
const [menuVisible, setMenuVisible] = React.useState(false);
|
|
104
|
+
const [focused, setFocused] = React.useState(false);
|
|
105
|
+
const multiSelectContainer = React.useRef();
|
|
106
|
+
const multiSelectRef = React.useRef();
|
|
107
|
+
const multiSelectClass = classnames(styles$1.multiSelect, {
|
|
108
|
+
[styles$1.active]: menuVisible,
|
|
109
|
+
[styles$1.large]: size === "large",
|
|
110
|
+
[styles$1.small]: size === "small",
|
|
111
|
+
});
|
|
112
|
+
function handleMenuVisibility() {
|
|
113
|
+
multiSelectRef.current.focus();
|
|
114
|
+
setMenuVisible(!menuVisible);
|
|
115
|
+
}
|
|
116
|
+
const handleClickOutside = (e) => {
|
|
117
|
+
var _a;
|
|
118
|
+
if (!((_a = multiSelectContainer === null || multiSelectContainer === void 0 ? void 0 : multiSelectContainer.current) === null || _a === void 0 ? void 0 : _a.contains(e.target))) {
|
|
119
|
+
setMenuVisible(false);
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
function handleKeydown(event) {
|
|
123
|
+
const { key, metaKey, ctrlKey } = event;
|
|
124
|
+
if (metaKey || ctrlKey)
|
|
125
|
+
return;
|
|
126
|
+
switch (key) {
|
|
127
|
+
case "Enter":
|
|
128
|
+
case " ": {
|
|
129
|
+
if (focused) {
|
|
130
|
+
setMenuVisible(!menuVisible);
|
|
131
|
+
}
|
|
132
|
+
break;
|
|
133
|
+
}
|
|
134
|
+
case "Escape": {
|
|
135
|
+
multiSelectRef.current.focus();
|
|
136
|
+
setMenuVisible(false);
|
|
137
|
+
break;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
React.useEffect(() => {
|
|
142
|
+
document.addEventListener("mousedown", handleClickOutside);
|
|
143
|
+
return () => document.removeEventListener("mousedown", handleClickOutside);
|
|
144
|
+
});
|
|
145
|
+
React.useEffect(() => {
|
|
146
|
+
const selected = options.filter(option => option.checked);
|
|
147
|
+
if (selected.length === 0) {
|
|
148
|
+
setLabel(defaultLabel);
|
|
149
|
+
}
|
|
150
|
+
else if (selected.length == options.length) {
|
|
151
|
+
setLabel(allSelectedLabel);
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
const selectedLabels = [];
|
|
155
|
+
selected.forEach(option => selectedLabels.push(option.label));
|
|
156
|
+
setLabel(selectedLabels.join(", "));
|
|
157
|
+
}
|
|
158
|
+
}, [options]);
|
|
159
|
+
return (React.createElement("div", { ref: multiSelectContainer, className: styles$1.multiSelectContainer, onKeyDown: handleKeydown },
|
|
160
|
+
React.createElement("div", { "data-testid": "multi-select", className: multiSelectClass, onClick: handleMenuVisibility, onFocus: () => setFocused(true), onBlur: () => setFocused(false), tabIndex: 0, ref: multiSelectRef, role: "button", "aria-label": `${defaultLabel}: ${label}`, "aria-multiselectable": true, "aria-haspopup": true },
|
|
161
|
+
React.createElement(Text.Text, null, label),
|
|
162
|
+
React.createElement(Icon.Icon, { name: "arrowDown" })),
|
|
163
|
+
menuVisible && (React.createElement(DropDownMenu, { options: options, setOptions: onOptionsChange }))));
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
exports.MultiSelect = MultiSelect;
|