@jetshop/ui 6.3.9-alpha.0 → 6.3.9-alpha.2
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/Accordion/Accordion.d.ts +33 -0
- package/Accordion/Accordion.js +59 -0
- package/Accordion/Accordion.js.map +1 -0
- package/Auth/FormFields/CountriesInput.d.ts +16 -0
- package/Auth/FormFields/CountriesInput.js +28 -0
- package/Auth/FormFields/CountriesInput.js.map +1 -0
- package/Auth/LogInBehavior.d.ts +22 -0
- package/Auth/LogInBehavior.js +24 -0
- package/Auth/LogInBehavior.js.map +1 -0
- package/Auth/LogInFormProvider.d.ts +7 -0
- package/Auth/LogInFormProvider.js +70 -0
- package/Auth/LogInFormProvider.js.map +1 -0
- package/Auth/LogOut.d.ts +10 -0
- package/Auth/LogOut.js +24 -0
- package/Auth/LogOut.js.map +1 -0
- package/Auth/logInValidator.d.ts +10 -0
- package/Auth/logInValidator.js +16 -0
- package/Auth/logInValidator.js.map +1 -0
- package/Breadcrumbs/Breadcrumbs.d.ts +14 -0
- package/Breadcrumbs/Breadcrumbs.js +84 -0
- package/Breadcrumbs/Breadcrumbs.js.map +1 -0
- package/Breadcrumbs/getParentsOrCanonicalRoute.d.ts +3 -0
- package/Breadcrumbs/getParentsOrCanonicalRoute.js +14 -0
- package/Breadcrumbs/getParentsOrCanonicalRoute.js.map +1 -0
- package/Breadcrumbs/index.d.ts +1 -0
- package/Breadcrumbs/index.js +2 -0
- package/Breadcrumbs/index.js.map +1 -0
- package/Breakpoints.d.ts +12 -0
- package/Breakpoints.js +36 -0
- package/Breakpoints.js.map +1 -0
- package/Button/Button.d.ts +14 -0
- package/Button/Button.js +60 -0
- package/Button/Button.js.map +1 -0
- package/Button/SecondaryButton.d.ts +2 -0
- package/Button/SecondaryButton.js +9 -0
- package/Button/SecondaryButton.js.map +1 -0
- package/Button/TrendButton.d.ts +2 -0
- package/Button/TrendButton.js +8 -0
- package/Button/TrendButton.js.map +1 -0
- package/Button/index.d.ts +4 -0
- package/Button/index.js +5 -0
- package/Button/index.js.map +1 -0
- package/CategoryLink.d.ts +11 -0
- package/CategoryLink.js +49 -0
- package/CategoryLink.js.map +1 -0
- package/ChannelSelector/ChannelListItem.d.ts +10 -0
- package/ChannelSelector/ChannelListItem.js +51 -0
- package/ChannelSelector/ChannelListItem.js.map +1 -0
- package/ChannelSelector/ChannelSelector.d.ts +63 -0
- package/ChannelSelector/ChannelSelector.js +80 -0
- package/ChannelSelector/ChannelSelector.js.map +1 -0
- package/ChannelSelector/ChannelSelectorButtons.d.ts +2 -0
- package/ChannelSelector/ChannelSelectorButtons.js +20 -0
- package/ChannelSelector/ChannelSelectorButtons.js.map +1 -0
- package/ChannelSelector/Channels.d.ts +17 -0
- package/ChannelSelector/Channels.js +12 -0
- package/ChannelSelector/Channels.js.map +1 -0
- package/ChannelSelector/LargeSelector.d.ts +3 -0
- package/ChannelSelector/LargeSelector.js +67 -0
- package/ChannelSelector/LargeSelector.js.map +1 -0
- package/ChannelSelector/MiniSelector.d.ts +4 -0
- package/ChannelSelector/MiniSelector.js +58 -0
- package/ChannelSelector/MiniSelector.js.map +1 -0
- package/ChannelSelector/Region.d.ts +28 -0
- package/ChannelSelector/Region.js +21 -0
- package/ChannelSelector/Region.js.map +1 -0
- package/ChannelSelector/groupBy.d.ts +7 -0
- package/ChannelSelector/groupBy.js +16 -0
- package/ChannelSelector/groupBy.js.map +1 -0
- package/Checkbox/Checkbox.d.ts +14 -0
- package/Checkbox/Checkbox.js +70 -0
- package/Checkbox/Checkbox.js.map +1 -0
- package/Checkbox/CheckboxGroup.d.ts +27 -0
- package/Checkbox/CheckboxGroup.js +22 -0
- package/Checkbox/CheckboxGroup.js.map +1 -0
- package/Checkbox/index.d.ts +2 -0
- package/Checkbox/index.js +3 -0
- package/Checkbox/index.js.map +1 -0
- package/CloudflareImage/BaseImage.d.ts +40 -0
- package/CloudflareImage/BaseImage.js +192 -0
- package/CloudflareImage/BaseImage.js.map +1 -0
- package/CloudflareImage/Fallback.d.ts +5 -0
- package/CloudflareImage/Fallback.js +4 -0
- package/CloudflareImage/Fallback.js.map +1 -0
- package/CloudflareImage/FlightImage.d.ts +51 -0
- package/CloudflareImage/FlightImage.js +61 -0
- package/CloudflareImage/FlightImage.js.map +1 -0
- package/CloudflareImage/Image.d.ts +2 -0
- package/CloudflareImage/Image.js +3 -0
- package/CloudflareImage/Image.js.map +1 -0
- package/CloudflareImage/index.d.ts +1 -0
- package/CloudflareImage/index.js +2 -0
- package/CloudflareImage/index.js.map +1 -0
- package/CloudflareImage/useConstructImage.d.ts +49 -0
- package/CloudflareImage/useConstructImage.js +122 -0
- package/CloudflareImage/useConstructImage.js.map +1 -0
- package/CloudflareImage/utils/aspectRatioToFraction.d.ts +2 -0
- package/CloudflareImage/utils/aspectRatioToFraction.js +11 -0
- package/CloudflareImage/utils/aspectRatioToFraction.js.map +1 -0
- package/CloudflareImage/utils/getFullUrl.d.ts +6 -0
- package/CloudflareImage/utils/getFullUrl.js +18 -0
- package/CloudflareImage/utils/getFullUrl.js.map +1 -0
- package/CloudflareImage/utils/getImageWidth.d.ts +1 -0
- package/CloudflareImage/utils/getImageWidth.js +12 -0
- package/CloudflareImage/utils/getImageWidth.js.map +1 -0
- package/CloudflareImage/utils/getImageWidths.d.ts +2 -0
- package/CloudflareImage/utils/getImageWidths.js +21 -0
- package/CloudflareImage/utils/getImageWidths.js.map +1 -0
- package/CloudflareImage/utils/getLQIP.d.ts +8 -0
- package/CloudflareImage/utils/getLQIP.js +21 -0
- package/CloudflareImage/utils/getLQIP.js.map +1 -0
- package/CloudflareImage/utils/getLargestSize.d.ts +7 -0
- package/CloudflareImage/utils/getLargestSize.js +17 -0
- package/CloudflareImage/utils/getLargestSize.js.map +1 -0
- package/CloudflareImage/utils/getSizeForBreakpoint.d.ts +2 -0
- package/CloudflareImage/utils/getSizeForBreakpoint.js +16 -0
- package/CloudflareImage/utils/getSizeForBreakpoint.js.map +1 -0
- package/CloudflareImage/utils/getSizesMap.d.ts +2 -0
- package/CloudflareImage/utils/getSizesMap.js +35 -0
- package/CloudflareImage/utils/getSizesMap.js.map +1 -0
- package/CloudflareImage/utils/getSmallestSize.d.ts +2 -0
- package/CloudflareImage/utils/getSmallestSize.js +12 -0
- package/CloudflareImage/utils/getSmallestSize.js.map +1 -0
- package/CloudflareImage/utils/getSrcSetFromWidths.d.ts +10 -0
- package/CloudflareImage/utils/getSrcSetFromWidths.js +10 -0
- package/CloudflareImage/utils/getSrcSetFromWidths.js.map +1 -0
- package/CloudflareImage/utils/getSrcWithParams.d.ts +3 -0
- package/CloudflareImage/utils/getSrcWithParams.js +33 -0
- package/CloudflareImage/utils/getSrcWithParams.js.map +1 -0
- package/CloudflareImage/utils/paddingForAspectRatio.d.ts +1 -0
- package/CloudflareImage/utils/paddingForAspectRatio.js +6 -0
- package/CloudflareImage/utils/paddingForAspectRatio.js.map +1 -0
- package/CloudflareImage/utils/remToPx.d.ts +1 -0
- package/CloudflareImage/utils/remToPx.js +2 -0
- package/CloudflareImage/utils/remToPx.js.map +1 -0
- package/CloudflareImage/utils/sizeToNumber.d.ts +2 -0
- package/CloudflareImage/utils/sizeToNumber.js +27 -0
- package/CloudflareImage/utils/sizeToNumber.js.map +1 -0
- package/ContentPageLink.d.ts +11 -0
- package/ContentPageLink.js +46 -0
- package/ContentPageLink.js.map +1 -0
- package/ContentRenderer.d.ts +9 -0
- package/ContentRenderer.js +36 -0
- package/ContentRenderer.js.map +1 -0
- package/DropdownMenu/Button.d.ts +7 -0
- package/DropdownMenu/Button.js +33 -0
- package/DropdownMenu/Button.js.map +1 -0
- package/DropdownMenu/DropdownMenu.d.ts +21 -0
- package/DropdownMenu/DropdownMenu.js +72 -0
- package/DropdownMenu/DropdownMenu.js.map +1 -0
- package/DropdownMenu/Item.d.ts +13 -0
- package/DropdownMenu/Item.js +48 -0
- package/DropdownMenu/Item.js.map +1 -0
- package/DropdownMenu/Items.d.ts +16 -0
- package/DropdownMenu/Items.js +53 -0
- package/DropdownMenu/Items.js.map +1 -0
- package/DropdownMenu/index.d.ts +4 -0
- package/DropdownMenu/index.js +5 -0
- package/DropdownMenu/index.js.map +1 -0
- package/ErrorBoundary/Generic.d.ts +18 -0
- package/ErrorBoundary/Generic.js +69 -0
- package/ErrorBoundary/Generic.js.map +1 -0
- package/ErrorBoundary/PassThrough.d.ts +3 -0
- package/ErrorBoundary/PassThrough.js +7 -0
- package/ErrorBoundary/PassThrough.js.map +1 -0
- package/Gallery/Gallery.d.ts +39 -0
- package/Gallery/Gallery.js +121 -0
- package/Gallery/Gallery.js.map +1 -0
- package/Gallery/constructGallery.d.ts +15 -0
- package/Gallery/constructGallery.js +40 -0
- package/Gallery/constructGallery.js.map +1 -0
- package/Image/BaseImage.d.ts +39 -0
- package/Image/BaseImage.js +192 -0
- package/Image/BaseImage.js.map +1 -0
- package/Image/Fallback.d.ts +5 -0
- package/Image/Fallback.js +4 -0
- package/Image/Fallback.js.map +1 -0
- package/Image/FlightImage.d.ts +51 -0
- package/Image/FlightImage.js +59 -0
- package/Image/FlightImage.js.map +1 -0
- package/Image/Image.d.ts +2 -0
- package/Image/Image.js +3 -0
- package/Image/Image.js.map +1 -0
- package/Image/index.d.ts +1 -0
- package/Image/index.js +2 -0
- package/Image/index.js.map +1 -0
- package/Image/useConstructImage.d.ts +49 -0
- package/Image/useConstructImage.js +122 -0
- package/Image/useConstructImage.js.map +1 -0
- package/Image/utils/aspectRatioToFraction.d.ts +2 -0
- package/Image/utils/aspectRatioToFraction.js +11 -0
- package/Image/utils/aspectRatioToFraction.js.map +1 -0
- package/Image/utils/getFullUrl.d.ts +6 -0
- package/Image/utils/getFullUrl.js +18 -0
- package/Image/utils/getFullUrl.js.map +1 -0
- package/Image/utils/getImageWidth.d.ts +1 -0
- package/Image/utils/getImageWidth.js +12 -0
- package/Image/utils/getImageWidth.js.map +1 -0
- package/Image/utils/getImageWidths.d.ts +2 -0
- package/Image/utils/getImageWidths.js +21 -0
- package/Image/utils/getImageWidths.js.map +1 -0
- package/Image/utils/getLQIP.d.ts +8 -0
- package/Image/utils/getLQIP.js +20 -0
- package/Image/utils/getLQIP.js.map +1 -0
- package/Image/utils/getLargestSize.d.ts +7 -0
- package/Image/utils/getLargestSize.js +17 -0
- package/Image/utils/getLargestSize.js.map +1 -0
- package/Image/utils/getSizeForBreakpoint.d.ts +2 -0
- package/Image/utils/getSizeForBreakpoint.js +16 -0
- package/Image/utils/getSizeForBreakpoint.js.map +1 -0
- package/Image/utils/getSizesMap.d.ts +2 -0
- package/Image/utils/getSizesMap.js +35 -0
- package/Image/utils/getSizesMap.js.map +1 -0
- package/Image/utils/getSmallestSize.d.ts +2 -0
- package/Image/utils/getSmallestSize.js +12 -0
- package/Image/utils/getSmallestSize.js.map +1 -0
- package/Image/utils/getSrcSetFromWidths.d.ts +10 -0
- package/Image/utils/getSrcSetFromWidths.js +9 -0
- package/Image/utils/getSrcSetFromWidths.js.map +1 -0
- package/Image/utils/getSrcWithParams.d.ts +3 -0
- package/Image/utils/getSrcWithParams.js +29 -0
- package/Image/utils/getSrcWithParams.js.map +1 -0
- package/Image/utils/paddingForAspectRatio.d.ts +1 -0
- package/Image/utils/paddingForAspectRatio.js +6 -0
- package/Image/utils/paddingForAspectRatio.js.map +1 -0
- package/Image/utils/remToPx.d.ts +1 -0
- package/Image/utils/remToPx.js +2 -0
- package/Image/utils/remToPx.js.map +1 -0
- package/Image/utils/sizeToNumber.d.ts +2 -0
- package/Image/utils/sizeToNumber.js +27 -0
- package/Image/utils/sizeToNumber.js.map +1 -0
- package/Input/Input.d.ts +6 -0
- package/Input/Input.js +45 -0
- package/Input/Input.js.map +1 -0
- package/Input/index.d.ts +3 -0
- package/Input/index.js +4 -0
- package/Input/index.js.map +1 -0
- package/JetshopText.d.ts +3 -0
- package/JetshopText.js +13 -0
- package/JetshopText.js.map +1 -0
- package/Loading/LoadingBar.d.ts +8 -0
- package/Loading/LoadingBar.js +58 -0
- package/Loading/LoadingBar.js.map +1 -0
- package/Loading/LoadingLine.d.ts +31 -0
- package/Loading/LoadingLine.js +26 -0
- package/Loading/LoadingLine.js.map +1 -0
- package/Loading/NetworkStatusNotifier.d.ts +6 -0
- package/Loading/NetworkStatusNotifier.js +8 -0
- package/Loading/NetworkStatusNotifier.js.map +1 -0
- package/Menu/MenuContainer.d.ts +28 -0
- package/Menu/MenuContainer.js +46 -0
- package/Menu/MenuContainer.js.map +1 -0
- package/Menu/RecursiveTree.d.ts +28 -0
- package/Menu/RecursiveTree.js +91 -0
- package/Menu/RecursiveTree.js.map +1 -0
- package/Modal/Drawer/Drawer.d.ts +12 -0
- package/Modal/Drawer/Drawer.js +31 -0
- package/Modal/Drawer/Drawer.js.map +1 -0
- package/Modal/Drawer/DrawerTarget.d.ts +6 -0
- package/Modal/Drawer/DrawerTarget.js +12 -0
- package/Modal/Drawer/DrawerTarget.js.map +1 -0
- package/Modal/Drawer/DrawerTrigger.d.ts +11 -0
- package/Modal/Drawer/DrawerTrigger.js +16 -0
- package/Modal/Drawer/DrawerTrigger.js.map +1 -0
- package/Modal/Drawer/index.d.ts +3 -0
- package/Modal/Drawer/index.js +4 -0
- package/Modal/Drawer/index.js.map +1 -0
- package/Modal/Flyout/FlyoutTarget.d.ts +10 -0
- package/Modal/Flyout/FlyoutTarget.js +15 -0
- package/Modal/Flyout/FlyoutTarget.js.map +1 -0
- package/Modal/Flyout/FlyoutTrigger.d.ts +15 -0
- package/Modal/Flyout/FlyoutTrigger.js +18 -0
- package/Modal/Flyout/FlyoutTrigger.js.map +1 -0
- package/Modal/Flyout/index.d.ts +2 -0
- package/Modal/Flyout/index.js +3 -0
- package/Modal/Flyout/index.js.map +1 -0
- package/Modal/ModalContext.d.ts +26 -0
- package/Modal/ModalContext.js +9 -0
- package/Modal/ModalContext.js.map +1 -0
- package/Modal/ModalProvider.d.ts +5 -0
- package/Modal/ModalProvider.js +83 -0
- package/Modal/ModalProvider.js.map +1 -0
- package/Modal/ModalRoot.d.ts +3 -0
- package/Modal/ModalRoot.js +44 -0
- package/Modal/ModalRoot.js.map +1 -0
- package/Modal/ModalTrigger.d.ts +9 -0
- package/Modal/ModalTrigger.js +9 -0
- package/Modal/ModalTrigger.js.map +1 -0
- package/Pagination/Pagination.d.ts +7 -0
- package/Pagination/Pagination.js +23 -0
- package/Pagination/Pagination.js.map +1 -0
- package/Pagination/PaginationBehaviour.d.ts +52 -0
- package/Pagination/PaginationBehaviour.js +68 -0
- package/Pagination/PaginationBehaviour.js.map +1 -0
- package/Pagination/index.d.ts +2 -0
- package/Pagination/index.js +3 -0
- package/Pagination/index.js.map +1 -0
- package/Pagination/usePagination.d.ts +15 -0
- package/Pagination/usePagination.js +46 -0
- package/Pagination/usePagination.js.map +1 -0
- package/PreOrderDateSelector/PreOrderDateSelector.d.ts +23 -0
- package/PreOrderDateSelector/PreOrderDateSelector.js +74 -0
- package/PreOrderDateSelector/PreOrderDateSelector.js.map +1 -0
- package/PreOrderDateSelector/index.d.ts +2 -0
- package/PreOrderDateSelector/index.js +3 -0
- package/PreOrderDateSelector/index.js.map +1 -0
- package/Price/Currency.d.ts +9 -0
- package/Price/Currency.js +11 -0
- package/Price/Currency.js.map +1 -0
- package/Price/Price.d.ts +44 -0
- package/Price/Price.js +74 -0
- package/Price/Price.js.map +1 -0
- package/Price/index.d.ts +1 -0
- package/Price/index.js +2 -0
- package/Price/index.js.map +1 -0
- package/ProductLink.d.ts +23 -0
- package/ProductLink.js +88 -0
- package/ProductLink.js.map +1 -0
- package/ProductList/Badges.d.ts +6 -0
- package/ProductList/Badges.js +56 -0
- package/ProductList/Badges.js.map +1 -0
- package/ProductList/GridProduct.d.ts +24 -0
- package/ProductList/GridProduct.js +58 -0
- package/ProductList/GridProduct.js.map +1 -0
- package/ProductList/ProductGrid.d.ts +16 -0
- package/ProductList/ProductGrid.js +30 -0
- package/ProductList/ProductGrid.js.map +1 -0
- package/ProductList/ProductImage.d.ts +12 -0
- package/ProductList/ProductImage.js +21 -0
- package/ProductList/ProductImage.js.map +1 -0
- package/ProductSpecifications/ProductSpecifications.d.ts +8 -0
- package/ProductSpecifications/ProductSpecifications.js +78 -0
- package/ProductSpecifications/ProductSpecifications.js.map +1 -0
- package/ScrollRestorationHandler/ScrollRestorationHandler.d.ts +8 -0
- package/ScrollRestorationHandler/ScrollRestorationHandler.js +17 -0
- package/ScrollRestorationHandler/ScrollRestorationHandler.js.map +1 -0
- package/ScrollRestorationHandler/index.d.ts +1 -0
- package/ScrollRestorationHandler/index.js +2 -0
- package/ScrollRestorationHandler/index.js.map +1 -0
- package/ScrollRestorationHandler/isInIgnoredRouteTypes.d.ts +8 -0
- package/ScrollRestorationHandler/isInIgnoredRouteTypes.js +8 -0
- package/ScrollRestorationHandler/isInIgnoredRouteTypes.js.map +1 -0
- package/ScrollRestorationHandler/useScrollRestore.d.ts +9 -0
- package/ScrollRestorationHandler/useScrollRestore.js +20 -0
- package/ScrollRestorationHandler/useScrollRestore.js.map +1 -0
- package/Search/SearchAutoCompleteContainer.d.ts +45 -0
- package/Search/SearchAutoCompleteContainer.js +172 -0
- package/Search/SearchAutoCompleteContainer.js.map +1 -0
- package/Search/SearchField.d.ts +26 -0
- package/Search/SearchField.js +98 -0
- package/Search/SearchField.js.map +1 -0
- package/Search/SearchPage/PageOf.d.ts +5 -0
- package/Search/SearchPage/PageOf.js +7 -0
- package/Search/SearchPage/PageOf.js.map +1 -0
- package/Search/SearchPage/SearchMeta.d.ts +16 -0
- package/Search/SearchPage/SearchMeta.js +20 -0
- package/Search/SearchPage/SearchMeta.js.map +1 -0
- package/Search/SearchPage/SearchPageBehaviour.d.ts +19 -0
- package/Search/SearchPage/SearchPageBehaviour.js +75 -0
- package/Search/SearchPage/SearchPageBehaviour.js.map +1 -0
- package/Search/SuggestedTerm.d.ts +16 -0
- package/Search/SuggestedTerm.js +35 -0
- package/Search/SuggestedTerm.js.map +1 -0
- package/Search/index.d.ts +1 -0
- package/Search/index.js +2 -0
- package/Search/index.js.map +1 -0
- package/Select/Components.d.ts +28 -0
- package/Select/Components.js +91 -0
- package/Select/Components.js.map +1 -0
- package/Select/SelectComponents/Quantity.d.ts +5 -0
- package/Select/SelectComponents/Quantity.js +8 -0
- package/Select/SelectComponents/Quantity.js.map +1 -0
- package/Select/index.d.ts +5 -0
- package/Select/index.js +2 -0
- package/Select/index.js.map +1 -0
- package/SortOrder/SortOrder.d.ts +16 -0
- package/SortOrder/SortOrder.js +33 -0
- package/SortOrder/SortOrder.js.map +1 -0
- package/SortOrder/SortOrderDropdown.d.ts +9 -0
- package/SortOrder/SortOrderDropdown.js +25 -0
- package/SortOrder/SortOrderDropdown.js.map +1 -0
- package/SortOrder/SortOrderList.d.ts +7 -0
- package/SortOrder/SortOrderList.js +17 -0
- package/SortOrder/SortOrderList.js.map +1 -0
- package/StartPageRenderer/StartPageRenderer.d.ts +17 -0
- package/StartPageRenderer/StartPageRenderer.js +52 -0
- package/StartPageRenderer/StartPageRenderer.js.map +1 -0
- package/StartPageRenderer/index.d.ts +1 -0
- package/StartPageRenderer/index.js +2 -0
- package/StartPageRenderer/index.js.map +1 -0
- package/Stock/StockStatusContainer.d.ts +21 -0
- package/Stock/StockStatusContainer.js +45 -0
- package/Stock/StockStatusContainer.js.map +1 -0
- package/Text/Text.d.ts +11 -0
- package/Text/Text.js +22 -0
- package/Text/Text.js.map +1 -0
- package/Text/index.d.ts +3 -0
- package/Text/index.js +4 -0
- package/Text/index.js.map +1 -0
- package/Theme/createTheme.d.ts +16 -0
- package/Theme/createTheme.js +5 -0
- package/Theme/createTheme.js.map +1 -0
- package/Theme/cssReset.d.ts +1 -0
- package/Theme/cssReset.js +160 -0
- package/Theme/cssReset.js.map +1 -0
- package/Theme/normalizeCss.d.ts +1 -0
- package/Theme/normalizeCss.js +357 -0
- package/Theme/normalizeCss.js.map +1 -0
- package/Theme/sanitizeCss.d.ts +1 -0
- package/Theme/sanitizeCss.js +572 -0
- package/Theme/sanitizeCss.js.map +1 -0
- package/WindowGrid/WindowGrid.d.ts +11 -0
- package/WindowGrid/WindowGrid.js +58 -0
- package/WindowGrid/WindowGrid.js.map +1 -0
- package/WindowGrid/index.d.ts +1 -0
- package/WindowGrid/index.js +2 -0
- package/WindowGrid/index.js.map +1 -0
- package/WindowGrid/useResizeObserver.d.ts +3 -0
- package/WindowGrid/useResizeObserver.js +14 -0
- package/WindowGrid/useResizeObserver.js.map +1 -0
- package/WindowGrid/useScrollWithWindow.d.ts +12 -0
- package/WindowGrid/useScrollWithWindow.js +39 -0
- package/WindowGrid/useScrollWithWindow.js.map +1 -0
- package/fuzzySearch/fuzzySearch.d.ts +8 -0
- package/fuzzySearch/fuzzySearch.js +43 -0
- package/fuzzySearch/fuzzySearch.js.map +1 -0
- package/fuzzySearch/index.d.ts +1 -0
- package/fuzzySearch/index.js +2 -0
- package/fuzzySearch/index.js.map +1 -0
- package/hooks/index.d.ts +2 -0
- package/hooks/index.js +3 -0
- package/hooks/index.js.map +1 -0
- package/hooks/useOnClickOutside.d.ts +6 -0
- package/hooks/useOnClickOutside.js +17 -0
- package/hooks/useOnClickOutside.js.map +1 -0
- package/hooks/useOnEsc.d.ts +4 -0
- package/hooks/useOnEsc.js +17 -0
- package/hooks/useOnEsc.js.map +1 -0
- package/package.json +3 -2
- package/utils/breakpoints.d.ts +23 -0
- package/utils/breakpoints.js +94 -0
- package/utils/breakpoints.js.map +1 -0
- package/utils/callAllEventHandlers.d.ts +5 -0
- package/utils/callAllEventHandlers.js +9 -0
- package/utils/callAllEventHandlers.js.map +1 -0
- package/utils/text.d.ts +1 -0
- package/utils/text.js +23 -0
- package/utils/text.js.map +1 -0
- package/utils/theme.d.ts +3 -0
- package/utils/theme.js +5 -0
- package/utils/theme.js.map +1 -0
- package/utils/useHoverIntent.d.ts +10 -0
- package/utils/useHoverIntent.js +78 -0
- package/utils/useHoverIntent.js.map +1 -0
- package/utils/usePropsOfType.d.ts +11 -0
- package/utils/usePropsOfType.js +18 -0
- package/utils/usePropsOfType.js.map +1 -0
- package/withFlightUI.d.ts +17 -0
- package/withFlightUI.js +20 -0
- package/withFlightUI.js.map +1 -0
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { createNetworkStatusNotifier } from 'react-apollo-network-status';
|
|
2
|
+
/**
|
|
3
|
+
* deprecate in favor of @jetshop/core/boot/NetworkStatusNotifier
|
|
4
|
+
* @deprecated deprecated in favor of @jetshop/core/boot/NetworkStatusNotifier
|
|
5
|
+
*/
|
|
6
|
+
const { link, useApolloNetworkStatus } = createNetworkStatusNotifier();
|
|
7
|
+
export { link, useApolloNetworkStatus };
|
|
8
|
+
//# sourceMappingURL=NetworkStatusNotifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NetworkStatusNotifier.js","sourceRoot":"","sources":["NetworkStatusNotifier.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,6BAA6B,CAAC;AAE1E;;;GAGG;AACH,MAAM,EAAE,IAAI,EAAE,sBAAsB,EAAE,GAAG,2BAA2B,EAAE,CAAC;AAEvE,OAAO,EAAE,IAAI,EAAE,sBAAsB,EAAE,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Category } from '@jetshop/core/types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
export interface MenuContainerProps {
|
|
4
|
+
children: (args: MenuContainerRender) => React.ReactNode;
|
|
5
|
+
allowMultipleActive?: boolean;
|
|
6
|
+
initialActiveCategories?: Category[];
|
|
7
|
+
}
|
|
8
|
+
export interface MenuContainerState {
|
|
9
|
+
activeCategories: Category[];
|
|
10
|
+
}
|
|
11
|
+
export interface MenuContainerRender {
|
|
12
|
+
activeCategories: Category[];
|
|
13
|
+
setActiveCategory(cat: Category): void;
|
|
14
|
+
removeActiveCategory(cat: Category): void;
|
|
15
|
+
toggleActiveCategory(cat: Category): void;
|
|
16
|
+
isActiveCategory(cat: Category): boolean;
|
|
17
|
+
clearActiveCategories(): void;
|
|
18
|
+
}
|
|
19
|
+
declare class MenuContainer extends React.PureComponent<MenuContainerProps, MenuContainerState> {
|
|
20
|
+
readonly state: MenuContainerState;
|
|
21
|
+
setActiveCategory: (activeCategory: Category) => void;
|
|
22
|
+
removeActiveCategory: (category: Category) => void;
|
|
23
|
+
toggleActiveCategory: (category: Category) => void;
|
|
24
|
+
clearActiveCategories: () => void;
|
|
25
|
+
isActiveCategory: (category: Category) => boolean;
|
|
26
|
+
render(): React.ReactNode;
|
|
27
|
+
}
|
|
28
|
+
export default MenuContainer;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
class MenuContainer extends React.PureComponent {
|
|
3
|
+
constructor() {
|
|
4
|
+
super(...arguments);
|
|
5
|
+
this.state = {
|
|
6
|
+
activeCategories: this.props.initialActiveCategories || []
|
|
7
|
+
};
|
|
8
|
+
this.setActiveCategory = (activeCategory) => {
|
|
9
|
+
var _a, _b;
|
|
10
|
+
const allowMultipleActive = (_b = (_a = this.props) === null || _a === void 0 ? void 0 : _a.allowMultipleActive) !== null && _b !== void 0 ? _b : false;
|
|
11
|
+
this.setState(({ activeCategories }) => ({
|
|
12
|
+
activeCategories: allowMultipleActive
|
|
13
|
+
? [...activeCategories, activeCategory]
|
|
14
|
+
: [activeCategory]
|
|
15
|
+
}));
|
|
16
|
+
};
|
|
17
|
+
this.removeActiveCategory = (category) => {
|
|
18
|
+
this.setState(({ activeCategories }) => {
|
|
19
|
+
return {
|
|
20
|
+
activeCategories: activeCategories.filter((cat) => cat.id !== category.id)
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
};
|
|
24
|
+
this.toggleActiveCategory = (category) => {
|
|
25
|
+
this.state.activeCategories.find((cat) => cat.id === category.id)
|
|
26
|
+
? this.removeActiveCategory(category)
|
|
27
|
+
: this.setActiveCategory(category);
|
|
28
|
+
};
|
|
29
|
+
this.clearActiveCategories = () => {
|
|
30
|
+
this.setState({ activeCategories: [] });
|
|
31
|
+
};
|
|
32
|
+
this.isActiveCategory = (category) => !!this.state.activeCategories.find((cat) => cat.id === category.id);
|
|
33
|
+
}
|
|
34
|
+
render() {
|
|
35
|
+
return this.props.children({
|
|
36
|
+
activeCategories: this.state.activeCategories,
|
|
37
|
+
setActiveCategory: this.setActiveCategory,
|
|
38
|
+
removeActiveCategory: this.removeActiveCategory,
|
|
39
|
+
toggleActiveCategory: this.toggleActiveCategory,
|
|
40
|
+
isActiveCategory: this.isActiveCategory,
|
|
41
|
+
clearActiveCategories: this.clearActiveCategories
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
export default MenuContainer;
|
|
46
|
+
//# sourceMappingURL=MenuContainer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MenuContainer.js","sourceRoot":"","sources":["MenuContainer.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAqB1B,MAAM,aAAc,SAAQ,KAAK,CAAC,aAGjC;IAHD;;QAIkB,UAAK,GAAuB;YAC1C,gBAAgB,EAAE,IAAI,CAAC,KAAK,CAAC,uBAAuB,IAAI,EAAE;SAC3D,CAAC;QAEF,sBAAiB,GAAG,CAAC,cAAwB,EAAE,EAAE;;YAC/C,MAAM,mBAAmB,GAAG,MAAA,MAAA,IAAI,CAAC,KAAK,0CAAE,mBAAmB,mCAAI,KAAK,CAAC;YAErE,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,gBAAgB,EAAE,EAAE,EAAE,CAAC,CAAC;gBACvC,gBAAgB,EAAE,mBAAmB;oBACnC,CAAC,CAAC,CAAC,GAAG,gBAAgB,EAAE,cAAc,CAAC;oBACvC,CAAC,CAAC,CAAC,cAAc,CAAC;aACrB,CAAC,CAAC,CAAC;QACN,CAAC,CAAC;QAEF,yBAAoB,GAAG,CAAC,QAAkB,EAAE,EAAE;YAC5C,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,gBAAgB,EAAE,EAAE,EAAE;gBACrC,OAAO;oBACL,gBAAgB,EAAE,gBAAgB,CAAC,MAAM,CACvC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,QAAQ,CAAC,EAAE,CAChC;iBACF,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;QAEF,yBAAoB,GAAG,CAAC,QAAkB,EAAE,EAAE;YAC5C,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,QAAQ,CAAC,EAAE,CAAC;gBAC/D,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC;gBACrC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QACvC,CAAC,CAAC;QAEF,0BAAqB,GAAG,GAAG,EAAE;YAC3B,IAAI,CAAC,QAAQ,CAAC,EAAE,gBAAgB,EAAE,EAAE,EAAE,CAAC,CAAC;QAC1C,CAAC,CAAC;QAEF,qBAAgB,GAAG,CAAC,QAAkB,EAAE,EAAE,CACxC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,QAAQ,CAAC,EAAE,CAAC,CAAC;IAYxE,CAAC;IAVC,MAAM;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YACzB,gBAAgB,EAAE,IAAI,CAAC,KAAK,CAAC,gBAAgB;YAC7C,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;YAC/C,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;YAC/C,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,qBAAqB,EAAE,IAAI,CAAC,qBAAqB;SAClD,CAAC,CAAC;IACL,CAAC;CACF;AAED,eAAe,aAAa,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Category } from '@jetshop/core/types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { MenuContainerRender } from './MenuContainer';
|
|
4
|
+
import { RouteChildrenProps } from 'react-router';
|
|
5
|
+
export interface RecursiveTreeProps {
|
|
6
|
+
/** The base category to render */
|
|
7
|
+
category: Category;
|
|
8
|
+
children(args: RecursiveTreeRender): React.ReactNode;
|
|
9
|
+
initialOpenMatchingCategories?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export interface RecursiveTreeRender {
|
|
12
|
+
/** Execute to fetch the next 3 levels of subcategories */
|
|
13
|
+
fetchMore(): void;
|
|
14
|
+
/** Props passed through from MenuContainer UI component */
|
|
15
|
+
menuContainerProps: MenuContainerRender;
|
|
16
|
+
/** Whether or not the current category has subcategories */
|
|
17
|
+
hasSubcategories: boolean;
|
|
18
|
+
/** An array of subcategories at the current level */
|
|
19
|
+
subcategories: Category[];
|
|
20
|
+
/** The current category being rendered */
|
|
21
|
+
category: Category;
|
|
22
|
+
/** The current category level */
|
|
23
|
+
level: number;
|
|
24
|
+
/** Execute to recursively render subcategories in place */
|
|
25
|
+
renderSubnav: React.ReactNode[];
|
|
26
|
+
}
|
|
27
|
+
declare const _default: React.ComponentClass<Pick<RecursiveTreeProps & RouteChildrenProps<{}, unknown>, keyof RecursiveTreeProps>, any> & import("react-router").WithRouterStatics<({ children, category, initialOpenMatchingCategories, ...rest }: RecursiveTreeProps & RouteChildrenProps<{}, unknown>) => React.JSX.Element>;
|
|
28
|
+
export default _default;
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import React, { useCallback, useState, useEffect, useMemo } from 'react';
|
|
13
|
+
import MenuContainer from './MenuContainer';
|
|
14
|
+
import getMoreSubCategoriesQuery from './GetMoreSubcategoriesQuery.gql';
|
|
15
|
+
import { matchPath, withRouter } from 'react-router';
|
|
16
|
+
import { useApolloClient } from '@apollo/client';
|
|
17
|
+
const RecursiveTree = (_a) => {
|
|
18
|
+
var { children, category, initialOpenMatchingCategories } = _a, rest = __rest(_a, ["children", "category", "initialOpenMatchingCategories"]);
|
|
19
|
+
const [hasFetchedMore, setHasFetchedMore] = useState(false);
|
|
20
|
+
const [subcategories, setSubcategories] = useState(category.subcategories || []);
|
|
21
|
+
const client = useApolloClient();
|
|
22
|
+
const { location } = rest;
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (category.subcategories && category.subcategories !== subcategories) {
|
|
25
|
+
setSubcategories(category.subcategories);
|
|
26
|
+
}
|
|
27
|
+
}, [category, subcategories]);
|
|
28
|
+
const fetchMoreSubcategories = useCallback(() => {
|
|
29
|
+
// Every second tier, fetch ahead 2 more tiers
|
|
30
|
+
if (category.hasSubcategories &&
|
|
31
|
+
category.level % 2 !== 0 &&
|
|
32
|
+
!hasFetchedMore) {
|
|
33
|
+
setHasFetchedMore(true);
|
|
34
|
+
return client
|
|
35
|
+
.query({
|
|
36
|
+
query: getMoreSubCategoriesQuery,
|
|
37
|
+
variables: { id: category.id }
|
|
38
|
+
})
|
|
39
|
+
.then((queryResult) => {
|
|
40
|
+
const { data: { category: { subcategories: fetchedCategories } } } = queryResult;
|
|
41
|
+
setSubcategories(fetchedCategories);
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
}, [
|
|
45
|
+
category.hasSubcategories,
|
|
46
|
+
category.id,
|
|
47
|
+
category.level,
|
|
48
|
+
client,
|
|
49
|
+
hasFetchedMore
|
|
50
|
+
]);
|
|
51
|
+
const renderRecursive = useCallback((props) => {
|
|
52
|
+
if (!category.hasSubcategories || !props.isActiveCategory(category))
|
|
53
|
+
return null;
|
|
54
|
+
return subcategories.map((subcat) => (React.createElement(RecursiveTree, Object.assign({ key: subcat.id, category: subcat, initialOpenMatchingCategories: initialOpenMatchingCategories }, rest), children)));
|
|
55
|
+
}, [category, subcategories, initialOpenMatchingCategories, rest, children]);
|
|
56
|
+
const initialActiveCategories = useMemo(() => {
|
|
57
|
+
if (initialOpenMatchingCategories) {
|
|
58
|
+
const params = {
|
|
59
|
+
path: category.primaryRoute.path,
|
|
60
|
+
strict: false,
|
|
61
|
+
exact: false
|
|
62
|
+
};
|
|
63
|
+
const match = matchPath(location.pathname, params);
|
|
64
|
+
if (match) {
|
|
65
|
+
return [category];
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return [];
|
|
69
|
+
}, [location, initialOpenMatchingCategories, category]);
|
|
70
|
+
useEffect(() => {
|
|
71
|
+
if (initialActiveCategories && !hasFetchedMore && !category.subcategories) {
|
|
72
|
+
fetchMoreSubcategories();
|
|
73
|
+
}
|
|
74
|
+
}, [
|
|
75
|
+
initialActiveCategories,
|
|
76
|
+
hasFetchedMore,
|
|
77
|
+
category,
|
|
78
|
+
fetchMoreSubcategories
|
|
79
|
+
]);
|
|
80
|
+
return (React.createElement(MenuContainer, { allowMultipleActive: true, initialActiveCategories: initialActiveCategories }, (menuProps) => children({
|
|
81
|
+
fetchMore: fetchMoreSubcategories,
|
|
82
|
+
menuContainerProps: menuProps,
|
|
83
|
+
subcategories,
|
|
84
|
+
hasSubcategories: category.hasSubcategories,
|
|
85
|
+
category,
|
|
86
|
+
renderSubnav: renderRecursive(menuProps),
|
|
87
|
+
level: category.level
|
|
88
|
+
})));
|
|
89
|
+
};
|
|
90
|
+
export default withRouter(RecursiveTree);
|
|
91
|
+
//# sourceMappingURL=RecursiveTree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RecursiveTree.js","sourceRoot":"","sources":["RecursiveTree.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface DrawerProps {
|
|
3
|
+
/** Whether to attach the drawer to the right of the screen. Defauts to false. */
|
|
4
|
+
right: boolean;
|
|
5
|
+
/** The size of the drawer in pixels. Defaults to 320. */
|
|
6
|
+
size: number;
|
|
7
|
+
/** Whether the drawer is open or not. Defaults to false. */
|
|
8
|
+
isOpen: boolean;
|
|
9
|
+
children?: React.ReactNode;
|
|
10
|
+
}
|
|
11
|
+
declare const Drawer: ({ right, size, isOpen, children }: DrawerProps) => React.JSX.Element;
|
|
12
|
+
export default Drawer;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { css, cx } from 'linaria';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
const containerStyles = css `
|
|
4
|
+
background: white;
|
|
5
|
+
height: 100%;
|
|
6
|
+
position: fixed;
|
|
7
|
+
display: flex;
|
|
8
|
+
flex-direction: column;
|
|
9
|
+
top: 0;
|
|
10
|
+
height: 100%;
|
|
11
|
+
z-index: 99999;
|
|
12
|
+
max-width: 100%;
|
|
13
|
+
-webkit-overflow-scrolling: touch;
|
|
14
|
+
overflow-y: auto;
|
|
15
|
+
|
|
16
|
+
transition: transform 0.3s ease-in-out;
|
|
17
|
+
`;
|
|
18
|
+
const Drawer = ({ right = false, size = 320, isOpen = false, children }) => {
|
|
19
|
+
const initialPosition = right // this is for server side rendering since popmotion doesn't support it
|
|
20
|
+
? {
|
|
21
|
+
transform: `translateX(${isOpen ? 0 : size}px)`,
|
|
22
|
+
right: 0
|
|
23
|
+
}
|
|
24
|
+
: {
|
|
25
|
+
transform: `translateX(-${isOpen ? 0 : size}px)`,
|
|
26
|
+
left: 0
|
|
27
|
+
};
|
|
28
|
+
return (React.createElement("div", { className: cx(containerStyles, isOpen ? 'open' : 'closed', right ? 'right' : 'left'), style: Object.assign({ width: `${size}px` }, initialPosition) }, children));
|
|
29
|
+
};
|
|
30
|
+
export default Drawer;
|
|
31
|
+
//# sourceMappingURL=Drawer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Drawer.js","sourceRoot":"","sources":["Drawer.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,eAAe,GAAG,GAAG,CAAA;;;;;;;;;;;;;;CAc1B,CAAC;AAYF,MAAM,MAAM,GAAG,CAAC,EACd,KAAK,GAAG,KAAK,EACb,IAAI,GAAG,GAAG,EACV,MAAM,GAAG,KAAK,EACd,QAAQ,EACI,EAAE,EAAE;IAChB,MAAM,eAAe,GAAG,KAAK,CAAC,uEAAuE;QACnG,CAAC,CAAC;YACE,SAAS,EAAE,cAAc,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK;YAC/C,KAAK,EAAE,CAAC;SACT;QACH,CAAC,CAAC;YACE,SAAS,EAAE,eAAe,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK;YAChD,IAAI,EAAE,CAAC;SACR,CAAC;IACN,OAAO,CACL,6BACE,SAAS,EAAE,EAAE,CACX,eAAe,EACf,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,EAC1B,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CACzB,EACD,KAAK,kBAAI,KAAK,EAAE,GAAG,IAAI,IAAI,IAAK,eAAe,KAE9C,QAAQ,CACL,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,MAAM,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import ModalContext from '../ModalContext';
|
|
3
|
+
export const DrawerTarget = ({ id, children }) => {
|
|
4
|
+
return (React.createElement(ModalContext.Consumer, null, ({ modals, hideTarget }) => {
|
|
5
|
+
const { modalId, isOpen } = modals.find(({ modalId }) => modalId === id) || {};
|
|
6
|
+
// For drawers, the child should always render.
|
|
7
|
+
// Drawers implement their own hide/show behaviour that relies
|
|
8
|
+
// on `isOpen` being toggled to trigger the animation
|
|
9
|
+
return children({ hideTarget, isOpen: isOpen && modalId === id });
|
|
10
|
+
}));
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=DrawerTarget.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DrawerTarget.js","sourceRoot":"","sources":["DrawerTarget.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,YAA4B,MAAM,iBAAiB,CAAC;AAE3D,MAAM,CAAC,MAAM,YAAY,GAGpB,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;IACxB,OAAO,CACL,oBAAC,YAAY,CAAC,QAAQ,QACnB,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,EAAE,EAAE;QAC1B,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,GACvB,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,OAAO,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC;QACrD,+CAA+C;QAC/C,8DAA8D;QAC9D,qDAAqD;QACrD,OAAO,QAAQ,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,IAAI,OAAO,KAAK,EAAE,EAAE,CAAC,CAAC;IACpE,CAAC,CACqB,CACzB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { ModalState } from '../ModalContext';
|
|
3
|
+
export declare const DrawerTrigger: ({ id, children, showCover, canCloseOnEsc, coverStyles }: {
|
|
4
|
+
id: string;
|
|
5
|
+
/** Whether to show a clickable semi-opaque Cover behind the flyout */
|
|
6
|
+
showCover: boolean;
|
|
7
|
+
/** Whether to prevent the body from scrolling when flyout is open */
|
|
8
|
+
canCloseOnEsc?: boolean;
|
|
9
|
+
coverStyles?: React.CSSProperties;
|
|
10
|
+
children: (args: Partial<ModalState>) => React.ReactNode;
|
|
11
|
+
}) => React.JSX.Element;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import ModalContext from '../ModalContext';
|
|
3
|
+
export const DrawerTrigger = ({ id, children, showCover = true, canCloseOnEsc = true, coverStyles }) => {
|
|
4
|
+
return (React.createElement(ModalContext.Consumer, null, ({ showTarget, hideTarget, modals }) => {
|
|
5
|
+
return children({
|
|
6
|
+
showTarget: () => showTarget(null, 'drawer', id, {
|
|
7
|
+
showCover,
|
|
8
|
+
coverStyles,
|
|
9
|
+
canCloseOnEsc
|
|
10
|
+
}),
|
|
11
|
+
hideTarget,
|
|
12
|
+
isOpen: modals.some(({ modalId }) => modalId === id)
|
|
13
|
+
});
|
|
14
|
+
}));
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=DrawerTrigger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DrawerTrigger.js","sourceRoot":"","sources":["DrawerTrigger.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,YAA4B,MAAM,iBAAiB,CAAC;AAE3D,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,EAC5B,EAAE,EACF,QAAQ,EACR,SAAS,GAAG,IAAI,EAChB,aAAa,GAAG,IAAI,EACpB,WAAW,EASZ,EAAE,EAAE;IACH,OAAO,CACL,oBAAC,YAAY,CAAC,QAAQ,QACnB,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,EAAE;QACtC,OAAO,QAAQ,CAAC;YACd,UAAU,EAAE,GAAG,EAAE,CACf,UAAU,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE;gBAC7B,SAAS;gBACT,WAAW;gBACX,aAAa;aACd,CAAC;YACJ,UAAU;YACV,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,OAAO,KAAK,EAAE,CAAC;SACrD,CAAC,CAAC;IACL,CAAC,CACqB,CACzB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { ModalState } from '../ModalContext';
|
|
3
|
+
export interface FlyoutTargetProps {
|
|
4
|
+
id: string;
|
|
5
|
+
children: (args: Partial<ModalState>) => React.ReactNode;
|
|
6
|
+
}
|
|
7
|
+
export declare class FlyoutTarget extends React.Component<FlyoutTargetProps, any> {
|
|
8
|
+
render(): React.JSX.Element;
|
|
9
|
+
}
|
|
10
|
+
export default FlyoutTarget;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import ModalContext from '../ModalContext';
|
|
3
|
+
export class FlyoutTarget extends React.Component {
|
|
4
|
+
render() {
|
|
5
|
+
const { id, children } = this.props;
|
|
6
|
+
return (React.createElement(ModalContext.Consumer, null, ({ modals }) => {
|
|
7
|
+
const { modalId, isOpen, modalType, hideTarget } = modals.find(({ modalId }) => modalId === id) || {};
|
|
8
|
+
return isOpen && modalId === id && modalType === 'flyout'
|
|
9
|
+
? children({ hideTarget, isOpen })
|
|
10
|
+
: null;
|
|
11
|
+
}));
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export default FlyoutTarget;
|
|
15
|
+
//# sourceMappingURL=FlyoutTarget.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FlyoutTarget.js","sourceRoot":"","sources":["FlyoutTarget.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,YAA4B,MAAM,iBAAiB,CAAC;AAO3D,MAAM,OAAO,YAAa,SAAQ,KAAK,CAAC,SAAiC;IACvE,MAAM;QACJ,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QACpC,OAAO,CACL,oBAAC,YAAY,CAAC,QAAQ,QACnB,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;YACd,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,GAC9C,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,OAAO,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC;YACrD,OAAO,MAAM,IAAI,OAAO,KAAK,EAAE,IAAI,SAAS,KAAK,QAAQ;gBACvD,CAAC,CAAC,QAAQ,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC;gBAClC,CAAC,CAAC,IAAI,CAAC;QACX,CAAC,CACqB,CACzB,CAAC;IACJ,CAAC;CACF;AAED,eAAe,YAAY,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { ModalState } from '../ModalContext';
|
|
3
|
+
export declare const FlyoutTrigger: React.SFC<{
|
|
4
|
+
id: string;
|
|
5
|
+
/** Whether to show a clickable semi-opaque Cover behind the flyout */
|
|
6
|
+
showCover?: boolean;
|
|
7
|
+
/** Whether to prevent the body from scrolling when flyout is open */
|
|
8
|
+
preventOverflow?: boolean;
|
|
9
|
+
/** Whether to able to close modal via Escape button */
|
|
10
|
+
canCloseOnEsc?: boolean;
|
|
11
|
+
coverStyles?: {};
|
|
12
|
+
children: (args: Pick<ModalState, 'hideTarget' | 'isOpen'> & {
|
|
13
|
+
showTarget: () => void;
|
|
14
|
+
}) => React.ReactNode;
|
|
15
|
+
}>;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import ModalContext from '../ModalContext';
|
|
3
|
+
export const FlyoutTrigger = ({ id, children, showCover = true, preventOverflow = false, canCloseOnEsc = true, coverStyles }) => {
|
|
4
|
+
return (React.createElement(ModalContext.Consumer, null, ({ showTarget, hideTarget, modals }) => {
|
|
5
|
+
const open = () => showTarget(null, 'flyout', id, {
|
|
6
|
+
showCover,
|
|
7
|
+
coverStyles,
|
|
8
|
+
preventOverflow,
|
|
9
|
+
canCloseOnEsc
|
|
10
|
+
});
|
|
11
|
+
return children({
|
|
12
|
+
showTarget: open,
|
|
13
|
+
hideTarget,
|
|
14
|
+
isOpen: modals.some(({ modalId }) => modalId === id)
|
|
15
|
+
});
|
|
16
|
+
}));
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=FlyoutTrigger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FlyoutTrigger.js","sourceRoot":"","sources":["FlyoutTrigger.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,YAA4B,MAAM,iBAAiB,CAAC;AAE3D,MAAM,CAAC,MAAM,aAAa,GAYrB,CAAC,EACJ,EAAE,EACF,QAAQ,EACR,SAAS,GAAG,IAAI,EAChB,eAAe,GAAG,KAAK,EACvB,aAAa,GAAG,IAAI,EACpB,WAAW,EACZ,EAAE,EAAE;IACH,OAAO,CACL,oBAAC,YAAY,CAAC,QAAQ,QACnB,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,EAAE;QACtC,MAAM,IAAI,GAAG,GAAG,EAAE,CAChB,UAAU,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE;YAC7B,SAAS;YACT,WAAW;YACX,eAAe;YACf,aAAa;SACd,CAAC,CAAC;QACL,OAAO,QAAQ,CAAC;YACd,UAAU,EAAE,IAAI;YAChB,UAAU;YACV,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,OAAO,KAAK,EAAE,CAAC;SACrD,CAAC,CAAC;IACL,CAAC,CACqB,CACzB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface ModalState {
|
|
3
|
+
/** If modalType is modal, render this component at the modalRoot */
|
|
4
|
+
modalComponent?: React.ReactNode;
|
|
5
|
+
/** The type of modal to display */
|
|
6
|
+
modalType: 'modal' | 'flyout' | 'drawer';
|
|
7
|
+
/** An ID used to identify which flyout to display */
|
|
8
|
+
modalId?: string;
|
|
9
|
+
/** Called when a modal is requested */
|
|
10
|
+
showTarget(...args: any[]): void;
|
|
11
|
+
/** Called when a modal is dismissed */
|
|
12
|
+
hideTarget(...args: any[]): void;
|
|
13
|
+
/** Whether a modal is open */
|
|
14
|
+
isOpen: boolean;
|
|
15
|
+
/** props to be passed on to the displayed modalComponent */
|
|
16
|
+
props?: any;
|
|
17
|
+
}
|
|
18
|
+
export interface ModalContextProps {
|
|
19
|
+
/** Called when a modal is requested */
|
|
20
|
+
showTarget(...args: any[]): void;
|
|
21
|
+
/** Called when a modal is dismissed */
|
|
22
|
+
hideTarget(...args: any[]): void;
|
|
23
|
+
modals: ModalState[];
|
|
24
|
+
}
|
|
25
|
+
declare const ModalContext: React.Context<ModalContextProps>;
|
|
26
|
+
export default ModalContext;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalContext.js","sourceRoot":"","sources":["ModalContext.ts"],"names":[],"mappings":"AAAA,OAAc,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AA2B7C,MAAM,iBAAiB,GAAsB;IAC3C,UAAU,EAAE,IAAI;IAChB,UAAU,EAAE,IAAI;IAChB,MAAM,EAAE,EAAE;CACX,CAAC;AAEF,MAAM,YAAY,GAAG,aAAa,CAAC,iBAAiB,CAAC,CAAC;AAEtD,eAAe,YAAY,CAAC"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import React, { useEffect, useState, useCallback } from 'react';
|
|
2
|
+
import ModalContext from './ModalContext';
|
|
3
|
+
import ReactModal from 'react-modal';
|
|
4
|
+
import { css } from 'linaria';
|
|
5
|
+
const preventBodyScrollStyle = css `
|
|
6
|
+
overflow: hidden;
|
|
7
|
+
`;
|
|
8
|
+
const ModalProvider = ({ children }) => {
|
|
9
|
+
const [modals, setModals] = useState([]);
|
|
10
|
+
function showTarget(modalComponent, modalType, modalId, props = {}) {
|
|
11
|
+
setModals((prevModals) => {
|
|
12
|
+
const newModals = [...prevModals];
|
|
13
|
+
const modalProps = {
|
|
14
|
+
modalComponent,
|
|
15
|
+
modalId,
|
|
16
|
+
modalType,
|
|
17
|
+
isOpen: true,
|
|
18
|
+
props,
|
|
19
|
+
showTarget,
|
|
20
|
+
hideTarget: () => hideTarget(modalId)
|
|
21
|
+
};
|
|
22
|
+
// Check if modal with same id already exists
|
|
23
|
+
const matchIndex = newModals.findIndex((modal) => modal.modalId === modalId);
|
|
24
|
+
if (matchIndex >= 0)
|
|
25
|
+
newModals[matchIndex] = modalProps;
|
|
26
|
+
else
|
|
27
|
+
newModals.push(modalProps);
|
|
28
|
+
return newModals;
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
function hideTarget(modalId) {
|
|
32
|
+
setModals((prevModals) => {
|
|
33
|
+
const newModals = [...prevModals];
|
|
34
|
+
// Calling hideTarget directly from a MouseEvent passes down an event
|
|
35
|
+
// object. Therefore we have to check if the passed prop is a string.
|
|
36
|
+
if (modalId && typeof modalId === 'string') {
|
|
37
|
+
// Removing the modal based on modalId if opened
|
|
38
|
+
const matchIndex = newModals.findIndex((modal) => modal.modalId === modalId);
|
|
39
|
+
if (matchIndex >= 0)
|
|
40
|
+
newModals.splice(matchIndex, 1);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
// Removing the last opened modal
|
|
44
|
+
newModals.pop();
|
|
45
|
+
}
|
|
46
|
+
return newModals;
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
// Handling modal close on Escape button
|
|
50
|
+
const handleKeydown = useCallback((e) => {
|
|
51
|
+
if (e.key !== 'Escape' || modals.length === 0)
|
|
52
|
+
return;
|
|
53
|
+
const lastModal = modals[modals.length - 1];
|
|
54
|
+
if (!lastModal.props.canCloseOnEsc)
|
|
55
|
+
return;
|
|
56
|
+
hideTarget();
|
|
57
|
+
}, [modals]);
|
|
58
|
+
useEffect(() => {
|
|
59
|
+
ReactModal.setAppElement('#root');
|
|
60
|
+
}, []);
|
|
61
|
+
useEffect(() => {
|
|
62
|
+
document.addEventListener('keydown', handleKeydown);
|
|
63
|
+
return () => document.removeEventListener('keydown', handleKeydown);
|
|
64
|
+
}, [handleKeydown]);
|
|
65
|
+
// Disabling scrolling when relevant
|
|
66
|
+
useEffect(() => {
|
|
67
|
+
const preventOverflow = modals.some((modal) => modal.props.preventOverflow ||
|
|
68
|
+
(modal.modalType === 'drawer' && modal.isOpen));
|
|
69
|
+
if (preventOverflow)
|
|
70
|
+
document.body.classList.add(preventBodyScrollStyle);
|
|
71
|
+
else
|
|
72
|
+
document.body.classList.remove(preventBodyScrollStyle);
|
|
73
|
+
return () => document.body.classList.remove(preventBodyScrollStyle);
|
|
74
|
+
}, [modals]);
|
|
75
|
+
const initialState = {
|
|
76
|
+
showTarget,
|
|
77
|
+
hideTarget,
|
|
78
|
+
modals
|
|
79
|
+
};
|
|
80
|
+
return (React.createElement(ModalContext.Provider, { value: initialState }, children));
|
|
81
|
+
};
|
|
82
|
+
export default ModalProvider;
|
|
83
|
+
//# sourceMappingURL=ModalProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalProvider.js","sourceRoot":"","sources":["ModalProvider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import ModalContext from './ModalContext';
|
|
3
|
+
import ReactModal from 'react-modal';
|
|
4
|
+
import { styled } from 'linaria/react';
|
|
5
|
+
const Cover = styled('div') `
|
|
6
|
+
position: fixed;
|
|
7
|
+
z-index: 3;
|
|
8
|
+
top: 0;
|
|
9
|
+
left: 0;
|
|
10
|
+
bottom: 0;
|
|
11
|
+
right: 0;
|
|
12
|
+
background: rgba(0, 0, 0, 0.2);
|
|
13
|
+
`;
|
|
14
|
+
Cover.displayName = 'Cover';
|
|
15
|
+
const Modal = ({ modalComponent, isOpen, modalType, hideTarget, props }) => {
|
|
16
|
+
/** Do not render anything if there is no active modal */
|
|
17
|
+
if (!isOpen)
|
|
18
|
+
return null;
|
|
19
|
+
const Component = modalComponent;
|
|
20
|
+
if (Component && isOpen && modalType === 'modal') {
|
|
21
|
+
/** A modal has been requested, from somewhere in the app */
|
|
22
|
+
return (React.createElement(ReactModal, Object.assign({ style: { overlay: { zIndex: 999 } }, className: props.modalStyles }, props.modalProps, {
|
|
23
|
+
/** isOpen should always be true here, since this is only rendered when a modal is requested */
|
|
24
|
+
isOpen: true,
|
|
25
|
+
/**
|
|
26
|
+
* react-modal requires an onRequestClose prop that takes a func to call when the modal is closed
|
|
27
|
+
* We use this to make sure the context is updated
|
|
28
|
+
*/
|
|
29
|
+
onRequestClose: hideTarget }),
|
|
30
|
+
React.createElement(Component, Object.assign({ hideTarget: hideTarget }, props))));
|
|
31
|
+
}
|
|
32
|
+
if (isOpen && props.showCover) {
|
|
33
|
+
const coverStyles = props === null || props === void 0 ? void 0 : props.coverStyles;
|
|
34
|
+
/** Inject a clickable 'cover' behind flyouts */
|
|
35
|
+
return React.createElement(Cover, { onClick: hideTarget, style: coverStyles });
|
|
36
|
+
}
|
|
37
|
+
return null;
|
|
38
|
+
};
|
|
39
|
+
const ModalRoot = () => {
|
|
40
|
+
const { modals } = React.useContext(ModalContext);
|
|
41
|
+
return (React.createElement(React.Fragment, null, modals.map((modalProps) => (React.createElement(Modal, Object.assign({ key: modalProps.modalId }, modalProps))))));
|
|
42
|
+
};
|
|
43
|
+
export default ModalRoot;
|
|
44
|
+
//# sourceMappingURL=ModalRoot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalRoot.js","sourceRoot":"","sources":["ModalRoot.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,YAA4B,MAAM,gBAAgB,CAAC;AAC1D,OAAO,UAAU,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;;;;;;;;CAQ1B,CAAC;AAEF,KAAK,CAAC,WAAW,GAAG,OAAO,CAAC;AAE5B,MAAM,KAAK,GAAG,CAAC,EACb,cAAc,EACd,MAAM,EACN,SAAS,EACT,UAAU,EACV,KAAK,EACM,EAAE,EAAE;IACf,yDAAyD;IACzD,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAC;IAEzB,MAAM,SAAS,GAAG,cAAmC,CAAC;IAEtD,IAAI,SAAS,IAAI,MAAM,IAAI,SAAS,KAAK,OAAO,EAAE;QAChD,6DAA6D;QAC7D,OAAO,CACL,oBAAC,UAAU,kBACT,KAAK,EAAE,EAAE,OAAO,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,EACnC,SAAS,EAAE,KAAK,CAAC,WAAW,IACxB,KAAK,CAAC,UAAU;YACpB,+FAA+F;YAC/F,MAAM;YACN;;;eAGG;YACH,cAAc,EAAE,UAAU;YAE1B,oBAAC,SAAS,kBAAC,UAAU,EAAE,UAAU,IAAM,KAAK,EAAI,CACrC,CACd,CAAC;KACH;IAED,IAAI,MAAM,IAAI,KAAK,CAAC,SAAS,EAAE;QAC7B,MAAM,WAAW,GAAG,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,WAAW,CAAC;QAEvC,gDAAgD;QAChD,OAAO,oBAAC,KAAK,IAAC,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,GAAI,CAAC;KAC3D;IAED,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,SAAS,GAAG,GAAG,EAAE;IACrB,MAAM,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;IAClD,OAAO,CACL,0CACG,MAAM,CAAC,GAAG,CAAC,CAAC,UAAsB,EAAE,EAAE,CAAC,CACtC,oBAAC,KAAK,kBAAC,GAAG,EAAE,UAAU,CAAC,OAAO,IAAM,UAAU,EAAI,CACnD,CAAC,CACD,CACJ,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,SAAS,CAAC"}
|