@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.
Files changed (400) hide show
  1. package/Accordion/Accordion.d.ts +33 -0
  2. package/Accordion/Accordion.js +59 -0
  3. package/Accordion/Accordion.js.map +1 -0
  4. package/Auth/FormFields/CountriesInput.d.ts +16 -0
  5. package/Auth/FormFields/CountriesInput.js +28 -0
  6. package/Auth/FormFields/CountriesInput.js.map +1 -0
  7. package/Auth/LogInBehavior.d.ts +22 -0
  8. package/Auth/LogInBehavior.js +24 -0
  9. package/Auth/LogInBehavior.js.map +1 -0
  10. package/Auth/LogInFormProvider.d.ts +7 -0
  11. package/Auth/LogInFormProvider.js +70 -0
  12. package/Auth/LogInFormProvider.js.map +1 -0
  13. package/Auth/LogOut.d.ts +10 -0
  14. package/Auth/LogOut.js +24 -0
  15. package/Auth/LogOut.js.map +1 -0
  16. package/Auth/logInValidator.d.ts +10 -0
  17. package/Auth/logInValidator.js +16 -0
  18. package/Auth/logInValidator.js.map +1 -0
  19. package/Breadcrumbs/Breadcrumbs.d.ts +14 -0
  20. package/Breadcrumbs/Breadcrumbs.js +84 -0
  21. package/Breadcrumbs/Breadcrumbs.js.map +1 -0
  22. package/Breadcrumbs/getParentsOrCanonicalRoute.d.ts +3 -0
  23. package/Breadcrumbs/getParentsOrCanonicalRoute.js +14 -0
  24. package/Breadcrumbs/getParentsOrCanonicalRoute.js.map +1 -0
  25. package/Breadcrumbs/index.d.ts +1 -0
  26. package/Breadcrumbs/index.js +2 -0
  27. package/Breadcrumbs/index.js.map +1 -0
  28. package/Breakpoints.d.ts +12 -0
  29. package/Breakpoints.js +36 -0
  30. package/Breakpoints.js.map +1 -0
  31. package/Button/Button.d.ts +14 -0
  32. package/Button/Button.js +60 -0
  33. package/Button/Button.js.map +1 -0
  34. package/Button/SecondaryButton.d.ts +2 -0
  35. package/Button/SecondaryButton.js +9 -0
  36. package/Button/SecondaryButton.js.map +1 -0
  37. package/Button/TrendButton.d.ts +2 -0
  38. package/Button/TrendButton.js +8 -0
  39. package/Button/TrendButton.js.map +1 -0
  40. package/Button/index.d.ts +4 -0
  41. package/Button/index.js +5 -0
  42. package/Button/index.js.map +1 -0
  43. package/CategoryLink.d.ts +11 -0
  44. package/CategoryLink.js +49 -0
  45. package/CategoryLink.js.map +1 -0
  46. package/ChannelSelector/ChannelListItem.d.ts +10 -0
  47. package/ChannelSelector/ChannelListItem.js +51 -0
  48. package/ChannelSelector/ChannelListItem.js.map +1 -0
  49. package/ChannelSelector/ChannelSelector.d.ts +63 -0
  50. package/ChannelSelector/ChannelSelector.js +80 -0
  51. package/ChannelSelector/ChannelSelector.js.map +1 -0
  52. package/ChannelSelector/ChannelSelectorButtons.d.ts +2 -0
  53. package/ChannelSelector/ChannelSelectorButtons.js +20 -0
  54. package/ChannelSelector/ChannelSelectorButtons.js.map +1 -0
  55. package/ChannelSelector/Channels.d.ts +17 -0
  56. package/ChannelSelector/Channels.js +12 -0
  57. package/ChannelSelector/Channels.js.map +1 -0
  58. package/ChannelSelector/LargeSelector.d.ts +3 -0
  59. package/ChannelSelector/LargeSelector.js +67 -0
  60. package/ChannelSelector/LargeSelector.js.map +1 -0
  61. package/ChannelSelector/MiniSelector.d.ts +4 -0
  62. package/ChannelSelector/MiniSelector.js +58 -0
  63. package/ChannelSelector/MiniSelector.js.map +1 -0
  64. package/ChannelSelector/Region.d.ts +28 -0
  65. package/ChannelSelector/Region.js +21 -0
  66. package/ChannelSelector/Region.js.map +1 -0
  67. package/ChannelSelector/groupBy.d.ts +7 -0
  68. package/ChannelSelector/groupBy.js +16 -0
  69. package/ChannelSelector/groupBy.js.map +1 -0
  70. package/Checkbox/Checkbox.d.ts +14 -0
  71. package/Checkbox/Checkbox.js +70 -0
  72. package/Checkbox/Checkbox.js.map +1 -0
  73. package/Checkbox/CheckboxGroup.d.ts +27 -0
  74. package/Checkbox/CheckboxGroup.js +22 -0
  75. package/Checkbox/CheckboxGroup.js.map +1 -0
  76. package/Checkbox/index.d.ts +2 -0
  77. package/Checkbox/index.js +3 -0
  78. package/Checkbox/index.js.map +1 -0
  79. package/ContentPageLink.d.ts +11 -0
  80. package/ContentPageLink.js +46 -0
  81. package/ContentPageLink.js.map +1 -0
  82. package/ContentRenderer.d.ts +9 -0
  83. package/ContentRenderer.js +36 -0
  84. package/ContentRenderer.js.map +1 -0
  85. package/DropdownMenu/Button.d.ts +7 -0
  86. package/DropdownMenu/Button.js +33 -0
  87. package/DropdownMenu/Button.js.map +1 -0
  88. package/DropdownMenu/DropdownMenu.d.ts +21 -0
  89. package/DropdownMenu/DropdownMenu.js +72 -0
  90. package/DropdownMenu/DropdownMenu.js.map +1 -0
  91. package/DropdownMenu/Item.d.ts +13 -0
  92. package/DropdownMenu/Item.js +48 -0
  93. package/DropdownMenu/Item.js.map +1 -0
  94. package/DropdownMenu/Items.d.ts +16 -0
  95. package/DropdownMenu/Items.js +53 -0
  96. package/DropdownMenu/Items.js.map +1 -0
  97. package/DropdownMenu/index.d.ts +4 -0
  98. package/DropdownMenu/index.js +5 -0
  99. package/DropdownMenu/index.js.map +1 -0
  100. package/ErrorBoundary/Generic.d.ts +18 -0
  101. package/ErrorBoundary/Generic.js +65 -0
  102. package/ErrorBoundary/Generic.js.map +1 -0
  103. package/ErrorBoundary/PassThrough.d.ts +3 -0
  104. package/ErrorBoundary/PassThrough.js +7 -0
  105. package/ErrorBoundary/PassThrough.js.map +1 -0
  106. package/Gallery/Gallery.d.ts +39 -0
  107. package/Gallery/Gallery.js +121 -0
  108. package/Gallery/Gallery.js.map +1 -0
  109. package/Gallery/constructGallery.d.ts +15 -0
  110. package/Gallery/constructGallery.js +40 -0
  111. package/Gallery/constructGallery.js.map +1 -0
  112. package/Image/BaseImage.d.ts +39 -0
  113. package/Image/BaseImage.js +192 -0
  114. package/Image/BaseImage.js.map +1 -0
  115. package/Image/Fallback.d.ts +5 -0
  116. package/Image/Fallback.js +4 -0
  117. package/Image/Fallback.js.map +1 -0
  118. package/Image/FlightImage.d.ts +51 -0
  119. package/Image/FlightImage.js +59 -0
  120. package/Image/FlightImage.js.map +1 -0
  121. package/Image/Image.d.ts +2 -0
  122. package/Image/Image.js +3 -0
  123. package/Image/Image.js.map +1 -0
  124. package/Image/index.d.ts +1 -0
  125. package/Image/index.js +2 -0
  126. package/Image/index.js.map +1 -0
  127. package/Image/useConstructImage.d.ts +49 -0
  128. package/Image/useConstructImage.js +122 -0
  129. package/Image/useConstructImage.js.map +1 -0
  130. package/Image/utils/aspectRatioToFraction.d.ts +2 -0
  131. package/Image/utils/aspectRatioToFraction.js +11 -0
  132. package/Image/utils/aspectRatioToFraction.js.map +1 -0
  133. package/Image/utils/getFullUrl.d.ts +6 -0
  134. package/Image/utils/getFullUrl.js +18 -0
  135. package/Image/utils/getFullUrl.js.map +1 -0
  136. package/Image/utils/getImageWidth.d.ts +1 -0
  137. package/Image/utils/getImageWidth.js +12 -0
  138. package/Image/utils/getImageWidth.js.map +1 -0
  139. package/Image/utils/getImageWidths.d.ts +2 -0
  140. package/Image/utils/getImageWidths.js +21 -0
  141. package/Image/utils/getImageWidths.js.map +1 -0
  142. package/Image/utils/getLQIP.d.ts +8 -0
  143. package/Image/utils/getLQIP.js +20 -0
  144. package/Image/utils/getLQIP.js.map +1 -0
  145. package/Image/utils/getLargestSize.d.ts +7 -0
  146. package/Image/utils/getLargestSize.js +17 -0
  147. package/Image/utils/getLargestSize.js.map +1 -0
  148. package/Image/utils/getSizeForBreakpoint.d.ts +2 -0
  149. package/Image/utils/getSizeForBreakpoint.js +16 -0
  150. package/Image/utils/getSizeForBreakpoint.js.map +1 -0
  151. package/Image/utils/getSizesMap.d.ts +2 -0
  152. package/Image/utils/getSizesMap.js +35 -0
  153. package/Image/utils/getSizesMap.js.map +1 -0
  154. package/Image/utils/getSmallestSize.d.ts +2 -0
  155. package/Image/utils/getSmallestSize.js +12 -0
  156. package/Image/utils/getSmallestSize.js.map +1 -0
  157. package/Image/utils/getSrcSetFromWidths.d.ts +10 -0
  158. package/Image/utils/getSrcSetFromWidths.js +9 -0
  159. package/Image/utils/getSrcSetFromWidths.js.map +1 -0
  160. package/Image/utils/getSrcWithParams.d.ts +3 -0
  161. package/Image/utils/getSrcWithParams.js +29 -0
  162. package/Image/utils/getSrcWithParams.js.map +1 -0
  163. package/Image/utils/paddingForAspectRatio.d.ts +1 -0
  164. package/Image/utils/paddingForAspectRatio.js +6 -0
  165. package/Image/utils/paddingForAspectRatio.js.map +1 -0
  166. package/Image/utils/remToPx.d.ts +1 -0
  167. package/Image/utils/remToPx.js +2 -0
  168. package/Image/utils/remToPx.js.map +1 -0
  169. package/Image/utils/sizeToNumber.d.ts +2 -0
  170. package/Image/utils/sizeToNumber.js +27 -0
  171. package/Image/utils/sizeToNumber.js.map +1 -0
  172. package/Input/Input.d.ts +6 -0
  173. package/Input/Input.js +45 -0
  174. package/Input/Input.js.map +1 -0
  175. package/Input/index.d.ts +3 -0
  176. package/Input/index.js +4 -0
  177. package/Input/index.js.map +1 -0
  178. package/JetshopText.d.ts +3 -0
  179. package/JetshopText.js +13 -0
  180. package/JetshopText.js.map +1 -0
  181. package/Loading/LoadingBar.d.ts +8 -0
  182. package/Loading/LoadingBar.js +58 -0
  183. package/Loading/LoadingBar.js.map +1 -0
  184. package/Loading/LoadingLine.d.ts +31 -0
  185. package/Loading/LoadingLine.js +26 -0
  186. package/Loading/LoadingLine.js.map +1 -0
  187. package/Loading/NetworkStatusNotifier.d.ts +6 -0
  188. package/Loading/NetworkStatusNotifier.js +8 -0
  189. package/Loading/NetworkStatusNotifier.js.map +1 -0
  190. package/Menu/MenuContainer.d.ts +28 -0
  191. package/Menu/MenuContainer.js +46 -0
  192. package/Menu/MenuContainer.js.map +1 -0
  193. package/Menu/RecursiveTree.d.ts +28 -0
  194. package/Menu/RecursiveTree.js +91 -0
  195. package/Menu/RecursiveTree.js.map +1 -0
  196. package/Modal/Drawer/Drawer.d.ts +12 -0
  197. package/Modal/Drawer/Drawer.js +31 -0
  198. package/Modal/Drawer/Drawer.js.map +1 -0
  199. package/Modal/Drawer/DrawerTarget.d.ts +6 -0
  200. package/Modal/Drawer/DrawerTarget.js +12 -0
  201. package/Modal/Drawer/DrawerTarget.js.map +1 -0
  202. package/Modal/Drawer/DrawerTrigger.d.ts +11 -0
  203. package/Modal/Drawer/DrawerTrigger.js +16 -0
  204. package/Modal/Drawer/DrawerTrigger.js.map +1 -0
  205. package/Modal/Drawer/index.d.ts +3 -0
  206. package/Modal/Drawer/index.js +4 -0
  207. package/Modal/Drawer/index.js.map +1 -0
  208. package/Modal/Flyout/FlyoutTarget.d.ts +10 -0
  209. package/Modal/Flyout/FlyoutTarget.js +15 -0
  210. package/Modal/Flyout/FlyoutTarget.js.map +1 -0
  211. package/Modal/Flyout/FlyoutTrigger.d.ts +15 -0
  212. package/Modal/Flyout/FlyoutTrigger.js +18 -0
  213. package/Modal/Flyout/FlyoutTrigger.js.map +1 -0
  214. package/Modal/Flyout/index.d.ts +2 -0
  215. package/Modal/Flyout/index.js +3 -0
  216. package/Modal/Flyout/index.js.map +1 -0
  217. package/Modal/ModalContext.d.ts +26 -0
  218. package/Modal/ModalContext.js +9 -0
  219. package/Modal/ModalContext.js.map +1 -0
  220. package/Modal/ModalProvider.d.ts +5 -0
  221. package/Modal/ModalProvider.js +83 -0
  222. package/Modal/ModalProvider.js.map +1 -0
  223. package/Modal/ModalRoot.d.ts +3 -0
  224. package/Modal/ModalRoot.js +44 -0
  225. package/Modal/ModalRoot.js.map +1 -0
  226. package/Modal/ModalTrigger.d.ts +9 -0
  227. package/Modal/ModalTrigger.js +9 -0
  228. package/Modal/ModalTrigger.js.map +1 -0
  229. package/Pagination/Pagination.d.ts +7 -0
  230. package/Pagination/Pagination.js +23 -0
  231. package/Pagination/Pagination.js.map +1 -0
  232. package/Pagination/PaginationBehaviour.d.ts +52 -0
  233. package/Pagination/PaginationBehaviour.js +68 -0
  234. package/Pagination/PaginationBehaviour.js.map +1 -0
  235. package/Pagination/index.d.ts +2 -0
  236. package/Pagination/index.js +3 -0
  237. package/Pagination/index.js.map +1 -0
  238. package/Pagination/usePagination.d.ts +15 -0
  239. package/Pagination/usePagination.js +46 -0
  240. package/Pagination/usePagination.js.map +1 -0
  241. package/PreOrderDateSelector/PreOrderDateSelector.d.ts +23 -0
  242. package/PreOrderDateSelector/PreOrderDateSelector.js +74 -0
  243. package/PreOrderDateSelector/PreOrderDateSelector.js.map +1 -0
  244. package/PreOrderDateSelector/index.d.ts +2 -0
  245. package/PreOrderDateSelector/index.js +3 -0
  246. package/PreOrderDateSelector/index.js.map +1 -0
  247. package/Price/Currency.d.ts +9 -0
  248. package/Price/Currency.js +11 -0
  249. package/Price/Currency.js.map +1 -0
  250. package/Price/Price.d.ts +44 -0
  251. package/Price/Price.js +74 -0
  252. package/Price/Price.js.map +1 -0
  253. package/Price/index.d.ts +1 -0
  254. package/Price/index.js +2 -0
  255. package/Price/index.js.map +1 -0
  256. package/ProductLink.d.ts +23 -0
  257. package/ProductLink.js +88 -0
  258. package/ProductLink.js.map +1 -0
  259. package/ProductList/Badges.d.ts +6 -0
  260. package/ProductList/Badges.js +56 -0
  261. package/ProductList/Badges.js.map +1 -0
  262. package/ProductList/GridProduct.d.ts +24 -0
  263. package/ProductList/GridProduct.js +58 -0
  264. package/ProductList/GridProduct.js.map +1 -0
  265. package/ProductList/ProductGrid.d.ts +16 -0
  266. package/ProductList/ProductGrid.js +30 -0
  267. package/ProductList/ProductGrid.js.map +1 -0
  268. package/ProductList/ProductImage.d.ts +12 -0
  269. package/ProductList/ProductImage.js +21 -0
  270. package/ProductList/ProductImage.js.map +1 -0
  271. package/ProductSpecifications/ProductSpecifications.d.ts +8 -0
  272. package/ProductSpecifications/ProductSpecifications.js +78 -0
  273. package/ProductSpecifications/ProductSpecifications.js.map +1 -0
  274. package/ScrollRestorationHandler/ScrollRestorationHandler.d.ts +8 -0
  275. package/ScrollRestorationHandler/ScrollRestorationHandler.js +17 -0
  276. package/ScrollRestorationHandler/ScrollRestorationHandler.js.map +1 -0
  277. package/ScrollRestorationHandler/index.d.ts +1 -0
  278. package/ScrollRestorationHandler/index.js +2 -0
  279. package/ScrollRestorationHandler/index.js.map +1 -0
  280. package/ScrollRestorationHandler/isInIgnoredRouteTypes.d.ts +8 -0
  281. package/ScrollRestorationHandler/isInIgnoredRouteTypes.js +8 -0
  282. package/ScrollRestorationHandler/isInIgnoredRouteTypes.js.map +1 -0
  283. package/ScrollRestorationHandler/useScrollRestore.d.ts +9 -0
  284. package/ScrollRestorationHandler/useScrollRestore.js +20 -0
  285. package/ScrollRestorationHandler/useScrollRestore.js.map +1 -0
  286. package/Search/SearchAutoCompleteContainer.d.ts +45 -0
  287. package/Search/SearchAutoCompleteContainer.js +172 -0
  288. package/Search/SearchAutoCompleteContainer.js.map +1 -0
  289. package/Search/SearchField.d.ts +26 -0
  290. package/Search/SearchField.js +98 -0
  291. package/Search/SearchField.js.map +1 -0
  292. package/Search/SearchPage/PageOf.d.ts +5 -0
  293. package/Search/SearchPage/PageOf.js +7 -0
  294. package/Search/SearchPage/PageOf.js.map +1 -0
  295. package/Search/SearchPage/SearchMeta.d.ts +16 -0
  296. package/Search/SearchPage/SearchMeta.js +20 -0
  297. package/Search/SearchPage/SearchMeta.js.map +1 -0
  298. package/Search/SearchPage/SearchPageBehaviour.d.ts +19 -0
  299. package/Search/SearchPage/SearchPageBehaviour.js +75 -0
  300. package/Search/SearchPage/SearchPageBehaviour.js.map +1 -0
  301. package/Search/SuggestedTerm.d.ts +16 -0
  302. package/Search/SuggestedTerm.js +35 -0
  303. package/Search/SuggestedTerm.js.map +1 -0
  304. package/Search/index.d.ts +1 -0
  305. package/Search/index.js +2 -0
  306. package/Search/index.js.map +1 -0
  307. package/Select/Components.d.ts +28 -0
  308. package/Select/Components.js +91 -0
  309. package/Select/Components.js.map +1 -0
  310. package/Select/SelectComponents/Quantity.d.ts +5 -0
  311. package/Select/SelectComponents/Quantity.js +8 -0
  312. package/Select/SelectComponents/Quantity.js.map +1 -0
  313. package/Select/index.d.ts +5 -0
  314. package/Select/index.js +2 -0
  315. package/Select/index.js.map +1 -0
  316. package/SortOrder/SortOrder.d.ts +16 -0
  317. package/SortOrder/SortOrder.js +33 -0
  318. package/SortOrder/SortOrder.js.map +1 -0
  319. package/SortOrder/SortOrderDropdown.d.ts +9 -0
  320. package/SortOrder/SortOrderDropdown.js +25 -0
  321. package/SortOrder/SortOrderDropdown.js.map +1 -0
  322. package/SortOrder/SortOrderList.d.ts +7 -0
  323. package/SortOrder/SortOrderList.js +17 -0
  324. package/SortOrder/SortOrderList.js.map +1 -0
  325. package/StartPageRenderer/StartPageRenderer.d.ts +17 -0
  326. package/StartPageRenderer/StartPageRenderer.js +52 -0
  327. package/StartPageRenderer/StartPageRenderer.js.map +1 -0
  328. package/StartPageRenderer/index.d.ts +1 -0
  329. package/StartPageRenderer/index.js +2 -0
  330. package/StartPageRenderer/index.js.map +1 -0
  331. package/Stock/StockStatusContainer.d.ts +21 -0
  332. package/Stock/StockStatusContainer.js +45 -0
  333. package/Stock/StockStatusContainer.js.map +1 -0
  334. package/Text/Text.d.ts +11 -0
  335. package/Text/Text.js +22 -0
  336. package/Text/Text.js.map +1 -0
  337. package/Text/index.d.ts +3 -0
  338. package/Text/index.js +4 -0
  339. package/Text/index.js.map +1 -0
  340. package/Theme/createTheme.d.ts +16 -0
  341. package/Theme/createTheme.js +5 -0
  342. package/Theme/createTheme.js.map +1 -0
  343. package/Theme/cssReset.d.ts +1 -0
  344. package/Theme/cssReset.js +160 -0
  345. package/Theme/cssReset.js.map +1 -0
  346. package/Theme/normalizeCss.d.ts +1 -0
  347. package/Theme/normalizeCss.js +357 -0
  348. package/Theme/normalizeCss.js.map +1 -0
  349. package/Theme/sanitizeCss.d.ts +1 -0
  350. package/Theme/sanitizeCss.js +572 -0
  351. package/Theme/sanitizeCss.js.map +1 -0
  352. package/WindowGrid/WindowGrid.d.ts +11 -0
  353. package/WindowGrid/WindowGrid.js +58 -0
  354. package/WindowGrid/WindowGrid.js.map +1 -0
  355. package/WindowGrid/index.d.ts +1 -0
  356. package/WindowGrid/index.js +2 -0
  357. package/WindowGrid/index.js.map +1 -0
  358. package/WindowGrid/useResizeObserver.d.ts +3 -0
  359. package/WindowGrid/useResizeObserver.js +14 -0
  360. package/WindowGrid/useResizeObserver.js.map +1 -0
  361. package/WindowGrid/useScrollWithWindow.d.ts +12 -0
  362. package/WindowGrid/useScrollWithWindow.js +39 -0
  363. package/WindowGrid/useScrollWithWindow.js.map +1 -0
  364. package/fuzzySearch/fuzzySearch.d.ts +8 -0
  365. package/fuzzySearch/fuzzySearch.js +43 -0
  366. package/fuzzySearch/fuzzySearch.js.map +1 -0
  367. package/fuzzySearch/index.d.ts +1 -0
  368. package/fuzzySearch/index.js +2 -0
  369. package/fuzzySearch/index.js.map +1 -0
  370. package/hooks/index.d.ts +2 -0
  371. package/hooks/index.js +3 -0
  372. package/hooks/index.js.map +1 -0
  373. package/hooks/useOnClickOutside.d.ts +6 -0
  374. package/hooks/useOnClickOutside.js +17 -0
  375. package/hooks/useOnClickOutside.js.map +1 -0
  376. package/hooks/useOnEsc.d.ts +4 -0
  377. package/hooks/useOnEsc.js +17 -0
  378. package/hooks/useOnEsc.js.map +1 -0
  379. package/package.json +1 -1
  380. package/utils/breakpoints.d.ts +23 -0
  381. package/utils/breakpoints.js +94 -0
  382. package/utils/breakpoints.js.map +1 -0
  383. package/utils/callAllEventHandlers.d.ts +5 -0
  384. package/utils/callAllEventHandlers.js +9 -0
  385. package/utils/callAllEventHandlers.js.map +1 -0
  386. package/utils/text.d.ts +1 -0
  387. package/utils/text.js +23 -0
  388. package/utils/text.js.map +1 -0
  389. package/utils/theme.d.ts +3 -0
  390. package/utils/theme.js +5 -0
  391. package/utils/theme.js.map +1 -0
  392. package/utils/useHoverIntent.d.ts +10 -0
  393. package/utils/useHoverIntent.js +78 -0
  394. package/utils/useHoverIntent.js.map +1 -0
  395. package/utils/usePropsOfType.d.ts +11 -0
  396. package/utils/usePropsOfType.js +18 -0
  397. package/utils/usePropsOfType.js.map +1 -0
  398. package/withFlightUI.d.ts +17 -0
  399. package/withFlightUI.js +20 -0
  400. 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,2 @@
1
+ export { FlyoutTrigger } from './FlyoutTrigger';
2
+ export { FlyoutTarget } from './FlyoutTarget';
@@ -0,0 +1,3 @@
1
+ export { FlyoutTrigger } from './FlyoutTrigger';
2
+ export { FlyoutTarget } from './FlyoutTarget';
3
+ //# sourceMappingURL=index.js.map
@@ -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,9 @@
1
+ import { createContext } from 'react';
2
+ const initialModalState = {
3
+ showTarget: null,
4
+ hideTarget: null,
5
+ modals: []
6
+ };
7
+ const ModalContext = createContext(initialModalState);
8
+ export default ModalContext;
9
+ //# sourceMappingURL=ModalContext.js.map
@@ -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,5 @@
1
+ import React from 'react';
2
+ declare const ModalProvider: ({ children }: {
3
+ children: React.ReactNode;
4
+ }) => React.JSX.Element;
5
+ export default ModalProvider;
@@ -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,3 @@
1
+ import * as React from 'react';
2
+ declare const ModalRoot: () => React.JSX.Element;
3
+ export default ModalRoot;
@@ -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,2 @@
1
+ export { default as Pagination } from './Pagination';
2
+ export { default as PaginationBehaviour } from './PaginationBehaviour';
@@ -0,0 +1,3 @@
1
+ export { default as Pagination } from './Pagination';
2
+ export { default as PaginationBehaviour } from './PaginationBehaviour';
3
+ //# sourceMappingURL=index.js.map
@@ -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;