@jobber/components 4.90.5 → 4.90.6
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.cjs → index.js} +3 -1
- package/dist/{AnimatedPresence-BWePg1sL.js → AnimatedPresence-20a02aaa.js} +7 -3
- package/dist/AnimatedSwitcher/index.js +13 -0
- package/dist/{AnimatedSwitcher-D_Qj_hx5.js → AnimatedSwitcher-3d45ec5d.js} +8 -4
- package/dist/AtlantisContext/{index.cjs → index.js} +3 -1
- package/dist/Autocomplete/index.js +214 -0
- package/dist/Avatar/index.js +15 -0
- package/dist/Avatar-76a799fa.js +78 -0
- package/dist/Banner/index.js +111 -0
- package/dist/Button/index.js +16 -0
- package/dist/Button-6b922fc1.js +57 -0
- package/dist/ButtonDismiss/index.js +17 -0
- package/dist/ButtonDismiss-a3ba1de2.js +14 -0
- package/dist/Card/index.js +24 -0
- package/dist/Card-01d6ba19.js +93 -0
- package/dist/Checkbox/index.js +18 -0
- package/dist/Checkbox-e481a4b1.js +63 -0
- package/dist/Chip/index.js +42 -0
- package/dist/Chip-76f18555.js +89 -0
- package/dist/Chips/index.js +525 -0
- package/dist/Combobox/index.js +41 -0
- package/dist/Combobox-6d864202.js +481 -0
- package/dist/ConfirmationModal/index.js +32 -0
- package/dist/{ConfirmationModal-AtuPSZb4.js → ConfirmationModal-b44e302f.js} +12 -8
- package/dist/Content/index.js +12 -0
- package/dist/Content-e3f7b6fc.js +24 -0
- package/dist/Countdown/index.js +72 -0
- package/dist/DataDump/index.js +37 -0
- package/dist/DataList/index.js +1346 -0
- package/dist/DataTable/index.js +301 -0
- package/dist/DatePicker/index.js +21 -0
- package/dist/DatePicker-305a5b82.js +144 -0
- package/dist/DescriptionList/index.js +24 -0
- package/dist/Disclosure/index.js +46 -0
- package/dist/Divider/index.js +29 -0
- package/dist/Drawer/index.js +50 -0
- package/dist/Emphasis/index.js +13 -0
- package/dist/Emphasis-a77d8ee9.js +19 -0
- package/dist/FeatureSwitch/index.js +71 -0
- package/dist/Flex/index.js +12 -0
- package/dist/Flex-d490c4db.js +38 -0
- package/dist/{Form-5myjIaNx.js → Form/index.js} +9 -3
- package/dist/FormField/index.js +24 -0
- package/dist/FormField-f6fadff2.js +253 -0
- package/dist/FormatDate/{index.cjs → index.js} +3 -1
- package/dist/{FormatDate-CcycFjAL.js → FormatDate-70ea5b43.js} +5 -1
- package/dist/FormatEmail/index.js +23 -0
- package/dist/FormatFile/index.js +37 -0
- package/dist/FormatFile-32228107.js +162 -0
- package/dist/{FormatRelativeDateTime-hdrEQWhy.js → FormatRelativeDateTime/index.js} +11 -5
- package/dist/{FormatTime-DrHluWW3.js → FormatTime/index.js} +7 -1
- package/dist/Gallery/index.js +101 -0
- package/dist/Glimmer/index.js +15 -0
- package/dist/Glimmer-84dee1ed.js +77 -0
- package/dist/Grid/index.js +76 -0
- package/dist/Heading/index.js +15 -0
- package/dist/{Heading-Y2BrFvzY.js → Heading-23d382a1.js} +7 -3
- package/dist/Icon/index.js +11 -0
- package/dist/Icon-405a216c.js +40 -0
- package/dist/InlineLabel/index.js +13 -0
- package/dist/InlineLabel-c8fc28f0.js +28 -0
- package/dist/InputAvatar/index.js +70 -0
- package/dist/{InputDate-kNxwMqkc.js → InputDate/index.js} +31 -6
- package/dist/InputEmail/index.js +43 -0
- package/dist/InputFile/index.js +25 -0
- package/dist/InputFile-20b9074a.js +190 -0
- package/dist/InputGroup/index.js +12 -0
- package/dist/InputGroup-8d4fd4eb.js +33 -0
- package/dist/InputNumber/index.js +25 -0
- package/dist/{InputNumber-CW4ttUb0.js → InputNumber-e15cc1a3.js} +6 -2
- package/dist/InputPassword/index.js +41 -0
- package/dist/{InputPhoneNumber-DHO2lp-T.js → InputPhoneNumber/index.js} +27 -7
- package/dist/InputText/index.js +26 -0
- package/dist/{InputText-C_iZe7xf.js → InputText-130b0440.js} +8 -4
- package/dist/{InputTime-DemVybcJ.js → InputTime/index.js} +25 -5
- package/dist/InputValidation/index.js +17 -0
- package/dist/InputValidation-a92bb519.js +29 -0
- package/dist/LightBox/index.js +25 -0
- package/dist/LightBox-7efe8932.js +121 -0
- package/dist/Link/index.js +15 -0
- package/dist/List/index.js +94 -0
- package/dist/Markdown/index.js +20 -0
- package/dist/Markdown-0f24de70.js +62 -0
- package/dist/Menu/index.js +21 -0
- package/dist/Menu-d6dd673e.js +139 -0
- package/dist/Modal/index.js +26 -0
- package/dist/Modal-067becad.js +73 -0
- package/dist/MultiSelect/index.js +182 -0
- package/dist/Option-a1dbc08a.js +19 -0
- package/dist/Page/index.js +78 -0
- package/dist/Popover/index.js +65 -0
- package/dist/ProgressBar/index.js +12 -0
- package/dist/ProgressBar-b68edc8f.js +43 -0
- package/dist/RadioGroup/index.js +15 -0
- package/dist/RadioGroup-678f4932.js +46 -0
- package/dist/RecurringSelect/index.js +227 -0
- package/dist/Select/index.js +26 -0
- package/dist/Spinner/index.js +12 -0
- package/dist/Spinner-9d8fc7ff.js +24 -0
- package/dist/StatusIndicator/index.js +11 -0
- package/dist/StatusIndicator-7b5258ea.js +18 -0
- package/dist/StatusLabel/index.js +28 -0
- package/dist/Switch/index.js +13 -0
- package/dist/Switch-eac89586.js +56 -0
- package/dist/Table/index.js +66 -0
- package/dist/Tabs/index.js +80 -0
- package/dist/Text/index.js +13 -0
- package/dist/{Text-BKFV1Z0j.js → Text-fbeaaca6.js} +6 -2
- package/dist/Toast/index.js +111 -0
- package/dist/Tooltip/index.js +17 -0
- package/dist/Tooltip-b9de6e57.js +114 -0
- package/dist/Typography/index.js +12 -0
- package/dist/Typography-e2a23b7e.js +62 -0
- package/dist/style-inject.es-9d2f5f4e.js +30 -0
- package/dist/tslib.es6-754e2961.js +46 -0
- package/dist/{useAtlantisConfig-Ckfr55qY.js → useAtlantisConfig-ed0bee66.js} +2 -2
- package/package.json +8 -394
- package/{rollup.config.mjs → rollup.config.js} +17 -50
- package/dist/AnimatedPresence/index.mjs +0 -4
- package/dist/AnimatedPresence-CzXm0q2a.js +0 -98
- package/dist/AnimatedSwitcher/index.cjs +0 -11
- package/dist/AnimatedSwitcher/index.mjs +0 -5
- package/dist/AnimatedSwitcher--j45gdP1.js +0 -90
- package/dist/AtlantisContext/index.mjs +0 -2
- package/dist/AtlantisContext-B0Zo5l8l.js +0 -18
- package/dist/Autocomplete/index.cjs +0 -33
- package/dist/Autocomplete/index.mjs +0 -27
- package/dist/Autocomplete-DQ9t1vLy.js +0 -190
- package/dist/Autocomplete-W9xb3p2A.js +0 -192
- package/dist/Avatar/index.cjs +0 -12
- package/dist/Avatar/index.mjs +0 -6
- package/dist/Avatar-BPd8t6BU.js +0 -67
- package/dist/Avatar-DTFS2kFm.js +0 -69
- package/dist/Banner/components/BannerIcon/index.cjs +0 -13
- package/dist/Banner/components/BannerIcon/index.mjs +0 -7
- package/dist/Banner/index.cjs +0 -23
- package/dist/Banner/index.mjs +0 -17
- package/dist/Banner-Dpwk3NK9.js +0 -79
- package/dist/Banner-DzeDUJLs.js +0 -81
- package/dist/BannerIcon-Co45J70u.js +0 -19
- package/dist/BannerIcon-CzBZbMVi.js +0 -22
- package/dist/Body-4eoS-dUC.js +0 -45
- package/dist/Body-CwY_QyVF.js +0 -54
- package/dist/Button/index.cjs +0 -13
- package/dist/Button/index.mjs +0 -7
- package/dist/Button-BH4Hhr2S.js +0 -47
- package/dist/Button-BPYGeGx2.js +0 -49
- package/dist/ButtonDismiss/index.cjs +0 -14
- package/dist/ButtonDismiss/index.mjs +0 -8
- package/dist/ButtonDismiss-BajTLHia.js +0 -10
- package/dist/ButtonDismiss-Dwe1QljB.js +0 -8
- package/dist/Card/index.cjs +0 -21
- package/dist/Card/index.mjs +0 -15
- package/dist/Card-DG7RIZdT.js +0 -83
- package/dist/Card-DWjfc534.js +0 -81
- package/dist/Checkbox/index.cjs +0 -15
- package/dist/Checkbox/index.mjs +0 -9
- package/dist/Checkbox-BDVwj5E8.js +0 -53
- package/dist/Checkbox-DDDvFfUJ.js +0 -55
- package/dist/Chip/hooks/index.cjs +0 -8
- package/dist/Chip/hooks/index.mjs +0 -2
- package/dist/Chip/index.cjs +0 -26
- package/dist/Chip/index.mjs +0 -18
- package/dist/Chip-Br7-JkgN.js +0 -70
- package/dist/Chip-CGMUQ-V-.js +0 -67
- package/dist/ChipDismissible-DETPCXth.js +0 -19
- package/dist/ChipDismissible-DyMHTSQ9.js +0 -22
- package/dist/Chips/InternalChipDismissible/hooks/index.cjs +0 -23
- package/dist/Chips/InternalChipDismissible/hooks/index.mjs +0 -13
- package/dist/Chips/InternalChipDismissible/index.cjs +0 -35
- package/dist/Chips/InternalChipDismissible/index.mjs +0 -29
- package/dist/Chips/index.cjs +0 -48
- package/dist/Chips/index.mjs +0 -44
- package/dist/Chips-B1RCrN1F.js +0 -93
- package/dist/Chips-DXbRgMUE.js +0 -91
- package/dist/Combobox/components/ComboboxAction/index.cjs +0 -12
- package/dist/Combobox/components/ComboboxAction/index.mjs +0 -6
- package/dist/Combobox/components/ComboboxActivator/index.cjs +0 -27
- package/dist/Combobox/components/ComboboxActivator/index.mjs +0 -21
- package/dist/Combobox/components/ComboboxContent/ComboboxContentHeader/index.cjs +0 -14
- package/dist/Combobox/components/ComboboxContent/ComboboxContentHeader/index.mjs +0 -8
- package/dist/Combobox/components/ComboboxContent/ComboboxContentList/index.cjs +0 -24
- package/dist/Combobox/components/ComboboxContent/ComboboxContentList/index.mjs +0 -18
- package/dist/Combobox/components/ComboboxContent/ComboboxContentSearch/index.cjs +0 -10
- package/dist/Combobox/components/ComboboxContent/ComboboxContentSearch/index.mjs +0 -4
- package/dist/Combobox/components/ComboboxContent/ComboboxLoadMore/index.cjs +0 -9
- package/dist/Combobox/components/ComboboxContent/ComboboxLoadMore/index.mjs +0 -3
- package/dist/Combobox/components/ComboboxContent/index.cjs +0 -34
- package/dist/Combobox/components/ComboboxContent/index.mjs +0 -28
- package/dist/Combobox/components/ComboboxOption/index.cjs +0 -14
- package/dist/Combobox/components/ComboboxOption/index.mjs +0 -8
- package/dist/Combobox/components/ComboboxTrigger/index.cjs +0 -25
- package/dist/Combobox/components/ComboboxTrigger/index.mjs +0 -19
- package/dist/Combobox/index.cjs +0 -53
- package/dist/Combobox/index.mjs +0 -46
- package/dist/Combobox-D0Qo3yYu.js +0 -117
- package/dist/Combobox-DxPzrwcK.js +0 -119
- package/dist/ComboboxAction-Ct0ao84E.js +0 -24
- package/dist/ComboboxAction-I7TT2mVE.js +0 -22
- package/dist/ComboboxActivator-BOGk012k.js +0 -26
- package/dist/ComboboxActivator-uU5VaZqF.js +0 -28
- package/dist/ComboboxContent-miRfjhNV.js +0 -145
- package/dist/ComboboxContent-u1C3PXKH.js +0 -143
- package/dist/ComboboxContentHeader-BF43vAXl.js +0 -27
- package/dist/ComboboxContentHeader-Cirx9k9L.js +0 -29
- package/dist/ComboboxContentList-DFv7m0NQ.js +0 -77
- package/dist/ComboboxContentList-nxCsc_XU.js +0 -75
- package/dist/ComboboxContentSearch-C2RHQNXR.js +0 -34
- package/dist/ComboboxContentSearch-DX-BiYTa.js +0 -32
- package/dist/ComboboxLoadMore-CUK0n3WY.js +0 -16
- package/dist/ComboboxLoadMore-t_s_eVDp.js +0 -14
- package/dist/ComboboxOption-BMg1O_Br.js +0 -20
- package/dist/ComboboxOption-DSzlMoup.js +0 -22
- package/dist/ComboboxProvider-GdvooWYJ.js +0 -10
- package/dist/ComboboxProvider-ku2HdEkO.js +0 -13
- package/dist/ComboboxTrigger-1KuifQvl.js +0 -24
- package/dist/ComboboxTrigger-CvcB6ptJ.js +0 -22
- package/dist/ConfirmationModal/index.cjs +0 -31
- package/dist/ConfirmationModal/index.mjs +0 -25
- package/dist/ConfirmationModal-DrQ-Nm1m.js +0 -94
- package/dist/Content/index.cjs +0 -9
- package/dist/Content/index.mjs +0 -3
- package/dist/Content-CobtdYug.js +0 -13
- package/dist/Content-D5eJgx6J.js +0 -15
- package/dist/Countdown/index.cjs +0 -11
- package/dist/Countdown/index.mjs +0 -5
- package/dist/Countdown-CXuL7Gh7.js +0 -659
- package/dist/Countdown-CnIjUABD.js +0 -657
- package/dist/DataDump/index.cjs +0 -24
- package/dist/DataDump/index.mjs +0 -18
- package/dist/DataDump-CXh_x55J.js +0 -15
- package/dist/DataDump-R0kwoLVp.js +0 -17
- package/dist/DataList/components/DataListAction/index.cjs +0 -13
- package/dist/DataList/components/DataListAction/index.mjs +0 -7
- package/dist/DataList/components/DataListActions/index.cjs +0 -43
- package/dist/DataList/components/DataListActions/index.mjs +0 -37
- package/dist/DataList/components/DataListActionsMenu/index.cjs +0 -17
- package/dist/DataList/components/DataListActionsMenu/index.mjs +0 -11
- package/dist/DataList/components/DataListBulkActions/index.cjs +0 -46
- package/dist/DataList/components/DataListBulkActions/index.mjs +0 -39
- package/dist/DataList/components/DataListEmptyState/index.cjs +0 -20
- package/dist/DataList/components/DataListEmptyState/index.mjs +0 -13
- package/dist/DataList/components/DataListFilters/components/DataListSort/index.cjs +0 -54
- package/dist/DataList/components/DataListFilters/components/DataListSort/index.mjs +0 -48
- package/dist/DataList/components/DataListFilters/index.cjs +0 -68
- package/dist/DataList/components/DataListFilters/index.mjs +0 -61
- package/dist/DataList/components/DataListHeader/index.cjs +0 -53
- package/dist/DataList/components/DataListHeader/index.mjs +0 -47
- package/dist/DataList/components/DataListHeaderTile/components/index.cjs +0 -12
- package/dist/DataList/components/DataListHeaderTile/components/index.mjs +0 -6
- package/dist/DataList/components/DataListHeaderTile/index.cjs +0 -20
- package/dist/DataList/components/DataListHeaderTile/index.mjs +0 -14
- package/dist/DataList/components/DataListItem/components/DataListItemClickable/index.cjs +0 -14
- package/dist/DataList/components/DataListItem/components/DataListItemClickable/index.mjs +0 -8
- package/dist/DataList/components/DataListItem/index.cjs +0 -52
- package/dist/DataList/components/DataListItem/index.mjs +0 -46
- package/dist/DataList/components/DataListItemActions/index.cjs +0 -45
- package/dist/DataList/components/DataListItemActions/index.mjs +0 -38
- package/dist/DataList/components/DataListItemActionsOverflow/index.cjs +0 -25
- package/dist/DataList/components/DataListItemActionsOverflow/index.mjs +0 -19
- package/dist/DataList/components/DataListItems/index.cjs +0 -53
- package/dist/DataList/components/DataListItems/index.mjs +0 -47
- package/dist/DataList/components/DataListLayout/index.cjs +0 -56
- package/dist/DataList/components/DataListLayout/index.mjs +0 -50
- package/dist/DataList/components/DataListLayoutActions/DataListLayoutContext/index.cjs +0 -9
- package/dist/DataList/components/DataListLayoutActions/DataListLayoutContext/index.mjs +0 -2
- package/dist/DataList/components/DataListLayoutActions/index.cjs +0 -33
- package/dist/DataList/components/DataListLayoutActions/index.mjs +0 -27
- package/dist/DataList/components/DataListLoadMore/index.cjs +0 -21
- package/dist/DataList/components/DataListLoadMore/index.mjs +0 -14
- package/dist/DataList/components/DataListLoadingState/index.cjs +0 -21
- package/dist/DataList/components/DataListLoadingState/index.mjs +0 -13
- package/dist/DataList/components/DataListOverflowFade/index.cjs +0 -11
- package/dist/DataList/components/DataListOverflowFade/index.mjs +0 -4
- package/dist/DataList/components/DataListSearch/index.cjs +0 -33
- package/dist/DataList/components/DataListSearch/index.mjs +0 -25
- package/dist/DataList/components/DataListStatusBar/index.cjs +0 -32
- package/dist/DataList/components/DataListStatusBar/index.mjs +0 -25
- package/dist/DataList/components/DataListStickyHeader/index.cjs +0 -11
- package/dist/DataList/components/DataListStickyHeader/index.mjs +0 -5
- package/dist/DataList/components/DataListTags/index.cjs +0 -12
- package/dist/DataList/components/DataListTags/index.mjs +0 -6
- package/dist/DataList/components/DataListTotalCount/index.cjs +0 -15
- package/dist/DataList/components/DataListTotalCount/index.mjs +0 -8
- package/dist/DataList/context/DataListContext/index.cjs +0 -12
- package/dist/DataList/context/DataListContext/index.mjs +0 -4
- package/dist/DataList/context/DataListLayoutContext/index.cjs +0 -12
- package/dist/DataList/context/DataListLayoutContext/index.mjs +0 -4
- package/dist/DataList/index.cjs +0 -98
- package/dist/DataList/index.mjs +0 -92
- package/dist/DataList-BRPBlIVp.js +0 -3
- package/dist/DataList-C_diEjjb.js +0 -5
- package/dist/DataList-DyUX97mL.js +0 -141
- package/dist/DataList-DzXNiSs1.js +0 -139
- package/dist/DataList.const-Bqcfo3vs.js +0 -38
- package/dist/DataList.const-z084v3KH.js +0 -25
- package/dist/DataList.utils-BjG-otvz.js +0 -168
- package/dist/DataList.utils-RcG6TvB4.js +0 -161
- package/dist/DataListAction-3U8gJcpE.js +0 -37
- package/dist/DataListAction-BN0qp_ae.js +0 -39
- package/dist/DataListActions-D1r_3WQD.js +0 -43
- package/dist/DataListActions-DV-03b5h.js +0 -45
- package/dist/DataListActionsMenu-Cg-ZZ0LI.js +0 -55
- package/dist/DataListActionsMenu-D9iOGk3i.js +0 -57
- package/dist/DataListBulkActions-BEFyOkWd.js +0 -29
- package/dist/DataListBulkActions-C2E5e2oE.js +0 -26
- package/dist/DataListContext-DTtBXteA.js +0 -25
- package/dist/DataListContext-qFN5DiHI.js +0 -29
- package/dist/DataListEmptyState-DTsqkHng.js +0 -50
- package/dist/DataListEmptyState-DfaWzs71.js +0 -53
- package/dist/DataListFilters-35MxtHUo.js +0 -43
- package/dist/DataListFilters-BjC9kPSD.js +0 -46
- package/dist/DataListHeader-CI-p6m7K.js +0 -93
- package/dist/DataListHeader-D5iNjhk1.js +0 -95
- package/dist/DataListHeaderTile-DwHOJPOJ.js +0 -81
- package/dist/DataListHeaderTile-K_UG9NgG.js +0 -79
- package/dist/DataListItem-BpD1kRWd.js +0 -112
- package/dist/DataListItem-CK9nQ-II.js +0 -114
- package/dist/DataListItemActions-B7Pbbv7U.js +0 -29
- package/dist/DataListItemActions-DDdszYpl.js +0 -32
- package/dist/DataListItemActionsOverflow-CmBtR4CV.js +0 -33
- package/dist/DataListItemActionsOverflow-D83sgU_z.js +0 -35
- package/dist/DataListItemClickable-BBVDmF_w.js +0 -45
- package/dist/DataListItemClickable-DluGOyKl.js +0 -47
- package/dist/DataListItems-DHSJSPeG.js +0 -21
- package/dist/DataListItems-hAiXRicl.js +0 -19
- package/dist/DataListLayout-CVVR8T7f.js +0 -21
- package/dist/DataListLayout-CiKR3P98.js +0 -19
- package/dist/DataListLayoutActions-BiR49Hjb.js +0 -36
- package/dist/DataListLayoutActions-CUWi8Fxy.js +0 -38
- package/dist/DataListLayoutContext-B3szPGTf.js +0 -8
- package/dist/DataListLayoutContext-CjAT05BI.js +0 -11
- package/dist/DataListLayoutContext-lF5Zk-jV.js +0 -18
- package/dist/DataListLayoutContext-p48sRC9i.js +0 -14
- package/dist/DataListLoadMore-CixukWAA.js +0 -31
- package/dist/DataListLoadMore-Cu32AbMo.js +0 -34
- package/dist/DataListLoadingState-CBsAzSFk.js +0 -22
- package/dist/DataListLoadingState-DFRSjdMI.js +0 -26
- package/dist/DataListOverflowFade-BGAt4dqm.js +0 -25
- package/dist/DataListOverflowFade-DU0y9j-T.js +0 -22
- package/dist/DataListSearch-C1PpW3kQ.js +0 -59
- package/dist/DataListSearch-uEaN0YJ7.js +0 -63
- package/dist/DataListSort-BrRFvXG5.js +0 -92
- package/dist/DataListSort-Dx6POURf.js +0 -94
- package/dist/DataListSortingOptions-BndDkYtw.js +0 -37
- package/dist/DataListSortingOptions-wYjmZSp4.js +0 -35
- package/dist/DataListStatusBar-B_NpGiAA.js +0 -22
- package/dist/DataListStatusBar-VdGpFaWQ.js +0 -25
- package/dist/DataListStickyHeader-CScdFohW.js +0 -25
- package/dist/DataListStickyHeader-YssmrZlM.js +0 -23
- package/dist/DataListTags-B4e8t5VV.js +0 -62
- package/dist/DataListTags-xHDVW7r1.js +0 -64
- package/dist/DataListTotalCount-FvMJCJV4.js +0 -27
- package/dist/DataListTotalCount-TVna906A.js +0 -24
- package/dist/DataTable/index.cjs +0 -36
- package/dist/DataTable/index.mjs +0 -25
- package/dist/DataTable/test-utilities/index.cjs +0 -246
- package/dist/DataTable/test-utilities/index.mjs +0 -238
- package/dist/DataTable-BhmuLCau.js +0 -236
- package/dist/DataTable-DRXABYeP.js +0 -238
- package/dist/DatePicker/index.cjs +0 -26
- package/dist/DatePicker/index.mjs +0 -20
- package/dist/DatePicker-BzXdyAsQ.js +0 -8554
- package/dist/DatePicker-CZnbHBrf.js +0 -8551
- package/dist/DayOfMonthSelect-GTME6B8V.js +0 -130
- package/dist/DayOfMonthSelect-Rxeaskdx.js +0 -137
- package/dist/DescriptionList/index.cjs +0 -10
- package/dist/DescriptionList/index.mjs +0 -4
- package/dist/DescriptionList-CMHhotQz.js +0 -12
- package/dist/DescriptionList-D4V2AGoH.js +0 -14
- package/dist/Disclosure/index.cjs +0 -17
- package/dist/Disclosure/index.mjs +0 -11
- package/dist/Disclosure-B_Ndy93n.js +0 -33
- package/dist/Disclosure-iwknokMb.js +0 -35
- package/dist/Divider/index.cjs +0 -9
- package/dist/Divider/index.mjs +0 -3
- package/dist/Divider-CQwVNie1.js +0 -17
- package/dist/Divider-aDM-8IiX.js +0 -19
- package/dist/Drawer/index.cjs +0 -19
- package/dist/Drawer/index.mjs +0 -12
- package/dist/DrawerGrid-Cy6jFIEj.js +0 -28
- package/dist/DrawerGrid-D-xjQAGo.js +0 -31
- package/dist/Emphasis/index.cjs +0 -10
- package/dist/Emphasis/index.mjs +0 -4
- package/dist/Emphasis-DIJAlzt-.js +0 -13
- package/dist/Emphasis-ZgoNe2R5.js +0 -15
- package/dist/FeatureSwitch/index.cjs +0 -26
- package/dist/FeatureSwitch/index.mjs +0 -20
- package/dist/FeatureSwitch-BKO31OVK.js +0 -52
- package/dist/FeatureSwitch-C4S0awPY.js +0 -54
- package/dist/Flex/index.cjs +0 -9
- package/dist/Flex/index.mjs +0 -3
- package/dist/Flex-Bfl-vL64.js +0 -28
- package/dist/Flex-Dh0WNozY.js +0 -30
- package/dist/Form/index.cjs +0 -10
- package/dist/Form/index.mjs +0 -4
- package/dist/Form-fdEPa2Di.js +0 -48
- package/dist/FormField/index.cjs +0 -20
- package/dist/FormField/index.mjs +0 -14
- package/dist/FormField-DY5JDjdc.js +0 -261
- package/dist/FormField-RMjW742D.js +0 -263
- package/dist/FormatDate/index.mjs +0 -2
- package/dist/FormatDate-YUbeta27.js +0 -27
- package/dist/FormatEmail/index.cjs +0 -9
- package/dist/FormatEmail/index.mjs +0 -3
- package/dist/FormatEmail-B7cAlIQY.js +0 -11
- package/dist/FormatEmail-DJLlhpQr.js +0 -13
- package/dist/FormatFile/index.cjs +0 -36
- package/dist/FormatFile/index.mjs +0 -30
- package/dist/FormatFile-BAZqq1p8.js +0 -149
- package/dist/FormatFile-CRPcqK86.js +0 -147
- package/dist/FormatRelativeDateTime/index.cjs +0 -8
- package/dist/FormatRelativeDateTime/index.mjs +0 -2
- package/dist/FormatRelativeDateTime-Ca1DyZ7Z.js +0 -64
- package/dist/FormatTime/index.cjs +0 -8
- package/dist/FormatTime/index.mjs +0 -2
- package/dist/FormatTime-DcIV5E6n.js +0 -29
- package/dist/Gallery/index.cjs +0 -42
- package/dist/Gallery/index.mjs +0 -36
- package/dist/Gallery-D9AVJQTM.js +0 -65
- package/dist/Gallery-Duiow0xg.js +0 -63
- package/dist/Glimmer/index.cjs +0 -12
- package/dist/Glimmer/index.mjs +0 -5
- package/dist/Glimmer-CG9tFCHs.js +0 -63
- package/dist/Glimmer-IWgpoHGI.js +0 -60
- package/dist/Grid/InternalGridCell/index.cjs +0 -9
- package/dist/Grid/InternalGridCell/index.mjs +0 -2
- package/dist/Grid/index.cjs +0 -14
- package/dist/Grid/index.mjs +0 -7
- package/dist/Grid-DzRYkCwi.js +0 -29
- package/dist/Grid-VQ3fN1ko.js +0 -32
- package/dist/Heading/index.cjs +0 -12
- package/dist/Heading/index.mjs +0 -6
- package/dist/Heading-D_ylbFzI.js +0 -49
- package/dist/Icon/index.cjs +0 -9
- package/dist/Icon/index.mjs +0 -3
- package/dist/Icon-C05AQvkv.js +0 -36
- package/dist/Icon-Dic5myD3.js +0 -34
- package/dist/InlineLabel/index.cjs +0 -10
- package/dist/InlineLabel/index.mjs +0 -4
- package/dist/InlineLabel-A3tenwf6.js +0 -20
- package/dist/InlineLabel-BLt0Q3bb.js +0 -18
- package/dist/InputAvatar/index.cjs +0 -26
- package/dist/InputAvatar/index.mjs +0 -20
- package/dist/InputAvatar-BdLo0JDy.js +0 -49
- package/dist/InputAvatar-Dqd68eBU.js +0 -47
- package/dist/InputDate/index.cjs +0 -34
- package/dist/InputDate/index.mjs +0 -28
- package/dist/InputDate-CEk7YABR.js +0 -48
- package/dist/InputEmail/index.cjs +0 -22
- package/dist/InputEmail/index.mjs +0 -15
- package/dist/InputEmail-C-EyDCxm.js +0 -20
- package/dist/InputEmail-wUgCu5JW.js +0 -23
- package/dist/InputFile/index.cjs +0 -23
- package/dist/InputFile/index.mjs +0 -16
- package/dist/InputFile-B4DD55KU.js +0 -1608
- package/dist/InputFile-D5DGGfOB.js +0 -1611
- package/dist/InputGroup/index.cjs +0 -9
- package/dist/InputGroup/index.mjs +0 -3
- package/dist/InputGroup-DeQx7ud8.js +0 -25
- package/dist/InputGroup-hh3QBfdL.js +0 -23
- package/dist/InputNumber/index.cjs +0 -21
- package/dist/InputNumber/index.mjs +0 -15
- package/dist/InputNumber-BveQrPyO.js +0 -56
- package/dist/InputPassword/index.cjs +0 -21
- package/dist/InputPassword/index.mjs +0 -15
- package/dist/InputPassword-C8V7VR78.js +0 -21
- package/dist/InputPassword-Dw7Go90j.js +0 -19
- package/dist/InputPhoneNumber/index.cjs +0 -21
- package/dist/InputPhoneNumber/index.mjs +0 -15
- package/dist/InputPhoneNumber-DVscxVqU.js +0 -94
- package/dist/InputText/index.cjs +0 -22
- package/dist/InputText/index.mjs +0 -16
- package/dist/InputText-COr1oIHK.js +0 -96
- package/dist/InputTime/index.cjs +0 -26
- package/dist/InputTime/index.mjs +0 -20
- package/dist/InputTime-_Oc4Hp9L.js +0 -190
- package/dist/InputValidation/index.cjs +0 -14
- package/dist/InputValidation/index.mjs +0 -8
- package/dist/InputValidation-BiJTp0aC.js +0 -22
- package/dist/InputValidation-CCkTBcxQ.js +0 -20
- package/dist/InternalChipDismissible-D8UrPjJC.js +0 -152
- package/dist/InternalChipDismissible-DUluzwH6.js +0 -157
- package/dist/InternalGridCell-Bi4IFFO8.js +0 -37
- package/dist/InternalGridCell-CE9IQZwO.js +0 -34
- package/dist/LightBox/index.cjs +0 -26
- package/dist/LightBox/index.mjs +0 -20
- package/dist/LightBox-CIWrYTaA.js +0 -110
- package/dist/LightBox-D-gmMO7L.js +0 -112
- package/dist/Link/index.cjs +0 -8
- package/dist/Link/index.mjs +0 -2
- package/dist/Link-_423xhjb.js +0 -7
- package/dist/Link-j486eamd.js +0 -9
- package/dist/List/index.cjs +0 -29
- package/dist/List/index.mjs +0 -22
- package/dist/List-BcQDY2Rj.js +0 -186
- package/dist/List-Dgwp7JmK.js +0 -189
- package/dist/Markdown/index.cjs +0 -19
- package/dist/Markdown/index.mjs +0 -13
- package/dist/Markdown-BfxzpIEM.js +0 -19011
- package/dist/Markdown-BhG7kPFl.js +0 -19013
- package/dist/Menu/index.cjs +0 -18
- package/dist/Menu/index.mjs +0 -12
- package/dist/Menu-CuPp5MtV.js +0 -129
- package/dist/Menu-DNImsnBT.js +0 -131
- package/dist/Modal/index.cjs +0 -23
- package/dist/Modal/index.mjs +0 -17
- package/dist/Modal-Cgz6UlsK.js +0 -62
- package/dist/Modal-DQHFlXp5.js +0 -60
- package/dist/MultiSelect/index.cjs +0 -16
- package/dist/MultiSelect/index.mjs +0 -10
- package/dist/MultiSelect-BxtKPK3-.js +0 -166
- package/dist/MultiSelect-DFR0vsTw.js +0 -164
- package/dist/Option-C87IriRr.js +0 -12
- package/dist/Option-X8lh2w6I.js +0 -15
- package/dist/Page/index.cjs +0 -32
- package/dist/Page/index.mjs +0 -26
- package/dist/Page-BgG3_7DX.js +0 -56
- package/dist/Page-BowBp8rI.js +0 -58
- package/dist/Popover/index.cjs +0 -17
- package/dist/Popover/index.mjs +0 -11
- package/dist/Popover-BwG9WBGX.js +0 -50
- package/dist/Popover-o9pOjTMP.js +0 -48
- package/dist/ProgressBar/index.cjs +0 -9
- package/dist/ProgressBar/index.mjs +0 -3
- package/dist/ProgressBar-CUTebo_k.js +0 -33
- package/dist/ProgressBar-OBLHnKRF.js +0 -31
- package/dist/RadioGroup/index.cjs +0 -12
- package/dist/RadioGroup/index.mjs +0 -5
- package/dist/RadioGroup-CxguJ9E7.js +0 -39
- package/dist/RadioGroup-Dt9_WguN.js +0 -36
- package/dist/RecurringSelect/components/index.cjs +0 -15
- package/dist/RecurringSelect/components/index.mjs +0 -6
- package/dist/RecurringSelect/index.cjs +0 -35
- package/dist/RecurringSelect/index.mjs +0 -21
- package/dist/RecurringSelect-BB2D2awE.js +0 -69
- package/dist/RecurringSelect-Dqle4F6a.js +0 -71
- package/dist/Select/index.cjs +0 -22
- package/dist/Select/index.mjs +0 -15
- package/dist/Spinner/index.cjs +0 -9
- package/dist/Spinner/index.mjs +0 -3
- package/dist/Spinner-CjTb3xIl.js +0 -16
- package/dist/Spinner-DGO8_Jsa.js +0 -14
- package/dist/StatusIndicator/index.cjs +0 -8
- package/dist/StatusIndicator/index.mjs +0 -2
- package/dist/StatusIndicator-CNH13isn.js +0 -11
- package/dist/StatusIndicator-DaWtSIUm.js +0 -9
- package/dist/StatusLabel/index.cjs +0 -11
- package/dist/StatusLabel/index.mjs +0 -5
- package/dist/StatusLabel-DuJzG65D.js +0 -18
- package/dist/StatusLabel-YebFZkcB.js +0 -16
- package/dist/Switch/index.cjs +0 -10
- package/dist/Switch/index.mjs +0 -4
- package/dist/Switch-CUBASre6.js +0 -46
- package/dist/Switch-KKEqlvTp.js +0 -48
- package/dist/Table/index.cjs +0 -17
- package/dist/Table/index.mjs +0 -4
- package/dist/Tabs/index.cjs +0 -11
- package/dist/Tabs/index.mjs +0 -4
- package/dist/Tabs-AoDyVJHh.js +0 -70
- package/dist/Tabs-CmCuGGLm.js +0 -67
- package/dist/Text/index.cjs +0 -10
- package/dist/Text/index.mjs +0 -4
- package/dist/Text-CfxmOdM-.js +0 -25
- package/dist/Toast/index.cjs +0 -16
- package/dist/Toast/index.mjs +0 -10
- package/dist/Tooltip/index.cjs +0 -14
- package/dist/Tooltip/index.mjs +0 -8
- package/dist/Tooltip-BrnUcSMD.js +0 -103
- package/dist/Tooltip-PbQMMMXT.js +0 -105
- package/dist/Typography/index.cjs +0 -9
- package/dist/Typography/index.mjs +0 -3
- package/dist/Typography-BiJhpsiL.js +0 -38
- package/dist/Typography-DscVWtp8.js +0 -36
- package/dist/_baseAssignValue-Byqm0l-g.js +0 -29
- package/dist/_baseAssignValue-ph7A7Tyf.js +0 -31
- package/dist/_baseEach-2sgXrDWN.js +0 -1073
- package/dist/_baseEach-DbUzYrtE.js +0 -1069
- package/dist/_commonjsHelpers-BHq9dk6I.js +0 -36
- package/dist/_commonjsHelpers-Dw5gAsMR.js +0 -32
- package/dist/_defineProperty-PEG-eSOB.js +0 -1326
- package/dist/_defineProperty-fDNRMxz-.js +0 -1306
- package/dist/_getTag-BBi2mXSK.js +0 -718
- package/dist/_getTag-CtczKdF2.js +0 -733
- package/dist/_polyfill-node.process-7AsFqJce.js +0 -258
- package/dist/_polyfill-node.process-B3Zw2Wh0.js +0 -255
- package/dist/_setToString-BEt-Msu3.js +0 -230
- package/dist/_setToString-BXD3rooF.js +0 -234
- package/dist/debounce-DHeCta_M.js +0 -329
- package/dist/debounce-DtVkjvKH.js +0 -332
- package/dist/helpers-BX_7EKw7.js +0 -15
- package/dist/helpers-BpmnB4Qy.js +0 -17
- package/dist/index-BE4KkyL_.js +0 -1186
- package/dist/index-dKBcvdAq.js +0 -1189
- package/dist/index.cjs +0 -275
- package/dist/index.d.mts +0 -74
- package/dist/index.d.ts +0 -74
- package/dist/index.mjs +0 -162
- package/dist/isObjectLike-53d8VfgU.js +0 -190
- package/dist/isObjectLike-zrq0mtNG.js +0 -197
- package/dist/isSymbol-B7o505jx.js +0 -35
- package/dist/isSymbol-Co3-vUC1.js +0 -33
- package/dist/noop-B8ZS2J9q.js +0 -24
- package/dist/noop-mF8IIYWw.js +0 -26
- package/dist/showToast-C4Fxtv_O.js +0 -97
- package/dist/showToast-Ckq11MSy.js +0 -99
- package/dist/styles.css +0 -8762
- package/dist/tslib.es6-5nrZ19JS.js +0 -97
- package/dist/tslib.es6-BBH1pS30.js +0 -102
- package/dist/useActiveLayout-BSipZn9t.js +0 -16
- package/dist/useActiveLayout-BqE7ZQY7.js +0 -14
- package/dist/useAssert-BTe43jaI.js +0 -27
- package/dist/useAssert-CSmf3rDf.js +0 -27
- package/dist/useAtlantisConfig-DC3Ppo_R.js +0 -14
- package/dist/useBatchSelect-KPnTra4u.js +0 -36
- package/dist/useBatchSelect-rQ55uZ7U.js +0 -38
- package/dist/useChildComponent-CwlKwCml.js +0 -15
- package/dist/useChildComponent-D7PbyArU.js +0 -17
- package/dist/useFocusTrap-B-xOQ79p.js +0 -74
- package/dist/useFocusTrap-D0gOZaSx.js +0 -74
- package/dist/useInView-CjeNEvX0.js +0 -25
- package/dist/useInView-DGjydyXL.js +0 -25
- package/dist/useIsMounted-BxDu0lnY.js +0 -47
- package/dist/useIsMounted-DfJrPzyU.js +0 -47
- package/dist/useOnKeyDown-07RktdgP.js +0 -40
- package/dist/useOnKeyDown-W2x-4HSi.js +0 -40
- package/dist/useRefocusOnActivator-BAub7L-i.js +0 -32
- package/dist/useRefocusOnActivator-BnM3unqN.js +0 -32
- package/dist/useResizeObserver-B4Vfml7U.js +0 -1192
- package/dist/useResizeObserver-DzMx2b66.js +0 -1189
- package/dist/useResponsiveSizing-DB6K2Viw.js +0 -51
- package/dist/useResponsiveSizing-DVb-nBuX.js +0 -49
- package/dist/useSafeLayoutEffect-BW_VIS6-.js +0 -12
- package/dist/useSafeLayoutEffect-juh5vdFE.js +0 -14
- package/dist/useScrollToActive-CQdgd_Dw.js +0 -591
- package/dist/useScrollToActive-DP9nvfrv.js +0 -597
- /package/{.eslintrc.cjs → .eslintrc.js} +0 -0
- /package/dist/{AtlantisContext-AiJSmYGH.js → AtlantisContext-64608897.js} +0 -0
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var classnames = require('classnames');
|
|
5
|
+
var framerMotion = require('framer-motion');
|
|
6
|
+
var useOnKeyDown = require('@jobber/hooks/useOnKeyDown');
|
|
7
|
+
var useRefocusOnActivator = require('@jobber/hooks/useRefocusOnActivator');
|
|
8
|
+
var useSafeLayoutEffect = require('@jobber/hooks/useSafeLayoutEffect');
|
|
9
|
+
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
10
|
+
var Button = require('./Button-6b922fc1.js');
|
|
11
|
+
var Typography = require('./Typography-e2a23b7e.js');
|
|
12
|
+
var Icon = require('./Icon-405a216c.js');
|
|
13
|
+
|
|
14
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
15
|
+
|
|
16
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
17
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
18
|
+
|
|
19
|
+
var css_248z = ".dT6M9tp1sZc- * {\n box-sizing: border-box;\n}\n\n.dT6M9tp1sZc- {\n --menu-space: var(--space-small);\n --menu-offset: var(--space-smallest);\n display: inline-block;\n position: relative;\n}\n\n.Qmxlsj0D3qM- {\n position: fixed;\n bottom: 0;\n left: 0;\n z-index: 6;\n z-index: var(--elevation-menu);\n width: 100%;\n max-height: 72vh;\n box-shadow: 0px calc(16px / 16) calc(16px / 4) 0px\n rgba(0, 0, 0, 0.1),\n 0px calc(16px / 4) 12px 0px rgba(0, 0, 0, 0.05);\n box-shadow: var(--shadow-base);\n padding: var(--menu-space);\n padding-bottom: calc(env(safe-area-inset-bottom) + var(--menu-space));\n border-radius: calc(16px / 8) calc(16px / 8) 0 0;\n border-radius: var(--radius-base) var(--radius-base) 0 0;\n -webkit-overflow-scrolling: touch;\n overflow-y: scroll;\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n}\n\n@media (min-width: 490px) {\n\n.Qmxlsj0D3qM- {\n position: absolute;\n left: auto;\n width: calc(16px * 12.5);\n width: calc(var(--base-unit) * 12.5);\n padding: var(--menu-space);\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n overflow: auto;\n}\n }\n\n@media (--small-screens-and-up) {\n\n.Qmxlsj0D3qM- {\n position: absolute;\n left: auto;\n width: calc(16px * 12.5);\n width: calc(var(--base-unit) * 12.5);\n padding: var(--menu-space);\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n overflow: auto;\n}\n }\n\n@media (min-width: 490px) {\n\n.QTisUfiHwL4- {\n bottom: 100%;\n margin-bottom: var(--menu-offset);\n}\n }\n\n@media (--small-screens-and-up) {\n\n.QTisUfiHwL4- {\n bottom: 100%;\n margin-bottom: var(--menu-offset);\n}\n }\n\n@media (min-width: 490px) {\n\n.qsch1dlpOHc- {\n top: 100%;\n bottom: auto;\n margin-top: var(--menu-offset);\n}\n }\n\n@media (--small-screens-and-up) {\n\n.qsch1dlpOHc- {\n top: 100%;\n bottom: auto;\n margin-top: var(--menu-offset);\n}\n }\n\n@media (min-width: 490px) {\n\n._0xR9-oxWMOU- {\n right: 0;\n left: auto;\n}\n }\n\n@media (--small-screens-and-up) {\n\n._0xR9-oxWMOU- {\n right: 0;\n left: auto;\n}\n }\n\n@media (min-width: 490px) {\n\n.gaZwsdyoG0k- {\n right: auto;\n left: 0;\n}\n }\n\n@media (--small-screens-and-up) {\n\n.gaZwsdyoG0k- {\n right: auto;\n left: 0;\n}\n }\n\n.LaKFjYCLHZc- {\n padding: var(--menu-space) 0;\n border-bottom: calc(16px / 16) solid rgb(217, 223, 225);\n border-bottom: var(--border-base) solid var(--color-border);\n}\n\n.LaKFjYCLHZc-:first-of-type {\n padding-top: 0;\n}\n\n.LaKFjYCLHZc-:last-of-type {\n padding-bottom: 0;\n border-bottom: none;\n}\n\n._7HB7dWnqCi0- {\n padding: var(--menu-space);\n}\n\n.jobber-retheme ._7HB7dWnqCi0- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-align: center;\n align-items: center;\n padding: calc(var(--menu-space) * 1.5) var(--menu-space);\n}\n\n.jobber-retheme ._7HB7dWnqCi0- h6 {\n /* can move into the Typography component post re-theme */\n font-size: calc((16px * 1) * 0.875);\n font-size: calc(calc(16px * 1) * 0.875);\n font-size: var(--typography--fontSize-base);\n font-weight: 400;\n text-transform: none;\n}\n\n.ZuceCiefKqw- {\n display: -ms-flexbox;\n display: flex;\n gap: calc(16px * 1);\n gap: var(--space-base);\n width: 100%;\n padding: var(--menu-space);\n border: none;\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n background-color: transparent;\n cursor: pointer;\n -ms-flex-align: center;\n align-items: center;\n}\n\n.jobber-retheme .ZuceCiefKqw- {\n gap: var(--menu-space);\n}\n\n.ZuceCiefKqw-:hover,\n.ZuceCiefKqw-:focus-visible {\n background-color: rgb(244, 246, 250);\n background-color: var(--color-surface--hover);\n outline-color: rgb(147, 161, 169);\n outline-color: var(--color-focus);\n}\n\n.jobber-retheme .ZuceCiefKqw- span {\n /* can move into the Typography component post re-theme */\n color: rgb(77, 105, 116);\n color: var(--color-text--secondary);\n font-weight: 600;\n}\n\n.jobber-retheme .Bz8TONF8kws- path {\n /* can move into the Icon component post re-theme */\n fill: rgba(101, 120, 132, 1);\n fill: var(--color-interactive--subtle);\n}\n\n.eKnUAucwwWU- {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 6;\n z-index: var(--elevation-menu);\n background-color: rgba(0, 0, 0, 0.32);\n background-color: var(--color-overlay);\n}\n\n@media (min-width: 490px) {\n\n.eKnUAucwwWU- {\n background-color: transparent;\n}\n }\n\n@media (--small-screens-and-up) {\n\n.eKnUAucwwWU- {\n background-color: transparent;\n}\n }\n\n.oaxefr58z-E- {\n width: 100%;\n}\n\n.vz9opIdwHFg- {\n position: absolute;\n width: 1px;\n height: 1px;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n}\n";
|
|
20
|
+
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-"};
|
|
21
|
+
styleInject_es.styleInject(css_248z);
|
|
22
|
+
|
|
23
|
+
const variation = {
|
|
24
|
+
overlayStartStop: { opacity: 0 },
|
|
25
|
+
startOrStop: (position) => {
|
|
26
|
+
let y = 10;
|
|
27
|
+
if (position === "below")
|
|
28
|
+
y *= -1;
|
|
29
|
+
if (window.innerWidth < 640)
|
|
30
|
+
y = 150;
|
|
31
|
+
return { opacity: 0, y };
|
|
32
|
+
},
|
|
33
|
+
done: { opacity: 1, y: 0 },
|
|
34
|
+
};
|
|
35
|
+
// eslint-disable-next-line max-statements
|
|
36
|
+
function Menu({ activator, items }) {
|
|
37
|
+
var _a;
|
|
38
|
+
const [visible, setVisible] = React.useState(false);
|
|
39
|
+
const fullWidth = ((_a = activator === null || activator === void 0 ? void 0 : activator.props) === null || _a === void 0 ? void 0 : _a.fullWidth) || false;
|
|
40
|
+
const [position, setPosition] = React.useState({
|
|
41
|
+
vertical: "below",
|
|
42
|
+
horizontal: "right",
|
|
43
|
+
});
|
|
44
|
+
const wrapperRef = React.createRef();
|
|
45
|
+
const buttonID = React.useId();
|
|
46
|
+
const menuID = React.useId();
|
|
47
|
+
useOnKeyDown.useOnKeyDown(handleKeyboardShortcut, ["Escape"]);
|
|
48
|
+
useSafeLayoutEffect.useSafeLayoutEffect(() => {
|
|
49
|
+
if (wrapperRef.current) {
|
|
50
|
+
const bounds = wrapperRef.current.getBoundingClientRect();
|
|
51
|
+
const newPosition = Object.assign({}, position);
|
|
52
|
+
if (bounds.top <= window.innerHeight / 2) {
|
|
53
|
+
newPosition.vertical = "below";
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
newPosition.vertical = "above";
|
|
57
|
+
}
|
|
58
|
+
if (bounds.left <= window.innerWidth / 2) {
|
|
59
|
+
newPosition.horizontal = "right";
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
newPosition.horizontal = "left";
|
|
63
|
+
}
|
|
64
|
+
setPosition(newPosition);
|
|
65
|
+
}
|
|
66
|
+
}, [visible, fullWidth]);
|
|
67
|
+
useRefocusOnActivator.useRefocusOnActivator(visible);
|
|
68
|
+
if (!activator) {
|
|
69
|
+
activator = (React__default["default"].createElement(Button.Button, { fullWidth: true, label: "More Actions", icon: "more", type: "secondary" }));
|
|
70
|
+
}
|
|
71
|
+
const menuClasses = classnames__default["default"](styles.menu, position.vertical === "above" && styles.above, position.vertical === "below" && styles.below, position.horizontal === "left" && styles.left, position.horizontal === "right" && styles.right);
|
|
72
|
+
const wrapperClasses = classnames__default["default"](styles.wrapper, {
|
|
73
|
+
[styles.fullWidth]: fullWidth,
|
|
74
|
+
});
|
|
75
|
+
return (React__default["default"].createElement("div", { className: wrapperClasses, ref: wrapperRef, onClick: handleParentClick },
|
|
76
|
+
React__default["default"].cloneElement(activator, {
|
|
77
|
+
onClick: toggle(activator.props.onClick),
|
|
78
|
+
id: buttonID,
|
|
79
|
+
ariaControls: menuID,
|
|
80
|
+
ariaExpanded: visible,
|
|
81
|
+
ariaHaspopup: true,
|
|
82
|
+
}),
|
|
83
|
+
React__default["default"].createElement(framerMotion.AnimatePresence, null, visible && (React__default["default"].createElement(React__default["default"].Fragment, null,
|
|
84
|
+
React__default["default"].createElement(framerMotion.motion.div, { className: styles.overlay, onClick: toggle(), variants: variation, initial: "overlayStartStop", animate: "done", exit: "overlayStartStop", transition: {
|
|
85
|
+
type: "tween",
|
|
86
|
+
duration: 0.15,
|
|
87
|
+
} }),
|
|
88
|
+
React__default["default"].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: {
|
|
89
|
+
type: "tween",
|
|
90
|
+
duration: 0.25,
|
|
91
|
+
} }, items.map((item, key) => (React__default["default"].createElement("div", { key: key, className: styles.section },
|
|
92
|
+
item.header && React__default["default"].createElement(SectionHeader, { text: item.header }),
|
|
93
|
+
item.actions.map((action, index) => (React__default["default"].createElement(Action, Object.assign({ sectionLabel: item.header, key: action.label, shouldFocus: key === 0 && index === 0 }, action)))))))))))));
|
|
94
|
+
function toggle(callbackPassthrough) {
|
|
95
|
+
return (event) => {
|
|
96
|
+
setVisible(!visible);
|
|
97
|
+
callbackPassthrough && callbackPassthrough(event);
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
function hide() {
|
|
101
|
+
setVisible(false);
|
|
102
|
+
}
|
|
103
|
+
function handleKeyboardShortcut(event) {
|
|
104
|
+
const { key } = event;
|
|
105
|
+
if (!visible)
|
|
106
|
+
return;
|
|
107
|
+
event.preventDefault();
|
|
108
|
+
event.stopPropagation();
|
|
109
|
+
key === "Escape" && hide();
|
|
110
|
+
}
|
|
111
|
+
function handleParentClick(event) {
|
|
112
|
+
// Since the menu is being rendered within the same parent as the activator,
|
|
113
|
+
// we need to stop the click event from bubbling up. If the Menu component
|
|
114
|
+
// gets added within a parent that has a click handler, any click on the
|
|
115
|
+
// menu will trigger the parent's click handler.
|
|
116
|
+
event.stopPropagation();
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
function SectionHeader({ text }) {
|
|
120
|
+
return (React__default["default"].createElement("div", { className: styles.sectionHeader, "aria-hidden": true },
|
|
121
|
+
React__default["default"].createElement(Typography.Typography, { element: "h6", size: "small", textCase: "uppercase", textColor: "textSecondary", fontWeight: "bold" }, text)));
|
|
122
|
+
}
|
|
123
|
+
function Action({ label, sectionLabel, icon, onClick, shouldFocus = false, }) {
|
|
124
|
+
const actionButtonRef = React.useRef();
|
|
125
|
+
React.useEffect(() => {
|
|
126
|
+
if (shouldFocus) {
|
|
127
|
+
// Focus on the next tick to allow useRefocusOnActivator to initialize
|
|
128
|
+
setTimeout(() => { var _a; return (_a = actionButtonRef.current) === null || _a === void 0 ? void 0 : _a.focus(); }, 0);
|
|
129
|
+
}
|
|
130
|
+
}, [shouldFocus]);
|
|
131
|
+
return (React__default["default"].createElement("button", { role: "menuitem", type: "button", className: styles.action, key: label, onClick: onClick, ref: actionButtonRef },
|
|
132
|
+
icon && (React__default["default"].createElement("span", { className: styles.icon },
|
|
133
|
+
React__default["default"].createElement(Icon.Icon, { name: icon }))),
|
|
134
|
+
React__default["default"].createElement(Typography.Typography, { element: "span", size: "base", textColor: "text" },
|
|
135
|
+
sectionLabel && (React__default["default"].createElement("span", { className: styles.screenReaderOnly }, sectionLabel)),
|
|
136
|
+
label)));
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
exports.Menu = Menu;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var Modal = require('../Modal-067becad.js');
|
|
6
|
+
require('react');
|
|
7
|
+
require('react-dom');
|
|
8
|
+
require('classnames');
|
|
9
|
+
require('framer-motion');
|
|
10
|
+
require('@jobber/hooks/useRefocusOnActivator');
|
|
11
|
+
require('@jobber/hooks/useOnKeyDown');
|
|
12
|
+
require('@jobber/hooks/useFocusTrap');
|
|
13
|
+
require('../style-inject.es-9d2f5f4e.js');
|
|
14
|
+
require('../Heading-23d382a1.js');
|
|
15
|
+
require('../Typography-e2a23b7e.js');
|
|
16
|
+
require('../useAtlantisConfig-ed0bee66.js');
|
|
17
|
+
require('@jobber/hooks/useSafeLayoutEffect');
|
|
18
|
+
require('../Button-6b922fc1.js');
|
|
19
|
+
require('react-router-dom');
|
|
20
|
+
require('../Icon-405a216c.js');
|
|
21
|
+
require('@jobber/design');
|
|
22
|
+
require('../ButtonDismiss-a3ba1de2.js');
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
exports.Modal = Modal.Modal;
|
|
@@ -0,0 +1,73 @@
|
|
|
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('@jobber/hooks/useRefocusOnActivator');
|
|
8
|
+
var useOnKeyDown = require('@jobber/hooks/useOnKeyDown');
|
|
9
|
+
var useFocusTrap = require('@jobber/hooks/useFocusTrap');
|
|
10
|
+
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
11
|
+
var Heading = require('./Heading-23d382a1.js');
|
|
12
|
+
var Button = require('./Button-6b922fc1.js');
|
|
13
|
+
var ButtonDismiss = require('./ButtonDismiss-a3ba1de2.js');
|
|
14
|
+
|
|
15
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
16
|
+
|
|
17
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
18
|
+
var ReactDOM__default = /*#__PURE__*/_interopDefaultLegacy(ReactDOM);
|
|
19
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
20
|
+
|
|
21
|
+
var css_248z$1 = ":root {\n --modal--width: calc(var(--base-unit) * 37.5);\n --modal--padding-horizontal: var(--space-base);\n --modal--padding-vertical: var(--space-base);\n --modal--padding: var(--modal--padding-vertical)\n var(--modal--padding-horizontal);\n}\n\n@media (min-width: 768px) {\n\n:root {\n --modal--padding-horizontal: var(--space-large);\n}\n }\n\n@media (--medium-screens-and-up) {\n\n:root {\n --modal--padding-horizontal: var(--space-large);\n}\n }\n\n:root .jobber-retheme {\n --modal--shadow: var(--shadow-base);\n}\n\n@media (min-width: 768px) {\n\n:root .jobber-retheme {\n --modal--padding-horizontal: var(--space-large);\n --modal--padding-vertical: var(--space-large);\n --modal--padding: var(--modal--padding-vertical)\n var(--modal--padding-horizontal);\n}\n }\n\n@media (--medium-screens-and-up) {\n\n:root .jobber-retheme {\n --modal--padding-horizontal: var(--space-large);\n --modal--padding-vertical: var(--space-large);\n --modal--padding: var(--modal--padding-vertical)\n var(--modal--padding-horizontal);\n}\n }\n\n.QGRLFHPoV5E- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-direction: column;\n flex-direction: column;\n z-index: 1001;\n z-index: var(--elevation-modal);\n padding: calc(16px / 2);\n padding: var(--space-small);\n overflow: auto;\n}\n\n.QGRLFHPoV5E-,\n._4WzGOMUGj5I- {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n}\n\n._4WzGOMUGj5I- {\n background-color: rgba(0, 0, 0, 0.32);\n background-color: var(--color-overlay);\n}\n\n.WLId2NJBQcQ- {\n position: relative;\n width: 100%;\n max-width: calc(16px * 37.5);\n max-width: var(--modal--width);\n box-shadow: var(--modal--shadow);\n margin: auto;\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n outline-color: rgb(147, 161, 169);\n outline-color: var(--color-focus);\n}\n\n/* Adjust `Content` and `Tab` components public padding to match the modal */\n\n.WLId2NJBQcQ- > * {\n --public-content--padding: var(--modal--padding);\n --public-tab--inset: var(--modal--padding-horizontal);\n}\n\n/* Remove the nested `Content` components public padding */\n\n.WLId2NJBQcQ- > * > * {\n --public-content--padding: 0;\n}\n\n.wjrPpIUNNrk- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-pack: justify;\n justify-content: space-between;\n -ms-flex-align: center;\n align-items: center;\n padding: calc(16px * 1)\n calc(16px * 1);\n padding: var(--modal--padding);\n background-color: rgb(238, 240, 242);\n background-color: var(--color-surface--background);\n}\n\n.jobber-retheme .wjrPpIUNNrk- {\n background-color: transparent;\n}\n\n.jobber-retheme .wjrPpIUNNrk- h3 {\n font-family: \"Inter\", Helvetica, Arial, sans-serif;\n font-family: var(--typography--fontFamily-normal);\n font-size: calc((16px * 1) * 1.5);\n font-size: calc(calc(16px * 1) * 1.5);\n font-size: var(--typography--fontSize-largest);\n}\n\n/**\n * Ensure there's no extra padding top on the next element. This mostly negates\n * the <Content /> padding\n */\n\n.jobber-retheme .wjrPpIUNNrk- + * {\n padding-top: 0;\n}\n\n.rKvigUnOyYE- {\n padding: 0;\n border: none;\n background-color: transparent;\n cursor: pointer;\n -webkit-appearance: none;\n appearance: none;\n}\n\n._62c8HLZFwvs- {\n display: -ms-flexbox;\n display: flex;\n padding: calc(16px * 1)\n calc(16px * 1);\n padding: var(--modal--padding);\n padding-top: 0;\n -ms-flex: 1 1 100%;\n flex: 1 1 100%;\n -ms-flex-pack: end;\n justify-content: flex-end;\n}\n\n/**\n * 1. Use CSS `order` to adjust the buttons position on the UI\n */\n\n.Xl1Ptn-P9Ew- {\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n -ms-flex-order: 1;\n order: 1; /* 1 */\n}\n\n.p2s7GtpoZz0- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n -ms-flex-order: 2;\n order: 2; /* 1 */\n}\n\n/* This is in a correct position and order */\n\n/* stylelint-disable-next-line no-descending-specificity */\n\n.p2s7GtpoZz0- > * {\n margin-left: calc(16px / 2);\n margin-left: var(--space-small);\n}\n\n.p2s7GtpoZz0- > *:first-child {\n -ms-flex-order: 2;\n order: 2; /* 1 */\n}\n\n.p2s7GtpoZz0- > *:nth-child(2) {\n -ms-flex-order: 1;\n order: 1; /* 1 */\n}\n";
|
|
22
|
+
var styles = {"container":"QGRLFHPoV5E-","overlay":"_4WzGOMUGj5I-","modal":"WLId2NJBQcQ-","header":"wjrPpIUNNrk-","closeButton":"rKvigUnOyYE-","actionBar":"_62c8HLZFwvs-","leftAction":"Xl1Ptn-P9Ew-","rightAction":"p2s7GtpoZz0-"};
|
|
23
|
+
styleInject_es.styleInject(css_248z$1);
|
|
24
|
+
|
|
25
|
+
var css_248z = "._65IpUjOZiBg- {\n --modal--padding: var(--space-base);\n --public-tab--inset: var(--space-base);\n max-width: calc(16px * 25);\n max-width: calc(var(--base-unit) * 25);\n}\n\n.Cpwnmw65caA- {\n max-width: calc(16px * 58.75);\n max-width: calc(var(--base-unit) * 58.75);\n}\n";
|
|
26
|
+
var sizes = {"small":"_65IpUjOZiBg-","large":"Cpwnmw65caA-"};
|
|
27
|
+
styleInject_es.styleInject(css_248z);
|
|
28
|
+
|
|
29
|
+
function Modal({ open = false, title, size, dismissible = true, children, primaryAction, secondaryAction, tertiaryAction, onRequestClose, }) {
|
|
30
|
+
const modalClassName = classnames__default["default"](styles.modal, size && sizes[size]);
|
|
31
|
+
useRefocusOnActivator.useRefocusOnActivator(open);
|
|
32
|
+
const modalRef = useFocusTrap.useFocusTrap(open);
|
|
33
|
+
useOnKeyDown.useOnKeyDown(handleRequestClose, "Escape");
|
|
34
|
+
const template = (React__default["default"].createElement(framerMotion.AnimatePresence, null, open && (React__default["default"].createElement("div", { ref: modalRef, role: "dialog", className: styles.container, tabIndex: 0 },
|
|
35
|
+
React__default["default"].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 } }),
|
|
36
|
+
React__default["default"].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: {
|
|
37
|
+
duration: 0.2,
|
|
38
|
+
ease: "easeInOut",
|
|
39
|
+
} },
|
|
40
|
+
title != undefined && (React__default["default"].createElement(Header, { title: title, dismissible: dismissible, onRequestClose: onRequestClose })),
|
|
41
|
+
children,
|
|
42
|
+
React__default["default"].createElement(Actions, { primary: primaryAction, secondary: secondaryAction, tertiary: tertiaryAction }))))));
|
|
43
|
+
return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
|
|
44
|
+
? ReactDOM__default["default"].createPortal(template, document.body)
|
|
45
|
+
: template;
|
|
46
|
+
function handleRequestClose() {
|
|
47
|
+
if (open && onRequestClose) {
|
|
48
|
+
onRequestClose();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
function Header({ title, dismissible, onRequestClose }) {
|
|
53
|
+
return (React__default["default"].createElement("div", { className: styles.header, "data-testid": "modal-header" },
|
|
54
|
+
React__default["default"].createElement(Heading.Heading, { level: 3 }, title),
|
|
55
|
+
dismissible && (React__default["default"].createElement(ButtonDismiss.ButtonDismiss, { onClick: onRequestClose, ariaLabel: "Close modal" }))));
|
|
56
|
+
}
|
|
57
|
+
function Actions({ primary, secondary, tertiary }) {
|
|
58
|
+
const shouldShow = primary != undefined || secondary != undefined || tertiary != undefined;
|
|
59
|
+
if (secondary != undefined) {
|
|
60
|
+
secondary = Object.assign({ type: "primary", variation: "subtle" }, secondary);
|
|
61
|
+
}
|
|
62
|
+
if (tertiary != undefined) {
|
|
63
|
+
tertiary = Object.assign({ type: "secondary", variation: "destructive" }, tertiary);
|
|
64
|
+
}
|
|
65
|
+
return (React__default["default"].createElement(React__default["default"].Fragment, null, shouldShow && (React__default["default"].createElement("div", { className: styles.actionBar },
|
|
66
|
+
React__default["default"].createElement("div", { className: styles.rightAction },
|
|
67
|
+
primary && React__default["default"].createElement(Button.Button, Object.assign({}, primary)),
|
|
68
|
+
secondary && React__default["default"].createElement(Button.Button, Object.assign({}, secondary))),
|
|
69
|
+
tertiary && (React__default["default"].createElement("div", { className: styles.leftAction },
|
|
70
|
+
React__default["default"].createElement(Button.Button, Object.assign({}, tertiary))))))));
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
exports.Modal = Modal;
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var classnames = require('classnames');
|
|
7
|
+
var styleInject_es = require('../style-inject.es-9d2f5f4e.js');
|
|
8
|
+
var Checkbox = require('../Checkbox-e481a4b1.js');
|
|
9
|
+
var Text = require('../Text-fbeaaca6.js');
|
|
10
|
+
var Icon = require('../Icon-405a216c.js');
|
|
11
|
+
require('../tslib.es6-754e2961.js');
|
|
12
|
+
require('react-hook-form');
|
|
13
|
+
require('../Typography-e2a23b7e.js');
|
|
14
|
+
require('@jobber/design');
|
|
15
|
+
|
|
16
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
17
|
+
|
|
18
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
19
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
20
|
+
|
|
21
|
+
var css_248z$1 = ".D-J03az6XL4- {\n position: relative;\n width: 100%;\n}\n\n.D-J03az6XL4- * {\n box-sizing: border-box;\n}\n\n.EzNdHgwsT40- {\n --field--height: var(--space-largest);\n\n --field--padding-top: calc(var(--space-base) - var(--space-smallest));\n --field--padding-bottom: calc(var(--space-base) - var(--space-smallest));\n --field--padding-left: var(--space-base);\n --field--padding-right: var(--space-base);\n\n display: -ms-flexbox;\n\n display: flex;\n -ms-flex-direction: row;\n flex-direction: row;\n -ms-flex-pack: justify;\n justify-content: space-between;\n -ms-flex-align: center;\n align-items: center;\n width: 100%;\n height: calc(16px * 3);\n height: var(--field--height);\n padding-top: calc((16px * 1) - (16px / 8));\n padding-top: calc(calc(16px * 1) - calc(16px / 8));\n padding-top: var(--field--padding-top);\n padding-bottom: calc((16px * 1) - (16px / 8));\n padding-bottom: calc(calc(16px * 1) - calc(16px / 8));\n padding-bottom: var(--field--padding-bottom);\n padding-left: calc(16px * 1);\n padding-left: var(--field--padding-left);\n padding-right: calc(16px * 1);\n padding-right: var(--field--padding-right);\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n}\n\n.EzNdHgwsT40- p {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.D-J03az6XL4-:hover,\n.D-J03az6XL4-.EzNdHgwsT40- {\n cursor: pointer;\n caret-color: transparent;\n}\n\n.EzNdHgwsT40-:focus,\n.EzNdHgwsT40-.bu7HWKRu6HI- {\n box-shadow: 0px 0px 0px calc(16px / 8) rgba(255, 255, 255, 1),\n 0px 0px 0px calc(16px / 4) rgb(147, 161, 169);\n box-shadow: var(--shadow-focus);\n outline: none;\n}\n\n.eQ6yfQg6zLc- {\n --field--padding-left: calc(var(--space-base) - var(--space-smaller));\n --field--padding-right: calc(var(--space-base) - var(--space-smaller));\n --field--height: calc(var(--space-larger) + var(--space-smaller));\n}\n\n.pM-ts4-QMZY- {\n --field--padding-left: var(--space-large);\n --field--padding-right: var(--space-large);\n --field--height: calc(var(--space-extravagant));\n}\n";
|
|
22
|
+
var styles$1 = {"multiSelectContainer":"D-J03az6XL4-","multiSelect":"EzNdHgwsT40-","active":"bu7HWKRu6HI-","small":"eQ6yfQg6zLc-","large":"pM-ts4-QMZY-"};
|
|
23
|
+
styleInject_es.styleInject(css_248z$1);
|
|
24
|
+
|
|
25
|
+
var css_248z = "._0SStdD4KRHs- {\n display: -ms-flexbox;\n display: flex;\n position: absolute;\n z-index: 6;\n z-index: var(--elevation-menu);\n width: 100%;\n max-height: calc((16px * 4) * 5);\n max-height: calc(calc(16px * 4) * 5);\n max-height: calc(var(--space-extravagant) * 5);\n box-shadow: 0px calc(16px / 16) calc(16px / 4) 0px\n rgba(0, 0, 0, 0.1),\n 0px calc(16px / 4) 12px 0px rgba(0, 0, 0, 0.05);\n box-shadow: var(--shadow-base);\n margin: 0;\n padding: 0;\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc(16px / 4);\n border-radius: var(--radius-large);\n overflow: auto;\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n -ms-flex-direction: column;\n flex-direction: column;\n scroll-behavior: smooth;\n}\n\n._0SStdD4KRHs- li {\n list-style: none;\n}\n\n.mFSgwOQZJm0- {\n display: -ms-flexbox;\n display: flex;\n width: 100%;\n padding: calc(16px / 2) calc(16px * 1);\n padding: var(--space-small) var(--space-base);\n cursor: pointer;\n transition: all 200ms;\n transition: all var(--timing-base);\n}\n\n.mFSgwOQZJm0-:focus,\n.mFSgwOQZJm0-.SepF4gvOxq8- {\n background-color: rgb(244, 246, 250);\n background-color: var(--color-surface--hover);\n outline-color: rgb(147, 161, 169);\n outline-color: var(--color-focus);\n}\n";
|
|
26
|
+
var styles = {"dropDownMenuContainer":"_0SStdD4KRHs-","option":"mFSgwOQZJm0-","active":"SepF4gvOxq8-"};
|
|
27
|
+
styleInject_es.styleInject(css_248z);
|
|
28
|
+
|
|
29
|
+
function DropDownMenu({ options, setOptions }) {
|
|
30
|
+
const [highlightedIndex, setHighlightedIndex] = React.useState(0);
|
|
31
|
+
const menuDiv = React.useRef();
|
|
32
|
+
const handleOptionClick = React.useCallback((clickedOption) => {
|
|
33
|
+
setOptions(current => current.map(option => {
|
|
34
|
+
if (option.label == clickedOption.label) {
|
|
35
|
+
return Object.assign(Object.assign({}, option), { checked: !clickedOption.checked });
|
|
36
|
+
}
|
|
37
|
+
return option;
|
|
38
|
+
}));
|
|
39
|
+
}, []);
|
|
40
|
+
function handleOptionHover(event, index) {
|
|
41
|
+
event.preventDefault();
|
|
42
|
+
setHighlightedIndex(index);
|
|
43
|
+
}
|
|
44
|
+
function handleOptionFocus(index) {
|
|
45
|
+
setHighlightedIndex(index);
|
|
46
|
+
if (menuDiv.current) {
|
|
47
|
+
const option = menuDiv.current.children[index].querySelector("input");
|
|
48
|
+
option === null || option === void 0 ? void 0 : option.focus();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
function scrollMenuIfItemNotInView(menuDivElement, direction) {
|
|
52
|
+
const itemDiv = menuDivElement.querySelector(`:nth-child(${highlightedIndex + 1})`);
|
|
53
|
+
if (!itemDiv)
|
|
54
|
+
return;
|
|
55
|
+
const menuTop = menuDivElement.getBoundingClientRect().top;
|
|
56
|
+
const { top: itemTop, height: itemHeight, bottom: itemBottom, } = itemDiv.getBoundingClientRect();
|
|
57
|
+
const itemTrueBottom = itemBottom + itemHeight;
|
|
58
|
+
const menuBottom = menuDivElement.getBoundingClientRect().bottom;
|
|
59
|
+
if (direction == "up" && itemTop - itemHeight < menuTop) {
|
|
60
|
+
menuDivElement.scrollTop -= itemHeight;
|
|
61
|
+
}
|
|
62
|
+
else if (direction == "down" && itemTrueBottom > menuBottom) {
|
|
63
|
+
menuDivElement.scrollTop += itemHeight;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
function handleKeyDown(event) {
|
|
67
|
+
const { key, metaKey, ctrlKey } = event;
|
|
68
|
+
if (metaKey || ctrlKey)
|
|
69
|
+
return;
|
|
70
|
+
switch (key) {
|
|
71
|
+
case "Enter": {
|
|
72
|
+
if (highlightedIndex >= 0) {
|
|
73
|
+
handleOptionClick(options[highlightedIndex]);
|
|
74
|
+
}
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
77
|
+
case "ArrowDown": {
|
|
78
|
+
handlePressDown(event);
|
|
79
|
+
break;
|
|
80
|
+
}
|
|
81
|
+
case "ArrowUp": {
|
|
82
|
+
handlePressUp(event);
|
|
83
|
+
break;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
React.useEffect(() => {
|
|
88
|
+
// focus first option
|
|
89
|
+
handleOptionFocus(0);
|
|
90
|
+
}, [menuDiv]);
|
|
91
|
+
return (React__default["default"].createElement("ul", { "data-testid": "dropdown-menu", className: styles.dropDownMenuContainer, ref: menuDiv, onKeyDown: handleKeyDown }, options.map((option, index) => {
|
|
92
|
+
const optionClass = classnames__default["default"](styles.option, {
|
|
93
|
+
[styles.active]: index === highlightedIndex,
|
|
94
|
+
});
|
|
95
|
+
return (React__default["default"].createElement("li", { key: `${index}-${option.label}`, className: optionClass, onClick: event => {
|
|
96
|
+
event.stopPropagation();
|
|
97
|
+
event.preventDefault();
|
|
98
|
+
handleOptionClick(option);
|
|
99
|
+
}, onMouseOver: e => handleOptionHover(e, index) },
|
|
100
|
+
React__default["default"].createElement(Checkbox.Checkbox, { label: option.label, checked: option.checked, onFocus: () => setHighlightedIndex(index) })));
|
|
101
|
+
})));
|
|
102
|
+
function handlePressUp(event) {
|
|
103
|
+
event.preventDefault();
|
|
104
|
+
const newIndex = Math.max(0, highlightedIndex - 1);
|
|
105
|
+
handleOptionFocus(newIndex);
|
|
106
|
+
scrollMenuIfItemNotInView(menuDiv.current, "up");
|
|
107
|
+
}
|
|
108
|
+
function handlePressDown(event) {
|
|
109
|
+
event.preventDefault();
|
|
110
|
+
const newIndex = Math.min(options.length - 1, highlightedIndex + 1);
|
|
111
|
+
handleOptionFocus(newIndex);
|
|
112
|
+
scrollMenuIfItemNotInView(menuDiv.current, "down");
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// eslint-disable-next-line max-statements
|
|
117
|
+
function MultiSelect({ defaultLabel, allSelectedLabel, options, onOptionsChange, size, }) {
|
|
118
|
+
const [label, setLabel] = React.useState(defaultLabel);
|
|
119
|
+
const [menuVisible, setMenuVisible] = React.useState(false);
|
|
120
|
+
const [focused, setFocused] = React.useState(false);
|
|
121
|
+
const multiSelectContainer = React.useRef();
|
|
122
|
+
const multiSelectRef = React.useRef();
|
|
123
|
+
const multiSelectClass = classnames__default["default"](styles$1.multiSelect, {
|
|
124
|
+
[styles$1.active]: menuVisible,
|
|
125
|
+
[styles$1.large]: size === "large",
|
|
126
|
+
[styles$1.small]: size === "small",
|
|
127
|
+
});
|
|
128
|
+
function handleMenuVisibility() {
|
|
129
|
+
multiSelectRef.current.focus();
|
|
130
|
+
setMenuVisible(!menuVisible);
|
|
131
|
+
}
|
|
132
|
+
const handleClickOutside = (e) => {
|
|
133
|
+
var _a;
|
|
134
|
+
if (!((_a = multiSelectContainer === null || multiSelectContainer === void 0 ? void 0 : multiSelectContainer.current) === null || _a === void 0 ? void 0 : _a.contains(e.target))) {
|
|
135
|
+
setMenuVisible(false);
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
function handleKeydown(event) {
|
|
139
|
+
const { key, metaKey, ctrlKey } = event;
|
|
140
|
+
if (metaKey || ctrlKey)
|
|
141
|
+
return;
|
|
142
|
+
switch (key) {
|
|
143
|
+
case "Enter":
|
|
144
|
+
case " ": {
|
|
145
|
+
if (focused) {
|
|
146
|
+
setMenuVisible(!menuVisible);
|
|
147
|
+
}
|
|
148
|
+
break;
|
|
149
|
+
}
|
|
150
|
+
case "Escape": {
|
|
151
|
+
multiSelectRef.current.focus();
|
|
152
|
+
setMenuVisible(false);
|
|
153
|
+
break;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
React.useEffect(() => {
|
|
158
|
+
document.addEventListener("mousedown", handleClickOutside);
|
|
159
|
+
return () => document.removeEventListener("mousedown", handleClickOutside);
|
|
160
|
+
});
|
|
161
|
+
React.useEffect(() => {
|
|
162
|
+
const selected = options.filter(option => option.checked);
|
|
163
|
+
if (selected.length === 0) {
|
|
164
|
+
setLabel(defaultLabel);
|
|
165
|
+
}
|
|
166
|
+
else if (selected.length == options.length) {
|
|
167
|
+
setLabel(allSelectedLabel);
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
const selectedLabels = [];
|
|
171
|
+
selected.forEach(option => selectedLabels.push(option.label));
|
|
172
|
+
setLabel(selectedLabels.join(", "));
|
|
173
|
+
}
|
|
174
|
+
}, [options]);
|
|
175
|
+
return (React__default["default"].createElement("div", { ref: multiSelectContainer, className: styles$1.multiSelectContainer, onKeyDown: handleKeydown },
|
|
176
|
+
React__default["default"].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 },
|
|
177
|
+
React__default["default"].createElement(Text.Text, null, label),
|
|
178
|
+
React__default["default"].createElement(Icon.Icon, { name: "arrowDown" })),
|
|
179
|
+
menuVisible && (React__default["default"].createElement(DropDownMenu, { options: options, setOptions: onOptionsChange }))));
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
exports.MultiSelect = MultiSelect;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var FormField = require('./FormField-f6fadff2.js');
|
|
5
|
+
|
|
6
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
7
|
+
|
|
8
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
9
|
+
|
|
10
|
+
function Select(props) {
|
|
11
|
+
return React__default["default"].createElement(FormField.FormField, Object.assign({ type: "select" }, props));
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
function SelectOption({ children, disabled, value }) {
|
|
15
|
+
return (React__default["default"].createElement("option", { disabled: disabled, value: value }, children));
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
exports.Select = Select;
|
|
19
|
+
exports.SelectOption = SelectOption;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var classnames = require('classnames');
|
|
7
|
+
var jobberHooks = require('@jobber/hooks/useResizeObserver');
|
|
8
|
+
var styleInject_es = require('../style-inject.es-9d2f5f4e.js');
|
|
9
|
+
var Heading = require('../Heading-23d382a1.js');
|
|
10
|
+
var Text = require('../Text-fbeaaca6.js');
|
|
11
|
+
var Content = require('../Content-e3f7b6fc.js');
|
|
12
|
+
var Markdown = require('../Markdown-0f24de70.js');
|
|
13
|
+
var Button = require('../Button-6b922fc1.js');
|
|
14
|
+
var Menu = require('../Menu-d6dd673e.js');
|
|
15
|
+
var Emphasis = require('../Emphasis-a77d8ee9.js');
|
|
16
|
+
require('../Typography-e2a23b7e.js');
|
|
17
|
+
require('../useAtlantisConfig-ed0bee66.js');
|
|
18
|
+
require('@jobber/hooks/useSafeLayoutEffect');
|
|
19
|
+
require('react-markdown');
|
|
20
|
+
require('react-router-dom');
|
|
21
|
+
require('../Icon-405a216c.js');
|
|
22
|
+
require('@jobber/design');
|
|
23
|
+
require('framer-motion');
|
|
24
|
+
require('@jobber/hooks/useOnKeyDown');
|
|
25
|
+
require('@jobber/hooks/useRefocusOnActivator');
|
|
26
|
+
|
|
27
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
28
|
+
|
|
29
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
30
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
31
|
+
|
|
32
|
+
var css_248z = ".pVEdXlwstrc- {\n width: 100%;\n box-sizing: border-box;\n padding: calc(16px * 1);\n padding: var(--space-base);\n}\n\n@media (min-width: 768px) {\n\n.pVEdXlwstrc- {\n padding: calc(16px * 1.5);\n padding: var(--space-large);\n}\n }\n\n@media (--medium-screens-and-up) {\n\n.pVEdXlwstrc- {\n padding: calc(16px * 1.5);\n padding: var(--space-large);\n}\n }\n\n._9r84iz--C5M- {\n max-width: none;\n}\n\n._0LO26JFXU9g- {\n max-width: calc(16px * 80);\n max-width: calc(var(--base-unit) * 80);\n}\n\n.KiMIF8eFbuE- {\n max-width: calc(16px * 64);\n max-width: calc(var(--base-unit) * 64);\n}\n\n.GCeQrLFyml4- h1 {\n -ms-flex: 0 1 auto;\n flex: 0 1 auto;\n margin-bottom: calc(16px * 1);\n margin-bottom: var(--space-base);\n}\n\n.GCeQrLFyml4- > .KP-BTjB82iQ- {\n -ms-flex: 1 0 auto;\n flex: 1 0 auto;\n}\n\n.GCeQrLFyml4-.GuFU-PgC1j4-,\n.GCeQrLFyml4-.qiwlkB5pxkA- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-wrap: wrap;\n flex-wrap: wrap;\n -ms-flex-pack: justify;\n justify-content: space-between;\n}\n\n.GCeQrLFyml4-.CbPnpIk7-EE- .KP-BTjB82iQ- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-wrap: wrap;\n flex-wrap: wrap;\n -ms-flex-pack: justify;\n justify-content: space-between;\n}\n\n.GCeQrLFyml4-.qiwlkB5pxkA- .KP-BTjB82iQ-,\n.GCeQrLFyml4-.GuFU-PgC1j4- .KP-BTjB82iQ- {\n -ms-flex-wrap: nowrap;\n flex-wrap: nowrap;\n}\n\n.GCeQrLFyml4-.qiwlkB5pxkA- .KP-BTjB82iQ- {\n -ms-flex-pack: end;\n justify-content: flex-end;\n}\n\n.E5FEsck9zwg- {\n -ms-flex: 0 0 100%;\n flex: 0 0 100%;\n margin-bottom: calc(16px / 2);\n margin-bottom: var(--space-small);\n}\n\n.Sn3-wJuNCqk- {\n margin-top: calc(16px / 2);\n margin-top: var(--space-small);\n -ms-flex: 1;\n flex: 1;\n}\n\n.Sn3-wJuNCqk- > div {\n width: 100%;\n}\n\n.GCeQrLFyml4-.CbPnpIk7-EE- .Sn3-wJuNCqk- {\n margin-top: 0;\n}\n\n.GCeQrLFyml4-.qiwlkB5pxkA- .E5FEsck9zwg-,\n.GCeQrLFyml4-.qiwlkB5pxkA- .Sn3-wJuNCqk- {\n margin: 0;\n -ms-flex: 0 auto;\n flex: 0 auto;\n}\n\n.GCeQrLFyml4-.qiwlkB5pxkA- .Sn3-wJuNCqk- {\n margin-left: calc(16px / 2);\n margin-left: var(--space-small);\n}\n\n.GCeQrLFyml4-.CbPnpIk7-EE- .Sn3-wJuNCqk- + .Sn3-wJuNCqk- {\n margin-left: calc(16px / 2);\n margin-left: var(--space-small);\n}\n\n.GCeQrLFyml4- ._9ZKFDK2jL80- {\n margin-bottom: calc(16px * 1);\n margin-bottom: var(--space-base);\n}\n";
|
|
33
|
+
var styles = {"page":"pVEdXlwstrc-","fill":"_9r84iz--C5M-","standard":"_0LO26JFXU9g-","narrow":"KiMIF8eFbuE-","titleBar":"GCeQrLFyml4-","actionGroup":"KP-BTjB82iQ-","large":"GuFU-PgC1j4-","medium":"qiwlkB5pxkA-","small":"CbPnpIk7-EE-","primaryAction":"E5FEsck9zwg-","actionButton":"Sn3-wJuNCqk-","subtitle":"_9ZKFDK2jL80-"};
|
|
34
|
+
styleInject_es.styleInject(css_248z);
|
|
35
|
+
|
|
36
|
+
// eslint-disable-next-line max-statements
|
|
37
|
+
function Page({ title, intro, externalIntroLinks, subtitle, children, width = "standard", primaryAction, secondaryAction, moreActionsMenu = [], }) {
|
|
38
|
+
const pageStyles = classnames__default["default"](styles.page, styles[width]);
|
|
39
|
+
const [titleBarRef, { width: titleBarWidth = jobberHooks.Breakpoints.large }] = jobberHooks.useResizeObserver();
|
|
40
|
+
const titleBarClasses = classnames__default["default"](styles.titleBar, {
|
|
41
|
+
[styles.small]: titleBarWidth > jobberHooks.Breakpoints.smaller,
|
|
42
|
+
[styles.medium]: titleBarWidth > jobberHooks.Breakpoints.small,
|
|
43
|
+
[styles.large]: titleBarWidth > jobberHooks.Breakpoints.base,
|
|
44
|
+
});
|
|
45
|
+
const showMenu = moreActionsMenu.length > 0;
|
|
46
|
+
const showActionGroup = showMenu || primaryAction;
|
|
47
|
+
if (primaryAction != undefined) {
|
|
48
|
+
primaryAction = Object.assign({ fullWidth: true }, primaryAction);
|
|
49
|
+
}
|
|
50
|
+
if (secondaryAction != undefined) {
|
|
51
|
+
secondaryAction = Object.assign({ type: "secondary", fullWidth: true }, secondaryAction);
|
|
52
|
+
}
|
|
53
|
+
if (secondaryAction != undefined) {
|
|
54
|
+
secondaryAction = Object.assign({ type: "secondary", fullWidth: true }, secondaryAction);
|
|
55
|
+
}
|
|
56
|
+
return (React__default["default"].createElement("div", { className: pageStyles },
|
|
57
|
+
React__default["default"].createElement(Content.Content, null,
|
|
58
|
+
React__default["default"].createElement(Content.Content, null,
|
|
59
|
+
React__default["default"].createElement("div", { className: titleBarClasses, ref: titleBarRef },
|
|
60
|
+
React__default["default"].createElement("div", null,
|
|
61
|
+
React__default["default"].createElement(Heading.Heading, { level: 1 }, title),
|
|
62
|
+
subtitle && (React__default["default"].createElement("div", { className: styles.subtitle },
|
|
63
|
+
React__default["default"].createElement(Text.Text, { size: "large", variation: "subdued" },
|
|
64
|
+
React__default["default"].createElement(Emphasis.Emphasis, { variation: "bold" },
|
|
65
|
+
React__default["default"].createElement(Markdown.Markdown, { content: subtitle, basicUsage: true })))))),
|
|
66
|
+
showActionGroup && (React__default["default"].createElement("div", { className: styles.actionGroup },
|
|
67
|
+
primaryAction && (React__default["default"].createElement("div", { className: styles.primaryAction },
|
|
68
|
+
React__default["default"].createElement(Button.Button, Object.assign({}, primaryAction)))),
|
|
69
|
+
secondaryAction && (React__default["default"].createElement("div", { className: styles.actionButton },
|
|
70
|
+
React__default["default"].createElement(Button.Button, Object.assign({}, secondaryAction)))),
|
|
71
|
+
showMenu && (React__default["default"].createElement("div", { className: styles.actionButton },
|
|
72
|
+
React__default["default"].createElement(Menu.Menu, { items: moreActionsMenu })))))),
|
|
73
|
+
intro && (React__default["default"].createElement(Text.Text, { size: "large" },
|
|
74
|
+
React__default["default"].createElement(Markdown.Markdown, { content: intro, basicUsage: true, externalLink: externalIntroLinks })))),
|
|
75
|
+
React__default["default"].createElement(Content.Content, null, children))));
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
exports.Page = Page;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var reactPopper = require('react-popper');
|
|
7
|
+
var useRefocusOnActivator = require('@jobber/hooks/useRefocusOnActivator');
|
|
8
|
+
var styleInject_es = require('../style-inject.es-9d2f5f4e.js');
|
|
9
|
+
var ButtonDismiss = require('../ButtonDismiss-a3ba1de2.js');
|
|
10
|
+
require('../Button-6b922fc1.js');
|
|
11
|
+
require('classnames');
|
|
12
|
+
require('react-router-dom');
|
|
13
|
+
require('../Icon-405a216c.js');
|
|
14
|
+
require('@jobber/design');
|
|
15
|
+
require('../Typography-e2a23b7e.js');
|
|
16
|
+
|
|
17
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
18
|
+
|
|
19
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
20
|
+
|
|
21
|
+
var css_248z = ":root {\n --card--base-padding: var(--space-base);\n --popover--padding: var(--space-base);\n --popover--width: calc(var(--base-unit) * 21.875);\n --dismiss--button-padding: calc(var(--base-unit) / 4);\n}\n\n.oSlK4rLUvzE- {\n display: -ms-flexbox;\n display: flex;\n position: \"relative\";\n padding: calc(16px * 1);\n padding: var(--popover--padding);\n -ms-flex-pack: justify;\n justify-content: space-between;\n -ms-flex-align: center;\n align-items: center;\n}\n\n.XVPpPb-7e30- {\n float: right;\n padding: calc(16px / 4);\n padding: var(--dismiss--button-padding);\n text-align: right;\n}\n\n.TDuYbqXaLW0- {\n z-index: 1002;\n z-index: var(--elevation-tooltip);\n width: -webkit-max-content;\n width: max-content;\n max-width: calc(16px * 21.875);\n max-width: var(--popover--width);\n box-shadow: 0px calc(16px / 16) calc(16px / 4) 0px\n rgba(0, 0, 0, 0.1),\n 0px calc(16px / 4) 12px 0px rgba(0, 0, 0, 0.05);\n box-shadow: var(--shadow-base);\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n font-size: calc((16px * 1) * 0.875);\n font-size: calc(calc(16px * 1) * 0.875);\n font-size: var(--typography--fontSize-base);\n line-height: normal;\n background: rgba(255, 255, 255, 1);\n background: var(--color-surface);\n}\n\n.TDuYbqXaLW0- > * {\n --public-content--padding: var(--card--base-padding);\n}\n\n.LJCpn0zf1e8- {\n visibility: hidden;\n}\n\n.LJCpn0zf1e8-,\n.LJCpn0zf1e8-::before {\n position: absolute;\n width: 16px;\n width: var(--base-unit);\n height: 16px;\n height: var(--base-unit);\n background: inherit;\n}\n\n.LJCpn0zf1e8-::before {\n content: \"\";\n visibility: visible;\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n -webkit-transform: rotate(45deg);\n transform: rotate(45deg);\n -webkit-transform-origin: center;\n transform-origin: center;\n -webkit-clip-path: polygon(-4px -4px, 15.3px 0, 0 15.3px);\n clip-path: polygon(-4px -4px, 15.3px 0, 0 15.3px);\n}\n\n.TDuYbqXaLW0-[data-popper-placement^=\"top\"] > .LJCpn0zf1e8- {\n bottom: -5px;\n}\n\n.TDuYbqXaLW0-[data-popper-placement^=\"top\"] > .LJCpn0zf1e8-::before {\n -webkit-transform: rotate(-135deg);\n transform: rotate(-135deg);\n}\n\n.TDuYbqXaLW0-[data-popper-placement^=\"bottom\"] > .LJCpn0zf1e8- {\n top: -7px;\n}\n\n.TDuYbqXaLW0-[data-popper-placement^=\"left\"] > .LJCpn0zf1e8- {\n right: -5px;\n}\n\n.TDuYbqXaLW0-[data-popper-placement^=\"left\"] > .LJCpn0zf1e8-::before {\n -webkit-transform: rotate(135deg);\n transform: rotate(135deg);\n}\n\n.TDuYbqXaLW0-[data-popper-placement^=\"right\"] > .LJCpn0zf1e8- {\n left: -7px;\n}\n\n.TDuYbqXaLW0-[data-popper-placement^=\"right\"] > .LJCpn0zf1e8-::before {\n -webkit-transform: rotate(-45deg);\n transform: rotate(-45deg);\n}\n";
|
|
22
|
+
var classes = {"header":"oSlK4rLUvzE-","dismissButton":"XVPpPb-7e30-","popover":"TDuYbqXaLW0-","arrow":"LJCpn0zf1e8-"};
|
|
23
|
+
styleInject_es.styleInject(css_248z);
|
|
24
|
+
|
|
25
|
+
function Popover({ onRequestClose, children, attachTo, open, preferredPlacement = "auto", }) {
|
|
26
|
+
const [popperElement, setPopperElement] = React.useState();
|
|
27
|
+
const [arrowElement, setArrowElement] = React.useState();
|
|
28
|
+
const { styles: popperStyles, attributes } = reactPopper.usePopper(isHTMLElement(attachTo) ? attachTo : attachTo.current, popperElement, {
|
|
29
|
+
modifiers: buildModifiers(arrowElement),
|
|
30
|
+
placement: preferredPlacement,
|
|
31
|
+
});
|
|
32
|
+
useRefocusOnActivator.useRefocusOnActivator(open);
|
|
33
|
+
return (React__default["default"].createElement(React__default["default"].Fragment, null, open && (React__default["default"].createElement("div", Object.assign({ role: "dialog", ref: setPopperElement, style: popperStyles.popper, className: classes.popover }, attributes.popper),
|
|
34
|
+
React__default["default"].createElement("div", { className: classes.dismissButton },
|
|
35
|
+
React__default["default"].createElement(ButtonDismiss.ButtonDismiss, { onClick: onRequestClose, ariaLabel: "Close dialog" })),
|
|
36
|
+
children,
|
|
37
|
+
React__default["default"].createElement("div", { ref: setArrowElement, className: classes.arrow, style: popperStyles.arrow })))));
|
|
38
|
+
}
|
|
39
|
+
function buildModifiers(arrowElement) {
|
|
40
|
+
const modifiers = [
|
|
41
|
+
{
|
|
42
|
+
name: "arrow",
|
|
43
|
+
options: { element: arrowElement, padding: 10 },
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
name: "offset",
|
|
47
|
+
options: {
|
|
48
|
+
offset: [0, 10],
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
name: "flip",
|
|
53
|
+
options: {
|
|
54
|
+
fallbackPlacements: ["auto"],
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
];
|
|
58
|
+
return modifiers;
|
|
59
|
+
}
|
|
60
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
61
|
+
function isHTMLElement(el) {
|
|
62
|
+
return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) && el instanceof Element;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
exports.Popover = Popover;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var ProgressBar = require('../ProgressBar-b68edc8f.js');
|
|
6
|
+
require('react');
|
|
7
|
+
require('classnames');
|
|
8
|
+
require('../style-inject.es-9d2f5f4e.js');
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
exports.ProgressBar = ProgressBar.ProgressBar;
|