@jobber/components 4.91.2-retheme-fe.2 → 4.91.2-retheme-fe.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AnimatedPresence/{index.js → index.cjs} +1 -3
- package/dist/AnimatedPresence/index.mjs +4 -0
- package/dist/AnimatedPresence-Dg0rSWmK.js +98 -0
- package/dist/{AnimatedPresence-20a02aaa.js → AnimatedPresence-kepj98O9.js} +3 -7
- package/dist/AnimatedSwitcher/index.cjs +11 -0
- package/dist/AnimatedSwitcher/index.mjs +5 -0
- package/dist/AnimatedSwitcher-B5GlT1r8.js +90 -0
- package/dist/{AnimatedSwitcher-3d45ec5d.js → AnimatedSwitcher-DkWeBaXx.js} +4 -8
- package/dist/AtlantisContext/{index.js → index.cjs} +1 -3
- package/dist/AtlantisContext/index.mjs +2 -0
- package/dist/AtlantisContext-BB6fVGP7.js +18 -0
- package/dist/Autocomplete/index.cjs +32 -0
- package/dist/Autocomplete/index.mjs +26 -0
- package/dist/Autocomplete-4jTEXjzp.js +192 -0
- package/dist/Autocomplete-B892iXrS.js +190 -0
- package/dist/Avatar/index.cjs +12 -0
- package/dist/Avatar/index.mjs +6 -0
- package/dist/Avatar-BcTE1VAK.js +69 -0
- package/dist/Avatar-D99qNu2q.js +67 -0
- package/dist/Banner/components/BannerIcon/index.cjs +11 -0
- package/dist/Banner/components/BannerIcon/index.mjs +5 -0
- package/dist/Banner/index.cjs +22 -0
- package/dist/Banner/index.mjs +16 -0
- package/dist/Banner-DXiLDPyP.js +66 -0
- package/dist/Banner-aDyK7ryS.js +68 -0
- package/dist/BannerIcon-CR5zIp9W.js +17 -0
- package/dist/BannerIcon-DaWJs7AC.js +14 -0
- package/dist/Body-CsnvKsQJ.js +45 -0
- package/dist/Body-Di3_1N_g.js +54 -0
- package/dist/Button/index.cjs +13 -0
- package/dist/Button/index.mjs +7 -0
- package/dist/Button-CrxxoYQF.js +49 -0
- package/dist/Button-DzwBVzGv.js +47 -0
- package/dist/ButtonDismiss/index.cjs +14 -0
- package/dist/ButtonDismiss/index.mjs +8 -0
- package/dist/ButtonDismiss-D77VYrSx.js +8 -0
- package/dist/ButtonDismiss-mNxpZX9b.js +10 -0
- package/dist/Card/index.cjs +20 -0
- package/dist/Card/index.mjs +14 -0
- package/dist/Card-BIuX0d8F.js +83 -0
- package/dist/Card-D3BWz4zt.js +81 -0
- package/dist/Checkbox/index.cjs +15 -0
- package/dist/Checkbox/index.mjs +9 -0
- package/dist/Checkbox-BeOyeqVV.js +53 -0
- package/dist/Checkbox-CgTUkcUJ.js +55 -0
- package/dist/Chip/hooks/index.cjs +8 -0
- package/dist/Chip/hooks/index.mjs +2 -0
- package/dist/Chip/index.cjs +26 -0
- package/dist/Chip/index.mjs +18 -0
- package/dist/Chip-BO6LPeGJ.js +67 -0
- package/dist/Chip-rCOZOjwt.js +70 -0
- package/dist/ChipDismissible-7huIAOo1.js +19 -0
- package/dist/ChipDismissible-CGJCNiKU.js +22 -0
- package/dist/Chips/InternalChipDismissible/hooks/index.cjs +23 -0
- package/dist/Chips/InternalChipDismissible/hooks/index.mjs +13 -0
- package/dist/Chips/InternalChipDismissible/index.cjs +35 -0
- package/dist/Chips/InternalChipDismissible/index.mjs +29 -0
- package/dist/Chips/index.cjs +48 -0
- package/dist/Chips/index.mjs +44 -0
- package/dist/Chips-BKPjQDju.js +93 -0
- package/dist/Chips-nzWX1NfH.js +91 -0
- package/dist/Combobox/components/ComboboxAction/index.cjs +12 -0
- package/dist/Combobox/components/ComboboxAction/index.mjs +6 -0
- package/dist/Combobox/components/ComboboxActivator/index.cjs +27 -0
- package/dist/Combobox/components/ComboboxActivator/index.mjs +21 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentHeader/index.cjs +14 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentHeader/index.mjs +8 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentList/index.cjs +24 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentList/index.mjs +18 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentSearch/index.cjs +10 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxContentSearch/index.mjs +4 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxLoadMore/index.cjs +9 -0
- package/dist/Combobox/components/ComboboxContent/ComboboxLoadMore/index.mjs +3 -0
- package/dist/Combobox/components/ComboboxContent/index.cjs +34 -0
- package/dist/Combobox/components/ComboboxContent/index.mjs +28 -0
- package/dist/Combobox/components/ComboboxOption/index.cjs +14 -0
- package/dist/Combobox/components/ComboboxOption/index.mjs +8 -0
- package/dist/Combobox/components/ComboboxTrigger/index.cjs +25 -0
- package/dist/Combobox/components/ComboboxTrigger/index.mjs +19 -0
- package/dist/Combobox/index.cjs +53 -0
- package/dist/Combobox/index.mjs +46 -0
- package/dist/Combobox-CPFiAWN6.js +117 -0
- package/dist/Combobox-ChHMTRwV.js +119 -0
- package/dist/ComboboxAction-C8vgEtWx.js +22 -0
- package/dist/ComboboxAction-CMtTeU6U.js +24 -0
- package/dist/ComboboxActivator-D9nXKLfL.js +26 -0
- package/dist/ComboboxActivator-DR2zBEhW.js +28 -0
- package/dist/ComboboxContent-hlcIQRLz.js +143 -0
- package/dist/ComboboxContent-oQDp-dEd.js +145 -0
- package/dist/ComboboxContentHeader-BpyDfau9.js +29 -0
- package/dist/ComboboxContentHeader-CJHYc30F.js +27 -0
- package/dist/ComboboxContentList-B46nuf36.js +75 -0
- package/dist/ComboboxContentList-DdhL57Bj.js +77 -0
- package/dist/ComboboxContentSearch-BgkQYIHq.js +34 -0
- package/dist/ComboboxContentSearch-CG16cjfz.js +32 -0
- package/dist/ComboboxLoadMore-9FgWV4Uv.js +16 -0
- package/dist/ComboboxLoadMore-lwIHDJ3e.js +14 -0
- package/dist/ComboboxOption-BPLxC2h4.js +20 -0
- package/dist/ComboboxOption-CJpTBVXu.js +22 -0
- package/dist/ComboboxProvider-BzFHJNMs.js +10 -0
- package/dist/ComboboxProvider-fgameO9B.js +13 -0
- package/dist/ComboboxTrigger-0H4T-Fa6.js +24 -0
- package/dist/ComboboxTrigger-Bro30eER.js +22 -0
- package/dist/ConfirmationModal/index.cjs +29 -0
- package/dist/ConfirmationModal/index.mjs +23 -0
- package/dist/{ConfirmationModal-289df9ad.js → ConfirmationModal-D_79ZcA-.js} +8 -12
- package/dist/ConfirmationModal-iPrJJhaV.js +94 -0
- package/dist/Content/index.cjs +9 -0
- package/dist/Content/index.mjs +3 -0
- package/dist/Content-DbO2GY5M.js +13 -0
- package/dist/Content-DzVNJZsM.js +15 -0
- package/dist/Countdown/index.cjs +11 -0
- package/dist/Countdown/index.mjs +5 -0
- package/dist/Countdown-7LRQSe5O.js +659 -0
- package/dist/Countdown-okI-Yhdd.js +657 -0
- package/dist/DataDump/index.cjs +23 -0
- package/dist/DataDump/index.mjs +17 -0
- package/dist/DataDump-DUj1DcI5.js +17 -0
- package/dist/DataDump-JGAum9NC.js +15 -0
- package/dist/DataList/components/DataListAction/index.cjs +13 -0
- package/dist/DataList/components/DataListAction/index.mjs +7 -0
- package/dist/DataList/components/DataListActions/index.cjs +42 -0
- package/dist/DataList/components/DataListActions/index.mjs +36 -0
- package/dist/DataList/components/DataListActionsMenu/index.cjs +17 -0
- package/dist/DataList/components/DataListActionsMenu/index.mjs +11 -0
- package/dist/DataList/components/DataListBulkActions/index.cjs +45 -0
- package/dist/DataList/components/DataListBulkActions/index.mjs +38 -0
- package/dist/DataList/components/DataListEmptyState/index.cjs +20 -0
- package/dist/DataList/components/DataListEmptyState/index.mjs +13 -0
- package/dist/DataList/components/DataListFilters/components/DataListSort/index.cjs +54 -0
- package/dist/DataList/components/DataListFilters/components/DataListSort/index.mjs +48 -0
- package/dist/DataList/components/DataListFilters/index.cjs +67 -0
- package/dist/DataList/components/DataListFilters/index.mjs +60 -0
- package/dist/DataList/components/DataListHeader/index.cjs +52 -0
- package/dist/DataList/components/DataListHeader/index.mjs +46 -0
- package/dist/DataList/components/DataListHeaderTile/components/index.cjs +12 -0
- package/dist/DataList/components/DataListHeaderTile/components/index.mjs +6 -0
- package/dist/DataList/components/DataListHeaderTile/index.cjs +20 -0
- package/dist/DataList/components/DataListHeaderTile/index.mjs +14 -0
- package/dist/DataList/components/DataListItem/components/DataListItemClickable/index.cjs +14 -0
- package/dist/DataList/components/DataListItem/components/DataListItemClickable/index.mjs +8 -0
- package/dist/DataList/components/DataListItem/index.cjs +51 -0
- package/dist/DataList/components/DataListItem/index.mjs +45 -0
- package/dist/DataList/components/DataListItemActions/index.cjs +44 -0
- package/dist/DataList/components/DataListItemActions/index.mjs +37 -0
- package/dist/DataList/components/DataListItemActionsOverflow/index.cjs +25 -0
- package/dist/DataList/components/DataListItemActionsOverflow/index.mjs +19 -0
- package/dist/DataList/components/DataListItems/index.cjs +52 -0
- package/dist/DataList/components/DataListItems/index.mjs +46 -0
- package/dist/DataList/components/DataListLayout/index.cjs +55 -0
- package/dist/DataList/components/DataListLayout/index.mjs +49 -0
- package/dist/DataList/components/DataListLayoutActions/DataListLayoutContext/index.cjs +9 -0
- package/dist/DataList/components/DataListLayoutActions/DataListLayoutContext/index.mjs +2 -0
- package/dist/DataList/components/DataListLayoutActions/index.cjs +33 -0
- package/dist/DataList/components/DataListLayoutActions/index.mjs +27 -0
- package/dist/DataList/components/DataListLoadMore/index.cjs +21 -0
- package/dist/DataList/components/DataListLoadMore/index.mjs +14 -0
- package/dist/DataList/components/DataListLoadingState/index.cjs +21 -0
- package/dist/DataList/components/DataListLoadingState/index.mjs +13 -0
- package/dist/DataList/components/DataListOverflowFade/index.cjs +11 -0
- package/dist/DataList/components/DataListOverflowFade/index.mjs +4 -0
- package/dist/DataList/components/DataListSearch/index.cjs +33 -0
- package/dist/DataList/components/DataListSearch/index.mjs +25 -0
- package/dist/DataList/components/DataListStatusBar/index.cjs +30 -0
- package/dist/DataList/components/DataListStatusBar/index.mjs +23 -0
- package/dist/DataList/components/DataListStickyHeader/index.cjs +11 -0
- package/dist/DataList/components/DataListStickyHeader/index.mjs +5 -0
- package/dist/DataList/components/DataListTags/index.cjs +12 -0
- package/dist/DataList/components/DataListTags/index.mjs +6 -0
- package/dist/DataList/components/DataListTotalCount/index.cjs +15 -0
- package/dist/DataList/components/DataListTotalCount/index.mjs +8 -0
- package/dist/DataList/context/DataListContext/index.cjs +12 -0
- package/dist/DataList/context/DataListContext/index.mjs +4 -0
- package/dist/DataList/context/DataListLayoutContext/index.cjs +12 -0
- package/dist/DataList/context/DataListLayoutContext/index.mjs +4 -0
- package/dist/DataList/index.cjs +97 -0
- package/dist/DataList/index.mjs +91 -0
- package/dist/DataList-B0YrIckS.js +141 -0
- package/dist/DataList-Dcbo0O6p.js +5 -0
- package/dist/DataList-DfyJDhUn.js +3 -0
- package/dist/DataList-I9cVfKBx.js +139 -0
- package/dist/DataList.const-B-WAZqZm.js +25 -0
- package/dist/DataList.const-DZ5upBs4.js +38 -0
- package/dist/DataList.utils-DKYlINpl.js +168 -0
- package/dist/DataList.utils-DmychB4b.js +161 -0
- package/dist/DataListAction-BTge_0LD.js +37 -0
- package/dist/DataListAction-HGpY_hOu.js +39 -0
- package/dist/DataListActions-CmIwf73f.js +43 -0
- package/dist/DataListActions-D94XxpZM.js +45 -0
- package/dist/DataListActionsMenu-BDlbxRpS.js +57 -0
- package/dist/DataListActionsMenu-DJ0jKNQ9.js +55 -0
- package/dist/DataListBulkActions-CqyhvwO3.js +29 -0
- package/dist/DataListBulkActions-DMU9T6TS.js +26 -0
- package/dist/DataListContext-B9QPGTE9.js +25 -0
- package/dist/DataListContext-CtxUHHfs.js +29 -0
- package/dist/DataListEmptyState-B-6AynZz.js +53 -0
- package/dist/DataListEmptyState-DSrTemd1.js +50 -0
- package/dist/DataListFilters-CVRcWy-9.js +43 -0
- package/dist/DataListFilters-LGIT4RTw.js +46 -0
- package/dist/DataListHeader-CKNSWwQo.js +95 -0
- package/dist/DataListHeader-CfZmYQG2.js +93 -0
- package/dist/DataListHeaderTile-BYDWDG_0.js +81 -0
- package/dist/DataListHeaderTile-I90vRaws.js +79 -0
- package/dist/DataListItem-BuwfdyIq.js +112 -0
- package/dist/DataListItem-EDyh_yml.js +114 -0
- package/dist/DataListItemActions-BcrNy34u.js +29 -0
- package/dist/DataListItemActions-E6TYqr0T.js +32 -0
- package/dist/DataListItemActionsOverflow-BFOFHLmm.js +35 -0
- package/dist/DataListItemActionsOverflow-OJZ4_d_f.js +33 -0
- package/dist/DataListItemClickable-DLS2uEpq.js +45 -0
- package/dist/DataListItemClickable-RGUCPgM5.js +47 -0
- package/dist/DataListItems-BjQ_XDeZ.js +19 -0
- package/dist/DataListItems-CN_kub24.js +21 -0
- package/dist/DataListLayout-BmLJ-mi_.js +19 -0
- package/dist/DataListLayout-kbVmXDsv.js +21 -0
- package/dist/DataListLayoutActions-D7dfXhpA.js +38 -0
- package/dist/DataListLayoutActions-DsqeiOLl.js +36 -0
- package/dist/DataListLayoutContext-CmT-yv31.js +14 -0
- package/dist/DataListLayoutContext-DbIuv3_7.js +8 -0
- package/dist/DataListLayoutContext-Dsm5THEw.js +11 -0
- package/dist/DataListLayoutContext-cLuet6uT.js +18 -0
- package/dist/DataListLoadMore-BXjOjGwa.js +34 -0
- package/dist/DataListLoadMore-C6Of-7M0.js +31 -0
- package/dist/DataListLoadingState-7erg1duA.js +26 -0
- package/dist/DataListLoadingState-Da7RpOd1.js +22 -0
- package/dist/DataListOverflowFade-B2Iz6CsX.js +25 -0
- package/dist/DataListOverflowFade-CzFRYirg.js +22 -0
- package/dist/DataListSearch-DVyuwX2c.js +59 -0
- package/dist/DataListSearch-Dh9PxyQp.js +63 -0
- package/dist/DataListSort-CgGWlSZ0.js +94 -0
- package/dist/DataListSort-Dql37zcM.js +92 -0
- package/dist/DataListSortingOptions-DW9pkdUG.js +37 -0
- package/dist/DataListSortingOptions-Eoovb0ni.js +35 -0
- package/dist/DataListStatusBar-B_NhZoAv.js +22 -0
- package/dist/DataListStatusBar-CoHWwL7-.js +25 -0
- package/dist/DataListStickyHeader-Ba82f3Im.js +25 -0
- package/dist/DataListStickyHeader-DBCXs6Rc.js +23 -0
- package/dist/DataListTags-DH4nIE2K.js +62 -0
- package/dist/DataListTags-scOaXzcs.js +64 -0
- package/dist/DataListTotalCount-DjKf6gMo.js +27 -0
- package/dist/DataListTotalCount-m2VGpCak.js +24 -0
- package/dist/DataTable/index.cjs +36 -0
- package/dist/DataTable/index.mjs +25 -0
- package/dist/DataTable/test-utilities/index.cjs +246 -0
- package/dist/DataTable/test-utilities/index.mjs +238 -0
- package/dist/DataTable-NxjqVEtH.js +238 -0
- package/dist/DataTable-x5RQEyBP.js +236 -0
- package/dist/DatePicker/index.cjs +26 -0
- package/dist/DatePicker/index.mjs +20 -0
- package/dist/DatePicker-BVcHoA7-.js +8554 -0
- package/dist/DatePicker-C8v-Zj4s.js +8551 -0
- package/dist/DayOfMonthSelect--FHzXJDW.js +137 -0
- package/dist/DayOfMonthSelect-C-fPPm2a.js +130 -0
- package/dist/DescriptionList/index.cjs +10 -0
- package/dist/DescriptionList/index.mjs +4 -0
- package/dist/DescriptionList-Cju_ltAl.js +14 -0
- package/dist/DescriptionList-DyycFYga.js +12 -0
- package/dist/Disclosure/index.cjs +17 -0
- package/dist/Disclosure/index.mjs +11 -0
- package/dist/Disclosure-BuGyUy0l.js +33 -0
- package/dist/Disclosure-CMxuffso.js +35 -0
- package/dist/Divider/index.cjs +9 -0
- package/dist/Divider/index.mjs +3 -0
- package/dist/Divider-CCH0JB2B.js +17 -0
- package/dist/Divider-L89PyUsw.js +19 -0
- package/dist/Drawer/index.cjs +17 -0
- package/dist/Drawer/index.mjs +10 -0
- package/dist/DrawerGrid-Bp4NRp42.js +31 -0
- package/dist/DrawerGrid-CZEJyoma.js +28 -0
- package/dist/Emphasis/index.cjs +10 -0
- package/dist/Emphasis/index.mjs +4 -0
- package/dist/Emphasis-BOCpUymX.js +15 -0
- package/dist/Emphasis-DyEYCEeY.js +13 -0
- package/dist/FeatureSwitch/index.cjs +24 -0
- package/dist/FeatureSwitch/index.mjs +18 -0
- package/dist/FeatureSwitch-Be-BLvA7.js +54 -0
- package/dist/FeatureSwitch-vqe0AQ2W.js +52 -0
- package/dist/Flex/index.cjs +9 -0
- package/dist/Flex/index.mjs +3 -0
- package/dist/Flex-DnI4PG_x.js +28 -0
- package/dist/Flex-DqHnYqYa.js +30 -0
- package/dist/Form/index.cjs +10 -0
- package/dist/Form/index.mjs +4 -0
- package/dist/{Form/index.js → Form-Clk5qGl3.js} +3 -9
- package/dist/Form-DVrhZAfE.js +48 -0
- package/dist/FormField/index.cjs +20 -0
- package/dist/FormField/index.mjs +14 -0
- package/dist/FormField-CDoeGp9o.js +261 -0
- package/dist/FormField-Dc7XoE3A.js +263 -0
- package/dist/FormatDate/{index.js → index.cjs} +1 -3
- package/dist/FormatDate/index.mjs +2 -0
- package/dist/FormatDate-B-4ItFF2.js +27 -0
- package/dist/{FormatDate-70ea5b43.js → FormatDate-BSQ5SYSD.js} +1 -5
- package/dist/FormatEmail/index.cjs +9 -0
- package/dist/FormatEmail/index.mjs +3 -0
- package/dist/FormatEmail-BoR_OfTf.js +11 -0
- package/dist/FormatEmail-CoezKTev.js +13 -0
- package/dist/FormatFile/index.cjs +34 -0
- package/dist/FormatFile/index.mjs +28 -0
- package/dist/FormatFile-RCY2HTZX.js +149 -0
- package/dist/FormatFile-YktXX0mA.js +147 -0
- package/dist/FormatRelativeDateTime/index.cjs +8 -0
- package/dist/FormatRelativeDateTime/index.mjs +2 -0
- package/dist/FormatRelativeDateTime-BU_6qDFz.js +64 -0
- package/dist/{FormatRelativeDateTime/index.js → FormatRelativeDateTime-CU2SvOF9.js} +5 -11
- package/dist/FormatTime/index.cjs +8 -0
- package/dist/FormatTime/index.mjs +2 -0
- package/dist/{FormatTime/index.js → FormatTime-BUB6E47S.js} +1 -7
- package/dist/FormatTime-DM6K5QTY.js +29 -0
- package/dist/Gallery/index.cjs +41 -0
- package/dist/Gallery/index.mjs +35 -0
- package/dist/Gallery-CHSQtOX4.js +65 -0
- package/dist/Gallery-Dr48QgPl.js +63 -0
- package/dist/Glimmer/index.cjs +12 -0
- package/dist/Glimmer/index.mjs +5 -0
- package/dist/Glimmer-BG7eX9ml.js +63 -0
- package/dist/Glimmer-C-o8hGKO.js +60 -0
- package/dist/Grid/InternalGridCell/index.cjs +9 -0
- package/dist/Grid/InternalGridCell/index.mjs +2 -0
- package/dist/Grid/index.cjs +14 -0
- package/dist/Grid/index.mjs +7 -0
- package/dist/Grid-D1qStNFU.js +32 -0
- package/dist/Grid-DtxggU52.js +29 -0
- package/dist/Heading/index.cjs +10 -0
- package/dist/Heading/index.mjs +4 -0
- package/dist/Heading-CLboCN8l.js +47 -0
- package/dist/{Heading-d025ffbb.js → Heading-D39OfHbk.js} +2 -6
- package/dist/Icon/index.cjs +9 -0
- package/dist/Icon/index.mjs +3 -0
- package/dist/Icon-5T1h0cSC.js +36 -0
- package/dist/Icon-zn-zanGs.js +34 -0
- package/dist/InlineLabel/index.cjs +10 -0
- package/dist/InlineLabel/index.mjs +4 -0
- package/dist/InlineLabel-BSjKYUfv.js +20 -0
- package/dist/InlineLabel-Bw_i26zR.js +18 -0
- package/dist/InputAvatar/index.cjs +26 -0
- package/dist/InputAvatar/index.mjs +20 -0
- package/dist/InputAvatar-BW3GFAXi.js +49 -0
- package/dist/InputAvatar-D_ghJoiU.js +47 -0
- package/dist/InputDate/index.cjs +34 -0
- package/dist/InputDate/index.mjs +28 -0
- package/dist/{InputDate/index.js → InputDate-EhlH_aDw.js} +6 -31
- package/dist/InputDate-zAEoCRbO.js +48 -0
- package/dist/InputEmail/index.cjs +22 -0
- package/dist/InputEmail/index.mjs +15 -0
- package/dist/InputEmail-DMIv0W-U.js +20 -0
- package/dist/InputEmail-Dvxsqv1m.js +23 -0
- package/dist/InputFile/index.cjs +23 -0
- package/dist/InputFile/index.mjs +16 -0
- package/dist/InputFile-2ME4Lx_J.js +1608 -0
- package/dist/InputFile-ApUNeer4.js +1611 -0
- package/dist/InputGroup/index.cjs +9 -0
- package/dist/InputGroup/index.mjs +3 -0
- package/dist/InputGroup-CuMESZ3e.js +23 -0
- package/dist/InputGroup-SgH2Znm3.js +25 -0
- package/dist/InputNumber/index.cjs +21 -0
- package/dist/InputNumber/index.mjs +15 -0
- package/dist/InputNumber-CiVi1adj.js +56 -0
- package/dist/{InputNumber-0cc0d204.js → InputNumber-DDZLNzAN.js} +2 -6
- package/dist/InputPassword/index.cjs +21 -0
- package/dist/InputPassword/index.mjs +15 -0
- package/dist/InputPassword-BX5iEGUi.js +19 -0
- package/dist/InputPassword-DSFVkKrW.js +21 -0
- package/dist/InputPhoneNumber/index.cjs +21 -0
- package/dist/InputPhoneNumber/index.mjs +15 -0
- package/dist/InputPhoneNumber-BtGDXTrX.js +94 -0
- package/dist/{InputPhoneNumber/index.js → InputPhoneNumber-D9f6nzaN.js} +7 -27
- package/dist/InputText/index.cjs +22 -0
- package/dist/InputText/index.mjs +16 -0
- package/dist/InputText-DAp8GDBJ.js +96 -0
- package/dist/{InputText-8af32879.js → InputText-DJvMLtTA.js} +4 -8
- package/dist/InputTime/index.cjs +26 -0
- package/dist/InputTime/index.mjs +20 -0
- package/dist/{InputTime/index.js → InputTime-BK32ZRmi.js} +5 -25
- package/dist/InputTime-Cwh6bsgB.js +190 -0
- package/dist/InputValidation/index.cjs +14 -0
- package/dist/InputValidation/index.mjs +8 -0
- package/dist/InputValidation-B0ocr1XO.js +20 -0
- package/dist/InputValidation-BxaW-DOL.js +22 -0
- package/dist/InternalChipDismissible-AydwPO6F.js +157 -0
- package/dist/InternalChipDismissible-BNj2lRac.js +152 -0
- package/dist/InternalGridCell-Dx7Dz3Xq.js +34 -0
- package/dist/InternalGridCell-puBI2ZeJ.js +37 -0
- package/dist/LightBox/index.cjs +26 -0
- package/dist/LightBox/index.mjs +20 -0
- package/dist/LightBox-BRZpFYeQ.js +110 -0
- package/dist/LightBox-CPK9oJpX.js +112 -0
- package/dist/Link/index.cjs +8 -0
- package/dist/Link/index.mjs +2 -0
- package/dist/Link-BMm-4O29.js +9 -0
- package/dist/Link-CacM5qqe.js +7 -0
- package/dist/List/index.cjs +27 -0
- package/dist/List/index.mjs +20 -0
- package/dist/List-D-5zOLA5.js +189 -0
- package/dist/List-tRcUMZA6.js +186 -0
- package/dist/Markdown/index.cjs +17 -0
- package/dist/Markdown/index.mjs +11 -0
- package/dist/Markdown-CRV63Nlg.js +19011 -0
- package/dist/Markdown-CjYVzppS.js +19013 -0
- package/dist/Menu/index.cjs +18 -0
- package/dist/Menu/index.mjs +12 -0
- package/dist/Menu-PQAVNqJX.js +128 -0
- package/dist/Menu-wYw5h0bM.js +130 -0
- package/dist/Modal/index.cjs +21 -0
- package/dist/Modal/index.mjs +15 -0
- package/dist/Modal-3fXNhDjb.js +63 -0
- package/dist/Modal-DpZxsqaF.js +61 -0
- package/dist/MultiSelect/index.cjs +16 -0
- package/dist/MultiSelect/index.mjs +10 -0
- package/dist/MultiSelect-BKA4GqeW.js +164 -0
- package/dist/MultiSelect-Bz5m3p2S.js +166 -0
- package/dist/Option-BWUCNzu-.js +15 -0
- package/dist/Option-CiWcXqo-.js +12 -0
- package/dist/Page/index.cjs +31 -0
- package/dist/Page/index.mjs +25 -0
- package/dist/Page-B4qMqVDr.js +56 -0
- package/dist/Page-D4-zBR88.js +58 -0
- package/dist/Popover/index.cjs +17 -0
- package/dist/Popover/index.mjs +11 -0
- package/dist/Popover-CNkUbTvG.js +50 -0
- package/dist/Popover-CxiiucKv.js +48 -0
- package/dist/ProgressBar/index.cjs +9 -0
- package/dist/ProgressBar/index.mjs +3 -0
- package/dist/ProgressBar-BRI8oId0.js +31 -0
- package/dist/ProgressBar-D4cWYAjk.js +33 -0
- package/dist/RadioGroup/index.cjs +12 -0
- package/dist/RadioGroup/index.mjs +5 -0
- package/dist/RadioGroup-BGqrJ6K9.js +39 -0
- package/dist/RadioGroup-Dx1Glowr.js +36 -0
- package/dist/RecurringSelect/components/index.cjs +15 -0
- package/dist/RecurringSelect/components/index.mjs +6 -0
- package/dist/RecurringSelect/index.cjs +35 -0
- package/dist/RecurringSelect/index.mjs +21 -0
- package/dist/RecurringSelect-D8bZAHBs.js +69 -0
- package/dist/RecurringSelect-D9qSmSek.js +71 -0
- package/dist/Select/index.cjs +22 -0
- package/dist/Select/index.mjs +15 -0
- package/dist/Spinner/index.cjs +9 -0
- package/dist/Spinner/index.mjs +3 -0
- package/dist/Spinner-CRjrJ0LO.js +14 -0
- package/dist/Spinner-DBuwcAqL.js +16 -0
- package/dist/StatusIndicator/index.cjs +8 -0
- package/dist/StatusIndicator/index.mjs +2 -0
- package/dist/StatusIndicator-DGvPdP50.js +9 -0
- package/dist/StatusIndicator-egqvK_8I.js +11 -0
- package/dist/StatusLabel/index.cjs +11 -0
- package/dist/StatusLabel/index.mjs +5 -0
- package/dist/StatusLabel-ClNWJSbx.js +16 -0
- package/dist/StatusLabel-gScnhH3r.js +18 -0
- package/dist/Switch/index.cjs +10 -0
- package/dist/Switch/index.mjs +4 -0
- package/dist/Switch-B6FDMgFW.js +48 -0
- package/dist/Switch-B8HlM_QY.js +46 -0
- package/dist/Table/index.cjs +17 -0
- package/dist/Table/index.mjs +4 -0
- package/dist/Tabs/index.cjs +11 -0
- package/dist/Tabs/index.mjs +4 -0
- package/dist/Tabs-BWBhsLmc.js +70 -0
- package/dist/Tabs-CqLdEcw_.js +67 -0
- package/dist/Text/index.cjs +10 -0
- package/dist/Text/index.mjs +4 -0
- package/dist/{Text-fdc65f0b.js → Text-C0pm--c0.js} +2 -6
- package/dist/Text-CyaxiLeN.js +25 -0
- package/dist/Toast/index.cjs +16 -0
- package/dist/Toast/index.mjs +10 -0
- package/dist/Tooltip/Tooltip.d.ts +7 -1
- package/dist/Tooltip/Tooltip.types.d.ts +1 -0
- package/dist/Tooltip/index.cjs +14 -0
- package/dist/Tooltip/index.mjs +8 -0
- package/dist/Tooltip/useTooltipPositioning.d.ts +7 -2
- package/dist/Tooltip-Cz3YrniM.js +107 -0
- package/dist/Tooltip-DwJncSM8.js +109 -0
- package/dist/Typography/index.cjs +9 -0
- package/dist/Typography/index.mjs +3 -0
- package/dist/Typography-BCKgZ_gv.js +38 -0
- package/dist/Typography-C0YR4XBl.js +36 -0
- package/dist/_baseAssignValue-BUu9BC9H.js +31 -0
- package/dist/_baseAssignValue-DF3A_efn.js +29 -0
- package/dist/_baseEach-CRlnkM7o.js +1069 -0
- package/dist/_baseEach-DVwKXi81.js +1073 -0
- package/dist/_commonjsHelpers-DAuvc7SO.js +36 -0
- package/dist/_commonjsHelpers-jBnpF2iq.js +32 -0
- package/dist/_defineProperty-B3SNVTd_.js +1326 -0
- package/dist/_defineProperty-JMBF-bcO.js +1306 -0
- package/dist/_getTag-5wQIlCbe.js +718 -0
- package/dist/_getTag-BBZ5PchE.js +733 -0
- package/dist/_polyfill-node.process-DT4I8V6P.js +258 -0
- package/dist/_polyfill-node.process-SftmnXC5.js +255 -0
- package/dist/_setToString-D6dO6z5c.js +234 -0
- package/dist/_setToString-Dgouhodc.js +230 -0
- package/dist/debounce-BIIhPHgB.js +332 -0
- package/dist/debounce-D4EqvIGN.js +329 -0
- package/dist/helpers-BQt4cjaM.js +15 -0
- package/dist/helpers-DMMJ1q7H.js +17 -0
- package/dist/index-Bd55olyf.js +1186 -0
- package/dist/index-CkGfA4vx.js +1189 -0
- package/dist/index.cjs +274 -0
- package/dist/index.d.mts +74 -0
- package/dist/index.d.ts +74 -0
- package/dist/index.mjs +161 -0
- package/dist/isObjectLike-BlLIuFVH.js +197 -0
- package/dist/isObjectLike-CAV2cIfa.js +190 -0
- package/dist/isSymbol-BxsxMlnF.js +35 -0
- package/dist/isSymbol-C2J0yjld.js +33 -0
- package/dist/noop-C9vKAtvJ.js +24 -0
- package/dist/noop-D4cCHWII.js +26 -0
- package/dist/showToast-DEz-eIM4.js +96 -0
- package/dist/showToast-d0XdpaJD.js +98 -0
- package/dist/styles.css +8401 -0
- package/dist/tslib.es6-6dmIhJTi.js +102 -0
- package/dist/tslib.es6-sBHgrKO6.js +97 -0
- package/dist/useActiveLayout-EZ1eunvS.js +16 -0
- package/dist/useActiveLayout-VN6ZOkxZ.js +14 -0
- package/dist/useAssert-BHj1OQqJ.js +27 -0
- package/dist/useAssert-knwpkZW0.js +27 -0
- package/dist/useBatchSelect-BTQ9PbXi.js +36 -0
- package/dist/useBatchSelect-C9775spd.js +38 -0
- package/dist/useChildComponent-BLLL1r7O.js +17 -0
- package/dist/useChildComponent-D9yXvtJR.js +15 -0
- package/dist/useFocusTrap-B8ok2cIh.js +74 -0
- package/dist/useFocusTrap-BBkfWfEx.js +74 -0
- package/dist/useInView-Bj_Jl5Bw.js +25 -0
- package/dist/useInView-fsT3lwCU.js +25 -0
- package/dist/useIsMounted-CYEXH1zH.js +47 -0
- package/dist/useIsMounted-Dcw7g7-d.js +47 -0
- package/dist/useOnKeyDown-DN2YGzzl.js +40 -0
- package/dist/useOnKeyDown-DrmWnz2G.js +40 -0
- package/dist/useRefocusOnActivator-DA8gO9ka.js +32 -0
- package/dist/useRefocusOnActivator-y6qNNjZw.js +32 -0
- package/dist/useResizeObserver-8FUujV3_.js +1192 -0
- package/dist/useResizeObserver-CatrBt7i.js +1189 -0
- package/dist/useResponsiveSizing--fEPoUpK.js +51 -0
- package/dist/useResponsiveSizing-Dh343Vot.js +49 -0
- package/dist/useSafeLayoutEffect-BQD8SqX2.js +12 -0
- package/dist/useSafeLayoutEffect-DOMGt2wv.js +14 -0
- package/dist/useScrollToActive-Cgc9Gsx0.js +597 -0
- package/dist/useScrollToActive-gryn6oCp.js +591 -0
- package/package.json +411 -11
- package/{rollup.config.js → rollup.config.mjs} +49 -17
- package/dist/AnimatedSwitcher/index.js +0 -13
- package/dist/Autocomplete/index.js +0 -213
- package/dist/Avatar/index.js +0 -15
- package/dist/Avatar-a5a90da9.js +0 -78
- package/dist/Banner/index.js +0 -92
- package/dist/Button/index.js +0 -16
- package/dist/Button-bb77a513.js +0 -57
- package/dist/ButtonDismiss/index.js +0 -17
- package/dist/ButtonDismiss-a1df8656.js +0 -14
- package/dist/Card/index.js +0 -23
- package/dist/Card-69212ecd.js +0 -93
- package/dist/Checkbox/index.js +0 -18
- package/dist/Checkbox-2ea61ab4.js +0 -63
- package/dist/Chip/index.js +0 -42
- package/dist/Chip-b67ae770.js +0 -89
- package/dist/Chips/index.js +0 -525
- package/dist/Combobox/index.js +0 -41
- package/dist/Combobox-faa6bffe.js +0 -481
- package/dist/ConfirmationModal/index.js +0 -30
- package/dist/Content/index.js +0 -12
- package/dist/Content-e3f7b6fc.js +0 -24
- package/dist/Countdown/index.js +0 -72
- package/dist/DataDump/index.js +0 -36
- package/dist/DataList/index.js +0 -1345
- package/dist/DataTable/index.js +0 -301
- package/dist/DatePicker/index.js +0 -21
- package/dist/DatePicker-8392951f.js +0 -144
- package/dist/DescriptionList/index.js +0 -24
- package/dist/Disclosure/index.js +0 -46
- package/dist/Divider/index.js +0 -29
- package/dist/Drawer/index.js +0 -48
- package/dist/Emphasis/index.js +0 -13
- package/dist/Emphasis-2bbe4da6.js +0 -19
- package/dist/FeatureSwitch/index.js +0 -69
- package/dist/Flex/index.js +0 -12
- package/dist/Flex-d490c4db.js +0 -38
- package/dist/FormField/index.js +0 -24
- package/dist/FormField-5134bf0e.js +0 -253
- package/dist/FormatEmail/index.js +0 -23
- package/dist/FormatFile/index.js +0 -35
- package/dist/FormatFile-7e432b0d.js +0 -162
- package/dist/Gallery/index.js +0 -99
- package/dist/Glimmer/index.js +0 -15
- package/dist/Glimmer-156bb2d1.js +0 -77
- package/dist/Grid/index.js +0 -76
- package/dist/Heading/index.js +0 -13
- package/dist/Icon/index.js +0 -11
- package/dist/Icon-405a216c.js +0 -40
- package/dist/InlineLabel/index.js +0 -13
- package/dist/InlineLabel-d092e45a.js +0 -28
- package/dist/InputAvatar/index.js +0 -70
- package/dist/InputEmail/index.js +0 -43
- package/dist/InputFile/index.js +0 -25
- package/dist/InputFile-5458fb6e.js +0 -190
- package/dist/InputGroup/index.js +0 -12
- package/dist/InputGroup-8d4fd4eb.js +0 -33
- package/dist/InputNumber/index.js +0 -25
- package/dist/InputPassword/index.js +0 -41
- package/dist/InputText/index.js +0 -26
- package/dist/InputValidation/index.js +0 -17
- package/dist/InputValidation-9c582130.js +0 -29
- package/dist/LightBox/index.js +0 -25
- package/dist/LightBox-ddbda5c6.js +0 -121
- package/dist/Link/index.js +0 -15
- package/dist/List/index.js +0 -92
- package/dist/Markdown/index.js +0 -18
- package/dist/Markdown-8150d535.js +0 -62
- package/dist/Menu/index.js +0 -21
- package/dist/Menu-f9fb99bb.js +0 -138
- package/dist/Modal/index.js +0 -24
- package/dist/Modal-4f48de3a.js +0 -74
- package/dist/MultiSelect/index.js +0 -182
- package/dist/Option-8faed3bf.js +0 -19
- package/dist/Page/index.js +0 -77
- package/dist/Popover/index.js +0 -65
- package/dist/ProgressBar/index.js +0 -12
- package/dist/ProgressBar-e4bb029e.js +0 -43
- package/dist/RadioGroup/index.js +0 -15
- package/dist/RadioGroup-c31c2e81.js +0 -46
- package/dist/RecurringSelect/index.js +0 -227
- package/dist/Select/index.js +0 -26
- package/dist/Spinner/index.js +0 -12
- package/dist/Spinner-e15a3ae0.js +0 -24
- package/dist/StatusIndicator/index.js +0 -11
- package/dist/StatusIndicator-dd1f0fd5.js +0 -18
- package/dist/StatusLabel/index.js +0 -28
- package/dist/Switch/index.js +0 -13
- package/dist/Switch-57fbf575.js +0 -56
- package/dist/Table/index.js +0 -66
- package/dist/Tabs/index.js +0 -80
- package/dist/Text/index.js +0 -13
- package/dist/Toast/index.js +0 -110
- package/dist/Tooltip/index.js +0 -17
- package/dist/Tooltip-1e3abeb6.js +0 -114
- package/dist/Typography/index.js +0 -12
- package/dist/Typography-018e1471.js +0 -62
- package/dist/style-inject.es-9d2f5f4e.js +0 -30
- package/dist/tslib.es6-754e2961.js +0 -46
- /package/{.eslintrc.js → .eslintrc.cjs} +0 -0
- /package/dist/{AtlantisContext-64608897.js → AtlantisContext-k356LtVM.js} +0 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var Button = require('./Button-CrxxoYQF.js');
|
|
5
|
+
var Chip = require('./Chip-rCOZOjwt.js');
|
|
6
|
+
require('./tslib.es6-6dmIhJTi.js');
|
|
7
|
+
require('@jobber/design');
|
|
8
|
+
var ComboboxProvider = require('./ComboboxProvider-fgameO9B.js');
|
|
9
|
+
|
|
10
|
+
function ComboboxActivator(props) {
|
|
11
|
+
const { handleClose, open, setOpen } = React.useContext(ComboboxProvider.ComboboxContext);
|
|
12
|
+
if (props.children.type === Button.Button || props.children.type === Chip.Chip) {
|
|
13
|
+
return React.cloneElement(props.children, {
|
|
14
|
+
role: "combobox",
|
|
15
|
+
onClick: () => {
|
|
16
|
+
if (open) {
|
|
17
|
+
handleClose();
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
setOpen(true);
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
return props.children;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
exports.ComboboxActivator = ComboboxActivator;
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import React, { useContext, useRef, useEffect } from 'react';
|
|
2
|
+
import classnames from 'classnames';
|
|
3
|
+
import ReactDOM from 'react-dom';
|
|
4
|
+
import { C as ComboboxContentSearch } from './ComboboxContentSearch-CG16cjfz.js';
|
|
5
|
+
import { C as ComboboxContentList } from './ComboboxContentList-B46nuf36.js';
|
|
6
|
+
import { C as ComboboxContentHeader } from './ComboboxContentHeader-CJHYc30F.js';
|
|
7
|
+
import { a as ComboboxContext } from './ComboboxProvider-BzFHJNMs.js';
|
|
8
|
+
import { u as useRefocusOnActivator_2 } from './useRefocusOnActivator-DA8gO9ka.js';
|
|
9
|
+
import { u as useFocusTrap_2 } from './useFocusTrap-B8ok2cIh.js';
|
|
10
|
+
import { usePopper } from 'react-popper';
|
|
11
|
+
import { u as useOnKeyDown_2 } from './useOnKeyDown-DrmWnz2G.js';
|
|
12
|
+
|
|
13
|
+
var styles = {"content":"m1w5vdUZ6rQ-","hidden":"Zlkv2HA096A-","actions":"YQry-Rd6zfQ-","actionPadding":"TcpqL34s4lI-"};
|
|
14
|
+
|
|
15
|
+
function useComboboxContent(open, selected) {
|
|
16
|
+
const { shouldScroll } = useContext(ComboboxContext);
|
|
17
|
+
const optionsListRef = useRef(null);
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
var _a;
|
|
20
|
+
if (open && shouldScroll.current && optionsListRef.current) {
|
|
21
|
+
const firstSelected = Array.from((_a = optionsListRef === null || optionsListRef === void 0 ? void 0 : optionsListRef.current) === null || _a === void 0 ? void 0 : _a.children).find(child => {
|
|
22
|
+
if (child instanceof HTMLElement) {
|
|
23
|
+
return child.dataset.selected === "true";
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
scrollToFirstSelected(firstSelected, shouldScroll);
|
|
27
|
+
}
|
|
28
|
+
}, [open, selected]);
|
|
29
|
+
return {
|
|
30
|
+
optionsListRef,
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
function scrollToFirstSelected(firstSelected, shouldScroll) {
|
|
34
|
+
if (firstSelected) {
|
|
35
|
+
firstSelected.scrollIntoView({
|
|
36
|
+
block: "nearest",
|
|
37
|
+
});
|
|
38
|
+
shouldScroll.current = false;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// eslint-disable-next-line max-statements
|
|
43
|
+
function useComboboxAccessibility(selectionCallback, filteredOptions, optionsListRef, open, wrapperRef) {
|
|
44
|
+
const { handleClose } = useContext(ComboboxContext);
|
|
45
|
+
const hasOptionsVisible = open && filteredOptions.length > 0;
|
|
46
|
+
const focusedIndex = useRef(null);
|
|
47
|
+
useRefocusOnActivator_2(open);
|
|
48
|
+
const popperRef = useFocusTrap_2(open);
|
|
49
|
+
const { styles: popperStyles, attributes, update, } = usePopper(wrapperRef.current, popperRef.current, {
|
|
50
|
+
modifiers: [
|
|
51
|
+
{
|
|
52
|
+
name: "flip",
|
|
53
|
+
options: {
|
|
54
|
+
fallbackPlacements: ["top-start"],
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
],
|
|
58
|
+
placement: "bottom-start",
|
|
59
|
+
});
|
|
60
|
+
useEffect(() => {
|
|
61
|
+
focusedIndex.current = null;
|
|
62
|
+
if (open) {
|
|
63
|
+
update === null || update === void 0 ? void 0 : update();
|
|
64
|
+
}
|
|
65
|
+
}, [open, filteredOptions.length]);
|
|
66
|
+
useEffect(() => {
|
|
67
|
+
var _a;
|
|
68
|
+
if (open) {
|
|
69
|
+
(_a = popperRef.current) === null || _a === void 0 ? void 0 : _a.addEventListener("keydown", handleContentKeydown);
|
|
70
|
+
}
|
|
71
|
+
return () => {
|
|
72
|
+
var _a;
|
|
73
|
+
(_a = popperRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener("keydown", handleContentKeydown);
|
|
74
|
+
};
|
|
75
|
+
}, [open, optionsListRef, filteredOptions]);
|
|
76
|
+
useOnKeyDown_2(() => {
|
|
77
|
+
if (open) {
|
|
78
|
+
handleClose();
|
|
79
|
+
}
|
|
80
|
+
}, "Escape");
|
|
81
|
+
function handleContentKeydown(event) {
|
|
82
|
+
var _a;
|
|
83
|
+
if (!hasOptionsVisible)
|
|
84
|
+
return;
|
|
85
|
+
if (event.key === "Enter" || event.key === " ") {
|
|
86
|
+
const activeElementInList = (_a = optionsListRef.current) === null || _a === void 0 ? void 0 : _a.contains(document.activeElement);
|
|
87
|
+
if (!activeElementInList)
|
|
88
|
+
return;
|
|
89
|
+
handleKeyboardSelection(event);
|
|
90
|
+
}
|
|
91
|
+
if (event.key === "ArrowDown") {
|
|
92
|
+
handleKeyboardNavigation(event, 1);
|
|
93
|
+
}
|
|
94
|
+
if (event.key === "ArrowUp") {
|
|
95
|
+
handleKeyboardNavigation(event, -1);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
function handleKeyboardNavigation(event, indexChange) {
|
|
99
|
+
var _a;
|
|
100
|
+
const newIndex = focusedIndex.current === null ? 0 : focusedIndex.current + indexChange;
|
|
101
|
+
if (newIndex < 0 || newIndex >= filteredOptions.length)
|
|
102
|
+
return;
|
|
103
|
+
const optionElement = (_a = optionsListRef.current) === null || _a === void 0 ? void 0 : _a.children[newIndex];
|
|
104
|
+
optionElement === null || optionElement === void 0 ? void 0 : optionElement.focus();
|
|
105
|
+
focusedIndex.current = newIndex;
|
|
106
|
+
event.preventDefault();
|
|
107
|
+
event.stopPropagation();
|
|
108
|
+
}
|
|
109
|
+
function handleKeyboardSelection(event) {
|
|
110
|
+
event.preventDefault();
|
|
111
|
+
event.stopPropagation();
|
|
112
|
+
if (focusedIndex.current !== null) {
|
|
113
|
+
selectionCallback(filteredOptions[focusedIndex.current]);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
return {
|
|
117
|
+
popperRef,
|
|
118
|
+
popperStyles,
|
|
119
|
+
attributes,
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
function ComboboxContent(props) {
|
|
124
|
+
const optionsExist = props.options.length > 0;
|
|
125
|
+
const { optionsListRef } = useComboboxContent(props.open, props.selected);
|
|
126
|
+
const { popperRef, popperStyles, attributes } = useComboboxAccessibility(props.handleSelection, props.options, optionsListRef, props.open, props.wrapperRef);
|
|
127
|
+
const template = (React.createElement("div", Object.assign({ ref: popperRef, id: "ATL-Combobox-Content", "data-testid": "ATL-Combobox-Content", tabIndex: 0, className: classnames(styles.content, { [styles.hidden]: !props.open }), style: popperStyles.popper }, attributes.popper),
|
|
128
|
+
React.createElement(ComboboxContentSearch, { open: props.open, placeholder: props.subjectNoun, searchValue: props.searchValue, setSearchValue: props.setSearchValue, handleSearchChange: props.handleSearchChange }),
|
|
129
|
+
props.multiselect && (optionsExist || props.selected.length > 0) && (React.createElement(ComboboxContentHeader, { hasOptionsVisible: optionsExist, subjectNoun: props.subjectNoun, selectedCount: props.selected.length, onClearAll: () => {
|
|
130
|
+
props.selectedStateSetter([]);
|
|
131
|
+
}, onSelectAll: () => {
|
|
132
|
+
props.selectedStateSetter(props.options);
|
|
133
|
+
} })),
|
|
134
|
+
React.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 }),
|
|
135
|
+
props.actionElements && (React.createElement("div", { className: styles.actions, role: "group" }, props.actionElements.map((child, index, childrenArray) => (React.createElement("div", { key: index, className: classnames({
|
|
136
|
+
[styles.actionPadding]: index === childrenArray.length - 1,
|
|
137
|
+
}) }, child)))))));
|
|
138
|
+
return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
|
|
139
|
+
? ReactDOM.createPortal(template, document.body)
|
|
140
|
+
: template;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
export { ComboboxContent as C };
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var classnames = require('classnames');
|
|
5
|
+
var ReactDOM = require('react-dom');
|
|
6
|
+
var ComboboxContentSearch = require('./ComboboxContentSearch-BgkQYIHq.js');
|
|
7
|
+
var ComboboxContentList = require('./ComboboxContentList-DdhL57Bj.js');
|
|
8
|
+
var ComboboxContentHeader = require('./ComboboxContentHeader-BpyDfau9.js');
|
|
9
|
+
var ComboboxProvider = require('./ComboboxProvider-fgameO9B.js');
|
|
10
|
+
var useRefocusOnActivator = require('./useRefocusOnActivator-y6qNNjZw.js');
|
|
11
|
+
var useFocusTrap = require('./useFocusTrap-BBkfWfEx.js');
|
|
12
|
+
var reactPopper = require('react-popper');
|
|
13
|
+
var useOnKeyDown = require('./useOnKeyDown-DN2YGzzl.js');
|
|
14
|
+
|
|
15
|
+
var styles = {"content":"m1w5vdUZ6rQ-","hidden":"Zlkv2HA096A-","actions":"YQry-Rd6zfQ-","actionPadding":"TcpqL34s4lI-"};
|
|
16
|
+
|
|
17
|
+
function useComboboxContent(open, selected) {
|
|
18
|
+
const { shouldScroll } = React.useContext(ComboboxProvider.ComboboxContext);
|
|
19
|
+
const optionsListRef = React.useRef(null);
|
|
20
|
+
React.useEffect(() => {
|
|
21
|
+
var _a;
|
|
22
|
+
if (open && shouldScroll.current && optionsListRef.current) {
|
|
23
|
+
const firstSelected = Array.from((_a = optionsListRef === null || optionsListRef === void 0 ? void 0 : optionsListRef.current) === null || _a === void 0 ? void 0 : _a.children).find(child => {
|
|
24
|
+
if (child instanceof HTMLElement) {
|
|
25
|
+
return child.dataset.selected === "true";
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
scrollToFirstSelected(firstSelected, shouldScroll);
|
|
29
|
+
}
|
|
30
|
+
}, [open, selected]);
|
|
31
|
+
return {
|
|
32
|
+
optionsListRef,
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
function scrollToFirstSelected(firstSelected, shouldScroll) {
|
|
36
|
+
if (firstSelected) {
|
|
37
|
+
firstSelected.scrollIntoView({
|
|
38
|
+
block: "nearest",
|
|
39
|
+
});
|
|
40
|
+
shouldScroll.current = false;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// eslint-disable-next-line max-statements
|
|
45
|
+
function useComboboxAccessibility(selectionCallback, filteredOptions, optionsListRef, open, wrapperRef) {
|
|
46
|
+
const { handleClose } = React.useContext(ComboboxProvider.ComboboxContext);
|
|
47
|
+
const hasOptionsVisible = open && filteredOptions.length > 0;
|
|
48
|
+
const focusedIndex = React.useRef(null);
|
|
49
|
+
useRefocusOnActivator.useRefocusOnActivator_2(open);
|
|
50
|
+
const popperRef = useFocusTrap.useFocusTrap_2(open);
|
|
51
|
+
const { styles: popperStyles, attributes, update, } = reactPopper.usePopper(wrapperRef.current, popperRef.current, {
|
|
52
|
+
modifiers: [
|
|
53
|
+
{
|
|
54
|
+
name: "flip",
|
|
55
|
+
options: {
|
|
56
|
+
fallbackPlacements: ["top-start"],
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
],
|
|
60
|
+
placement: "bottom-start",
|
|
61
|
+
});
|
|
62
|
+
React.useEffect(() => {
|
|
63
|
+
focusedIndex.current = null;
|
|
64
|
+
if (open) {
|
|
65
|
+
update === null || update === void 0 ? void 0 : update();
|
|
66
|
+
}
|
|
67
|
+
}, [open, filteredOptions.length]);
|
|
68
|
+
React.useEffect(() => {
|
|
69
|
+
var _a;
|
|
70
|
+
if (open) {
|
|
71
|
+
(_a = popperRef.current) === null || _a === void 0 ? void 0 : _a.addEventListener("keydown", handleContentKeydown);
|
|
72
|
+
}
|
|
73
|
+
return () => {
|
|
74
|
+
var _a;
|
|
75
|
+
(_a = popperRef.current) === null || _a === void 0 ? void 0 : _a.removeEventListener("keydown", handleContentKeydown);
|
|
76
|
+
};
|
|
77
|
+
}, [open, optionsListRef, filteredOptions]);
|
|
78
|
+
useOnKeyDown.useOnKeyDown_2(() => {
|
|
79
|
+
if (open) {
|
|
80
|
+
handleClose();
|
|
81
|
+
}
|
|
82
|
+
}, "Escape");
|
|
83
|
+
function handleContentKeydown(event) {
|
|
84
|
+
var _a;
|
|
85
|
+
if (!hasOptionsVisible)
|
|
86
|
+
return;
|
|
87
|
+
if (event.key === "Enter" || event.key === " ") {
|
|
88
|
+
const activeElementInList = (_a = optionsListRef.current) === null || _a === void 0 ? void 0 : _a.contains(document.activeElement);
|
|
89
|
+
if (!activeElementInList)
|
|
90
|
+
return;
|
|
91
|
+
handleKeyboardSelection(event);
|
|
92
|
+
}
|
|
93
|
+
if (event.key === "ArrowDown") {
|
|
94
|
+
handleKeyboardNavigation(event, 1);
|
|
95
|
+
}
|
|
96
|
+
if (event.key === "ArrowUp") {
|
|
97
|
+
handleKeyboardNavigation(event, -1);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
function handleKeyboardNavigation(event, indexChange) {
|
|
101
|
+
var _a;
|
|
102
|
+
const newIndex = focusedIndex.current === null ? 0 : focusedIndex.current + indexChange;
|
|
103
|
+
if (newIndex < 0 || newIndex >= filteredOptions.length)
|
|
104
|
+
return;
|
|
105
|
+
const optionElement = (_a = optionsListRef.current) === null || _a === void 0 ? void 0 : _a.children[newIndex];
|
|
106
|
+
optionElement === null || optionElement === void 0 ? void 0 : optionElement.focus();
|
|
107
|
+
focusedIndex.current = newIndex;
|
|
108
|
+
event.preventDefault();
|
|
109
|
+
event.stopPropagation();
|
|
110
|
+
}
|
|
111
|
+
function handleKeyboardSelection(event) {
|
|
112
|
+
event.preventDefault();
|
|
113
|
+
event.stopPropagation();
|
|
114
|
+
if (focusedIndex.current !== null) {
|
|
115
|
+
selectionCallback(filteredOptions[focusedIndex.current]);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
return {
|
|
119
|
+
popperRef,
|
|
120
|
+
popperStyles,
|
|
121
|
+
attributes,
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
function ComboboxContent(props) {
|
|
126
|
+
const optionsExist = props.options.length > 0;
|
|
127
|
+
const { optionsListRef } = useComboboxContent(props.open, props.selected);
|
|
128
|
+
const { popperRef, popperStyles, attributes } = useComboboxAccessibility(props.handleSelection, props.options, optionsListRef, props.open, props.wrapperRef);
|
|
129
|
+
const template = (React.createElement("div", Object.assign({ ref: popperRef, id: "ATL-Combobox-Content", "data-testid": "ATL-Combobox-Content", tabIndex: 0, className: classnames(styles.content, { [styles.hidden]: !props.open }), style: popperStyles.popper }, attributes.popper),
|
|
130
|
+
React.createElement(ComboboxContentSearch.ComboboxContentSearch, { open: props.open, placeholder: props.subjectNoun, searchValue: props.searchValue, setSearchValue: props.setSearchValue, handleSearchChange: props.handleSearchChange }),
|
|
131
|
+
props.multiselect && (optionsExist || props.selected.length > 0) && (React.createElement(ComboboxContentHeader.ComboboxContentHeader, { hasOptionsVisible: optionsExist, subjectNoun: props.subjectNoun, selectedCount: props.selected.length, onClearAll: () => {
|
|
132
|
+
props.selectedStateSetter([]);
|
|
133
|
+
}, onSelectAll: () => {
|
|
134
|
+
props.selectedStateSetter(props.options);
|
|
135
|
+
} })),
|
|
136
|
+
React.createElement(ComboboxContentList.ComboboxContentList, { multiselect: props.multiselect, options: props.options, selected: props.selected, optionsListRef: optionsListRef, searchValue: props.searchValue, subjectNoun: props.subjectNoun, loading: props.loading, onLoadMore: props.onLoadMore }),
|
|
137
|
+
props.actionElements && (React.createElement("div", { className: styles.actions, role: "group" }, props.actionElements.map((child, index, childrenArray) => (React.createElement("div", { key: index, className: classnames({
|
|
138
|
+
[styles.actionPadding]: index === childrenArray.length - 1,
|
|
139
|
+
}) }, child)))))));
|
|
140
|
+
return (globalThis === null || globalThis === void 0 ? void 0 : globalThis.document)
|
|
141
|
+
? ReactDOM.createPortal(template, document.body)
|
|
142
|
+
: template;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
exports.ComboboxContent = ComboboxContent;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var Typography = require('./Typography-BCKgZ_gv.js');
|
|
5
|
+
var Button = require('./Button-CrxxoYQF.js');
|
|
6
|
+
|
|
7
|
+
var styles = {"header":"Q-mwo-g5Fi8-"};
|
|
8
|
+
|
|
9
|
+
function ComboboxContentHeader(props) {
|
|
10
|
+
const hasSelected = props.selectedCount > 0;
|
|
11
|
+
const actionLabel = hasSelected ? "Clear" : "Select all";
|
|
12
|
+
const label = getLabel(hasSelected, props.selectedCount, props.subjectNoun);
|
|
13
|
+
const handleSelectAll = hasSelected ? props.onClearAll : props.onSelectAll;
|
|
14
|
+
const showAction = hasSelected || props.hasOptionsVisible;
|
|
15
|
+
return (React.createElement("div", { className: styles.header, "data-testid": "ATL-Combobox-Header" },
|
|
16
|
+
React.createElement(Typography.Typography, { textColor: "heading", fontWeight: "semiBold" }, label),
|
|
17
|
+
showAction && (React.createElement(Button.Button, { size: "small", label: actionLabel, type: "tertiary", onClick: handleSelectAll }))));
|
|
18
|
+
}
|
|
19
|
+
function getLabel(hasSelected, count, subjectNoun) {
|
|
20
|
+
if (hasSelected) {
|
|
21
|
+
return `${count} selected`;
|
|
22
|
+
}
|
|
23
|
+
if (subjectNoun) {
|
|
24
|
+
return `Select ${subjectNoun}`;
|
|
25
|
+
}
|
|
26
|
+
return "Select";
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
exports.ComboboxContentHeader = ComboboxContentHeader;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { T as Typography } from './Typography-C0YR4XBl.js';
|
|
3
|
+
import { B as Button } from './Button-DzwBVzGv.js';
|
|
4
|
+
|
|
5
|
+
var styles = {"header":"Q-mwo-g5Fi8-"};
|
|
6
|
+
|
|
7
|
+
function ComboboxContentHeader(props) {
|
|
8
|
+
const hasSelected = props.selectedCount > 0;
|
|
9
|
+
const actionLabel = hasSelected ? "Clear" : "Select all";
|
|
10
|
+
const label = getLabel(hasSelected, props.selectedCount, props.subjectNoun);
|
|
11
|
+
const handleSelectAll = hasSelected ? props.onClearAll : props.onSelectAll;
|
|
12
|
+
const showAction = hasSelected || props.hasOptionsVisible;
|
|
13
|
+
return (React.createElement("div", { className: styles.header, "data-testid": "ATL-Combobox-Header" },
|
|
14
|
+
React.createElement(Typography, { textColor: "heading", fontWeight: "semiBold" }, label),
|
|
15
|
+
showAction && (React.createElement(Button, { size: "small", label: actionLabel, type: "tertiary", onClick: handleSelectAll }))));
|
|
16
|
+
}
|
|
17
|
+
function getLabel(hasSelected, count, subjectNoun) {
|
|
18
|
+
if (hasSelected) {
|
|
19
|
+
return `${count} selected`;
|
|
20
|
+
}
|
|
21
|
+
if (subjectNoun) {
|
|
22
|
+
return `Select ${subjectNoun}`;
|
|
23
|
+
}
|
|
24
|
+
return "Select";
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export { ComboboxContentHeader as C };
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import classnames from 'classnames';
|
|
3
|
+
import { T as Text } from './Text-CyaxiLeN.js';
|
|
4
|
+
import { G as Glimmer } from './Glimmer-C-o8hGKO.js';
|
|
5
|
+
import { S as Spinner } from './Spinner-CRjrJ0LO.js';
|
|
6
|
+
import { A as AnimatedPresence } from './AnimatedPresence-Dg0rSWmK.js';
|
|
7
|
+
import { C as ComboboxOption } from './ComboboxOption-BPLxC2h4.js';
|
|
8
|
+
import { C as ComboboxLoadMore } from './ComboboxLoadMore-lwIHDJ3e.js';
|
|
9
|
+
|
|
10
|
+
var styles = {"container":"SgMzjOcdE-E-","optionsList":"TwoTCjgcssc-","filterMessage":"_8T5M7MGwCRE-","emptyStateMessage":"_4y5NXkNeIQM-","scrollTop":"T6E3VwBGoQM-","scrollNone":"_6HQzxMQkXnE-","scrollBottom":"_5YsJZyMDkbA-","loadingContainer":"A6z4OI58xoE-","hasOptions":"QqHBSf52fPk-"};
|
|
11
|
+
|
|
12
|
+
function ComboboxContentList(props) {
|
|
13
|
+
const optionsExist = props.options.length > 0;
|
|
14
|
+
const hasSearchTerm = props.searchValue.length > 0;
|
|
15
|
+
const { listScrollState } = useScrollState(props.optionsListRef, props.options);
|
|
16
|
+
return (React.createElement("div", { className: classnames(styles.container, styles[listScrollState]) },
|
|
17
|
+
optionsExist && (React.createElement("ul", { className: styles.optionsList, role: "listbox", "aria-multiselectable": props.multiselect, ref: props.optionsListRef },
|
|
18
|
+
props.options.map(option => {
|
|
19
|
+
return (React.createElement(ComboboxOption, { key: option.id, id: option.id, label: option.label, prefix: option.prefix }));
|
|
20
|
+
}),
|
|
21
|
+
React.createElement("div", { className: classnames([styles.loadingContainer, styles.hasOptions]) },
|
|
22
|
+
React.createElement(AnimatedPresence, { transition: "fromBottom" }, Boolean(props.loading && optionsExist) && (React.createElement(Spinner, { size: "small" })))),
|
|
23
|
+
props.onLoadMore && (React.createElement(ComboboxLoadMore, { onLoadMore: props.onLoadMore })))),
|
|
24
|
+
props.loading && !optionsExist && (React.createElement(React.Fragment, null, Array.from({ length: 5 }).map((_, index) => (React.createElement("div", { className: styles.loadingContainer, key: index },
|
|
25
|
+
React.createElement(Glimmer, { shape: "rectangle", size: "small" })))))),
|
|
26
|
+
hasSearchTerm && !props.loading && !optionsExist && (React.createElement("div", { className: styles.filterMessage },
|
|
27
|
+
React.createElement(Text, { variation: "subdued" },
|
|
28
|
+
"No results for ",
|
|
29
|
+
`“${props.searchValue}”`))),
|
|
30
|
+
!hasSearchTerm && !props.loading && !optionsExist && (React.createElement("div", { className: styles.emptyStateMessage },
|
|
31
|
+
React.createElement(Text, { variation: "subdued" }, getZeroIndexStateText(props.subjectNoun))))));
|
|
32
|
+
}
|
|
33
|
+
function getZeroIndexStateText(subjectNoun) {
|
|
34
|
+
if (subjectNoun) {
|
|
35
|
+
return `You don't have any ${subjectNoun} yet`;
|
|
36
|
+
}
|
|
37
|
+
return "No options yet";
|
|
38
|
+
}
|
|
39
|
+
function useScrollState(optionsListRef, options) {
|
|
40
|
+
const [listScrollState, setlistScrollState] = useState("");
|
|
41
|
+
useEffect(() => {
|
|
42
|
+
const handleScroll = () => {
|
|
43
|
+
if (optionsListRef.current) {
|
|
44
|
+
const { scrollTop, clientHeight, scrollHeight } = optionsListRef.current;
|
|
45
|
+
if (scrollHeight === clientHeight) {
|
|
46
|
+
setlistScrollState("scrollNone");
|
|
47
|
+
}
|
|
48
|
+
else if (scrollTop === 0) {
|
|
49
|
+
setlistScrollState("scrollTop");
|
|
50
|
+
}
|
|
51
|
+
else if (scrollTop + clientHeight >= scrollHeight) {
|
|
52
|
+
setlistScrollState("scrollBottom");
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
setlistScrollState("");
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
if (options.length === 0) {
|
|
60
|
+
handleScroll();
|
|
61
|
+
}
|
|
62
|
+
if (optionsListRef.current) {
|
|
63
|
+
optionsListRef.current.addEventListener("scroll", handleScroll);
|
|
64
|
+
handleScroll();
|
|
65
|
+
}
|
|
66
|
+
return () => {
|
|
67
|
+
if (optionsListRef.current) {
|
|
68
|
+
optionsListRef.current.removeEventListener("scroll", handleScroll);
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
}, [options]);
|
|
72
|
+
return { listScrollState };
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
export { ComboboxContentList as C };
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var classnames = require('classnames');
|
|
5
|
+
var Text = require('./Text-C0pm--c0.js');
|
|
6
|
+
var Glimmer = require('./Glimmer-BG7eX9ml.js');
|
|
7
|
+
var Spinner = require('./Spinner-DBuwcAqL.js');
|
|
8
|
+
var AnimatedPresence = require('./AnimatedPresence-kepj98O9.js');
|
|
9
|
+
var ComboboxOption = require('./ComboboxOption-CJpTBVXu.js');
|
|
10
|
+
var ComboboxLoadMore = require('./ComboboxLoadMore-9FgWV4Uv.js');
|
|
11
|
+
|
|
12
|
+
var styles = {"container":"SgMzjOcdE-E-","optionsList":"TwoTCjgcssc-","filterMessage":"_8T5M7MGwCRE-","emptyStateMessage":"_4y5NXkNeIQM-","scrollTop":"T6E3VwBGoQM-","scrollNone":"_6HQzxMQkXnE-","scrollBottom":"_5YsJZyMDkbA-","loadingContainer":"A6z4OI58xoE-","hasOptions":"QqHBSf52fPk-"};
|
|
13
|
+
|
|
14
|
+
function ComboboxContentList(props) {
|
|
15
|
+
const optionsExist = props.options.length > 0;
|
|
16
|
+
const hasSearchTerm = props.searchValue.length > 0;
|
|
17
|
+
const { listScrollState } = useScrollState(props.optionsListRef, props.options);
|
|
18
|
+
return (React.createElement("div", { className: classnames(styles.container, styles[listScrollState]) },
|
|
19
|
+
optionsExist && (React.createElement("ul", { className: styles.optionsList, role: "listbox", "aria-multiselectable": props.multiselect, ref: props.optionsListRef },
|
|
20
|
+
props.options.map(option => {
|
|
21
|
+
return (React.createElement(ComboboxOption.ComboboxOption, { key: option.id, id: option.id, label: option.label, prefix: option.prefix }));
|
|
22
|
+
}),
|
|
23
|
+
React.createElement("div", { className: classnames([styles.loadingContainer, styles.hasOptions]) },
|
|
24
|
+
React.createElement(AnimatedPresence.AnimatedPresence, { transition: "fromBottom" }, Boolean(props.loading && optionsExist) && (React.createElement(Spinner.Spinner, { size: "small" })))),
|
|
25
|
+
props.onLoadMore && (React.createElement(ComboboxLoadMore.ComboboxLoadMore, { onLoadMore: props.onLoadMore })))),
|
|
26
|
+
props.loading && !optionsExist && (React.createElement(React.Fragment, null, Array.from({ length: 5 }).map((_, index) => (React.createElement("div", { className: styles.loadingContainer, key: index },
|
|
27
|
+
React.createElement(Glimmer.Glimmer, { shape: "rectangle", size: "small" })))))),
|
|
28
|
+
hasSearchTerm && !props.loading && !optionsExist && (React.createElement("div", { className: styles.filterMessage },
|
|
29
|
+
React.createElement(Text.Text, { variation: "subdued" },
|
|
30
|
+
"No results for ",
|
|
31
|
+
`“${props.searchValue}”`))),
|
|
32
|
+
!hasSearchTerm && !props.loading && !optionsExist && (React.createElement("div", { className: styles.emptyStateMessage },
|
|
33
|
+
React.createElement(Text.Text, { variation: "subdued" }, getZeroIndexStateText(props.subjectNoun))))));
|
|
34
|
+
}
|
|
35
|
+
function getZeroIndexStateText(subjectNoun) {
|
|
36
|
+
if (subjectNoun) {
|
|
37
|
+
return `You don't have any ${subjectNoun} yet`;
|
|
38
|
+
}
|
|
39
|
+
return "No options yet";
|
|
40
|
+
}
|
|
41
|
+
function useScrollState(optionsListRef, options) {
|
|
42
|
+
const [listScrollState, setlistScrollState] = React.useState("");
|
|
43
|
+
React.useEffect(() => {
|
|
44
|
+
const handleScroll = () => {
|
|
45
|
+
if (optionsListRef.current) {
|
|
46
|
+
const { scrollTop, clientHeight, scrollHeight } = optionsListRef.current;
|
|
47
|
+
if (scrollHeight === clientHeight) {
|
|
48
|
+
setlistScrollState("scrollNone");
|
|
49
|
+
}
|
|
50
|
+
else if (scrollTop === 0) {
|
|
51
|
+
setlistScrollState("scrollTop");
|
|
52
|
+
}
|
|
53
|
+
else if (scrollTop + clientHeight >= scrollHeight) {
|
|
54
|
+
setlistScrollState("scrollBottom");
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
setlistScrollState("");
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
if (options.length === 0) {
|
|
62
|
+
handleScroll();
|
|
63
|
+
}
|
|
64
|
+
if (optionsListRef.current) {
|
|
65
|
+
optionsListRef.current.addEventListener("scroll", handleScroll);
|
|
66
|
+
handleScroll();
|
|
67
|
+
}
|
|
68
|
+
return () => {
|
|
69
|
+
if (optionsListRef.current) {
|
|
70
|
+
optionsListRef.current.removeEventListener("scroll", handleScroll);
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
}, [options]);
|
|
74
|
+
return { listScrollState };
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
exports.ComboboxContentList = ComboboxContentList;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var Icon = require('./Icon-5T1h0cSC.js');
|
|
5
|
+
|
|
6
|
+
var styles = {"search":"MIyb-oFZg9w-","searchInput":"WZPK91I4aJs-","clearSearch":"_7loHrVUe-Rk-"};
|
|
7
|
+
|
|
8
|
+
function ComboboxContentSearch(props) {
|
|
9
|
+
const searchRef = React.useRef(null);
|
|
10
|
+
React.useEffect(() => {
|
|
11
|
+
if (props.open) {
|
|
12
|
+
setTimeout(() => {
|
|
13
|
+
var _a;
|
|
14
|
+
(_a = searchRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
|
15
|
+
}, 0);
|
|
16
|
+
}
|
|
17
|
+
}, [props.open]);
|
|
18
|
+
return (React.createElement("div", { className: styles.search },
|
|
19
|
+
React.createElement("input", { type: "search", ref: searchRef, className: styles.searchInput, placeholder: props.placeholder ? `Search ${props.placeholder}` : "Search", onChange: (event) => handleSearch(event), value: props.searchValue }),
|
|
20
|
+
props.searchValue && (React.createElement("button", { className: styles.clearSearch, onClick: clearSearch, type: "button", "data-testid": "ATL-Combobox-Content-Search-Clear", "aria-label": "Clear search" },
|
|
21
|
+
React.createElement(Icon.Icon, { name: "remove", size: "small" })))));
|
|
22
|
+
function clearSearch() {
|
|
23
|
+
var _a;
|
|
24
|
+
props.setSearchValue("");
|
|
25
|
+
props.handleSearchChange("");
|
|
26
|
+
(_a = searchRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
|
27
|
+
}
|
|
28
|
+
function handleSearch(event) {
|
|
29
|
+
props.setSearchValue(event.currentTarget.value);
|
|
30
|
+
props.handleSearchChange(event.currentTarget.value);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
exports.ComboboxContentSearch = ComboboxContentSearch;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import React, { useRef, useEffect } from 'react';
|
|
2
|
+
import { I as Icon } from './Icon-zn-zanGs.js';
|
|
3
|
+
|
|
4
|
+
var styles = {"search":"MIyb-oFZg9w-","searchInput":"WZPK91I4aJs-","clearSearch":"_7loHrVUe-Rk-"};
|
|
5
|
+
|
|
6
|
+
function ComboboxContentSearch(props) {
|
|
7
|
+
const searchRef = useRef(null);
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
if (props.open) {
|
|
10
|
+
setTimeout(() => {
|
|
11
|
+
var _a;
|
|
12
|
+
(_a = searchRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
|
13
|
+
}, 0);
|
|
14
|
+
}
|
|
15
|
+
}, [props.open]);
|
|
16
|
+
return (React.createElement("div", { className: styles.search },
|
|
17
|
+
React.createElement("input", { type: "search", ref: searchRef, className: styles.searchInput, placeholder: props.placeholder ? `Search ${props.placeholder}` : "Search", onChange: (event) => handleSearch(event), value: props.searchValue }),
|
|
18
|
+
props.searchValue && (React.createElement("button", { className: styles.clearSearch, onClick: clearSearch, type: "button", "data-testid": "ATL-Combobox-Content-Search-Clear", "aria-label": "Clear search" },
|
|
19
|
+
React.createElement(Icon, { name: "remove", size: "small" })))));
|
|
20
|
+
function clearSearch() {
|
|
21
|
+
var _a;
|
|
22
|
+
props.setSearchValue("");
|
|
23
|
+
props.handleSearchChange("");
|
|
24
|
+
(_a = searchRef.current) === null || _a === void 0 ? void 0 : _a.focus();
|
|
25
|
+
}
|
|
26
|
+
function handleSearch(event) {
|
|
27
|
+
props.setSearchValue(event.currentTarget.value);
|
|
28
|
+
props.handleSearchChange(event.currentTarget.value);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export { ComboboxContentSearch as C };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var useInView = require('./useInView-fsT3lwCU.js');
|
|
5
|
+
|
|
6
|
+
var styles = {"trigger":"_3s8-RC5Ky3s-"};
|
|
7
|
+
|
|
8
|
+
function ComboboxLoadMore({ onLoadMore }) {
|
|
9
|
+
const [inViewRef, isInView] = useInView.useInView_2();
|
|
10
|
+
React.useEffect(() => {
|
|
11
|
+
isInView && onLoadMore();
|
|
12
|
+
}, [isInView]);
|
|
13
|
+
return (React.createElement("div", { "data-testid": "ATL-Combobox-Loadmore-Trigger", ref: inViewRef, className: styles.trigger }));
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
exports.ComboboxLoadMore = ComboboxLoadMore;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React, { useEffect } from 'react';
|
|
2
|
+
import { u as useInView_2 } from './useInView-Bj_Jl5Bw.js';
|
|
3
|
+
|
|
4
|
+
var styles = {"trigger":"_3s8-RC5Ky3s-"};
|
|
5
|
+
|
|
6
|
+
function ComboboxLoadMore({ onLoadMore }) {
|
|
7
|
+
const [inViewRef, isInView] = useInView_2();
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
isInView && onLoadMore();
|
|
10
|
+
}, [isInView]);
|
|
11
|
+
return (React.createElement("div", { "data-testid": "ATL-Combobox-Loadmore-Trigger", ref: inViewRef, className: styles.trigger }));
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export { ComboboxLoadMore as C };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
import classnames from 'classnames';
|
|
3
|
+
import { I as Icon } from './Icon-zn-zanGs.js';
|
|
4
|
+
import { F as Flex } from './Flex-DnI4PG_x.js';
|
|
5
|
+
import { a as ComboboxContext } from './ComboboxProvider-BzFHJNMs.js';
|
|
6
|
+
|
|
7
|
+
var styles = {"option":"_5QdRGmaNHvc-"};
|
|
8
|
+
|
|
9
|
+
function ComboboxOption(props) {
|
|
10
|
+
const { selected, selectionHandler } = useContext(ComboboxContext);
|
|
11
|
+
const isSelected = selected.some(selection => selection.id.toString() === props.id.toString());
|
|
12
|
+
return (React.createElement("li", { key: props.id, tabIndex: -1, "data-selected": isSelected, role: "option", "aria-selected": isSelected, onClick: () => selectionHandler &&
|
|
13
|
+
selectionHandler({ id: props.id, label: props.label }), className: classnames(styles.option) },
|
|
14
|
+
React.createElement(Flex, { template: props.prefix ? ["shrink", "grow"] : ["grow"] },
|
|
15
|
+
props.prefix,
|
|
16
|
+
props.label),
|
|
17
|
+
React.createElement("div", null, isSelected && React.createElement(Icon, { name: "checkmark", color: "blue" }))));
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export { ComboboxOption as C };
|