@jetshop/ui 7.0.0-alpha-3 → 7.0.0-alpha-5
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/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 +65 -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 +1 -1
- 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,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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { ModalState } from './ModalContext';
|
|
3
|
+
export declare const ModalTrigger: React.SFC<{
|
|
4
|
+
/** The React component that you would like to display inside the modal */
|
|
5
|
+
target: React.ReactNode;
|
|
6
|
+
/** Style to apply to the modal itself */
|
|
7
|
+
modalStyles?: {};
|
|
8
|
+
children: (args: Partial<ModalState>) => React.ReactNode;
|
|
9
|
+
}>;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import ModalContext from './ModalContext';
|
|
3
|
+
export const ModalTrigger = ({ target, children, modalStyles }) => {
|
|
4
|
+
return (React.createElement(ModalContext.Consumer, null, ({ showTarget, hideTarget }) => {
|
|
5
|
+
const show = () => showTarget(target, 'modal', null, { hideTarget, modalStyles });
|
|
6
|
+
return children({ showTarget: show });
|
|
7
|
+
}));
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=ModalTrigger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ModalTrigger.js","sourceRoot":"","sources":["ModalTrigger.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,YAA4B,MAAM,gBAAgB,CAAC;AAE1D,MAAM,CAAC,MAAM,YAAY,GAMpB,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,EAAE,EAAE;IACzC,OAAO,CACL,oBAAC,YAAY,CAAC,QAAQ,QACnB,CAAC,EAAE,UAAU,EAAE,UAAU,EAAE,EAAE,EAAE;QAC9B,MAAM,IAAI,GAAG,GAAG,EAAE,CAChB,UAAU,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE,UAAU,EAAE,WAAW,EAAE,CAAC,CAAC;QACjE,OAAO,QAAQ,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;IACxC,CAAC,CACqB,CACzB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { PaginationBehaviourRenderProps } from '@jetshop/ui/Pagination/PaginationBehaviour';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
export declare const PaginationWrapper: import("linaria/lib/StyledMeta").StyledMeta & React.FunctionComponent<React.ClassAttributes<HTMLDivElement> & React.HTMLAttributes<HTMLDivElement> & {
|
|
4
|
+
as?: React.ElementType<any>;
|
|
5
|
+
}>;
|
|
6
|
+
declare const Pagination: React.SFC<PaginationBehaviourRenderProps>;
|
|
7
|
+
export default Pagination;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import formatMessage from '@jetshop/intl';
|
|
2
|
+
import { styled } from 'linaria/react';
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import usePagination from './usePagination';
|
|
5
|
+
export const PaginationWrapper = styled('div') `
|
|
6
|
+
display: flex;
|
|
7
|
+
width: 100%;
|
|
8
|
+
justify-content: space-between;
|
|
9
|
+
align-items: center;
|
|
10
|
+
`;
|
|
11
|
+
const Pagination = (props) => {
|
|
12
|
+
const { hasPages, totalPages, className, currentPage } = props;
|
|
13
|
+
const { prevHref, nextHref, prevOnClick, nextOnClick, isPrevDisabled, isNextDisabled } = usePagination(props);
|
|
14
|
+
return hasPages && !isNaN(totalPages) ? (React.createElement(PaginationWrapper, { className: className },
|
|
15
|
+
React.createElement("a", { href: prevHref, onClick: prevOnClick, "data-disabled": isPrevDisabled }, formatMessage('Prev')),
|
|
16
|
+
React.createElement("div", null, formatMessage(`Page {currentPage} of {totalPages}`, {
|
|
17
|
+
currentPage,
|
|
18
|
+
totalPages
|
|
19
|
+
})),
|
|
20
|
+
React.createElement("a", { href: nextHref, onClick: nextOnClick, "data-disabled": isNextDisabled }, formatMessage('Next')))) : null;
|
|
21
|
+
};
|
|
22
|
+
export default Pagination;
|
|
23
|
+
//# sourceMappingURL=Pagination.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Pagination.js","sourceRoot":"","sources":["Pagination.tsx"],"names":[],"mappings":"AAAA,OAAO,aAAa,MAAM,eAAe,CAAC;AAE1C,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAE5C,MAAM,CAAC,MAAM,iBAAiB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;;;;;CAK7C,CAAC;AAEF,MAAM,UAAU,GAA8C,CAAC,KAAK,EAAE,EAAE;IACtE,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,KAAK,CAAC;IAE/D,MAAM,EACJ,QAAQ,EACR,QAAQ,EACR,WAAW,EACX,WAAW,EACX,cAAc,EACd,cAAc,EACf,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;IAEzB,OAAO,QAAQ,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CACtC,oBAAC,iBAAiB,IAAC,SAAS,EAAE,SAAS;QACrC,2BAAG,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,mBAAiB,cAAc,IACnE,aAAa,CAAC,MAAM,CAAC,CACpB;QACJ,iCACG,aAAa,CAAC,oCAAoC,EAAE;YACnD,WAAW;YACX,UAAU;SACX,CAAC,CACE;QACN,2BAAG,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,mBAAiB,cAAc,IACnE,aAAa,CAAC,MAAM,CAAC,CACpB,CACc,CACrB,CAAC,CAAC,CAAC,IAAI,CAAC;AACX,CAAC,CAAC;AAEF,eAAe,UAAU,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { PaginationState } from '@jetshop/core/components/Pagination/PaginationContext';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
export interface PaginationProps extends PaginationState {
|
|
4
|
+
total: number;
|
|
5
|
+
children(props: PaginationBehaviourRenderProps): React.ReactNode;
|
|
6
|
+
}
|
|
7
|
+
export interface TotalPagesState {
|
|
8
|
+
totalPages: number;
|
|
9
|
+
}
|
|
10
|
+
export interface PaginationBehaviourRenderProps {
|
|
11
|
+
/** The total number of items */
|
|
12
|
+
totalItems: number;
|
|
13
|
+
/** The total number of pages */
|
|
14
|
+
totalPages: number;
|
|
15
|
+
/** The current page number */
|
|
16
|
+
currentPage: number;
|
|
17
|
+
/** Navigate to the next page */
|
|
18
|
+
nextPage: () => void;
|
|
19
|
+
/** Navigate to the previous page */
|
|
20
|
+
prevPage: () => void;
|
|
21
|
+
/** Navigate to given page number */
|
|
22
|
+
goToPage: (page: number) => void;
|
|
23
|
+
setProductsPerPage: (perPage: number) => void;
|
|
24
|
+
/** Whether the current page is the first */
|
|
25
|
+
isFirstPage: boolean;
|
|
26
|
+
/** Whether the current page is the last */
|
|
27
|
+
isLastPage: boolean;
|
|
28
|
+
/** Whether there are pages to render */
|
|
29
|
+
hasPages: boolean;
|
|
30
|
+
className?: string;
|
|
31
|
+
}
|
|
32
|
+
export default class PaginationBehaviour extends React.Component<PaginationProps, TotalPagesState> {
|
|
33
|
+
constructor(props: PaginationProps);
|
|
34
|
+
componentDidMount(): void;
|
|
35
|
+
componentDidUpdate(prevProps: PaginationProps): void;
|
|
36
|
+
setTotalPages: () => number;
|
|
37
|
+
nextPage: () => void;
|
|
38
|
+
prevPage: () => void;
|
|
39
|
+
getStateAndProps: () => {
|
|
40
|
+
totalItems: number;
|
|
41
|
+
totalPages: number;
|
|
42
|
+
currentPage: number;
|
|
43
|
+
prevPage: () => void;
|
|
44
|
+
nextPage: () => void;
|
|
45
|
+
goToPage: (page: number, options?: import("@jetshop/core/components/Pagination/PaginationContext").GoToPageOptions) => void;
|
|
46
|
+
setProductsPerPage: (perPage: number) => void;
|
|
47
|
+
isFirstPage: boolean;
|
|
48
|
+
isLastPage: boolean;
|
|
49
|
+
hasPages: boolean;
|
|
50
|
+
};
|
|
51
|
+
render(): React.ReactNode;
|
|
52
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
const getTotalPages = ({ perPage, total }) => Math.ceil(total / perPage);
|
|
3
|
+
const checkPageValidity = (totalPages, { total, currentPage, goToPage }) => {
|
|
4
|
+
// Go to the last available page if the selected page does not exist
|
|
5
|
+
if (total > 0 && totalPages < currentPage)
|
|
6
|
+
goToPage(totalPages);
|
|
7
|
+
if (total === 0 && currentPage > 1)
|
|
8
|
+
goToPage && goToPage(1);
|
|
9
|
+
};
|
|
10
|
+
const incrementPage = (page) => {
|
|
11
|
+
return page + 1;
|
|
12
|
+
};
|
|
13
|
+
const decrementPage = (page) => {
|
|
14
|
+
return page - 1;
|
|
15
|
+
};
|
|
16
|
+
export default class PaginationBehaviour extends React.Component {
|
|
17
|
+
constructor(props) {
|
|
18
|
+
super(props);
|
|
19
|
+
this.setTotalPages = () => {
|
|
20
|
+
const totalPages = getTotalPages(this.props);
|
|
21
|
+
this.setState({ totalPages });
|
|
22
|
+
return totalPages;
|
|
23
|
+
};
|
|
24
|
+
this.nextPage = () => {
|
|
25
|
+
const { currentPage } = this.props;
|
|
26
|
+
const { totalPages } = this.state;
|
|
27
|
+
currentPage < totalPages && this.props.goToPage(incrementPage(currentPage));
|
|
28
|
+
};
|
|
29
|
+
this.prevPage = () => {
|
|
30
|
+
const { currentPage } = this.props;
|
|
31
|
+
currentPage !== 1 && this.props.goToPage(decrementPage(currentPage));
|
|
32
|
+
};
|
|
33
|
+
this.getStateAndProps = () => {
|
|
34
|
+
return {
|
|
35
|
+
totalItems: this.props.total,
|
|
36
|
+
totalPages: this.state.totalPages,
|
|
37
|
+
currentPage: this.props.currentPage,
|
|
38
|
+
prevPage: this.prevPage,
|
|
39
|
+
nextPage: this.nextPage,
|
|
40
|
+
goToPage: this.props.goToPage,
|
|
41
|
+
setProductsPerPage: this.props.setProductsPerPage,
|
|
42
|
+
isFirstPage: this.props.currentPage === 1,
|
|
43
|
+
isLastPage: this.props.currentPage === this.state.totalPages,
|
|
44
|
+
hasPages: this.state.totalPages !== 0
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
this.state = {
|
|
48
|
+
totalPages: getTotalPages(props)
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
componentDidMount() {
|
|
52
|
+
const totalPages = this.setTotalPages();
|
|
53
|
+
checkPageValidity(totalPages, this.props);
|
|
54
|
+
}
|
|
55
|
+
componentDidUpdate(prevProps) {
|
|
56
|
+
if (prevProps.total !== this.props.total) {
|
|
57
|
+
const totalPages = this.setTotalPages();
|
|
58
|
+
checkPageValidity(totalPages, this.props);
|
|
59
|
+
}
|
|
60
|
+
if (prevProps.perPage !== this.props.perPage) {
|
|
61
|
+
this.setTotalPages();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
render() {
|
|
65
|
+
return this.props.children(this.getStateAndProps());
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=PaginationBehaviour.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PaginationBehaviour.js","sourceRoot":"","sources":["PaginationBehaviour.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,uBAAuB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { PaginationBehaviourRenderProps } from '@jetshop/ui/Pagination/PaginationBehaviour';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
export declare const PaginationWrapper: import("linaria/lib/StyledMeta").StyledMeta & React.FunctionComponent<React.ClassAttributes<HTMLDivElement> & React.HTMLAttributes<HTMLDivElement> & {
|
|
4
|
+
as?: React.ElementType<any>;
|
|
5
|
+
}>;
|
|
6
|
+
declare function usePagination({ prevPage, nextPage, currentPage, isFirstPage, isLastPage }: Partial<PaginationBehaviourRenderProps>): {
|
|
7
|
+
prevHref: string;
|
|
8
|
+
nextHref: string;
|
|
9
|
+
goToHref: (page: number) => string;
|
|
10
|
+
prevOnClick: (e: React.MouseEvent<HTMLElement>) => void;
|
|
11
|
+
nextOnClick: (e: React.MouseEvent<HTMLElement>) => void;
|
|
12
|
+
isPrevDisabled: boolean;
|
|
13
|
+
isNextDisabled: boolean;
|
|
14
|
+
};
|
|
15
|
+
export default usePagination;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import PaginationContext from '@jetshop/core/components/Pagination/PaginationContext';
|
|
2
|
+
import { styled } from 'linaria/react';
|
|
3
|
+
import qs from 'qs';
|
|
4
|
+
import * as React from 'react';
|
|
5
|
+
import { useLocation } from 'react-router';
|
|
6
|
+
export const PaginationWrapper = styled('div') `
|
|
7
|
+
display: flex;
|
|
8
|
+
width: 100%;
|
|
9
|
+
justify-content: space-between;
|
|
10
|
+
align-items: center;
|
|
11
|
+
`;
|
|
12
|
+
function usePagination({ prevPage, nextPage, currentPage, isFirstPage, isLastPage }) {
|
|
13
|
+
const { queryParam } = React.useContext(PaginationContext);
|
|
14
|
+
const location = useLocation();
|
|
15
|
+
const currentLocation = qs.parse(typeof window === 'undefined' ? location.search : window.location.search, {
|
|
16
|
+
ignoreQueryPrefix: true
|
|
17
|
+
});
|
|
18
|
+
const nextHref = location.pathname +
|
|
19
|
+
qs.stringify(Object.assign(Object.assign({}, currentLocation), { [queryParam]: isLastPage ? currentPage : currentPage + 1 }), { addQueryPrefix: true, encodeValuesOnly: true, skipNulls: true });
|
|
20
|
+
const prevHref = location.pathname +
|
|
21
|
+
qs.stringify(Object.assign(Object.assign({}, currentLocation), { [queryParam]: isFirstPage ? currentPage : currentPage - 1 }), { addQueryPrefix: true, encodeValuesOnly: true, skipNulls: true });
|
|
22
|
+
const goToHref = (page) => {
|
|
23
|
+
const href = location.pathname +
|
|
24
|
+
qs.stringify(Object.assign(Object.assign({}, currentLocation), { [queryParam]: page }), { addQueryPrefix: true, encodeValuesOnly: true, skipNulls: true });
|
|
25
|
+
return href;
|
|
26
|
+
};
|
|
27
|
+
function prevOnClick(e) {
|
|
28
|
+
e.preventDefault();
|
|
29
|
+
prevPage();
|
|
30
|
+
}
|
|
31
|
+
function nextOnClick(e) {
|
|
32
|
+
e.preventDefault();
|
|
33
|
+
nextPage();
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
prevHref,
|
|
37
|
+
nextHref,
|
|
38
|
+
goToHref,
|
|
39
|
+
prevOnClick,
|
|
40
|
+
nextOnClick,
|
|
41
|
+
isPrevDisabled: isFirstPage ? true : null,
|
|
42
|
+
isNextDisabled: isLastPage ? true : null
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
export default usePagination;
|
|
46
|
+
//# sourceMappingURL=usePagination.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usePagination.js","sourceRoot":"","sources":["usePagination.ts"],"names":[],"mappings":"AAAA,OAAO,iBAAiB,MAAM,uDAAuD,CAAC;AAEtF,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,MAAM,CAAC,MAAM,iBAAiB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;;;;;CAK7C,CAAC;AAEF,SAAS,aAAa,CAAC,EACrB,QAAQ,EACR,QAAQ,EACR,WAAW,EACX,WAAW,EACX,UAAU,EAC8B;IACxC,MAAM,EAAE,UAAU,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;IAC3D,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IAE/B,MAAM,eAAe,GAAG,EAAE,CAAC,KAAK,CAC9B,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,EACxE;QACE,iBAAiB,EAAE,IAAI;KACxB,CACF,CAAC;IAEF,MAAM,QAAQ,GACZ,QAAQ,CAAC,QAAQ;QACjB,EAAE,CAAC,SAAS,iCAEL,eAAe,KAClB,CAAC,UAAU,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,KAE1D,EAAE,cAAc,EAAE,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,CAClE,CAAC;IAEJ,MAAM,QAAQ,GACZ,QAAQ,CAAC,QAAQ;QACjB,EAAE,CAAC,SAAS,iCAEL,eAAe,KAClB,CAAC,UAAU,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,KAE3D,EAAE,cAAc,EAAE,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,CAClE,CAAC;IAEJ,MAAM,QAAQ,GAAG,CAAC,IAAY,EAAE,EAAE;QAChC,MAAM,IAAI,GACR,QAAQ,CAAC,QAAQ;YACjB,EAAE,CAAC,SAAS,iCAEL,eAAe,KAClB,CAAC,UAAU,CAAC,EAAE,IAAI,KAEpB,EAAE,cAAc,EAAE,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,CAClE,CAAC;QACJ,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF,SAAS,WAAW,CAAC,CAAgC;QACnD,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,QAAQ,EAAE,CAAC;IACb,CAAC;IAED,SAAS,WAAW,CAAC,CAAgC;QACnD,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,QAAQ,EAAE,CAAC;IACb,CAAC;IAED,OAAO;QACL,QAAQ;QACR,QAAQ;QACR,QAAQ;QACR,WAAW;QACX,WAAW;QACX,cAAc,EAAE,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI;QACzC,cAAc,EAAE,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI;KACzC,CAAC;AACJ,CAAC;AAED,eAAe,aAAa,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/// <reference types="hoist-non-react-statics" />
|
|
2
|
+
import React from 'react';
|
|
3
|
+
type PreOrderDropdownType = {
|
|
4
|
+
values: PreOrderDatesType[];
|
|
5
|
+
selectedDate: string;
|
|
6
|
+
selectDate: React.Dispatch<React.SetStateAction<string>>;
|
|
7
|
+
};
|
|
8
|
+
type PreOrderInputType = {
|
|
9
|
+
value: PreOrderDatesType;
|
|
10
|
+
selectDate: React.Dispatch<React.SetStateAction<string>>;
|
|
11
|
+
callback?: Function;
|
|
12
|
+
className?: string;
|
|
13
|
+
};
|
|
14
|
+
type PreOrderDatesType = {
|
|
15
|
+
value: string;
|
|
16
|
+
name: string;
|
|
17
|
+
};
|
|
18
|
+
export declare const PreOrderDropdown: ({ values, selectedDate, selectDate }: PreOrderDropdownType) => React.JSX.Element;
|
|
19
|
+
export declare const PreOrderInput: ({ value, selectDate, callback, className }: PreOrderInputType) => React.JSX.Element;
|
|
20
|
+
declare const _default: React.FC<unknown> & import("hoist-non-react-statics").NonReactStatics<React.ComponentClass<{
|
|
21
|
+
formik: import("formik").FormikContextType<{}>;
|
|
22
|
+
}, any>, {}>;
|
|
23
|
+
export default _default;
|