@jobber/components 4.90.5 → 4.91.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/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-b7da32ac.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-b771c7fd.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-4ce1ec79.js +74 -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,481 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var classnames = require('classnames');
|
|
5
|
+
var ReactDOM = require('react-dom');
|
|
6
|
+
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
7
|
+
var Icon = require('./Icon-405a216c.js');
|
|
8
|
+
var Text = require('./Text-fbeaaca6.js');
|
|
9
|
+
var Glimmer = require('./Glimmer-84dee1ed.js');
|
|
10
|
+
var Spinner = require('./Spinner-9d8fc7ff.js');
|
|
11
|
+
var AnimatedPresence = require('./AnimatedPresence-20a02aaa.js');
|
|
12
|
+
var Flex = require('./Flex-d490c4db.js');
|
|
13
|
+
var tslib_es6 = require('./tslib.es6-754e2961.js');
|
|
14
|
+
var useInView = require('@jobber/hooks/useInView');
|
|
15
|
+
var Typography = require('./Typography-e2a23b7e.js');
|
|
16
|
+
var Button = require('./Button-6b922fc1.js');
|
|
17
|
+
var useRefocusOnActivator = require('@jobber/hooks/useRefocusOnActivator');
|
|
18
|
+
var useFocusTrap = require('@jobber/hooks/useFocusTrap');
|
|
19
|
+
var reactPopper = require('react-popper');
|
|
20
|
+
var useOnKeyDown = require('@jobber/hooks/useOnKeyDown');
|
|
21
|
+
var Chip = require('./Chip-76f18555.js');
|
|
22
|
+
var debounce = require('lodash/debounce');
|
|
23
|
+
var noop = require('lodash/noop');
|
|
24
|
+
require('@jobber/design');
|
|
25
|
+
var useAssert = require('@jobber/hooks/useAssert');
|
|
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
|
+
var ReactDOM__default = /*#__PURE__*/_interopDefaultLegacy(ReactDOM);
|
|
32
|
+
var debounce__default = /*#__PURE__*/_interopDefaultLegacy(debounce);
|
|
33
|
+
var noop__default = /*#__PURE__*/_interopDefaultLegacy(noop);
|
|
34
|
+
|
|
35
|
+
var css_248z$7 = ".m1w5vdUZ6rQ- {\n z-index: 1002;\n z-index: var(--elevation-tooltip);\n width: calc((16px * 4) * 3.75);\n width: calc(calc(16px * 4) * 3.75);\n width: calc(var(--space-extravagant) * 3.75);\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-top: calc(16px / 2);\n margin-top: var(--space-small);\n border: calc(16px / 16) solid rgb(217, 223, 225);\n border: var(--border-base) solid var(--color-border);\n border-radius: calc(16px / 2);\n border-radius: var(--radius-larger);\n overflow: auto;\n background: rgba(255, 255, 255, 1);\n background: var(--color-surface);\n}\n\n.jobber-retheme .m1w5vdUZ6rQ- {\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n}\n\n/* CAUTION: Tests for content visibility assume this class' presence hides the content\n* so please be careful if you change this class name, or the css rules within.\n*/\n\n.m1w5vdUZ6rQ-.Zlkv2HA096A- {\n display: none;\n visibility: hidden;\n}\n\n.m1w5vdUZ6rQ-:focus,\n.m1w5vdUZ6rQ-:focus-visible {\n outline: none;\n}\n\n.m1w5vdUZ6rQ-:focus-visible {\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}\n\n.YQry-Rd6zfQ- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-direction: column;\n flex-direction: column;\n position: sticky;\n gap: calc(16px / 4);\n gap: var(--space-smaller);\n bottom: 0;\n width: 100%;\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n}\n\n.TcpqL34s4lI- {\n padding-bottom: calc(16px / 2);\n padding-bottom: var(--space-small);\n}\n";
|
|
36
|
+
var styles$7 = {"content":"m1w5vdUZ6rQ-","hidden":"Zlkv2HA096A-","actions":"YQry-Rd6zfQ-","actionPadding":"TcpqL34s4lI-"};
|
|
37
|
+
styleInject_es.styleInject(css_248z$7);
|
|
38
|
+
|
|
39
|
+
var css_248z$6 = ".MIyb-oFZg9w- {\n position: relative;\n}\n\n.WZPK91I4aJs- {\n width: 100%;\n padding: calc(16px * 1);\n padding: var(--space-base);\n padding-right: calc((16px * 1.5) * 2.25);\n padding-right: calc(calc(16px * 1.5) * 2.25);\n padding-right: calc(var(--space-large) * 2.25);\n border: none;\n border-bottom: calc(16px / 16) solid rgb(217, 223, 225);\n border-bottom: var(--border-base) solid var(--color-border);\n font-family: \"Inter\", Helvetica, Arial, sans-serif;\n font-family: var(--typography--fontFamily-normal);\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}\n\n.WZPK91I4aJs-::-webkit-search-decoration,\n.WZPK91I4aJs-::-webkit-search-cancel-button,\n.WZPK91I4aJs-::-webkit-search-results-button,\n.WZPK91I4aJs-::-webkit-search-results-decoration {\n -webkit-appearance: none;\n}\n\n.WZPK91I4aJs-:focus {\n outline: none;\n}\n\n._7loHrVUe-Rk- {\n display: -ms-flexbox;\n display: flex;\n position: absolute;\n top: 50%;\n right: calc(16px * 1);\n right: var(--space-base);\n z-index: 1002;\n z-index: var(--elevation-tooltip);\n width: calc(16px * 1.5);\n width: var(--space-large);\n height: calc(16px * 1.5);\n height: var(--space-large);\n padding: 0;\n border: none;\n border-radius: 100%;\n border-radius: var(--radius-circle);\n background-color: rgb(238, 240, 242);\n background-color: var(--color-surface--background);\n cursor: pointer;\n -webkit-transform: translateY(-50%);\n transform: translateY(-50%);\n -ms-flex-pack: center;\n justify-content: center;\n -ms-flex-align: center;\n align-items: center;\n}\n\n._7loHrVUe-Rk-:focus {\n outline: transparent;\n}\n\n._7loHrVUe-Rk-:focus-visible {\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}\n";
|
|
40
|
+
var styles$6 = {"search":"MIyb-oFZg9w-","searchInput":"WZPK91I4aJs-","clearSearch":"_7loHrVUe-Rk-"};
|
|
41
|
+
styleInject_es.styleInject(css_248z$6);
|
|
42
|
+
|
|
43
|
+
function ComboboxContentSearch(props) {
|
|
44
|
+
const searchRef = React.useRef(null);
|
|
45
|
+
React.useEffect(() => {
|
|
46
|
+
if (props.open) {
|
|
47
|
+
setTimeout(() => {
|
|
48
|
+
var _a;
|
|
49
|
+
(_a = searchRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
|
50
|
+
}, 0);
|
|
51
|
+
}
|
|
52
|
+
}, [props.open]);
|
|
53
|
+
return (React__default["default"].createElement("div", { className: styles$6.search },
|
|
54
|
+
React__default["default"].createElement("input", { type: "search", ref: searchRef, className: styles$6.searchInput, placeholder: props.placeholder ? `Search ${props.placeholder}` : "Search", onChange: (event) => handleSearch(event), value: props.searchValue }),
|
|
55
|
+
props.searchValue && (React__default["default"].createElement("button", { className: styles$6.clearSearch, onClick: clearSearch, type: "button", "data-testid": "ATL-Combobox-Content-Search-Clear", "aria-label": "Clear search" },
|
|
56
|
+
React__default["default"].createElement(Icon.Icon, { name: "remove", size: "small" })))));
|
|
57
|
+
function clearSearch() {
|
|
58
|
+
var _a;
|
|
59
|
+
props.setSearchValue("");
|
|
60
|
+
props.handleSearchChange("");
|
|
61
|
+
(_a = searchRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
|
62
|
+
}
|
|
63
|
+
function handleSearch(event) {
|
|
64
|
+
props.setSearchValue(event.currentTarget.value);
|
|
65
|
+
props.handleSearchChange(event.currentTarget.value);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
var css_248z$5 = ".SgMzjOcdE-E- {\n position: relative;\n padding: calc(16px / 2) 0;\n padding: var(--space-small) 0;\n}\n\n.TwoTCjgcssc- {\n display: -ms-flexbox;\n display: flex;\n\n max-height: calc((16px / 2) * 33.33);\n\n max-height: calc(calc(16px / 2) * 33.33);\n\n max-height: calc(var(--space-small) * 33.33);\n margin: 0;\n padding: 0;\n overflow: auto;\n list-style: none;\n -ms-flex-direction: column;\n flex-direction: column;\n gap: calc(16px / 4);\n gap: var(--space-smaller);\n}\n\n._8T5M7MGwCRE-,\n._4y5NXkNeIQM- {\n padding: calc(16px / 2) calc(16px * 1);\n padding: var(--space-small) var(--space-base);\n}\n\n.SgMzjOcdE-E-::before,\n.SgMzjOcdE-E-::after {\n content: \"\";\n display: block;\n position: absolute;\n right: 0;\n left: 0;\n height: calc(16px * 1);\n height: var(--space-base);\n pointer-events: none;\n transition: opacity 0.3s ease-in-out;\n}\n\n.SgMzjOcdE-E-::after {\n bottom: calc(16px / 2);\n bottom: var(--space-small);\n background: linear-gradient(\n 180deg,\n rgba(255, 255, 255, 0) 0%,\n rgb(255, 255, 255) 100%\n );\n}\n\n.SgMzjOcdE-E-::before {\n top: calc(16px / 2);\n top: var(--space-small);\n background: linear-gradient(\n to bottom,\n rgba(255, 255, 255, 1),\n rgba(255, 255, 255, 0)\n );\n}\n\n.T6E3VwBGoQM-::before,\n._6HQzxMQkXnE-::before {\n opacity: 0;\n}\n\n._5YsJZyMDkbA-::after,\n._6HQzxMQkXnE-::after {\n opacity: 0;\n}\n\n.A6z4OI58xoE- {\n padding: calc(16px * 1) calc(16px * 1);\n padding: var(--space-base) var(--space-base);\n}\n\n.A6z4OI58xoE-.QqHBSf52fPk- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-pack: center;\n justify-content: center;\n position: sticky;\n bottom: 0;\n padding: calc(16px * 1) 0;\n padding: var(--space-base) 0;\n}\n\n.A6z4OI58xoE-.QqHBSf52fPk-:empty {\n display: none;\n}\n";
|
|
70
|
+
var styles$5 = {"container":"SgMzjOcdE-E-","optionsList":"TwoTCjgcssc-","filterMessage":"_8T5M7MGwCRE-","emptyStateMessage":"_4y5NXkNeIQM-","scrollTop":"T6E3VwBGoQM-","scrollNone":"_6HQzxMQkXnE-","scrollBottom":"_5YsJZyMDkbA-","loadingContainer":"A6z4OI58xoE-","hasOptions":"QqHBSf52fPk-"};
|
|
71
|
+
styleInject_es.styleInject(css_248z$5);
|
|
72
|
+
|
|
73
|
+
var css_248z$4 = "._5QdRGmaNHvc- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-negative: 0;\n flex-shrink: 0;\n min-height: calc((calc(16px * 3) - calc(16px / 4)));\n min-height: calc((var(--space-largest) - var(--space-smaller)));\n box-sizing: border-box;\n margin: 0 calc(16px / 2);\n margin: 0 var(--space-small);\n padding: calc(16px / 2);\n padding: var(--space-small);\n border-radius: calc(16px / 4);\n border-radius: var(--radius-large);\n color: rgb(1, 41, 57);\n color: var(--color-heading);\n font-weight: 500;\n cursor: pointer;\n transition: all 200ms;\n transition: all var(--timing-base);\n -ms-flex-pack: justify;\n justify-content: space-between;\n -ms-flex-align: center;\n align-items: center;\n}\n\n.jobber-retheme ._5QdRGmaNHvc- {\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n}\n\n._5QdRGmaNHvc-:hover,\n._5QdRGmaNHvc-:focus-visible {\n background-color: rgb(244, 246, 250);\n background-color: var(--color-surface--hover);\n}\n\n._5QdRGmaNHvc-:focus,\n._5QdRGmaNHvc-:focus-visible {\n outline: none;\n}\n\n._5QdRGmaNHvc-:focus-visible {\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}\n";
|
|
74
|
+
var styles$4 = {"option":"_5QdRGmaNHvc-"};
|
|
75
|
+
styleInject_es.styleInject(css_248z$4);
|
|
76
|
+
|
|
77
|
+
const ComboboxContext = React__default["default"].createContext({});
|
|
78
|
+
function ComboboxContextProvider(_a) {
|
|
79
|
+
var { children } = _a, props = tslib_es6.__rest(_a, ["children"]);
|
|
80
|
+
return (React__default["default"].createElement(ComboboxContext.Provider, { value: props }, children));
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
function ComboboxOption(props) {
|
|
84
|
+
const { selected, selectionHandler } = React.useContext(ComboboxContext);
|
|
85
|
+
const isSelected = selected.some(selection => selection.id.toString() === props.id.toString());
|
|
86
|
+
return (React__default["default"].createElement("li", { key: props.id, tabIndex: -1, "data-selected": isSelected, role: "option", "aria-selected": isSelected, onClick: () => selectionHandler &&
|
|
87
|
+
selectionHandler({ id: props.id, label: props.label }), className: classnames__default["default"](styles$4.option) },
|
|
88
|
+
React__default["default"].createElement(Flex.Flex, { template: props.prefix ? ["shrink", "grow"] : ["grow"] },
|
|
89
|
+
props.prefix,
|
|
90
|
+
props.label),
|
|
91
|
+
React__default["default"].createElement("div", null, isSelected && React__default["default"].createElement(Icon.Icon, { name: "checkmark", color: "blue" }))));
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
var css_248z$3 = "._3s8-RC5Ky3s- {\n -webkit-transform: translateY(calc((16px * 3) * -1));\n -webkit-transform: translateY(calc(calc(16px * 3) * -1));\n -webkit-transform: translateY(calc(var(--space-largest) * -1));\n transform: translateY(calc((16px * 3) * -1));\n transform: translateY(calc(calc(16px * 3) * -1));\n transform: translateY(calc(var(--space-largest) * -1));\n}\n";
|
|
95
|
+
var styles$3 = {"trigger":"_3s8-RC5Ky3s-"};
|
|
96
|
+
styleInject_es.styleInject(css_248z$3);
|
|
97
|
+
|
|
98
|
+
function ComboboxLoadMore({ onLoadMore }) {
|
|
99
|
+
const [inViewRef, isInView] = useInView.useInView();
|
|
100
|
+
React.useEffect(() => {
|
|
101
|
+
isInView && onLoadMore();
|
|
102
|
+
}, [isInView]);
|
|
103
|
+
return (React__default["default"].createElement("div", { "data-testid": "ATL-Combobox-Loadmore-Trigger", ref: inViewRef, className: styles$3.trigger }));
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
function ComboboxContentList(props) {
|
|
107
|
+
const optionsExist = props.options.length > 0;
|
|
108
|
+
const hasSearchTerm = props.searchValue.length > 0;
|
|
109
|
+
const { listScrollState } = useScrollState(props.optionsListRef, props.options);
|
|
110
|
+
return (React__default["default"].createElement("div", { className: classnames__default["default"](styles$5.container, styles$5[listScrollState]) },
|
|
111
|
+
optionsExist && (React__default["default"].createElement("ul", { className: styles$5.optionsList, role: "listbox", "aria-multiselectable": props.multiselect, ref: props.optionsListRef },
|
|
112
|
+
props.options.map(option => {
|
|
113
|
+
return (React__default["default"].createElement(ComboboxOption, { key: option.id, id: option.id, label: option.label, prefix: option.prefix }));
|
|
114
|
+
}),
|
|
115
|
+
React__default["default"].createElement("div", { className: classnames__default["default"]([styles$5.loadingContainer, styles$5.hasOptions]) },
|
|
116
|
+
React__default["default"].createElement(AnimatedPresence.AnimatedPresence, { transition: "fromBottom" }, Boolean(props.loading && optionsExist) && (React__default["default"].createElement(Spinner.Spinner, { size: "small" })))),
|
|
117
|
+
props.onLoadMore && (React__default["default"].createElement(ComboboxLoadMore, { onLoadMore: props.onLoadMore })))),
|
|
118
|
+
props.loading && !optionsExist && (React__default["default"].createElement(React__default["default"].Fragment, null, Array.from({ length: 5 }).map((_, index) => (React__default["default"].createElement("div", { className: styles$5.loadingContainer, key: index },
|
|
119
|
+
React__default["default"].createElement(Glimmer.Glimmer, { shape: "rectangle", size: "small" })))))),
|
|
120
|
+
hasSearchTerm && !props.loading && !optionsExist && (React__default["default"].createElement("div", { className: styles$5.filterMessage },
|
|
121
|
+
React__default["default"].createElement(Text.Text, { variation: "subdued" },
|
|
122
|
+
"No results for ",
|
|
123
|
+
`“${props.searchValue}”`))),
|
|
124
|
+
!hasSearchTerm && !props.loading && !optionsExist && (React__default["default"].createElement("div", { className: styles$5.emptyStateMessage },
|
|
125
|
+
React__default["default"].createElement(Text.Text, { variation: "subdued" }, getZeroIndexStateText(props.subjectNoun))))));
|
|
126
|
+
}
|
|
127
|
+
function getZeroIndexStateText(subjectNoun) {
|
|
128
|
+
if (subjectNoun) {
|
|
129
|
+
return `You don't have any ${subjectNoun} yet`;
|
|
130
|
+
}
|
|
131
|
+
return "No options yet";
|
|
132
|
+
}
|
|
133
|
+
function useScrollState(optionsListRef, options) {
|
|
134
|
+
const [listScrollState, setlistScrollState] = React.useState("");
|
|
135
|
+
React.useEffect(() => {
|
|
136
|
+
const handleScroll = () => {
|
|
137
|
+
if (optionsListRef.current) {
|
|
138
|
+
const { scrollTop, clientHeight, scrollHeight } = optionsListRef.current;
|
|
139
|
+
if (scrollHeight === clientHeight) {
|
|
140
|
+
setlistScrollState("scrollNone");
|
|
141
|
+
}
|
|
142
|
+
else if (scrollTop === 0) {
|
|
143
|
+
setlistScrollState("scrollTop");
|
|
144
|
+
}
|
|
145
|
+
else if (scrollTop + clientHeight >= scrollHeight) {
|
|
146
|
+
setlistScrollState("scrollBottom");
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
setlistScrollState("");
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
};
|
|
153
|
+
if (options.length === 0) {
|
|
154
|
+
handleScroll();
|
|
155
|
+
}
|
|
156
|
+
if (optionsListRef.current) {
|
|
157
|
+
optionsListRef.current.addEventListener("scroll", handleScroll);
|
|
158
|
+
handleScroll();
|
|
159
|
+
}
|
|
160
|
+
return () => {
|
|
161
|
+
if (optionsListRef.current) {
|
|
162
|
+
optionsListRef.current.removeEventListener("scroll", handleScroll);
|
|
163
|
+
}
|
|
164
|
+
};
|
|
165
|
+
}, [options]);
|
|
166
|
+
return { listScrollState };
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
var css_248z$2 = ".Q-mwo-g5Fi8- {\n display: -ms-flexbox;\n display: flex;\n padding: calc(16px * 1) calc(16px / 2) 0 calc(16px * 1);\n padding: var(--space-base) var(--space-small) 0 var(--space-base);\n -ms-flex-pack: justify;\n justify-content: space-between;\n -ms-flex-align: baseline;\n align-items: baseline;\n gap: calc(16px / 4);\n gap: var(--space-smaller);\n}\n";
|
|
170
|
+
var styles$2 = {"header":"Q-mwo-g5Fi8-"};
|
|
171
|
+
styleInject_es.styleInject(css_248z$2);
|
|
172
|
+
|
|
173
|
+
function ComboboxContentHeader(props) {
|
|
174
|
+
const hasSelected = props.selectedCount > 0;
|
|
175
|
+
const actionLabel = hasSelected ? "Clear" : "Select all";
|
|
176
|
+
const label = getLabel(hasSelected, props.selectedCount, props.subjectNoun);
|
|
177
|
+
const handleSelectAll = hasSelected ? props.onClearAll : props.onSelectAll;
|
|
178
|
+
const showAction = hasSelected || props.hasOptionsVisible;
|
|
179
|
+
return (React__default["default"].createElement("div", { className: styles$2.header, "data-testid": "ATL-Combobox-Header" },
|
|
180
|
+
React__default["default"].createElement(Typography.Typography, { textColor: "heading", fontWeight: "semiBold" }, label),
|
|
181
|
+
showAction && (React__default["default"].createElement(Button.Button, { size: "small", label: actionLabel, type: "tertiary", onClick: handleSelectAll }))));
|
|
182
|
+
}
|
|
183
|
+
function getLabel(hasSelected, count, subjectNoun) {
|
|
184
|
+
if (hasSelected) {
|
|
185
|
+
return `${count} selected`;
|
|
186
|
+
}
|
|
187
|
+
if (subjectNoun) {
|
|
188
|
+
return `Select ${subjectNoun}`;
|
|
189
|
+
}
|
|
190
|
+
return "Select";
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
function useComboboxContent(open, selected) {
|
|
194
|
+
const { shouldScroll } = React.useContext(ComboboxContext);
|
|
195
|
+
const optionsListRef = React.useRef(null);
|
|
196
|
+
React.useEffect(() => {
|
|
197
|
+
var _a;
|
|
198
|
+
if (open && shouldScroll.current && optionsListRef.current) {
|
|
199
|
+
const firstSelected = Array.from((_a = optionsListRef === null || optionsListRef === void 0 ? void 0 : optionsListRef.current) === null || _a === void 0 ? void 0 : _a.children).find(child => {
|
|
200
|
+
if (child instanceof HTMLElement) {
|
|
201
|
+
return child.dataset.selected === "true";
|
|
202
|
+
}
|
|
203
|
+
});
|
|
204
|
+
scrollToFirstSelected(firstSelected, shouldScroll);
|
|
205
|
+
}
|
|
206
|
+
}, [open, selected]);
|
|
207
|
+
return {
|
|
208
|
+
optionsListRef,
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
function scrollToFirstSelected(firstSelected, shouldScroll) {
|
|
212
|
+
if (firstSelected) {
|
|
213
|
+
firstSelected.scrollIntoView({
|
|
214
|
+
block: "nearest",
|
|
215
|
+
});
|
|
216
|
+
shouldScroll.current = false;
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
// eslint-disable-next-line max-statements
|
|
221
|
+
function useComboboxAccessibility(selectionCallback, filteredOptions, optionsListRef, open, wrapperRef) {
|
|
222
|
+
const { handleClose } = React.useContext(ComboboxContext);
|
|
223
|
+
const hasOptionsVisible = open && filteredOptions.length > 0;
|
|
224
|
+
const focusedIndex = React.useRef(null);
|
|
225
|
+
useRefocusOnActivator.useRefocusOnActivator(open);
|
|
226
|
+
const popperRef = useFocusTrap.useFocusTrap(open);
|
|
227
|
+
const { styles: popperStyles, attributes, update, } = reactPopper.usePopper(wrapperRef.current, popperRef.current, {
|
|
228
|
+
modifiers: [
|
|
229
|
+
{
|
|
230
|
+
name: "flip",
|
|
231
|
+
options: {
|
|
232
|
+
fallbackPlacements: ["top-start"],
|
|
233
|
+
},
|
|
234
|
+
},
|
|
235
|
+
],
|
|
236
|
+
placement: "bottom-start",
|
|
237
|
+
});
|
|
238
|
+
React.useEffect(() => {
|
|
239
|
+
focusedIndex.current = null;
|
|
240
|
+
if (open) {
|
|
241
|
+
update === null || update === void 0 ? void 0 : update();
|
|
242
|
+
}
|
|
243
|
+
}, [open, filteredOptions.length]);
|
|
244
|
+
React.useEffect(() => {
|
|
245
|
+
var _a;
|
|
246
|
+
if (open) {
|
|
247
|
+
(_a = popperRef.current) === null || _a === void 0 ? void 0 : _a.addEventListener("keydown", handleContentKeydown);
|
|
248
|
+
}
|
|
249
|
+
return () => {
|
|
250
|
+
var _a;
|
|
251
|
+
(_a = popperRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener("keydown", handleContentKeydown);
|
|
252
|
+
};
|
|
253
|
+
}, [open, optionsListRef, filteredOptions]);
|
|
254
|
+
useOnKeyDown.useOnKeyDown(() => {
|
|
255
|
+
if (open) {
|
|
256
|
+
handleClose();
|
|
257
|
+
}
|
|
258
|
+
}, "Escape");
|
|
259
|
+
function handleContentKeydown(event) {
|
|
260
|
+
var _a;
|
|
261
|
+
if (!hasOptionsVisible)
|
|
262
|
+
return;
|
|
263
|
+
if (event.key === "Enter" || event.key === " ") {
|
|
264
|
+
const activeElementInList = (_a = optionsListRef.current) === null || _a === void 0 ? void 0 : _a.contains(document.activeElement);
|
|
265
|
+
if (!activeElementInList)
|
|
266
|
+
return;
|
|
267
|
+
handleKeyboardSelection(event);
|
|
268
|
+
}
|
|
269
|
+
if (event.key === "ArrowDown") {
|
|
270
|
+
handleKeyboardNavigation(event, 1);
|
|
271
|
+
}
|
|
272
|
+
if (event.key === "ArrowUp") {
|
|
273
|
+
handleKeyboardNavigation(event, -1);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
function handleKeyboardNavigation(event, indexChange) {
|
|
277
|
+
var _a;
|
|
278
|
+
const newIndex = focusedIndex.current === null ? 0 : focusedIndex.current + indexChange;
|
|
279
|
+
if (newIndex < 0 || newIndex >= filteredOptions.length)
|
|
280
|
+
return;
|
|
281
|
+
const optionElement = (_a = optionsListRef.current) === null || _a === void 0 ? void 0 : _a.children[newIndex];
|
|
282
|
+
optionElement === null || optionElement === void 0 ? void 0 : optionElement.focus();
|
|
283
|
+
focusedIndex.current = newIndex;
|
|
284
|
+
event.preventDefault();
|
|
285
|
+
event.stopPropagation();
|
|
286
|
+
}
|
|
287
|
+
function handleKeyboardSelection(event) {
|
|
288
|
+
event.preventDefault();
|
|
289
|
+
event.stopPropagation();
|
|
290
|
+
if (focusedIndex.current !== null) {
|
|
291
|
+
selectionCallback(filteredOptions[focusedIndex.current]);
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
return {
|
|
295
|
+
popperRef,
|
|
296
|
+
popperStyles,
|
|
297
|
+
attributes,
|
|
298
|
+
};
|
|
299
|
+
}
|
|
300
|
+
|
|
301
|
+
function ComboboxContent(props) {
|
|
302
|
+
const optionsExist = props.options.length > 0;
|
|
303
|
+
const { optionsListRef } = useComboboxContent(props.open, props.selected);
|
|
304
|
+
const { popperRef, popperStyles, attributes } = useComboboxAccessibility(props.handleSelection, props.options, optionsListRef, props.open, props.wrapperRef);
|
|
305
|
+
const template = (React__default["default"].createElement("div", Object.assign({ ref: popperRef, id: "ATL-Combobox-Content", "data-testid": "ATL-Combobox-Content", tabIndex: 0, className: classnames__default["default"](styles$7.content, { [styles$7.hidden]: !props.open }), style: popperStyles.popper }, attributes.popper),
|
|
306
|
+
React__default["default"].createElement(ComboboxContentSearch, { open: props.open, placeholder: props.subjectNoun, searchValue: props.searchValue, setSearchValue: props.setSearchValue, handleSearchChange: props.handleSearchChange }),
|
|
307
|
+
props.multiselect && (optionsExist || props.selected.length > 0) && (React__default["default"].createElement(ComboboxContentHeader, { hasOptionsVisible: optionsExist, subjectNoun: props.subjectNoun, selectedCount: props.selected.length, onClearAll: () => {
|
|
308
|
+
props.selectedStateSetter([]);
|
|
309
|
+
}, onSelectAll: () => {
|
|
310
|
+
props.selectedStateSetter(props.options);
|
|
311
|
+
} })),
|
|
312
|
+
React__default["default"].createElement(ComboboxContentList, { multiselect: props.multiselect, options: props.options, selected: props.selected, optionsListRef: optionsListRef, searchValue: props.searchValue, subjectNoun: props.subjectNoun, loading: props.loading, onLoadMore: props.onLoadMore }),
|
|
313
|
+
props.actionElements && (React__default["default"].createElement("div", { className: styles$7.actions, role: "group" }, props.actionElements.map((child, index, childrenArray) => (React__default["default"].createElement("div", { key: index, className: classnames__default["default"]({
|
|
314
|
+
[styles$7.actionPadding]: index === childrenArray.length - 1,
|
|
315
|
+
}) }, child)))))));
|
|
316
|
+
return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
|
|
317
|
+
? ReactDOM__default["default"].createPortal(template, document.body)
|
|
318
|
+
: template;
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
var css_248z$1 = ".Ow9wSNnGP-g- {\n width: 100%;\n box-sizing: border-box;\n padding: 0 calc(16px / 2);\n padding: 0 var(--space-small);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n}\n\n.ncp0nKHQ7d8- {\n position: relative;\n width: 100%;\n min-height: calc((calc(16px * 3) - calc(16px / 2)));\n min-height: calc((var(--space-largest) - var(--space-small)));\n padding: calc(16px / 2) 0;\n padding: var(--space-small) 0;\n border: none;\n border-radius: calc(16px / 4);\n border-radius: var(--radius-large);\n text-align: left;\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n cursor: pointer;\n transition: all 200ms;\n transition: all var(--timing-base);\n}\n\n.jobber-retheme .ncp0nKHQ7d8- {\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n}\n\n.ncp0nKHQ7d8-:focus {\n outline: none;\n}\n\n.ncp0nKHQ7d8-:hover,\n.ncp0nKHQ7d8-:focus-visible {\n outline: none;\n background-color: rgb(244, 246, 250);\n background-color: var(--color-surface--hover);\n}\n\n.ncp0nKHQ7d8-:focus-visible {\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}\n\n.ncp0nKHQ7d8- span {\n margin-left: calc(16px / 2);\n margin-left: var(--space-small);\n}\n";
|
|
322
|
+
var styles$1 = {"actionContainer":"Ow9wSNnGP-g-","actionButton":"ncp0nKHQ7d8-"};
|
|
323
|
+
styleInject_es.styleInject(css_248z$1);
|
|
324
|
+
|
|
325
|
+
function ComboboxAction(props) {
|
|
326
|
+
const { searchValue } = React.useContext(ComboboxContext);
|
|
327
|
+
if (props.visible) {
|
|
328
|
+
const isVisible = typeof props.visible === "function" && !props.visible({ searchValue });
|
|
329
|
+
if (isVisible || !props.visible) {
|
|
330
|
+
return null;
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
const options = { searchValue };
|
|
334
|
+
const computedLabel = typeof props.label === "string" ? props.label : props.label(options);
|
|
335
|
+
return (React__default["default"].createElement("div", { className: styles$1.actionContainer },
|
|
336
|
+
React__default["default"].createElement("button", { className: styles$1.actionButton, onClick: e => props.onClick(e, options), type: "button" },
|
|
337
|
+
React__default["default"].createElement(Typography.Typography, { element: "span", size: "base", textColor: "green", fontWeight: "semiBold" }, computedLabel))));
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
function ComboboxTrigger({ label = "Select", selected, }) {
|
|
341
|
+
const { handleClose, open, setOpen } = React__default["default"].useContext(ComboboxContext);
|
|
342
|
+
const hasSelection = selected.length;
|
|
343
|
+
const selectedLabel = selected.map(option => option.label).join(", ");
|
|
344
|
+
return (React__default["default"].createElement(Chip.Chip, { variation: hasSelection ? "base" : "subtle", label: hasSelection ? selectedLabel : "", ariaLabel: label, heading: label, onClick: () => {
|
|
345
|
+
if (open) {
|
|
346
|
+
handleClose();
|
|
347
|
+
}
|
|
348
|
+
else {
|
|
349
|
+
setOpen(true);
|
|
350
|
+
}
|
|
351
|
+
}, role: "combobox" }, !hasSelection && (React__default["default"].createElement(Chip.Chip.Suffix, null,
|
|
352
|
+
React__default["default"].createElement(Icon.Icon, { name: "add", size: "small" })))));
|
|
353
|
+
}
|
|
354
|
+
|
|
355
|
+
var css_248z = ".W8qMZnORYxI- {\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: transparent;\n}\n\n._-0dkolvLF-Y- {\n display: inline-block;\n}\n";
|
|
356
|
+
var styles = {"overlay":"W8qMZnORYxI-","wrapper":"_-0dkolvLF-Y-"};
|
|
357
|
+
styleInject_es.styleInject(css_248z);
|
|
358
|
+
|
|
359
|
+
function useMakeComboboxHandlers(setOpen, setSearchValue, selectedOptions, shouldScroll, selectedStateSetter, multiSelect, onClose, onSearch) {
|
|
360
|
+
const handleClose = React.useCallback(() => {
|
|
361
|
+
setOpen(false);
|
|
362
|
+
setSearchValue("");
|
|
363
|
+
onSearch && onSearch("");
|
|
364
|
+
onClose && onClose();
|
|
365
|
+
if (selectedOptions.length > 0) {
|
|
366
|
+
shouldScroll.current = true;
|
|
367
|
+
}
|
|
368
|
+
}, [setOpen, setSearchValue, onClose, onSearch, selectedOptions.length]);
|
|
369
|
+
const handleSelection = React.useCallback((selection) => {
|
|
370
|
+
if (multiSelect) {
|
|
371
|
+
handleMultiSelect(selectedStateSetter, selectedOptions, selection);
|
|
372
|
+
}
|
|
373
|
+
else {
|
|
374
|
+
handleSingleSelect(selectedStateSetter, selection);
|
|
375
|
+
}
|
|
376
|
+
}, [multiSelect, selectedStateSetter, selectedOptions]);
|
|
377
|
+
const handleSingleSelect = React.useCallback((selectCallback, selection) => {
|
|
378
|
+
selectCallback([selection]);
|
|
379
|
+
handleClose();
|
|
380
|
+
}, []);
|
|
381
|
+
return {
|
|
382
|
+
handleClose,
|
|
383
|
+
handleSelection,
|
|
384
|
+
};
|
|
385
|
+
}
|
|
386
|
+
function handleMultiSelect(selectCallback, selected, selection) {
|
|
387
|
+
if (selected.some(s => s.id === selection.id)) {
|
|
388
|
+
selectCallback(selected.filter(s => s.id !== selection.id));
|
|
389
|
+
}
|
|
390
|
+
else {
|
|
391
|
+
selectCallback([...selected, selection]);
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
|
|
395
|
+
function useCombobox(selected, onSelect, options, onClose, multiSelect, onSearch, debounceTime = 300) {
|
|
396
|
+
const wrapperRef = React.useRef(null);
|
|
397
|
+
const shouldScroll = React.useRef(false);
|
|
398
|
+
const [open, setOpen] = React.useState(false);
|
|
399
|
+
const [searchValue, setSearchValue] = React.useState("");
|
|
400
|
+
const searchCallback = React.useCallback(debounce__default["default"]((value) => onSearch === null || onSearch === void 0 ? void 0 : onSearch(value), debounceTime), [onSearch, debounceTime]);
|
|
401
|
+
const { handleClose, handleSelection } = useMakeComboboxHandlers(setOpen, setSearchValue, selected, shouldScroll, onSelect, multiSelect, onClose, onSearch);
|
|
402
|
+
const internalFilteredOptions = options.filter(option => option.label.toLowerCase().includes(searchValue.toLowerCase()));
|
|
403
|
+
return {
|
|
404
|
+
wrapperRef,
|
|
405
|
+
searchValue,
|
|
406
|
+
setSearchValue,
|
|
407
|
+
open,
|
|
408
|
+
setOpen,
|
|
409
|
+
selectedOptions: selected,
|
|
410
|
+
selectedStateSetter: onSelect,
|
|
411
|
+
shouldScroll,
|
|
412
|
+
handleClose,
|
|
413
|
+
handleSelection,
|
|
414
|
+
internalFilteredOptions,
|
|
415
|
+
handleSearchChange: onSearch ? searchCallback : noop__default["default"],
|
|
416
|
+
};
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
function ComboboxActivator(props) {
|
|
420
|
+
const { handleClose, open, setOpen } = React__default["default"].useContext(ComboboxContext);
|
|
421
|
+
if (props.children.type === Button.Button || props.children.type === Chip.Chip) {
|
|
422
|
+
return React__default["default"].cloneElement(props.children, {
|
|
423
|
+
role: "combobox",
|
|
424
|
+
onClick: () => {
|
|
425
|
+
if (open) {
|
|
426
|
+
handleClose();
|
|
427
|
+
}
|
|
428
|
+
else {
|
|
429
|
+
setOpen(true);
|
|
430
|
+
}
|
|
431
|
+
},
|
|
432
|
+
});
|
|
433
|
+
}
|
|
434
|
+
return props.children;
|
|
435
|
+
}
|
|
436
|
+
|
|
437
|
+
const COMBOBOX_TRIGGER_COUNT_ERROR_MESSAGE = "Combobox must have exactly one Trigger element";
|
|
438
|
+
function useComboboxValidation(children) {
|
|
439
|
+
const optionElements = getCompoundComponents(ComboboxOption, children);
|
|
440
|
+
const actionElements = getCompoundComponents(ComboboxAction, children);
|
|
441
|
+
const activatorElements = getCompoundComponents(ComboboxActivator, children);
|
|
442
|
+
const shouldThrowTriggerError = isInvalid(activatorElements);
|
|
443
|
+
useAssert.useAssert(shouldThrowTriggerError, COMBOBOX_TRIGGER_COUNT_ERROR_MESSAGE);
|
|
444
|
+
return {
|
|
445
|
+
optionElements,
|
|
446
|
+
triggerElement: activatorElements[0],
|
|
447
|
+
actionElements,
|
|
448
|
+
};
|
|
449
|
+
}
|
|
450
|
+
function isInvalid(activators) {
|
|
451
|
+
return activators.length > 1 ? true : false;
|
|
452
|
+
}
|
|
453
|
+
/**
|
|
454
|
+
* Return all instances child component that matches the `type` provided
|
|
455
|
+
*/
|
|
456
|
+
function getCompoundComponents(type, children) {
|
|
457
|
+
const childrenArray = React.Children.toArray(children);
|
|
458
|
+
const elements = childrenArray.filter((child) => React.isValidElement(child) && child.type === type);
|
|
459
|
+
return elements;
|
|
460
|
+
}
|
|
461
|
+
|
|
462
|
+
function Combobox(props) {
|
|
463
|
+
const { optionElements, triggerElement, actionElements } = useComboboxValidation(props.children);
|
|
464
|
+
const options = React.useMemo(() => (optionElements === null || optionElements === void 0 ? void 0 : optionElements.map(option => ({
|
|
465
|
+
id: option.props.id,
|
|
466
|
+
label: option.props.label,
|
|
467
|
+
prefix: option.props.prefix,
|
|
468
|
+
}))) || [], [optionElements]);
|
|
469
|
+
const { selectedOptions, selectedStateSetter, shouldScroll, wrapperRef, searchValue, setSearchValue, open, setOpen, handleClose, handleSelection, internalFilteredOptions, handleSearchChange, } = useCombobox(props.selected, props.onSelect, options, props.onClose, props.multiSelect, props.onSearch, props.onSearchDebounce);
|
|
470
|
+
return (React__default["default"].createElement(ComboboxContextProvider, { selected: selectedOptions, selectionHandler: handleSelection, open: open, setOpen: setOpen, handleClose: handleClose, shouldScroll: shouldScroll, searchValue: searchValue },
|
|
471
|
+
React__default["default"].createElement("div", { ref: wrapperRef, className: styles.wrapper },
|
|
472
|
+
open && (React__default["default"].createElement("div", { className: styles.overlay, onClick: () => handleClose(), "data-testid": "ATL-Combobox-Overlay" })),
|
|
473
|
+
triggerElement || (React__default["default"].createElement(ComboboxTrigger, { label: props.label, selected: props.selected })),
|
|
474
|
+
React__default["default"].createElement(ComboboxContent, { multiselect: props.multiSelect, subjectNoun: props.subjectNoun, selected: selectedOptions, actionElements: actionElements, selectedStateSetter: selectedStateSetter, handleSelection: handleSelection, searchValue: searchValue, setSearchValue: setSearchValue, wrapperRef: wrapperRef, open: open, setOpen: setOpen, options: props.onSearch ? options : internalFilteredOptions, loading: props.loading, handleSearchChange: handleSearchChange, onLoadMore: props.onLoadMore }))));
|
|
475
|
+
}
|
|
476
|
+
Combobox.Activator = ComboboxActivator;
|
|
477
|
+
Combobox.Action = ComboboxAction;
|
|
478
|
+
Combobox.Option = ComboboxOption;
|
|
479
|
+
|
|
480
|
+
exports.Combobox = Combobox;
|
|
481
|
+
exports.ComboboxContextProvider = ComboboxContextProvider;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var ConfirmationModal = require('../ConfirmationModal-b7da32ac.js');
|
|
6
|
+
require('react');
|
|
7
|
+
require('@jobber/hooks/useOnKeyDown');
|
|
8
|
+
require('../Modal-4ce1ec79.js');
|
|
9
|
+
require('react-dom');
|
|
10
|
+
require('classnames');
|
|
11
|
+
require('framer-motion');
|
|
12
|
+
require('@jobber/hooks/useRefocusOnActivator');
|
|
13
|
+
require('@jobber/hooks/useFocusTrap');
|
|
14
|
+
require('../style-inject.es-9d2f5f4e.js');
|
|
15
|
+
require('../Heading-23d382a1.js');
|
|
16
|
+
require('../Typography-e2a23b7e.js');
|
|
17
|
+
require('../useAtlantisConfig-ed0bee66.js');
|
|
18
|
+
require('@jobber/hooks/useSafeLayoutEffect');
|
|
19
|
+
require('../Button-6b922fc1.js');
|
|
20
|
+
require('react-router-dom');
|
|
21
|
+
require('../Icon-405a216c.js');
|
|
22
|
+
require('@jobber/design');
|
|
23
|
+
require('../ButtonDismiss-a3ba1de2.js');
|
|
24
|
+
require('../Content-e3f7b6fc.js');
|
|
25
|
+
require('../Markdown-0f24de70.js');
|
|
26
|
+
require('react-markdown');
|
|
27
|
+
require('../Text-fbeaaca6.js');
|
|
28
|
+
require('../Emphasis-a77d8ee9.js');
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
exports.ConfirmationModal = ConfirmationModal.ConfirmationModal;
|
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var React = require('react');
|
|
4
|
-
var useOnKeyDown = require('
|
|
5
|
-
var Modal = require('./Modal-
|
|
6
|
-
var Content = require('./Content-
|
|
7
|
-
var Markdown = require('./Markdown-
|
|
4
|
+
var useOnKeyDown = require('@jobber/hooks/useOnKeyDown');
|
|
5
|
+
var Modal = require('./Modal-4ce1ec79.js');
|
|
6
|
+
var Content = require('./Content-e3f7b6fc.js');
|
|
7
|
+
var Markdown = require('./Markdown-0f24de70.js');
|
|
8
|
+
|
|
9
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
10
|
+
|
|
11
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
8
12
|
|
|
9
13
|
function confirmationModalReducer(state, action) {
|
|
10
14
|
switch (action.type) {
|
|
@@ -55,16 +59,16 @@ const ConfirmationModal = React.forwardRef(function ConfirmationModalInternal({
|
|
|
55
59
|
onCancel }),
|
|
56
60
|
});
|
|
57
61
|
}, [title, message, confirmLabel, cancelLabel, onConfirm, onCancel]);
|
|
58
|
-
useOnKeyDown.
|
|
59
|
-
return (
|
|
62
|
+
useOnKeyDown.useOnKeyDown(handleKeyboardShortcut, ["Escape", "Enter"]);
|
|
63
|
+
return (React__default["default"].createElement(Modal.Modal, { title: state.title, open: open || state.open, size: size, dismissible: false, primaryAction: {
|
|
60
64
|
label: state.confirmLabel,
|
|
61
65
|
onClick: handleAction("confirm"),
|
|
62
66
|
variation: variation === "destructive" ? "destructive" : "work",
|
|
63
67
|
}, secondaryAction: {
|
|
64
68
|
label: state.cancelLabel,
|
|
65
69
|
onClick: handleAction("cancel"),
|
|
66
|
-
} }, state.message ? (
|
|
67
|
-
|
|
70
|
+
} }, state.message ? (React__default["default"].createElement(Content.Content, null,
|
|
71
|
+
React__default["default"].createElement(Markdown.Markdown, { content: state.message }))) : (children)));
|
|
68
72
|
function handleAction(type) {
|
|
69
73
|
return () => {
|
|
70
74
|
dispatch({ type });
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var Content = require('../Content-e3f7b6fc.js');
|
|
6
|
+
require('react');
|
|
7
|
+
require('classnames');
|
|
8
|
+
require('../style-inject.es-9d2f5f4e.js');
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
exports.Content = Content.Content;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var classnames = require('classnames');
|
|
5
|
+
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
6
|
+
|
|
7
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
8
|
+
|
|
9
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
10
|
+
|
|
11
|
+
var css_248z$1 = "._340SlNuzSDQ- > :not(:last-child) {\n margin-bottom: calc(16px / 16);\n margin-bottom: var(--space-minuscule);\n}\n\n.H1BK-YSBQBQ- > :not(:last-child) {\n margin-bottom: calc(16px / 8);\n margin-bottom: var(--space-smallest);\n}\n\n.xUe31mY0kro- > :not(:last-child) {\n margin-bottom: calc(16px / 4);\n margin-bottom: var(--space-smaller);\n}\n\n.rDJFaGPzCbE- > :not(:last-child) {\n margin-bottom: calc(16px / 2);\n margin-bottom: var(--space-small);\n}\n\n.SRYe3DkjH1c- > :not(:last-child) {\n margin-bottom: calc(16px * 1);\n margin-bottom: var(--space-base);\n}\n\n._7TZ4MI3kr4Y- > :not(:last-child) {\n margin-bottom: calc(16px * 1.5);\n margin-bottom: var(--space-large);\n}\n\n.jvPl3aAN9PA- > :not(:last-child) {\n margin-bottom: calc(16px * 2);\n margin-bottom: var(--space-larger);\n}\n\n.fFTgb4ra1X0- > :not(:last-child) {\n margin-bottom: calc(16px * 3);\n margin-bottom: var(--space-largest);\n}\n\n.kKnfL37LO6A- > :not(:last-child) {\n margin-bottom: calc(16px * 4);\n margin-bottom: var(--space-extravagant);\n}\n";
|
|
12
|
+
var spacings = {"minuscule":"_340SlNuzSDQ-","smallest":"H1BK-YSBQBQ-","smaller":"xUe31mY0kro-","small":"rDJFaGPzCbE-","base":"SRYe3DkjH1c-","large":"_7TZ4MI3kr4Y-","larger":"jvPl3aAN9PA-","largest":"fFTgb4ra1X0-","extravagant":"kKnfL37LO6A-"};
|
|
13
|
+
styleInject_es.styleInject(css_248z$1);
|
|
14
|
+
|
|
15
|
+
var css_248z = "._4On2F-4nWuY- {\n padding: 0;\n padding: var(--public-content--padding, 0);\n}\n";
|
|
16
|
+
var styles = {"padded":"_4On2F-4nWuY-"};
|
|
17
|
+
styleInject_es.styleInject(css_248z);
|
|
18
|
+
|
|
19
|
+
function Content({ children, spacing = "base", type = "div", }) {
|
|
20
|
+
const className = classnames__default["default"](styles.padded, spacings[spacing]);
|
|
21
|
+
return React.createElement(type, { className }, children);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
exports.Content = Content;
|