@jobber/components 4.90.3 → 4.90.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AnimatedPresence/{index.cjs → index.js} +3 -1
- package/dist/{AnimatedPresence-CNNu0y2V.js → AnimatedPresence-20a02aaa.js} +7 -3
- package/dist/AnimatedSwitcher/index.js +13 -0
- package/dist/{AnimatedSwitcher-CXKNa7td.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-BJRisSRI.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-C1OZbkgH.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-F_hdjag1.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-DJIQHUEo.js → FormatRelativeDateTime/index.js} +11 -5
- package/dist/{FormatTime-Bf1p46AK.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-CCFoOnua.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-ChvqCIwy.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-B1xScmfR.js → InputNumber-e15cc1a3.js} +6 -2
- package/dist/InputPassword/index.js +41 -0
- package/dist/{InputPhoneNumber-DWdXIF84.js → InputPhoneNumber/index.js} +27 -7
- package/dist/InputText/index.js +26 -0
- package/dist/{InputText-Br2K1C4M.js → InputText-130b0440.js} +8 -4
- package/dist/{InputTime-CpoUMFJT.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-Bopx9dUr.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-BbG41OXr.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-Cp8tOatE.js +0 -98
- package/dist/AnimatedSwitcher/index.cjs +0 -11
- package/dist/AnimatedSwitcher/index.mjs +0 -5
- package/dist/AnimatedSwitcher-DJqwc2sj.js +0 -90
- package/dist/AtlantisContext/index.mjs +0 -2
- package/dist/AtlantisContext-B2cWxzkp.js +0 -18
- package/dist/Autocomplete/index.cjs +0 -33
- package/dist/Autocomplete/index.mjs +0 -27
- package/dist/Autocomplete-CHcTq0Do.js +0 -192
- package/dist/Autocomplete-CswBpc7U.js +0 -190
- package/dist/Avatar/index.cjs +0 -12
- package/dist/Avatar/index.mjs +0 -6
- package/dist/Avatar-NVE7Yqd4.js +0 -69
- package/dist/Avatar-Q8rB73I2.js +0 -67
- 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-AzSFwco8.js +0 -79
- package/dist/Banner-DH176e7P.js +0 -81
- package/dist/BannerIcon-BDM1qFzc.js +0 -19
- package/dist/BannerIcon-Dg3SkxI7.js +0 -22
- package/dist/Body-ChUi3aq5.js +0 -54
- package/dist/Body-D1DdNQ7t.js +0 -45
- package/dist/Button/index.cjs +0 -13
- package/dist/Button/index.mjs +0 -7
- package/dist/Button-C6SHw1kI.js +0 -49
- package/dist/Button-Cfp4SFrN.js +0 -47
- package/dist/ButtonDismiss/index.cjs +0 -14
- package/dist/ButtonDismiss/index.mjs +0 -8
- package/dist/ButtonDismiss-Cf-2rvG0.js +0 -8
- package/dist/ButtonDismiss-DVALYLmq.js +0 -10
- package/dist/Card/index.cjs +0 -21
- package/dist/Card/index.mjs +0 -15
- package/dist/Card-DE7aMoA7.js +0 -83
- package/dist/Card-DXsK_SD7.js +0 -81
- package/dist/Checkbox/index.cjs +0 -15
- package/dist/Checkbox/index.mjs +0 -9
- package/dist/Checkbox-BXh_wazi.js +0 -55
- package/dist/Checkbox-DxC81YWi.js +0 -53
- 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-DDl2lMHv.js +0 -70
- package/dist/Chip-DhTvoOnl.js +0 -67
- package/dist/ChipDismissible-S-txJuLF.js +0 -19
- package/dist/ChipDismissible-dx2J1n-C.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-BBnCrPul.js +0 -93
- package/dist/Chips-KPKpzxUx.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-DL8grBGD.js +0 -119
- package/dist/Combobox-DkiMKBIq.js +0 -117
- package/dist/ComboboxAction-BZcUzPiS.js +0 -22
- package/dist/ComboboxAction-BrphUdTc.js +0 -24
- package/dist/ComboboxActivator-B-hbPIvc.js +0 -28
- package/dist/ComboboxActivator-GbDe5-gd.js +0 -26
- package/dist/ComboboxContent-PbGOqYiy.js +0 -145
- package/dist/ComboboxContent-Y7XnpDxG.js +0 -143
- package/dist/ComboboxContentHeader-CXeTEKPJ.js +0 -29
- package/dist/ComboboxContentHeader-R33IqVfI.js +0 -27
- package/dist/ComboboxContentList-BcRD6OP7.js +0 -75
- package/dist/ComboboxContentList-QdY3v22O.js +0 -77
- package/dist/ComboboxContentSearch-BQoi8eST.js +0 -32
- package/dist/ComboboxContentSearch-BYHUi0_0.js +0 -34
- package/dist/ComboboxLoadMore-CTue6Ccg.js +0 -16
- package/dist/ComboboxLoadMore-Dwov5fXg.js +0 -14
- package/dist/ComboboxOption-BQAcmD8S.js +0 -20
- package/dist/ComboboxOption-CEM44lR4.js +0 -22
- package/dist/ComboboxProvider-BfK8pUar.js +0 -13
- package/dist/ComboboxProvider-CnooL3he.js +0 -10
- package/dist/ComboboxTrigger-BPoUI5Eo.js +0 -24
- package/dist/ComboboxTrigger-CUU6Np4P.js +0 -22
- package/dist/ConfirmationModal/index.cjs +0 -31
- package/dist/ConfirmationModal/index.mjs +0 -25
- package/dist/ConfirmationModal-DWSRaZne.js +0 -94
- package/dist/Content/index.cjs +0 -9
- package/dist/Content/index.mjs +0 -3
- package/dist/Content-BfbXarkv.js +0 -15
- package/dist/Content-DcpJaJjo.js +0 -13
- package/dist/Countdown/index.cjs +0 -11
- package/dist/Countdown/index.mjs +0 -5
- package/dist/Countdown-B1qWObYf.js +0 -659
- package/dist/Countdown-BcPHGeXW.js +0 -657
- package/dist/DataDump/index.cjs +0 -24
- package/dist/DataDump/index.mjs +0 -18
- package/dist/DataDump-CVjjQmzE.js +0 -17
- package/dist/DataDump-IdZ5dfe5.js +0 -15
- 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-BNFt3ksk.js +0 -139
- package/dist/DataList-Cr9VCHIX.js +0 -5
- package/dist/DataList-DHFR_-wI.js +0 -141
- package/dist/DataList-Dz5NINSZ.js +0 -3
- package/dist/DataList.const-D7NaHwv2.js +0 -25
- package/dist/DataList.const-DD8VmZp1.js +0 -38
- package/dist/DataList.utils-DhJ6Bzfb.js +0 -161
- package/dist/DataList.utils-nlVavDa-.js +0 -168
- package/dist/DataListAction-BLmcBkv3.js +0 -39
- package/dist/DataListAction-z0r8dyGZ.js +0 -37
- package/dist/DataListActions-4k1qQRcL.js +0 -43
- package/dist/DataListActions-DNsv1N2R.js +0 -45
- package/dist/DataListActionsMenu-4y3C6RwI.js +0 -55
- package/dist/DataListActionsMenu-D7LvCqEb.js +0 -57
- package/dist/DataListBulkActions-By-GrAPp.js +0 -29
- package/dist/DataListBulkActions-Ck89g6ye.js +0 -26
- package/dist/DataListContext-54s0cQ2-.js +0 -29
- package/dist/DataListContext-BQjPQQPp.js +0 -25
- package/dist/DataListEmptyState-5-J-3X4D.js +0 -53
- package/dist/DataListEmptyState-BtuGoNX6.js +0 -50
- package/dist/DataListFilters-sd7jBhQE.js +0 -46
- package/dist/DataListFilters-vylASUtC.js +0 -43
- package/dist/DataListHeader-Bkxr7WIZ.js +0 -95
- package/dist/DataListHeader-PvjsNn2I.js +0 -93
- package/dist/DataListHeaderTile-BybGOG6C.js +0 -81
- package/dist/DataListHeaderTile-KJ8Eae63.js +0 -79
- package/dist/DataListItem-BqNp3Eqq.js +0 -112
- package/dist/DataListItem-CCbOb4ts.js +0 -114
- package/dist/DataListItemActions-C25oc6Y-.js +0 -29
- package/dist/DataListItemActions-DPiWyGS1.js +0 -32
- package/dist/DataListItemActionsOverflow-Dy8lheES.js +0 -33
- package/dist/DataListItemActionsOverflow-ul1diZ44.js +0 -35
- package/dist/DataListItemClickable-BuMjNn5E.js +0 -47
- package/dist/DataListItemClickable-DQ5Sq-4_.js +0 -45
- package/dist/DataListItems--_6Rb8Jq.js +0 -19
- package/dist/DataListItems-DwAPcNSD.js +0 -21
- package/dist/DataListLayout-DWQ3LcOJ.js +0 -21
- package/dist/DataListLayout-DYcpl2hP.js +0 -19
- package/dist/DataListLayoutActions-B1EVoxK2.js +0 -36
- package/dist/DataListLayoutActions-DLj3XiZ5.js +0 -38
- package/dist/DataListLayoutContext-Dl1JtgLH.js +0 -11
- package/dist/DataListLayoutContext-DwmprXbf.js +0 -18
- package/dist/DataListLayoutContext-Il_5jPik.js +0 -14
- package/dist/DataListLayoutContext-TpQb0Nj2.js +0 -8
- package/dist/DataListLoadMore-FkGD7vHM.js +0 -34
- package/dist/DataListLoadMore-ZmJj5-i9.js +0 -31
- package/dist/DataListLoadingState-CR1Z1_AR.js +0 -26
- package/dist/DataListLoadingState-xQup12W4.js +0 -22
- package/dist/DataListOverflowFade-10aOxr8Q.js +0 -25
- package/dist/DataListOverflowFade-D0Nqey5v.js +0 -22
- package/dist/DataListSearch-DyYTAMCq.js +0 -59
- package/dist/DataListSearch-I4HkoS-h.js +0 -63
- package/dist/DataListSort-DWwMojZr.js +0 -94
- package/dist/DataListSort-GHDVPJ_E.js +0 -92
- package/dist/DataListSortingOptions-DpPwd-YR.js +0 -35
- package/dist/DataListSortingOptions-nk9dclSJ.js +0 -37
- package/dist/DataListStatusBar-Cq2c6T6R.js +0 -22
- package/dist/DataListStatusBar-DoDXKGHi.js +0 -25
- package/dist/DataListStickyHeader-6xUwJJD7.js +0 -23
- package/dist/DataListStickyHeader-xrbxWP2I.js +0 -25
- package/dist/DataListTags-69zAArZ2.js +0 -64
- package/dist/DataListTags-Ck_VOCzy.js +0 -62
- package/dist/DataListTotalCount-CJZ9FD36.js +0 -27
- package/dist/DataListTotalCount-Cns_GwAL.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-Bt0NOwH4.js +0 -236
- package/dist/DataTable-CNVDhnqd.js +0 -238
- package/dist/DatePicker/index.cjs +0 -26
- package/dist/DatePicker/index.mjs +0 -20
- package/dist/DatePicker-BRUF_5jL.js +0 -8554
- package/dist/DatePicker-Ck4FVQQS.js +0 -8551
- package/dist/DayOfMonthSelect-BdCBk0Fz.js +0 -130
- package/dist/DayOfMonthSelect-CmghghbK.js +0 -137
- package/dist/DescriptionList/index.cjs +0 -10
- package/dist/DescriptionList/index.mjs +0 -4
- package/dist/DescriptionList-BHllIrT9.js +0 -14
- package/dist/DescriptionList-BX86_iJ-.js +0 -12
- package/dist/Disclosure/index.cjs +0 -17
- package/dist/Disclosure/index.mjs +0 -11
- package/dist/Disclosure-BOotfD-_.js +0 -33
- package/dist/Disclosure-CwDEaUmN.js +0 -35
- package/dist/Divider/index.cjs +0 -9
- package/dist/Divider/index.mjs +0 -3
- package/dist/Divider-CGLchhDF.js +0 -17
- package/dist/Divider-yff7rtIo.js +0 -19
- package/dist/Drawer/index.cjs +0 -19
- package/dist/Drawer/index.mjs +0 -12
- package/dist/DrawerGrid-Csj6IRXw.js +0 -28
- package/dist/DrawerGrid-Dhe6uh-8.js +0 -31
- package/dist/Emphasis/index.cjs +0 -10
- package/dist/Emphasis/index.mjs +0 -4
- package/dist/Emphasis-RZbI_yDN.js +0 -15
- package/dist/Emphasis-ieWWb3pq.js +0 -13
- package/dist/FeatureSwitch/index.cjs +0 -26
- package/dist/FeatureSwitch/index.mjs +0 -20
- package/dist/FeatureSwitch-BcLRihpc.js +0 -52
- package/dist/FeatureSwitch-DKsr91OR.js +0 -54
- package/dist/Flex/index.cjs +0 -9
- package/dist/Flex/index.mjs +0 -3
- package/dist/Flex-CloUiW2f.js +0 -28
- package/dist/Flex-mRkBGC1G.js +0 -30
- package/dist/Form/index.cjs +0 -10
- package/dist/Form/index.mjs +0 -4
- package/dist/Form-Brm98BxU.js +0 -48
- package/dist/FormField/index.cjs +0 -20
- package/dist/FormField/index.mjs +0 -14
- package/dist/FormField-CevGrDGm.js +0 -261
- package/dist/FormField-DgvKr2RR.js +0 -263
- package/dist/FormatDate/index.mjs +0 -2
- package/dist/FormatDate-Cuu1uyX_.js +0 -27
- package/dist/FormatEmail/index.cjs +0 -9
- package/dist/FormatEmail/index.mjs +0 -3
- package/dist/FormatEmail-BL75oJKz.js +0 -11
- package/dist/FormatEmail-FWzV4fL2.js +0 -13
- package/dist/FormatFile/index.cjs +0 -36
- package/dist/FormatFile/index.mjs +0 -30
- package/dist/FormatFile-CaULPATZ.js +0 -149
- package/dist/FormatFile-Dkkpc4RO.js +0 -147
- package/dist/FormatRelativeDateTime/index.cjs +0 -8
- package/dist/FormatRelativeDateTime/index.mjs +0 -2
- package/dist/FormatRelativeDateTime-SwQGKFKx.js +0 -64
- package/dist/FormatTime/index.cjs +0 -8
- package/dist/FormatTime/index.mjs +0 -2
- package/dist/FormatTime-BUp8wKYB.js +0 -29
- package/dist/Gallery/index.cjs +0 -42
- package/dist/Gallery/index.mjs +0 -36
- package/dist/Gallery-iRUMatk_.js +0 -65
- package/dist/Gallery-ondjCKOu.js +0 -63
- package/dist/Glimmer/index.cjs +0 -12
- package/dist/Glimmer/index.mjs +0 -5
- package/dist/Glimmer-CVTrhX52.js +0 -60
- package/dist/Glimmer-CnsLTogn.js +0 -63
- 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-DC7GAarU.js +0 -29
- package/dist/Grid-c8FgrzP7.js +0 -32
- package/dist/Heading/index.cjs +0 -12
- package/dist/Heading/index.mjs +0 -6
- package/dist/Heading-Cik7AvDW.js +0 -49
- package/dist/Icon/index.cjs +0 -9
- package/dist/Icon/index.mjs +0 -3
- package/dist/Icon-Cprfa6DH.js +0 -34
- package/dist/Icon-DN6zZdoZ.js +0 -36
- package/dist/InlineLabel/index.cjs +0 -10
- package/dist/InlineLabel/index.mjs +0 -4
- package/dist/InlineLabel-DjcM6md2.js +0 -18
- package/dist/InlineLabel-DpGHWyZ1.js +0 -20
- package/dist/InputAvatar/index.cjs +0 -26
- package/dist/InputAvatar/index.mjs +0 -20
- package/dist/InputAvatar-0CRsukeF.js +0 -49
- package/dist/InputAvatar-BR9CNN8N.js +0 -47
- package/dist/InputDate/index.cjs +0 -34
- package/dist/InputDate/index.mjs +0 -28
- package/dist/InputDate-Di1ilUDK.js +0 -48
- package/dist/InputEmail/index.cjs +0 -22
- package/dist/InputEmail/index.mjs +0 -15
- package/dist/InputEmail-2iUVN3lX.js +0 -23
- package/dist/InputEmail-DIaAL1Fj.js +0 -20
- package/dist/InputFile/index.cjs +0 -23
- package/dist/InputFile/index.mjs +0 -16
- package/dist/InputFile-CQcJalUx.js +0 -1611
- package/dist/InputFile-DrLKxOEw.js +0 -1608
- package/dist/InputGroup/index.cjs +0 -9
- package/dist/InputGroup/index.mjs +0 -3
- package/dist/InputGroup-CDAggb3R.js +0 -25
- package/dist/InputGroup-CqwRtrCP.js +0 -23
- package/dist/InputNumber/index.cjs +0 -21
- package/dist/InputNumber/index.mjs +0 -15
- package/dist/InputNumber-CJabx_OX.js +0 -56
- package/dist/InputPassword/index.cjs +0 -21
- package/dist/InputPassword/index.mjs +0 -15
- package/dist/InputPassword-558tvE1p.js +0 -21
- package/dist/InputPassword-DIzD-pX3.js +0 -19
- package/dist/InputPhoneNumber/index.cjs +0 -21
- package/dist/InputPhoneNumber/index.mjs +0 -15
- package/dist/InputPhoneNumber-DRdIU41q.js +0 -94
- package/dist/InputText/index.cjs +0 -22
- package/dist/InputText/index.mjs +0 -16
- package/dist/InputText-CyGO_Jef.js +0 -96
- package/dist/InputTime/index.cjs +0 -26
- package/dist/InputTime/index.mjs +0 -20
- package/dist/InputTime-kqDNzoYY.js +0 -190
- package/dist/InputValidation/index.cjs +0 -14
- package/dist/InputValidation/index.mjs +0 -8
- package/dist/InputValidation-CA3D4HMZ.js +0 -22
- package/dist/InputValidation-D4MvsPKI.js +0 -20
- package/dist/InternalChipDismissible-B7LrCyb7.js +0 -152
- package/dist/InternalChipDismissible-C52ZoCE0.js +0 -157
- package/dist/InternalGridCell-DqEoIvP9.js +0 -34
- package/dist/InternalGridCell-zig0sMW5.js +0 -37
- package/dist/LightBox/index.cjs +0 -26
- package/dist/LightBox/index.mjs +0 -20
- package/dist/LightBox-BMcZ0zUE.js +0 -112
- package/dist/LightBox-DdN2Kv2x.js +0 -110
- package/dist/Link/index.cjs +0 -8
- package/dist/Link/index.mjs +0 -2
- package/dist/Link-BXg1N0uc.js +0 -7
- package/dist/Link-D4vsUc4Q.js +0 -9
- package/dist/List/index.cjs +0 -29
- package/dist/List/index.mjs +0 -22
- package/dist/List-DEIH9jaA.js +0 -189
- package/dist/List-Dh-L_8Vd.js +0 -186
- package/dist/Markdown/index.cjs +0 -19
- package/dist/Markdown/index.mjs +0 -13
- package/dist/Markdown-DIOh2S0u.js +0 -19011
- package/dist/Markdown-GR9F9CIO.js +0 -19013
- package/dist/Menu/index.cjs +0 -18
- package/dist/Menu/index.mjs +0 -12
- package/dist/Menu-D4apJOhh.js +0 -131
- package/dist/Menu-IjuAzGId.js +0 -129
- package/dist/Modal/index.cjs +0 -23
- package/dist/Modal/index.mjs +0 -17
- package/dist/Modal-Dr-Y4-gf.js +0 -62
- package/dist/Modal-aGXkiuSS.js +0 -60
- package/dist/MultiSelect/index.cjs +0 -16
- package/dist/MultiSelect/index.mjs +0 -10
- package/dist/MultiSelect-1LkHc-4a.js +0 -166
- package/dist/MultiSelect-CIFWIwY6.js +0 -164
- package/dist/Option-DLsUvwdO.js +0 -12
- package/dist/Option-c12Y1Noe.js +0 -15
- package/dist/Page/index.cjs +0 -32
- package/dist/Page/index.mjs +0 -26
- package/dist/Page-CakXCvoE.js +0 -58
- package/dist/Page-DwQymzZk.js +0 -56
- package/dist/Popover/index.cjs +0 -17
- package/dist/Popover/index.mjs +0 -11
- package/dist/Popover-BY0EW6zV.js +0 -48
- package/dist/Popover-ByVk1LqF.js +0 -50
- package/dist/ProgressBar/index.cjs +0 -9
- package/dist/ProgressBar/index.mjs +0 -3
- package/dist/ProgressBar-52i53SJE.js +0 -33
- package/dist/ProgressBar-BaSkqP8J.js +0 -31
- package/dist/RadioGroup/index.cjs +0 -12
- package/dist/RadioGroup/index.mjs +0 -5
- package/dist/RadioGroup-CRwAZq63.js +0 -36
- package/dist/RadioGroup-TNqC7foh.js +0 -39
- 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-VBGk4Lt2.js +0 -71
- package/dist/RecurringSelect-cwPdAc_S.js +0 -69
- 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-L0bWOO6S.js +0 -16
- package/dist/Spinner-gZOK7Pbk.js +0 -14
- package/dist/StatusIndicator/index.cjs +0 -8
- package/dist/StatusIndicator/index.mjs +0 -2
- package/dist/StatusIndicator-CQ4BuDSG.js +0 -9
- package/dist/StatusIndicator-CQu-mhiP.js +0 -11
- package/dist/StatusLabel/index.cjs +0 -11
- package/dist/StatusLabel/index.mjs +0 -5
- package/dist/StatusLabel-C8xAbAuq.js +0 -18
- package/dist/StatusLabel-O-4M1wUA.js +0 -16
- package/dist/Switch/index.cjs +0 -10
- package/dist/Switch/index.mjs +0 -4
- package/dist/Switch-DMYTNJjq.js +0 -48
- package/dist/Switch-DqzUCyHn.js +0 -46
- 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-C3qMIs1F.js +0 -67
- package/dist/Tabs-CRY_vyNW.js +0 -70
- package/dist/Text/index.cjs +0 -10
- package/dist/Text/index.mjs +0 -4
- package/dist/Text-DALHhxHl.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-B2DBKrJM.js +0 -103
- package/dist/Tooltip-VHTRuZ4Y.js +0 -105
- package/dist/Typography/index.cjs +0 -9
- package/dist/Typography/index.mjs +0 -3
- package/dist/Typography-D6YoQOGF.js +0 -36
- package/dist/Typography-WLLQxuNl.js +0 -38
- package/dist/_baseAssignValue-BthOhxdo.js +0 -29
- package/dist/_baseAssignValue-Dt4F7vTV.js +0 -31
- package/dist/_baseEach-BECef8ru.js +0 -1069
- package/dist/_baseEach-Dze5I6UM.js +0 -1073
- package/dist/_commonjsHelpers-COf7qtKz.js +0 -32
- package/dist/_commonjsHelpers-vq2WA-uE.js +0 -36
- package/dist/_defineProperty-2TBZHj_H.js +0 -1306
- package/dist/_defineProperty-DxuhV38S.js +0 -1326
- package/dist/_getTag-BhVE5Z9s.js +0 -733
- package/dist/_getTag-Z6aLseUE.js +0 -718
- package/dist/_polyfill-node.process-e5fcXoUk.js +0 -255
- package/dist/_polyfill-node.process-mCRQTL4d.js +0 -258
- package/dist/_setToString-CFGrPYbk.js +0 -230
- package/dist/_setToString-D9q1MBnP.js +0 -234
- package/dist/debounce-DNEaQL1N.js +0 -332
- package/dist/debounce-DgeBwtKp.js +0 -329
- package/dist/helpers-QJ7YD42d.js +0 -17
- package/dist/helpers-cJmOwx3u.js +0 -15
- package/dist/index-C4SneFNu.js +0 -1186
- package/dist/index-yqmGqwFM.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-BLBufvwS.js +0 -197
- package/dist/isObjectLike-CqUyaiWM.js +0 -190
- package/dist/isSymbol-MYvz4htB.js +0 -35
- package/dist/isSymbol-_Iyy_jRJ.js +0 -33
- package/dist/noop-C8qh6oDm.js +0 -26
- package/dist/noop-CNfu_5-L.js +0 -24
- package/dist/showToast-BB8OsmX0.js +0 -97
- package/dist/showToast-DNc6Ghvi.js +0 -99
- package/dist/styles.css +0 -8762
- package/dist/tslib.es6-CQnq_FvL.js +0 -97
- package/dist/tslib.es6-v7P0Y776.js +0 -102
- package/dist/useActiveLayout-C0_CiH6w.js +0 -16
- package/dist/useActiveLayout-CpgnILog.js +0 -14
- package/dist/useAssert--FSFxEub.js +0 -27
- package/dist/useAssert-BRTg70rg.js +0 -27
- package/dist/useAtlantisConfig-ClMTcI5f.js +0 -14
- package/dist/useBatchSelect-CTMzNd5R.js +0 -36
- package/dist/useBatchSelect-nB5zKoLG.js +0 -38
- package/dist/useChildComponent-2LnkmIw0.js +0 -15
- package/dist/useChildComponent-Dv0rjZs2.js +0 -17
- package/dist/useFocusTrap-DDVdHPLP.js +0 -74
- package/dist/useFocusTrap-J4nqJhkL.js +0 -74
- package/dist/useInView-D7JiU6w9.js +0 -25
- package/dist/useInView-DRRNAygj.js +0 -25
- package/dist/useIsMounted-Ds9qZzhJ.js +0 -47
- package/dist/useIsMounted-sw4iFcH2.js +0 -47
- package/dist/useOnKeyDown-BBUzTpsM.js +0 -40
- package/dist/useOnKeyDown-ClBoAl9o.js +0 -40
- package/dist/useRefocusOnActivator-DhXYZbJ2.js +0 -32
- package/dist/useRefocusOnActivator-JhjmSWbr.js +0 -32
- package/dist/useResizeObserver-Bt-giwIv.js +0 -1192
- package/dist/useResizeObserver-D7zJHmH-.js +0 -1189
- package/dist/useResponsiveSizing-CaFHa0P8.js +0 -49
- package/dist/useResponsiveSizing-X79bu1Sd.js +0 -51
- package/dist/useSafeLayoutEffect-87KYIon5.js +0 -14
- package/dist/useSafeLayoutEffect-IMNHxeSN.js +0 -12
- package/dist/useScrollToActive-AgUIt0XS.js +0 -591
- package/dist/useScrollToActive-D4MUBncA.js +0 -597
- /package/{.eslintrc.cjs → .eslintrc.js} +0 -0
- /package/dist/{AtlantisContext-kZu_c9Er.js → AtlantisContext-64608897.js} +0 -0
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var AnimatedPresence = require('../AnimatedPresence-20a02aaa.js');
|
|
4
6
|
require('react');
|
|
5
7
|
require('framer-motion');
|
|
6
8
|
require('@jobber/design');
|
|
@@ -4,6 +4,10 @@ var React = require('react');
|
|
|
4
4
|
var framerMotion = require('framer-motion');
|
|
5
5
|
var design = require('@jobber/design');
|
|
6
6
|
|
|
7
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
8
|
+
|
|
9
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
10
|
+
|
|
7
11
|
const TIMING_QUICK = toSeconds(design.tokens["timing-quick"]);
|
|
8
12
|
const TIMING_BASE = toSeconds(design.tokens["timing-base"]);
|
|
9
13
|
const baseTransition = {
|
|
@@ -69,9 +73,9 @@ const transitions = {
|
|
|
69
73
|
function AnimatedPresence(props) {
|
|
70
74
|
const shouldReduceMotion = framerMotion.useReducedMotion();
|
|
71
75
|
if (shouldReduceMotion) {
|
|
72
|
-
return
|
|
76
|
+
return React__default["default"].createElement(React__default["default"].Fragment, null, props.children);
|
|
73
77
|
}
|
|
74
|
-
return
|
|
78
|
+
return React__default["default"].createElement(InternalAnimatedPresence, Object.assign({}, props));
|
|
75
79
|
}
|
|
76
80
|
function InternalAnimatedPresence({ transition = "fromTop", initial = false, children, }) {
|
|
77
81
|
const transitionVariation = transitions[transition];
|
|
@@ -84,7 +88,7 @@ function InternalAnimatedPresence({ transition = "fromTop", initial = false, chi
|
|
|
84
88
|
React.useEffect(() => {
|
|
85
89
|
setLastChildIndex(childCount - 1);
|
|
86
90
|
}, [childCount]);
|
|
87
|
-
return (
|
|
91
|
+
return (React__default["default"].createElement(framerMotion.AnimatePresence, { initial: initial, mode: "popLayout" }, React.Children.map(children, (child, i) => child && (React__default["default"].createElement(framerMotion.motion.div, { layout: true, variants: transitionVariation, initial: hasInitialTransition ? "initial" : "hidden", animate: "visible", exit: "hidden", transition: {
|
|
88
92
|
duration: TIMING_BASE,
|
|
89
93
|
delay: generateDelayTime(i),
|
|
90
94
|
} }, child)))));
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var AnimatedSwitcher = require('../AnimatedSwitcher-3d45ec5d.js');
|
|
6
|
+
require('react');
|
|
7
|
+
require('framer-motion');
|
|
8
|
+
require('../Icon-405a216c.js');
|
|
9
|
+
require('@jobber/design');
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
exports.AnimatedSwitcher = AnimatedSwitcher.AnimatedSwitcher;
|
|
@@ -2,7 +2,11 @@
|
|
|
2
2
|
|
|
3
3
|
var React = require('react');
|
|
4
4
|
var framerMotion = require('framer-motion');
|
|
5
|
-
var Icon = require('./Icon-
|
|
5
|
+
var Icon = require('./Icon-405a216c.js');
|
|
6
|
+
|
|
7
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
8
|
+
|
|
9
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
6
10
|
|
|
7
11
|
const DURATION_SIMPLE = 0.1;
|
|
8
12
|
const DURATION_AVERAGE = 0.2;
|
|
@@ -47,8 +51,8 @@ function AnimatedSwitcher({ initialChild, switched, switchTo, type = "slideFromB
|
|
|
47
51
|
const [ref, setRef] = React.useState(null);
|
|
48
52
|
const isSwitchingBetweenIcons = initialChild.type === Icon.Icon && switchTo.type === Icon.Icon;
|
|
49
53
|
const { key, transition, child, duration } = getChildData();
|
|
50
|
-
return (
|
|
51
|
-
|
|
54
|
+
return (React__default["default"].createElement(framerMotion.AnimatePresence, { mode: "wait", initial: false },
|
|
55
|
+
React__default["default"].createElement(framerMotion.motion.div, { ref: setRef, key: key, variants: transition, initial: "hidden", animate: "visible", exit: "hidden", transition: { duration }, style: { display: getDisplayValue() } }, child)));
|
|
52
56
|
function getDisplayValue() {
|
|
53
57
|
if (ref === null || ref === void 0 ? void 0 : ref.firstElementChild) {
|
|
54
58
|
return window.getComputedStyle(ref.firstElementChild).display;
|
|
@@ -86,7 +90,7 @@ function AnimatedSwitcher({ initialChild, switched, switchTo, type = "slideFromB
|
|
|
86
90
|
}
|
|
87
91
|
}
|
|
88
92
|
AnimatedSwitcher.Icon = function AnimatedSwitcherIcon({ switchToIcon, switched, initialIcon, }) {
|
|
89
|
-
return (
|
|
93
|
+
return (React__default["default"].createElement(AnimatedSwitcher, { switched: switched, initialChild: React__default["default"].createElement(Icon.Icon, { name: initialIcon }), switchTo: React__default["default"].createElement(Icon.Icon, { name: switchToIcon }) }));
|
|
90
94
|
};
|
|
91
95
|
|
|
92
96
|
exports.AnimatedSwitcher = AnimatedSwitcher;
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var tslib_es6 = require('../tslib.es6-754e2961.js');
|
|
6
|
+
var React = require('react');
|
|
7
|
+
var debounce = require('lodash/debounce');
|
|
8
|
+
var styleInject_es = require('../style-inject.es-9d2f5f4e.js');
|
|
9
|
+
var classnames = require('classnames');
|
|
10
|
+
var ReactDOM = require('react-dom');
|
|
11
|
+
var reactPopper = require('react-popper');
|
|
12
|
+
var useOnKeyDown = require('@jobber/hooks/useOnKeyDown');
|
|
13
|
+
var useSafeLayoutEffect = require('@jobber/hooks/useSafeLayoutEffect');
|
|
14
|
+
var useIsMounted = require('@jobber/hooks/useIsMounted');
|
|
15
|
+
var Text = require('../Text-fbeaaca6.js');
|
|
16
|
+
var Icon = require('../Icon-405a216c.js');
|
|
17
|
+
var Heading = require('../Heading-23d382a1.js');
|
|
18
|
+
var InputText = require('../InputText-130b0440.js');
|
|
19
|
+
require('../Typography-e2a23b7e.js');
|
|
20
|
+
require('@jobber/design');
|
|
21
|
+
require('../useAtlantisConfig-ed0bee66.js');
|
|
22
|
+
require('../FormField-f6fadff2.js');
|
|
23
|
+
require('react-hook-form');
|
|
24
|
+
require('@jobber/hooks/useShowClear');
|
|
25
|
+
require('../Button-6b922fc1.js');
|
|
26
|
+
require('react-router-dom');
|
|
27
|
+
require('../InputValidation-a92bb519.js');
|
|
28
|
+
require('framer-motion');
|
|
29
|
+
require('../Spinner-9d8fc7ff.js');
|
|
30
|
+
|
|
31
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
32
|
+
|
|
33
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
34
|
+
var debounce__default = /*#__PURE__*/_interopDefaultLegacy(debounce);
|
|
35
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
36
|
+
|
|
37
|
+
var css_248z = ".v0Cys9vQ-NE- {\n position: relative;\n width: 100%;\n}\n\n.CX-N-e0e6og- {\n display: none;\n position: absolute;\n z-index: calc(6 + 1001);\n z-index: calc(var(--elevation-menu) + var(--elevation-modal));\n width: 100%;\n /* Unfortunately this is how we define our line item picker height in jobber online.\n This is a concession to maintain visual parity. */\n max-height: 300px;\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 box-sizing: border-box;\n margin: 0;\n padding: 0;\n border: calc(16px / 16) solid var(--color-color-border);\n border: var(--border-base) solid var(--color-color-border);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n overflow: auto;\n scroll-behavior: smooth;\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n}\n\n.CX-N-e0e6og- h5 {\n padding: calc(16px / 2) 0 calc(16px / 4) calc(16px / 2);\n padding: var(--space-small) 0 var(--space-smaller) var(--space-small);\n border-bottom: calc(16px / 16) solid rgb(1, 41, 57);\n border-bottom: var(--border-base) solid var(--color-border--section);\n}\n\n.CX-N-e0e6og-._4PlUaegVpkk- {\n display: block;\n}\n\n.CX-N-e0e6og-._4PlUaegVpkk-:empty {\n display: none;\n}\n\n.ucQtG0iwqbo- {\n display: -ms-flexbox;\n display: flex;\n width: 100%;\n -ms-flex-direction: row;\n flex-direction: row;\n -ms-flex-wrap: nowrap;\n flex-wrap: nowrap;\n -ms-flex-pack: start;\n justify-content: flex-start;\n -ms-flex-line-pack: stretch;\n align-content: stretch;\n -ms-flex-align: center;\n align-items: center;\n padding: calc(16px / 2);\n padding: var(--space-small);\n border: none;\n text-align: left;\n list-style: none;\n background-color: transparent;\n cursor: pointer;\n transition: all 200ms;\n transition: all var(--timing-base);\n}\n\n.ucQtG0iwqbo-:hover,\n.ucQtG0iwqbo-:focus,\n.ucQtG0iwqbo-.r8HS-ma79QE- {\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.ucQtG0iwqbo-.ydwLX44YFZc-:not(:last-child) {\n border-bottom: calc(16px / 16) solid rgb(217, 223, 225);\n border-bottom: var(--border-base) solid var(--color-border);\n}\n\n.CX-N-e0e6og-:hover .ucQtG0iwqbo-.r8HS-ma79QE-:not(:hover) {\n background-color: transparent;\n outline-color: transparent;\n}\n\n.v0Cys9vQ-NE- .PvUgNoAUG7A-:not(:first-child) {\n padding-top: calc(16px / 2);\n padding-top: var(--space-small);\n}\n\n.ucQtG0iwqbo- .DAOOFUZ1BRM- {\n -ms-flex: 0 1 auto;\n flex: 0 1 auto;\n -ms-flex-item-align: auto;\n align-self: auto;\n width: calc(16px * 1.5);\n width: var(--space-large);\n}\n\n.ucQtG0iwqbo- .cjKJFup6hGY- {\n display: -ms-inline-flexbox;\n display: inline-flex;\n -ms-flex: 1 100%;\n flex: 1 100%;\n -ms-flex-wrap: wrap;\n flex-wrap: wrap;\n}\n\n.ucQtG0iwqbo- .hG5zNBuI2wA- {\n -ms-flex: 2;\n flex: 2;\n}\n\n.ucQtG0iwqbo- ._3CwjFCbhqi4- {\n -ms-flex: 1;\n flex: 1;\n -ms-flex-item-align: end;\n align-self: flex-end;\n text-align: right;\n}\n";
|
|
38
|
+
var styles = {"autocomplete":"v0Cys9vQ-NE-","options":"CX-N-e0e6og-","visible":"_4PlUaegVpkk-","option":"ucQtG0iwqbo-","active":"r8HS-ma79QE-","separator":"ydwLX44YFZc-","heading":"PvUgNoAUG7A-","icon":"DAOOFUZ1BRM-","text":"cjKJFup6hGY-","label":"hG5zNBuI2wA-","details":"_3CwjFCbhqi4-"};
|
|
39
|
+
styleInject_es.styleInject(css_248z);
|
|
40
|
+
|
|
41
|
+
var IndexChange;
|
|
42
|
+
(function (IndexChange) {
|
|
43
|
+
IndexChange[IndexChange["Previous"] = -1] = "Previous";
|
|
44
|
+
IndexChange[IndexChange["Next"] = 1] = "Next";
|
|
45
|
+
})(IndexChange || (IndexChange = {}));
|
|
46
|
+
// Adding useIsMounted is what tipped this to 13 statements.
|
|
47
|
+
// Any additions beyond useIsMounted should probably see this component refactored a bit
|
|
48
|
+
// eslint-disable-next-line max-statements
|
|
49
|
+
function Menu({ visible, options, selectedOption, onOptionSelect, attachTo, }) {
|
|
50
|
+
const [highlightedIndex, setHighlightedIndex] = React.useState(0);
|
|
51
|
+
const { menuRef, setMenuRef, styles: popperStyles, attributes, targetWidth, } = useRepositionMenu(attachTo, visible);
|
|
52
|
+
const detectSeparatorCondition = (option) => option.description || option.details;
|
|
53
|
+
const detectGroups = (option) => option.options;
|
|
54
|
+
const addSeparators = options.some(detectSeparatorCondition);
|
|
55
|
+
const initialHighlight = options.some(detectGroups) ? 1 : 0;
|
|
56
|
+
setupKeyListeners();
|
|
57
|
+
React.useEffect(() => setHighlightedIndex(initialHighlight), [options]);
|
|
58
|
+
const mounted = useIsMounted.useIsMounted();
|
|
59
|
+
const menu = (React__default["default"].createElement("div", Object.assign({ className: classnames__default["default"](styles.options, { [styles.visible]: visible }), ref: setMenuRef, style: Object.assign(Object.assign({}, popperStyles.popper), { width: targetWidth }) }, attributes.popper), options.map((option, index) => {
|
|
60
|
+
const optionClass = classnames__default["default"](styles.option, {
|
|
61
|
+
[styles.active]: index === highlightedIndex,
|
|
62
|
+
[styles.separator]: addSeparators,
|
|
63
|
+
});
|
|
64
|
+
if (isGroup(option)) {
|
|
65
|
+
return (React__default["default"].createElement("div", { key: option.label, className: styles.heading },
|
|
66
|
+
React__default["default"].createElement(Heading.Heading, { level: 5 }, option.label)));
|
|
67
|
+
}
|
|
68
|
+
return (React__default["default"].createElement("button", { className: optionClass, key: option.value, onMouseDown: onOptionSelect.bind(undefined, option) },
|
|
69
|
+
React__default["default"].createElement("div", { className: styles.icon }, isOptionSelected(selectedOption, option) && (React__default["default"].createElement(Icon.Icon, { name: "checkmark", size: "small" }))),
|
|
70
|
+
React__default["default"].createElement("div", { className: styles.text },
|
|
71
|
+
React__default["default"].createElement("div", { className: styles.label },
|
|
72
|
+
React__default["default"].createElement(Text.Text, null, option.label),
|
|
73
|
+
option.description !== undefined && (React__default["default"].createElement(Text.Text, { variation: "subdued" }, option.description))),
|
|
74
|
+
option.details !== undefined && (React__default["default"].createElement("div", { className: styles.details },
|
|
75
|
+
React__default["default"].createElement(Text.Text, null, option.details))))));
|
|
76
|
+
})));
|
|
77
|
+
return mounted.current ? ReactDOM.createPortal(menu, document.body) : menu;
|
|
78
|
+
function setupKeyListeners() {
|
|
79
|
+
React.useEffect(() => {
|
|
80
|
+
var _a, _b;
|
|
81
|
+
(_b = (_a = menuRef === null || menuRef === void 0 ? void 0 : menuRef.children[highlightedIndex]) === null || _a === void 0 ? void 0 : _a.scrollIntoView) === null || _b === void 0 ? void 0 : _b.call(_a, {
|
|
82
|
+
behavior: "smooth",
|
|
83
|
+
block: "nearest",
|
|
84
|
+
inline: "start",
|
|
85
|
+
});
|
|
86
|
+
}, [highlightedIndex]);
|
|
87
|
+
useOnKeyDown.useOnKeyDown((event) => {
|
|
88
|
+
const indexChange = arrowKeyPress(event, IndexChange.Next);
|
|
89
|
+
if (indexChange) {
|
|
90
|
+
setHighlightedIndex(Math.min(options.length - 1, highlightedIndex + indexChange));
|
|
91
|
+
}
|
|
92
|
+
}, "ArrowDown");
|
|
93
|
+
useOnKeyDown.useOnKeyDown((event) => {
|
|
94
|
+
const indexChange = arrowKeyPress(event, IndexChange.Previous);
|
|
95
|
+
if (indexChange) {
|
|
96
|
+
setHighlightedIndex(Math.max(0, highlightedIndex + indexChange));
|
|
97
|
+
}
|
|
98
|
+
}, "ArrowUp");
|
|
99
|
+
useOnKeyDown.useOnKeyDown((event) => {
|
|
100
|
+
if (!visible)
|
|
101
|
+
return;
|
|
102
|
+
if (isGroup(options[highlightedIndex]))
|
|
103
|
+
return;
|
|
104
|
+
event.preventDefault();
|
|
105
|
+
onOptionSelect(options[highlightedIndex]);
|
|
106
|
+
}, "Enter");
|
|
107
|
+
}
|
|
108
|
+
function arrowKeyPress(event, direction) {
|
|
109
|
+
if (!visible)
|
|
110
|
+
return;
|
|
111
|
+
event.preventDefault();
|
|
112
|
+
const requestedIndex = options[highlightedIndex + direction];
|
|
113
|
+
return requestedIndex && isGroup(requestedIndex)
|
|
114
|
+
? direction + direction
|
|
115
|
+
: direction;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
function isOptionSelected(selectedOption, option) {
|
|
119
|
+
return selectedOption && selectedOption.value === option.value;
|
|
120
|
+
}
|
|
121
|
+
function isGroup(option) {
|
|
122
|
+
if (option.options)
|
|
123
|
+
return true;
|
|
124
|
+
return false;
|
|
125
|
+
}
|
|
126
|
+
function useRepositionMenu(attachTo, visible = false) {
|
|
127
|
+
var _a;
|
|
128
|
+
const [menuRef, setMenuRef] = React.useState();
|
|
129
|
+
const popper = reactPopper.usePopper(attachTo.current, menuRef, {
|
|
130
|
+
modifiers: [
|
|
131
|
+
{ name: "offset", options: { offset: [0, 8] } },
|
|
132
|
+
{ name: "flip", options: { fallbackPlacements: ["top"] } },
|
|
133
|
+
],
|
|
134
|
+
});
|
|
135
|
+
useSafeLayoutEffect.useSafeLayoutEffect(() => {
|
|
136
|
+
var _a;
|
|
137
|
+
(_a = popper === null || popper === void 0 ? void 0 : popper.update) === null || _a === void 0 ? void 0 : _a.call(popper);
|
|
138
|
+
}, [visible]);
|
|
139
|
+
const targetWidth = (_a = attachTo.current) === null || _a === void 0 ? void 0 : _a.clientWidth;
|
|
140
|
+
return Object.assign(Object.assign({}, popper), { menuRef, setMenuRef, targetWidth });
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// Max statements increased to make room for the debounce functions
|
|
144
|
+
/* eslint max-statements: ["error", 14] */
|
|
145
|
+
function AutocompleteInternal(_a, ref) {
|
|
146
|
+
var _b;
|
|
147
|
+
var { initialOptions = [], value, allowFreeForm = true, size = undefined, debounce: debounceRate = 300, onChange, getOptions, placeholder, onBlur, onFocus, validations } = _a, inputProps = tslib_es6.__rest(_a, ["initialOptions", "value", "allowFreeForm", "size", "debounce", "onChange", "getOptions", "placeholder", "onBlur", "onFocus", "validations"]);
|
|
148
|
+
const [options, setOptions] = React.useState(initialOptions);
|
|
149
|
+
const [menuVisible, setMenuVisible] = React.useState(false);
|
|
150
|
+
const [inputText, setInputText] = React.useState((_b = value === null || value === void 0 ? void 0 : value.label) !== null && _b !== void 0 ? _b : "");
|
|
151
|
+
const autocompleteRef = React.useRef(null);
|
|
152
|
+
const delayedSearch = debounce__default["default"](updateSearch, debounceRate);
|
|
153
|
+
React.useEffect(() => {
|
|
154
|
+
delayedSearch();
|
|
155
|
+
return delayedSearch.cancel;
|
|
156
|
+
}, [inputText]);
|
|
157
|
+
React.useEffect(() => {
|
|
158
|
+
var _a;
|
|
159
|
+
updateInput((_a = value === null || value === void 0 ? void 0 : value.label) !== null && _a !== void 0 ? _a : "");
|
|
160
|
+
}, [value]);
|
|
161
|
+
return (React__default["default"].createElement("div", { className: styles.autocomplete, ref: autocompleteRef },
|
|
162
|
+
React__default["default"].createElement(InputText.InputText, Object.assign({ ref: ref, autocomplete: false, size: size, value: inputText, onChange: handleInputChange, placeholder: placeholder, onFocus: handleInputFocus, onBlur: handleInputBlur, validations: validations }, inputProps)),
|
|
163
|
+
menuVisible && (React__default["default"].createElement(Menu, { attachTo: autocompleteRef, visible: menuVisible && options.length > 0, options: options, selectedOption: value, onOptionSelect: handleMenuChange }))));
|
|
164
|
+
function updateInput(newText) {
|
|
165
|
+
setInputText(newText);
|
|
166
|
+
if (newText === "") {
|
|
167
|
+
setOptions(mapToOptions(initialOptions));
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
function updateSearch() {
|
|
171
|
+
return tslib_es6.__awaiter(this, void 0, void 0, function* () {
|
|
172
|
+
const updatedOptions = yield getOptions(inputText);
|
|
173
|
+
const filteredOptions = updatedOptions.filter((option) => "options" in option && option.options ? option.options.length > 0 : true);
|
|
174
|
+
setOptions(mapToOptions(filteredOptions));
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
function handleMenuChange(chosenOption) {
|
|
178
|
+
onChange(chosenOption);
|
|
179
|
+
updateInput(chosenOption.label);
|
|
180
|
+
setMenuVisible(false);
|
|
181
|
+
}
|
|
182
|
+
function handleInputChange(newText) {
|
|
183
|
+
updateInput(newText);
|
|
184
|
+
if (allowFreeForm) {
|
|
185
|
+
onChange({ label: newText });
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
function handleInputBlur() {
|
|
189
|
+
setMenuVisible(false);
|
|
190
|
+
if (value == undefined || value.label !== inputText) {
|
|
191
|
+
setInputText("");
|
|
192
|
+
onChange(undefined);
|
|
193
|
+
}
|
|
194
|
+
onBlur && onBlur();
|
|
195
|
+
}
|
|
196
|
+
function handleInputFocus() {
|
|
197
|
+
setMenuVisible(true);
|
|
198
|
+
if (onFocus) {
|
|
199
|
+
onFocus();
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
function mapToOptions(items) {
|
|
204
|
+
return items.reduce(function (result, item) {
|
|
205
|
+
result = result.concat([item]);
|
|
206
|
+
if (item.options) {
|
|
207
|
+
result = result.concat(item.options);
|
|
208
|
+
}
|
|
209
|
+
return result;
|
|
210
|
+
}, []);
|
|
211
|
+
}
|
|
212
|
+
const Autocomplete = React.forwardRef(AutocompleteInternal);
|
|
213
|
+
|
|
214
|
+
exports.Autocomplete = Autocomplete;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var Avatar = require('../Avatar-76a799fa.js');
|
|
6
|
+
require('react');
|
|
7
|
+
require('classnames');
|
|
8
|
+
require('../style-inject.es-9d2f5f4e.js');
|
|
9
|
+
require('color');
|
|
10
|
+
require('../Icon-405a216c.js');
|
|
11
|
+
require('@jobber/design');
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
exports.Avatar = Avatar.Avatar;
|
|
@@ -0,0 +1,78 @@
|
|
|
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
|
+
var Color = require('color');
|
|
7
|
+
var Icon = require('./Icon-405a216c.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);
|
|
12
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
13
|
+
var Color__default = /*#__PURE__*/_interopDefaultLegacy(Color);
|
|
14
|
+
|
|
15
|
+
var css_248z = ":root {\n --avatar-size: calc(var(--base-unit) * 2);\n --avatar-border-size: var(--border-base);\n}\n\n.WniTNadEyPk- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex-align: center;\n align-items: center;\n -ms-flex-pack: center;\n justify-content: center;\n width: calc(16px * 2);\n width: var(--avatar-size);\n height: calc(16px * 2);\n height: var(--avatar-size);\n min-width: calc(16px * 2);\n min-width: var(--avatar-size);\n min-height: calc(16px * 2);\n min-height: var(--avatar-size);\n border-radius: 100%;\n border-radius: var(--radius-circle);\n color: rgb(1, 41, 57);\n color: var(--color-heading);\n font-size: calc(16px * 2);\n font-size: var(--avatar-size);\n -webkit-font-smoothing: antialiased;\n background: no-repeat center center rgba(101, 120, 132, 1);\n background: no-repeat center center var(--color-greyBlue);\n background-size: cover;\n}\n\n.WniTNadEyPk-:focus {\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._8Pqn2uZpaZg- {\n --avatar-size: calc(var(--base-unit) * 4.5);\n --avatar-border-size: var(--border-thick);\n}\n\n.S-edTXYA-7E- {\n --avatar-size: calc(var(--base-unit) * 1.5);\n}\n\n.S1iBGElfOUA- {\n color: rgba(255, 255, 255, 1);\n color: var(--color-text--reverse);\n}\n\n.ErPhpHHpiBQ- {\n font-size: calc((16px * 2) / 2);\n font-size: calc(calc(16px * 2) / 2);\n font-size: calc(var(--avatar-size) / 2);\n text-transform: uppercase;\n}\n\n.aC-d-mngrIc- {\n font-size: calc((16px * 2) / 2.25);\n font-size: calc(calc(16px * 2) / 2.25);\n font-size: calc(var(--avatar-size) / 2.25);\n}\n\n.nR0S-GzjDnQ- {\n width: calc((16px * 2) - (calc(16px / 16) * 2));\n width: calc(calc(16px * 2) - (calc(16px / 16) * 2));\n width: calc(var(--avatar-size) - (var(--avatar-border-size) * 2));\n height: calc((16px * 2) - (calc(16px / 16) * 2));\n height: calc(calc(16px * 2) - (calc(16px / 16) * 2));\n height: calc(var(--avatar-size) - (var(--avatar-border-size) * 2));\n box-shadow: 0 0 0 calc(16px / 8) rgba(255, 255, 255, 1) inset;\n box-shadow: 0 0 0 var(--border-thick) var(--color-white) inset;\n border-style: solid;\n border-width: calc(16px / 16);\n border-width: var(--avatar-border-size);\n}\n";
|
|
16
|
+
var styles = {"avatar":"WniTNadEyPk-","large":"_8Pqn2uZpaZg-","small":"S-edTXYA-7E-","isDark":"S1iBGElfOUA-","initials":"ErPhpHHpiBQ-","smallInitials":"aC-d-mngrIc-","hasBorder":"nR0S-GzjDnQ-"};
|
|
17
|
+
styleInject_es.styleInject(css_248z);
|
|
18
|
+
|
|
19
|
+
function isDark(colorToCheck) {
|
|
20
|
+
if (colorToCheck == undefined) {
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
if (colorToCheck) {
|
|
24
|
+
try {
|
|
25
|
+
return Color__default["default"](deconstructCssCustomProperty(colorToCheck)).isDark();
|
|
26
|
+
}
|
|
27
|
+
catch (err) {
|
|
28
|
+
console.log(err);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
function deconstructCssCustomProperty(color) {
|
|
34
|
+
if (!color) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
if (!color.toLowerCase().startsWith("var(")) {
|
|
38
|
+
return color;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Rips apart the `var(--custom-property)` into just `--custom-property`.
|
|
42
|
+
*/
|
|
43
|
+
const customProperty = color
|
|
44
|
+
.replace("var(", "")
|
|
45
|
+
.slice(0, -1)
|
|
46
|
+
.split(" ")
|
|
47
|
+
.join("");
|
|
48
|
+
return getComputedStyle(document.documentElement)
|
|
49
|
+
.getPropertyValue(customProperty)
|
|
50
|
+
.trim();
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
function Avatar({ imageUrl, name, initials, size = "base", color, }) {
|
|
54
|
+
const style = {
|
|
55
|
+
backgroundColor: color,
|
|
56
|
+
borderColor: color,
|
|
57
|
+
};
|
|
58
|
+
if (imageUrl) {
|
|
59
|
+
style.backgroundImage = `url(${imageUrl})`;
|
|
60
|
+
}
|
|
61
|
+
const shouldBeDark = color == undefined || isDark(color);
|
|
62
|
+
const className = classnames__default["default"](styles.avatar, size !== "base" && styles[size], {
|
|
63
|
+
[styles.hasBorder]: imageUrl && color,
|
|
64
|
+
[styles.isDark]: shouldBeDark,
|
|
65
|
+
});
|
|
66
|
+
return (React__default["default"].createElement("div", { className: className, style: style, role: imageUrl && "img", "aria-label": name }, !imageUrl && (React__default["default"].createElement(Initials, { initials: initials, dark: shouldBeDark, iconSize: size }))));
|
|
67
|
+
}
|
|
68
|
+
function Initials({ initials, dark = false, iconSize = "base", }) {
|
|
69
|
+
if (!initials) {
|
|
70
|
+
return (React__default["default"].createElement(Icon.Icon, { name: "person", color: dark ? "white" : "blue", size: iconSize }));
|
|
71
|
+
}
|
|
72
|
+
const className = classnames__default["default"](styles.initials, {
|
|
73
|
+
[styles.smallInitials]: initials.length > 2,
|
|
74
|
+
});
|
|
75
|
+
return React__default["default"].createElement("span", { className: className }, initials.substr(0, 3));
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
exports.Avatar = Avatar;
|
|
@@ -0,0 +1,111 @@
|
|
|
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 useAtlantisConfig = require('../useAtlantisConfig-ed0bee66.js');
|
|
10
|
+
var Icon = require('../Icon-405a216c.js');
|
|
11
|
+
var Text = require('../Text-fbeaaca6.js');
|
|
12
|
+
var Button = require('../Button-6b922fc1.js');
|
|
13
|
+
require('@jobber/hooks/useSafeLayoutEffect');
|
|
14
|
+
require('@jobber/design');
|
|
15
|
+
require('../Typography-e2a23b7e.js');
|
|
16
|
+
require('react-router-dom');
|
|
17
|
+
|
|
18
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
19
|
+
|
|
20
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
21
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
22
|
+
|
|
23
|
+
var css_248z$2 = ".meuT8gYQPJU- {\n display: -ms-flexbox;\n display: flex;\n position: relative;\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: calc(16px * 1);\n padding: var(--space-base);\n color: rgb(66, 78, 86);\n color: var(--color-text);\n background-color: rgb(238, 240, 242);\n background-color: var(--color-surface--background);\n gap: calc(16px / 2);\n gap: var(--space-small);\n -ms-flex-align: center;\n align-items: center;\n}\n\n.jobber-retheme .meuT8gYQPJU- {\n padding: calc((16px * 1) - (16px / 4)) calc(16px * 1);\n padding: calc(calc(16px * 1) - calc(16px / 4)) calc(16px * 1);\n padding: calc(var(--space-base) - var(--space-smaller)) var(--space-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 background-color: rgba(255, 255, 255, 1);\n background-color: var(--color-surface);\n}\n\n.y4BapyZr-fo- > a {\n color: rgb(66, 78, 86);\n color: var(--color-text);\n}\n\n.y4BapyZr-fo- > a:hover {\n color: rgb(1, 41, 57);\n color: var(--color-blue);\n}\n\n._6v1woNSLEvc- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex: 1 1 auto;\n flex: 1 1 auto;\n gap: calc(16px / 2);\n gap: var(--space-small);\n -ms-flex-wrap: nowrap;\n flex-wrap: nowrap;\n -ms-flex-pack: justify;\n justify-content: space-between;\n -ms-flex-align: start;\n align-items: flex-start;\n}\n\n@media (max-width: 489px) {\n\n._6v1woNSLEvc- {\n -ms-flex-wrap: wrap;\n flex-wrap: wrap;\n}\n }\n\n@media (--small-screens-and-below) {\n\n._6v1woNSLEvc- {\n -ms-flex-wrap: wrap;\n flex-wrap: wrap;\n}\n }\n\n.y4BapyZr-fo- {\n -ms-flex: 1;\n flex: 1;\n -ms-flex-item-align: center;\n align-self: center;\n}\n\n._6v1woNSLEvc- > *:last-child {\n margin-bottom: 0;\n}\n\n.bocgLmEhcTU- .y4BapyZr-fo- {\n -ms-flex: 1;\n flex: 1;\n}\n\n.rtNjEzmABX4- {\n display: -ms-flexbox;\n display: flex;\n -ms-flex: 0 0 auto;\n flex: 0 0 auto;\n}\n\n@media (max-width: 489px) {\n\n.rtNjEzmABX4- {\n width: 100%;\n margin-top: calc(16px / 2);\n margin-top: var(--space-small);\n}\n }\n\n@media (--small-screens-and-below) {\n\n.rtNjEzmABX4- {\n width: 100%;\n margin-top: calc(16px / 2);\n margin-top: var(--space-small);\n}\n }\n\n.lunQ5SOfyLg- {\n margin: calc((16px / 8) * -1) 0;\n margin: calc(calc(16px / 8) * -1) 0;\n margin: calc(var(--space-smallest) * -1) 0;\n padding: calc(16px / 8);\n padding: var(--space-smallest);\n border: none;\n background-color: transparent;\n cursor: pointer;\n -webkit-appearance: none;\n appearance: none;\n -ms-flex: 0;\n flex: 0;\n -ms-flex-item-align: start;\n align-self: flex-start;\n}\n\n.lunQ5SOfyLg-:hover {\n background: rgba(0, 0, 0, 0.025);\n}\n\n.lunQ5SOfyLg-:focus {\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 background: rgba(0, 0, 0, 0.05);\n}\n\n.SG8xSJADp2k- {\n display: -ms-inline-flexbox;\n display: inline-flex;\n padding: calc(16px / 4);\n padding: var(--space-smaller);\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}\n\n.jobber-retheme .bocgLmEhcTU- .SG8xSJADp2k- {\n -ms-flex-item-align: center;\n align-self: center;\n}\n";
|
|
24
|
+
var styles = {"banner":"meuT8gYQPJU-","bannerChildren":"y4BapyZr-fo-","bannerContent":"_6v1woNSLEvc-","medium":"bocgLmEhcTU-","bannerAction":"rtNjEzmABX4-","closeButton":"lunQ5SOfyLg-","iconWrapper":"SG8xSJADp2k-"};
|
|
25
|
+
styleInject_es.styleInject(css_248z$2);
|
|
26
|
+
|
|
27
|
+
var css_248z$1 = ".wWW-2T7rCV0- {\n background-color: rgb(226, 241, 250);\n background-color: var(--color-informative--surface);\n}\n\n/* Our Banner \"surface\" colors should be lighter than they are so we're leaving the following alone for now */\n\n._7h8FUHIkVjg- {\n background-color: rgb(203, 223, 159);\n background-color: var(--color-green--lighter);\n}\n\n.d5fXcE1L0lc- {\n background-color: rgb(241, 231, 159);\n background-color: var(--color-yellow--lighter);\n}\n\n.oYaw-T3c0IU- {\n background-color: rgb(255, 206, 194);\n background-color: var(--color-red--lighter);\n}\n";
|
|
28
|
+
var types = {"notice":"wWW-2T7rCV0-","success":"_7h8FUHIkVjg-","warning":"d5fXcE1L0lc-","error":"oYaw-T3c0IU-"};
|
|
29
|
+
styleInject_es.styleInject(css_248z$1);
|
|
30
|
+
|
|
31
|
+
var css_248z = "._5-B0X5vn0eA- {\n background-color: rgb(125, 176, 14);\n background-color: var(--color-success);\n}\n\n.r3hqur-vxwI- {\n background-color: rgb(201, 66, 33);\n background-color: var(--color-destructive);\n}\n\n.-c8TbjyV5YU- {\n background-color: rgb(221, 195, 15);\n background-color: var(--color-warning);\n}\n\n.bMc69fYWngM- {\n background-color: rgb(60, 162, 224);\n background-color: var(--color-informative);\n}\n";
|
|
32
|
+
var iconStyles = {"success":"_5-B0X5vn0eA-","error":"r3hqur-vxwI-","warning":"-c8TbjyV5YU-","notice":"bMc69fYWngM-"};
|
|
33
|
+
styleInject_es.styleInject(css_248z);
|
|
34
|
+
|
|
35
|
+
function BannerIcon({ icon, type }) {
|
|
36
|
+
const { JOBBER_RETHEME } = useAtlantisConfig.useAtlantisConfig();
|
|
37
|
+
if (JOBBER_RETHEME) {
|
|
38
|
+
return (React__default["default"].createElement("span", { className: classnames__default["default"](styles.iconWrapper, iconStyles[type]) },
|
|
39
|
+
React__default["default"].createElement(Icon.Icon, { name: icon, color: "white", size: "small" })));
|
|
40
|
+
}
|
|
41
|
+
return React__default["default"].createElement(Icon.Icon, { name: icon, color: "greyBlueDark" });
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
function Banner({ children, type, primaryAction, dismissible = true, icon, onDismiss, }) {
|
|
45
|
+
const { JOBBER_RETHEME } = useAtlantisConfig.useAtlantisConfig();
|
|
46
|
+
const [showBanner, setShowBanner] = React.useState(true);
|
|
47
|
+
const bannerIcon = icon || getBannerIcon(type);
|
|
48
|
+
const bannerWidths = {
|
|
49
|
+
small: 320,
|
|
50
|
+
medium: 480,
|
|
51
|
+
};
|
|
52
|
+
const [bannerRef, { width: bannerWidth = bannerWidths.small }] = jobberHooks.useResizeObserver({
|
|
53
|
+
widths: bannerWidths,
|
|
54
|
+
});
|
|
55
|
+
const iconColors = {
|
|
56
|
+
notice: "informative",
|
|
57
|
+
success: "success",
|
|
58
|
+
warning: "warning",
|
|
59
|
+
error: "critical",
|
|
60
|
+
};
|
|
61
|
+
if (primaryAction != undefined) {
|
|
62
|
+
primaryAction = Object.assign({
|
|
63
|
+
size: "small",
|
|
64
|
+
type: "tertiary",
|
|
65
|
+
variation: type === "notice" ? "learning" : "work",
|
|
66
|
+
}, primaryAction);
|
|
67
|
+
}
|
|
68
|
+
const bannerClassNames = classnames__default["default"](styles.banner, types[type], {
|
|
69
|
+
[styles.medium]: bannerWidth >= bannerWidths.medium,
|
|
70
|
+
});
|
|
71
|
+
if (!showBanner)
|
|
72
|
+
return null;
|
|
73
|
+
return (React__default["default"].createElement("div", { className: bannerClassNames, ref: bannerRef, role: type === "error" ? "alert" : "status" },
|
|
74
|
+
React__default["default"].createElement("div", { className: styles.bannerContent },
|
|
75
|
+
bannerIcon && React__default["default"].createElement(BannerIcon, { icon: bannerIcon, type: type }),
|
|
76
|
+
React__default["default"].createElement("div", { className: styles.bannerChildren },
|
|
77
|
+
React__default["default"].createElement(BannerChildren, null, children)),
|
|
78
|
+
primaryAction && (React__default["default"].createElement("div", { className: styles.bannerAction },
|
|
79
|
+
React__default["default"].createElement(Button.Button, Object.assign({}, primaryAction))))),
|
|
80
|
+
dismissible && (React__default["default"].createElement("button", { type: "button", className: styles.closeButton, onClick: handleClose, "aria-label": "Close this notification" },
|
|
81
|
+
React__default["default"].createElement(Icon.Icon, { name: "cross", color: JOBBER_RETHEME ? "interactiveSubtle" : iconColors[type] })))));
|
|
82
|
+
function handleClose() {
|
|
83
|
+
setShowBanner(!showBanner);
|
|
84
|
+
onDismiss && onDismiss();
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
function getBannerIcon(type) {
|
|
88
|
+
const { JOBBER_RETHEME } = useAtlantisConfig.useAtlantisConfig();
|
|
89
|
+
if (!JOBBER_RETHEME)
|
|
90
|
+
return;
|
|
91
|
+
switch (type) {
|
|
92
|
+
case "notice":
|
|
93
|
+
return "starburst";
|
|
94
|
+
case "success":
|
|
95
|
+
return "checkmark";
|
|
96
|
+
case "warning":
|
|
97
|
+
return "help";
|
|
98
|
+
case "error":
|
|
99
|
+
return "alert";
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
function BannerChildren({ children, }) {
|
|
103
|
+
if (!children)
|
|
104
|
+
return React__default["default"].createElement(React__default["default"].Fragment, null);
|
|
105
|
+
if (children && typeof children === "string") {
|
|
106
|
+
return React__default["default"].createElement(Text.Text, null, children);
|
|
107
|
+
}
|
|
108
|
+
return React__default["default"].createElement(React__default["default"].Fragment, null, children);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
exports.Banner = Banner;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var Button = require('../Button-6b922fc1.js');
|
|
6
|
+
require('react');
|
|
7
|
+
require('classnames');
|
|
8
|
+
require('react-router-dom');
|
|
9
|
+
require('../style-inject.es-9d2f5f4e.js');
|
|
10
|
+
require('../Icon-405a216c.js');
|
|
11
|
+
require('@jobber/design');
|
|
12
|
+
require('../Typography-e2a23b7e.js');
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
exports.Button = Button.Button;
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var classnames = require('classnames');
|
|
5
|
+
var reactRouterDom = require('react-router-dom');
|
|
6
|
+
var styleInject_es = require('./style-inject.es-9d2f5f4e.js');
|
|
7
|
+
var Icon = require('./Icon-405a216c.js');
|
|
8
|
+
var Typography = require('./Typography-e2a23b7e.js');
|
|
9
|
+
|
|
10
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
11
|
+
|
|
12
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
13
|
+
var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
|
|
14
|
+
|
|
15
|
+
var css_248z = ":root {\n --button--color-variation: var(--color-interactive);\n --button--color-variation--hover: var(--color-interactive--hover);\n --button--color-surface: var(--color-surface);\n --button--color-surface--hover: var(--color-surface--hover);\n --button--color-primaryLabel: var(--color-surface);\n\n --button--duration-loading: var(--timing-loading--extended);\n}\n\n.U9VsquOtk2I- {\n display: -ms-inline-flexbox;\n display: inline-flex;\n min-height: calc(16px * 2.25);\n min-height: calc(var(--base-unit) * 2.25);\n box-sizing: border-box;\n margin: 0;\n border: calc(16px / 16) solid rgb(125, 176, 14);\n border: var(--border-base) solid var(--button--color-variation);\n border-radius: calc(16px / 8);\n border-radius: var(--radius-base);\n color: rgb(125, 176, 14);\n color: var(--button--color-variation);\n -webkit-font-smoothing: antialiased;\n letter-spacing: calc(16px / 40);\n letter-spacing: var(--typography--letterSpacing-loose);\n text-align: center;\n -webkit-text-decoration: none;\n text-decoration: none;\n vertical-align: middle;\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--button--color-surface);\n cursor: pointer;\n transition: all 200ms ease-out;\n transition: all var(--timing-base) ease-out;\n -webkit-appearance: none;\n appearance: none;\n fill: rgb(125, 176, 14);\n fill: var(--button--color-variation);\n -ms-flex-align: center;\n align-items: center;\n -ms-flex-pack: center;\n justify-content: center;\n}\n\n.jobber-retheme .U9VsquOtk2I- {\n min-height: calc(16px * 2.5);\n min-height: calc(var(--base-unit) * 2.5);\n}\n\n.U9VsquOtk2I- * {\n fill: inherit !important;\n}\n\n.U9VsquOtk2I- * {\n color: inherit;\n /* required to over-ride very specific fill from <Icon> */\n}\n\n.jobber-retheme .U9VsquOtk2I- * {\n font-weight: 600 !important;\n}\n\n.jobber-retheme .U9VsquOtk2I- * {\n line-height: 1;\n letter-spacing: 0;\n /* post-retheme this can move into the TSX on L177 */\n}\n\n.U9VsquOtk2I-:hover,\na.U9VsquOtk2I-:hover,\n.U9VsquOtk2I-:focus-visible,\na.U9VsquOtk2I-:focus-visible,\n.U9VsquOtk2I-:active,\na.U9VsquOtk2I-:active {\n border-color: rgb(81, 114, 9);\n border-color: var(--button--color-variation--hover);\n color: rgb(81, 114, 9);\n color: var(--button--color-variation--hover);\n fill: rgb(81, 114, 9);\n fill: var(--button--color-variation--hover);\n background-color: rgb(244, 246, 250);\n background-color: var(--button--color-surface--hover);\n}\n\n.U9VsquOtk2I-:focus-visible,\na.U9VsquOtk2I-:focus-visible,\n.U9VsquOtk2I-:active,\na.U9VsquOtk2I-:active {\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: transparent;\n}\n\n/* Variation */\n\n.qkFQwI0PKfw- {\n --button--color-variation: var(--color-interactive);\n --button--color-variation--hover: var(--color-interactive--hover);\n}\n\n.jsKQEOBdJ0k- {\n --button--color-variation: var(--color-informative);\n --button--color-variation--hover: var(--color-informative--onSurface);\n}\n\n.jobber-retheme .jsKQEOBdJ0k- {\n --button--color-variation: var(--color-interactive--subtle);\n --button--color-variation--hover: var(--color-interactive--subtle--hover);\n}\n\n._4W8X0dxZDK4- {\n --button--color-variation: var(--color-destructive);\n --button--color-variation--hover: var(--color-destructive--hover);\n}\n\n/* Subtle is special because, by default, it's styled as a secondary button */\n\n.vDKO-cmh8vY- {\n --button--color-variation: var(--color-interactive--subtle);\n --button--color-variation--hover: var(--color-interactive--subtle--hover);\n}\n\n/* Type */\n\n.FXqN12jWtPo-:not(.vDKO-cmh8vY-):not(.bg-l22drjd0-),\n.FXqN12jWtPo-:not(.vDKO-cmh8vY-):not(.bg-l22drjd0-):hover,\n.FXqN12jWtPo-:not(.vDKO-cmh8vY-):not(.bg-l22drjd0-):focus-visible {\n color: rgba(255, 255, 255, 1);\n color: var(--button--color-primaryLabel);\n background-color: rgb(125, 176, 14);\n background-color: var(--button--color-variation);\n fill: rgba(255, 255, 255, 1);\n fill: var(--button--color-primaryLabel);\n}\n\n.FXqN12jWtPo-:not(.vDKO-cmh8vY-):not(.bg-l22drjd0-):hover,\n.FXqN12jWtPo-:not(.vDKO-cmh8vY-):not(.bg-l22drjd0-):focus-visible {\n background-color: rgb(81, 114, 9);\n background-color: var(--button--color-variation--hover);\n}\n\n.vDKO-cmh8vY-.FXqN12jWtPo- {\n color: rgb(125, 176, 14);\n color: var(--button--color-variation);\n fill: rgb(125, 176, 14);\n fill: var(--button--color-variation);\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--button--color-surface);\n}\n\n.pf6G840lKdA-,\n.vDKO-cmh8vY-.FXqN12jWtPo- {\n border-color: rgb(125, 176, 14);\n border-color: var(--button--color-variation);\n}\n\n.jobber-retheme .pf6G840lKdA-,\n.jobber-retheme .vDKO-cmh8vY-.FXqN12jWtPo- {\n border-color: rgb(217, 223, 225);\n border-color: var(--color-border);\n}\n\n.vDKO-cmh8vY-.FXqN12jWtPo-:hover,\n.vDKO-cmh8vY-.FXqN12jWtPo-:focus-visible {\n color: rgb(81, 114, 9);\n color: var(--button--color-variation--hover);\n background-color: rgb(244, 246, 250);\n background-color: var(--button--color-surface--hover);\n fill: rgb(81, 114, 9);\n fill: var(--button--color-variation--hover);\n}\n\n.jobber-retheme .pf6G840lKdA-:hover,\n.jobber-retheme .vDKO-cmh8vY-.FXqN12jWtPo-:hover,\n.jobber-retheme .pf6G840lKdA-:focus-visible,\n.jobber-retheme .vDKO-cmh8vY-.FXqN12jWtPo-:focus-visible {\n border-color: rgb(81, 114, 9);\n border-color: var(--button--color-variation--hover);\n}\n\n.vDKO-cmh8vY-.pf6G840lKdA- {\n background-color: rgba(255, 255, 255, 1);\n background-color: var(--button--color-surface);\n}\n\n.m7DbwRZWcNk-,\n.vDKO-cmh8vY-.pf6G840lKdA- {\n border-color: transparent;\n}\n\n.jobber-retheme .m7DbwRZWcNk- {\n border-color: rgb(217, 223, 225);\n border-color: var(--color-border);\n}\n\n.vDKO-cmh8vY-.pf6G840lKdA-:hover,\n.vDKO-cmh8vY-.pf6G840lKdA-:focus-visible {\n background-color: rgb(244, 246, 250);\n background-color: var(--button--color-surface--hover);\n}\n\n.m7DbwRZWcNk-:hover,\n.m7DbwRZWcNk-:focus-visible,\na.m7DbwRZWcNk-:hover,\na.m7DbwRZWcNk-:focus-visible,\n.vDKO-cmh8vY-.pf6G840lKdA-:hover,\n.vDKO-cmh8vY-.pf6G840lKdA-:focus-visible,\na.vDKO-cmh8vY-.pf6G840lKdA-:hover,\na.vDKO-cmh8vY-.pf6G840lKdA-:focus-visible {\n border-color: transparent;\n}\n\n.jobber-retheme .m7DbwRZWcNk-:hover,\n.jobber-retheme .m7DbwRZWcNk-:focus-visible,\n.jobber-retheme a.m7DbwRZWcNk-:hover,\n.jobber-retheme a.m7DbwRZWcNk-:focus-visible {\n border-color: rgb(81, 114, 9);\n border-color: var(--button--color-variation--hover);\n}\n\n.vDKO-cmh8vY-.m7DbwRZWcNk- {\n border-color: transparent;\n background-color: transparent;\n}\n\n.vDKO-cmh8vY-.m7DbwRZWcNk-:hover,\n.vDKO-cmh8vY-.m7DbwRZWcNk-:focus-visible,\na.vDKO-cmh8vY-.m7DbwRZWcNk-:hover,\na.vDKO-cmh8vY-.m7DbwRZWcNk-:focus-visible {\n border-color: transparent;\n color: rgb(66, 78, 86);\n color: var(--color-interactive--subtle--hover);\n fill: rgb(66, 78, 86);\n fill: var(--color-interactive--subtle--hover);\n}\n\n/* Disabled */\n\n.U9VsquOtk2I-.bg-l22drjd0-,\na.U9VsquOtk2I-.bg-l22drjd0-,\n.U9VsquOtk2I-.bg-l22drjd0-:hover,\na.U9VsquOtk2I-.bg-l22drjd0-:hover {\n border-color: rgb(225, 225, 225);\n border-color: var(--color-disabled--secondary);\n color: rgb(181, 181, 181);\n color: var(--color-disabled);\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none;\n background-color: rgb(225, 225, 225);\n background-color: var(--color-disabled--secondary);\n fill: rgb(181, 181, 181);\n fill: var(--color-disabled);\n pointer-events: none;\n cursor: not-allowed;\n}\n\n/* Sizes */\n\n.STSDgSRREx4- {\n min-height: calc(16px * 1.5);\n min-height: calc(var(--base-unit) * 1.5);\n padding: 0 calc(16px / 2);\n padding: 0 var(--space-small);\n letter-spacing: 0;\n}\n\n.jobber-retheme .STSDgSRREx4- {\n min-height: calc(16px * 1.5);\n min-height: var(--space-large);\n padding: calc(16px / 2) calc((16px * 1) - (16px / 4));\n padding: calc(16px / 2) calc(calc(16px * 1) - calc(16px / 4));\n padding: var(--space-small) calc(var(--space-base) - var(--space-smaller));\n}\n\n.jobber-retheme .STSDgSRREx4- span {\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.amIh7vPETfo- {\n padding: 0 calc((16px * 1) - (16px / 4));\n padding: 0 calc(calc(16px * 1) - calc(16px / 4));\n padding: 0 calc(var(--space-base) - var(--space-smaller));\n}\n\n.jobber-retheme .amIh7vPETfo- {\n padding: 0 calc(16px * 1);\n padding: 0 var(--space-base);\n}\n\n.ON6ezOojFVo- {\n min-height: calc(16px * 3);\n min-height: calc(var(--base-unit) * 3);\n padding: 0 calc(16px * 1);\n padding: 0 var(--space-base);\n}\n\n.jobber-retheme .ON6ezOojFVo- {\n min-height: calc(16px * 3);\n min-height: calc(var(--base-unit) * 3);\n padding: 0 calc((16px * 1) + (16px / 4));\n padding: 0 calc(calc(16px * 1) + calc(16px / 4));\n padding: 0 calc(var(--space-base) + var(--space-smaller));\n}\n\n/* Icon */\n\n.U9VsquOtk2I- svg {\n -ms-flex-negative: 0;\n flex-shrink: 0;\n}\n\n.Qq-idRLJTCk- {\n width: calc(16px * 2.25);\n width: calc(var(--base-unit) * 2.25);\n padding: 0;\n}\n\n.Qq-idRLJTCk-.STSDgSRREx4- {\n width: calc((16px / 2) * 3);\n width: calc(calc(16px / 2) * 3);\n width: calc(var(--space-small) * 3);\n}\n\n.Qq-idRLJTCk-.amIh7vPETfo- {\n width: calc((16px * 1) * 2.25);\n width: calc(calc(16px * 1) * 2.25);\n width: calc(var(--space-base) * 2.25);\n}\n\n.jobber-retheme .Qq-idRLJTCk-.amIh7vPETfo- {\n width: calc((16px * 1) * 2.5);\n width: calc(calc(16px * 1) * 2.5);\n width: calc(var(--space-base) * 2.5);\n}\n\n.Qq-idRLJTCk-.ON6ezOojFVo- {\n width: calc((16px * 1.5) * 2);\n width: calc(calc(16px * 1.5) * 2);\n width: calc(var(--space-large) * 2);\n}\n\n.EWh1gvgPJQg- {\n width: auto;\n gap: calc(16px / 2);\n gap: var(--space-small);\n}\n\n.jobber-retheme .EWh1gvgPJQg- {\n gap: calc(16px / 4);\n gap: var(--space-smaller);\n}\n\n/* Don't want to move things that will update after re-theme */\n\n/* stylelint-disable-next-line no-descending-specificity */\n\n.EWh1gvgPJQg- > * {\n text-align: left;\n}\n\n.pfzTUMgNb3o- > *:first-child {\n -ms-flex-order: 1;\n order: 1;\n}\n\n.jobber-retheme .EWh1gvgPJQg- > *:first-child {\n margin-left: calc((16px / 4) * -1);\n margin-left: calc(calc(16px / 4) * -1);\n margin-left: calc(var(--space-smaller) * -1);\n}\n\n.jobber-retheme .pfzTUMgNb3o- > *:first-child {\n margin-left: 0;\n margin-right: calc((16px / 4) * -1);\n margin-right: calc(calc(16px / 4) * -1);\n margin-right: calc(var(--space-smaller) * -1);\n}\n\n.ZCHqCEyLBw0- {\n width: 100%;\n}\n\n.VVFKEv1ksMA- {\n background-image: linear-gradient(\n 135deg,\n rgba(0, 0, 0, 0.1) 0%,\n rgba(0, 0, 0, 0.1) 25%,\n transparent 25%,\n transparent 50%,\n rgba(0, 0, 0, 0.1) 50%,\n rgba(0, 0, 0, 0.1) 75%,\n transparent 75%,\n transparent 100%\n );\n background-size: calc(16px * 2) calc(16px * 2);\n background-size: var(--space-larger) var(--space-larger);\n pointer-events: none;\n cursor: not-allowed;\n -webkit-animation-duration: 2000ms;\n -webkit-animation-duration: var(--button--duration-loading);\n animation-duration: 2000ms;\n animation-duration: var(--button--duration-loading);\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-name: a8Q-0lnKH5M-;\n animation-name: a8Q-0lnKH5M-;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear;\n}\n\n.FXqN12jWtPo-.VVFKEv1ksMA-:not(.vDKO-cmh8vY-) {\n background-image: linear-gradient(\n 135deg,\n rgba(255, 255, 255, 0.25) 0%,\n rgba(255, 255, 255, 0.25) 25%,\n transparent 25%,\n transparent 50%,\n rgba(255, 255, 255, 0.25) 50%,\n rgba(255, 255, 255, 0.25) 75%,\n transparent 75%,\n transparent 100%\n );\n}\n\n@-webkit-keyframes a8Q-0lnKH5M- {\n 0% {\n background-position: 0 0;\n }\n\n 100% {\n background-position: calc(16px * 2) calc(16px * 2);\n background-position: var(--space-larger) var(--space-larger);\n }\n}\n\n@keyframes a8Q-0lnKH5M- {\n 0% {\n background-position: 0 0;\n }\n\n 100% {\n background-position: calc(16px * 2) calc(16px * 2);\n background-position: var(--space-larger) var(--space-larger);\n }\n}\n";
|
|
16
|
+
var styles = {"button":"U9VsquOtk2I-","work":"qkFQwI0PKfw-","learning":"jsKQEOBdJ0k-","destructive":"_4W8X0dxZDK4-","subtle":"vDKO-cmh8vY-","primary":"FXqN12jWtPo-","disabled":"bg-l22drjd0-","secondary":"pf6G840lKdA-","tertiary":"m7DbwRZWcNk-","small":"STSDgSRREx4-","base":"amIh7vPETfo-","large":"ON6ezOojFVo-","onlyIcon":"Qq-idRLJTCk-","hasIconAndLabel":"EWh1gvgPJQg-","iconOnRight":"pfzTUMgNb3o-","fullWidth":"ZCHqCEyLBw0-","loading":"VVFKEv1ksMA-","animateStripes":"a8Q-0lnKH5M-"};
|
|
17
|
+
styleInject_es.styleInject(css_248z);
|
|
18
|
+
|
|
19
|
+
function Button(props) {
|
|
20
|
+
const { ariaControls, ariaHaspopup, ariaExpanded, ariaLabel, disabled = false, external, fullWidth, icon, label, iconOnRight, id, loading, onClick, onMouseDown, role, size = "base", type = "primary", url, to, variation = "work", submit, } = props;
|
|
21
|
+
const buttonClassNames = classnames__default["default"](styles.button, styles[size], {
|
|
22
|
+
[styles.onlyIcon]: icon && !label,
|
|
23
|
+
[styles.hasIconAndLabel]: icon && label,
|
|
24
|
+
[styles.iconOnRight]: iconOnRight,
|
|
25
|
+
[styles[variation]]: variation,
|
|
26
|
+
[styles[type]]: type,
|
|
27
|
+
[styles.disabled]: disabled,
|
|
28
|
+
[styles.fullWidth]: fullWidth,
|
|
29
|
+
[styles.loading]: loading,
|
|
30
|
+
});
|
|
31
|
+
const buttonType = submit ? "submit" : "button";
|
|
32
|
+
const tagProps = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ className: buttonClassNames, disabled,
|
|
33
|
+
id }, (!disabled && { href: url })), (!disabled && { onClick: onClick })), (!disabled && { onMouseDown: onMouseDown })), (external && { target: "_blank" })), (url === undefined && to === undefined && { type: buttonType })), { "aria-controls": ariaControls, "aria-haspopup": ariaHaspopup, "aria-expanded": ariaExpanded, "aria-label": ariaLabel, role: role });
|
|
34
|
+
const buttonInternals = React__default["default"].createElement(ButtonInternals, Object.assign({}, props));
|
|
35
|
+
if (to) {
|
|
36
|
+
return (React__default["default"].createElement(reactRouterDom.Link, Object.assign({}, tagProps, { to: to }), buttonInternals));
|
|
37
|
+
}
|
|
38
|
+
const Tag = url ? "a" : "button";
|
|
39
|
+
return React__default["default"].createElement(Tag, Object.assign({}, tagProps), buttonInternals);
|
|
40
|
+
}
|
|
41
|
+
function ButtonInternals({ label, icon, size = "base" }) {
|
|
42
|
+
return (React__default["default"].createElement(React__default["default"].Fragment, null,
|
|
43
|
+
icon && React__default["default"].createElement(Icon.Icon, { name: icon, size: size }),
|
|
44
|
+
React__default["default"].createElement(Typography.Typography, { element: "span", fontWeight: "extraBold", fontFamily: "base", size: getTypeSizes(size) }, label)));
|
|
45
|
+
}
|
|
46
|
+
function getTypeSizes(size) {
|
|
47
|
+
switch (size) {
|
|
48
|
+
case "small":
|
|
49
|
+
return "small";
|
|
50
|
+
case "large":
|
|
51
|
+
return "large";
|
|
52
|
+
default:
|
|
53
|
+
return "base";
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
exports.Button = Button;
|