@jetshop/ui 6.3.9-alpha.1 → 6.5.0

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 (463) 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/CloudflareImage/BaseImage.d.ts +41 -0
  80. package/CloudflareImage/BaseImage.js +192 -0
  81. package/CloudflareImage/BaseImage.js.map +1 -0
  82. package/CloudflareImage/Fallback.d.ts +5 -0
  83. package/CloudflareImage/Fallback.js +4 -0
  84. package/CloudflareImage/Fallback.js.map +1 -0
  85. package/CloudflareImage/FlightImage.d.ts +73 -0
  86. package/CloudflareImage/FlightImage.js +61 -0
  87. package/CloudflareImage/FlightImage.js.map +1 -0
  88. package/CloudflareImage/Image.d.ts +2 -0
  89. package/CloudflareImage/Image.js +3 -0
  90. package/CloudflareImage/Image.js.map +1 -0
  91. package/CloudflareImage/index.d.ts +1 -0
  92. package/CloudflareImage/index.js +2 -0
  93. package/CloudflareImage/index.js.map +1 -0
  94. package/CloudflareImage/useConstructImage.d.ts +49 -0
  95. package/CloudflareImage/useConstructImage.js +122 -0
  96. package/CloudflareImage/useConstructImage.js.map +1 -0
  97. package/CloudflareImage/utils/aspectRatioToFraction.d.ts +2 -0
  98. package/CloudflareImage/utils/aspectRatioToFraction.js +11 -0
  99. package/CloudflareImage/utils/aspectRatioToFraction.js.map +1 -0
  100. package/CloudflareImage/utils/getFullUrl.d.ts +6 -0
  101. package/CloudflareImage/utils/getFullUrl.js +18 -0
  102. package/CloudflareImage/utils/getFullUrl.js.map +1 -0
  103. package/CloudflareImage/utils/getImageWidth.d.ts +1 -0
  104. package/CloudflareImage/utils/getImageWidth.js +12 -0
  105. package/CloudflareImage/utils/getImageWidth.js.map +1 -0
  106. package/CloudflareImage/utils/getImageWidths.d.ts +2 -0
  107. package/CloudflareImage/utils/getImageWidths.js +21 -0
  108. package/CloudflareImage/utils/getImageWidths.js.map +1 -0
  109. package/CloudflareImage/utils/getLQIP.d.ts +8 -0
  110. package/CloudflareImage/utils/getLQIP.js +28 -0
  111. package/CloudflareImage/utils/getLQIP.js.map +1 -0
  112. package/CloudflareImage/utils/getLargestSize.d.ts +7 -0
  113. package/CloudflareImage/utils/getLargestSize.js +17 -0
  114. package/CloudflareImage/utils/getLargestSize.js.map +1 -0
  115. package/CloudflareImage/utils/getSizeForBreakpoint.d.ts +2 -0
  116. package/CloudflareImage/utils/getSizeForBreakpoint.js +16 -0
  117. package/CloudflareImage/utils/getSizeForBreakpoint.js.map +1 -0
  118. package/CloudflareImage/utils/getSizesMap.d.ts +2 -0
  119. package/CloudflareImage/utils/getSizesMap.js +35 -0
  120. package/CloudflareImage/utils/getSizesMap.js.map +1 -0
  121. package/CloudflareImage/utils/getSmallestSize.d.ts +2 -0
  122. package/CloudflareImage/utils/getSmallestSize.js +12 -0
  123. package/CloudflareImage/utils/getSmallestSize.js.map +1 -0
  124. package/CloudflareImage/utils/getSrcSetFromWidths.d.ts +10 -0
  125. package/CloudflareImage/utils/getSrcSetFromWidths.js +10 -0
  126. package/CloudflareImage/utils/getSrcSetFromWidths.js.map +1 -0
  127. package/CloudflareImage/utils/getSrcWithParams.d.ts +3 -0
  128. package/CloudflareImage/utils/getSrcWithParams.js +61 -0
  129. package/CloudflareImage/utils/getSrcWithParams.js.map +1 -0
  130. package/CloudflareImage/utils/paddingForAspectRatio.d.ts +1 -0
  131. package/CloudflareImage/utils/paddingForAspectRatio.js +6 -0
  132. package/CloudflareImage/utils/paddingForAspectRatio.js.map +1 -0
  133. package/CloudflareImage/utils/remToPx.d.ts +1 -0
  134. package/CloudflareImage/utils/remToPx.js +2 -0
  135. package/CloudflareImage/utils/remToPx.js.map +1 -0
  136. package/CloudflareImage/utils/sizeToNumber.d.ts +2 -0
  137. package/CloudflareImage/utils/sizeToNumber.js +27 -0
  138. package/CloudflareImage/utils/sizeToNumber.js.map +1 -0
  139. package/ContentPageLink.d.ts +11 -0
  140. package/ContentPageLink.js +46 -0
  141. package/ContentPageLink.js.map +1 -0
  142. package/ContentRenderer.d.ts +9 -0
  143. package/ContentRenderer.js +36 -0
  144. package/ContentRenderer.js.map +1 -0
  145. package/DropdownMenu/Button.d.ts +7 -0
  146. package/DropdownMenu/Button.js +33 -0
  147. package/DropdownMenu/Button.js.map +1 -0
  148. package/DropdownMenu/DropdownMenu.d.ts +21 -0
  149. package/DropdownMenu/DropdownMenu.js +72 -0
  150. package/DropdownMenu/DropdownMenu.js.map +1 -0
  151. package/DropdownMenu/Item.d.ts +13 -0
  152. package/DropdownMenu/Item.js +48 -0
  153. package/DropdownMenu/Item.js.map +1 -0
  154. package/DropdownMenu/Items.d.ts +16 -0
  155. package/DropdownMenu/Items.js +53 -0
  156. package/DropdownMenu/Items.js.map +1 -0
  157. package/DropdownMenu/index.d.ts +4 -0
  158. package/DropdownMenu/index.js +5 -0
  159. package/DropdownMenu/index.js.map +1 -0
  160. package/ErrorBoundary/Generic.d.ts +18 -0
  161. package/ErrorBoundary/Generic.js +69 -0
  162. package/ErrorBoundary/Generic.js.map +1 -0
  163. package/ErrorBoundary/PassThrough.d.ts +3 -0
  164. package/ErrorBoundary/PassThrough.js +7 -0
  165. package/ErrorBoundary/PassThrough.js.map +1 -0
  166. package/Gallery/Gallery.d.ts +39 -0
  167. package/Gallery/Gallery.js +121 -0
  168. package/Gallery/Gallery.js.map +1 -0
  169. package/Gallery/constructGallery.d.ts +15 -0
  170. package/Gallery/constructGallery.js +40 -0
  171. package/Gallery/constructGallery.js.map +1 -0
  172. package/Image/BaseImage.d.ts +40 -0
  173. package/Image/BaseImage.js +192 -0
  174. package/Image/BaseImage.js.map +1 -0
  175. package/Image/DispatchFlightImage.d.ts +7 -0
  176. package/Image/DispatchFlightImage.js +11 -0
  177. package/Image/DispatchFlightImage.js.map +1 -0
  178. package/Image/Fallback.d.ts +5 -0
  179. package/Image/Fallback.js +4 -0
  180. package/Image/Fallback.js.map +1 -0
  181. package/Image/FlightImage.d.ts +51 -0
  182. package/Image/FlightImage.js +59 -0
  183. package/Image/FlightImage.js.map +1 -0
  184. package/Image/Image.d.ts +2 -0
  185. package/Image/Image.js +3 -0
  186. package/Image/Image.js.map +1 -0
  187. package/Image/index.d.ts +2 -0
  188. package/Image/index.js +3 -0
  189. package/Image/index.js.map +1 -0
  190. package/Image/useConstructImage.d.ts +49 -0
  191. package/Image/useConstructImage.js +122 -0
  192. package/Image/useConstructImage.js.map +1 -0
  193. package/Image/utils/aspectRatioToFraction.d.ts +2 -0
  194. package/Image/utils/aspectRatioToFraction.js +11 -0
  195. package/Image/utils/aspectRatioToFraction.js.map +1 -0
  196. package/Image/utils/getFullUrl.d.ts +6 -0
  197. package/Image/utils/getFullUrl.js +18 -0
  198. package/Image/utils/getFullUrl.js.map +1 -0
  199. package/Image/utils/getImageWidth.d.ts +1 -0
  200. package/Image/utils/getImageWidth.js +12 -0
  201. package/Image/utils/getImageWidth.js.map +1 -0
  202. package/Image/utils/getImageWidths.d.ts +2 -0
  203. package/Image/utils/getImageWidths.js +21 -0
  204. package/Image/utils/getImageWidths.js.map +1 -0
  205. package/Image/utils/getLQIP.d.ts +8 -0
  206. package/Image/utils/getLQIP.js +20 -0
  207. package/Image/utils/getLQIP.js.map +1 -0
  208. package/Image/utils/getLargestSize.d.ts +7 -0
  209. package/Image/utils/getLargestSize.js +17 -0
  210. package/Image/utils/getLargestSize.js.map +1 -0
  211. package/Image/utils/getSizeForBreakpoint.d.ts +2 -0
  212. package/Image/utils/getSizeForBreakpoint.js +16 -0
  213. package/Image/utils/getSizeForBreakpoint.js.map +1 -0
  214. package/Image/utils/getSizesMap.d.ts +2 -0
  215. package/Image/utils/getSizesMap.js +35 -0
  216. package/Image/utils/getSizesMap.js.map +1 -0
  217. package/Image/utils/getSmallestSize.d.ts +2 -0
  218. package/Image/utils/getSmallestSize.js +12 -0
  219. package/Image/utils/getSmallestSize.js.map +1 -0
  220. package/Image/utils/getSrcSetFromWidths.d.ts +10 -0
  221. package/Image/utils/getSrcSetFromWidths.js +9 -0
  222. package/Image/utils/getSrcSetFromWidths.js.map +1 -0
  223. package/Image/utils/getSrcWithParams.d.ts +3 -0
  224. package/Image/utils/getSrcWithParams.js +29 -0
  225. package/Image/utils/getSrcWithParams.js.map +1 -0
  226. package/Image/utils/paddingForAspectRatio.d.ts +1 -0
  227. package/Image/utils/paddingForAspectRatio.js +6 -0
  228. package/Image/utils/paddingForAspectRatio.js.map +1 -0
  229. package/Image/utils/remToPx.d.ts +1 -0
  230. package/Image/utils/remToPx.js +2 -0
  231. package/Image/utils/remToPx.js.map +1 -0
  232. package/Image/utils/sizeToNumber.d.ts +2 -0
  233. package/Image/utils/sizeToNumber.js +27 -0
  234. package/Image/utils/sizeToNumber.js.map +1 -0
  235. package/Input/Input.d.ts +6 -0
  236. package/Input/Input.js +45 -0
  237. package/Input/Input.js.map +1 -0
  238. package/Input/index.d.ts +3 -0
  239. package/Input/index.js +4 -0
  240. package/Input/index.js.map +1 -0
  241. package/JetshopText.d.ts +3 -0
  242. package/JetshopText.js +13 -0
  243. package/JetshopText.js.map +1 -0
  244. package/Loading/LoadingBar.d.ts +8 -0
  245. package/Loading/LoadingBar.js +58 -0
  246. package/Loading/LoadingBar.js.map +1 -0
  247. package/Loading/LoadingLine.d.ts +31 -0
  248. package/Loading/LoadingLine.js +26 -0
  249. package/Loading/LoadingLine.js.map +1 -0
  250. package/Loading/NetworkStatusNotifier.d.ts +6 -0
  251. package/Loading/NetworkStatusNotifier.js +8 -0
  252. package/Loading/NetworkStatusNotifier.js.map +1 -0
  253. package/Menu/MenuContainer.d.ts +28 -0
  254. package/Menu/MenuContainer.js +46 -0
  255. package/Menu/MenuContainer.js.map +1 -0
  256. package/Menu/RecursiveTree.d.ts +28 -0
  257. package/Menu/RecursiveTree.js +91 -0
  258. package/Menu/RecursiveTree.js.map +1 -0
  259. package/Modal/Drawer/Drawer.d.ts +12 -0
  260. package/Modal/Drawer/Drawer.js +31 -0
  261. package/Modal/Drawer/Drawer.js.map +1 -0
  262. package/Modal/Drawer/DrawerTarget.d.ts +6 -0
  263. package/Modal/Drawer/DrawerTarget.js +12 -0
  264. package/Modal/Drawer/DrawerTarget.js.map +1 -0
  265. package/Modal/Drawer/DrawerTrigger.d.ts +11 -0
  266. package/Modal/Drawer/DrawerTrigger.js +16 -0
  267. package/Modal/Drawer/DrawerTrigger.js.map +1 -0
  268. package/Modal/Drawer/index.d.ts +3 -0
  269. package/Modal/Drawer/index.js +4 -0
  270. package/Modal/Drawer/index.js.map +1 -0
  271. package/Modal/Flyout/FlyoutTarget.d.ts +10 -0
  272. package/Modal/Flyout/FlyoutTarget.js +15 -0
  273. package/Modal/Flyout/FlyoutTarget.js.map +1 -0
  274. package/Modal/Flyout/FlyoutTrigger.d.ts +15 -0
  275. package/Modal/Flyout/FlyoutTrigger.js +18 -0
  276. package/Modal/Flyout/FlyoutTrigger.js.map +1 -0
  277. package/Modal/Flyout/index.d.ts +2 -0
  278. package/Modal/Flyout/index.js +3 -0
  279. package/Modal/Flyout/index.js.map +1 -0
  280. package/Modal/ModalContext.d.ts +26 -0
  281. package/Modal/ModalContext.js +9 -0
  282. package/Modal/ModalContext.js.map +1 -0
  283. package/Modal/ModalProvider.d.ts +5 -0
  284. package/Modal/ModalProvider.js +83 -0
  285. package/Modal/ModalProvider.js.map +1 -0
  286. package/Modal/ModalRoot.d.ts +3 -0
  287. package/Modal/ModalRoot.js +44 -0
  288. package/Modal/ModalRoot.js.map +1 -0
  289. package/Modal/ModalTrigger.d.ts +9 -0
  290. package/Modal/ModalTrigger.js +9 -0
  291. package/Modal/ModalTrigger.js.map +1 -0
  292. package/Pagination/Pagination.d.ts +7 -0
  293. package/Pagination/Pagination.js +23 -0
  294. package/Pagination/Pagination.js.map +1 -0
  295. package/Pagination/PaginationBehaviour.d.ts +52 -0
  296. package/Pagination/PaginationBehaviour.js +68 -0
  297. package/Pagination/PaginationBehaviour.js.map +1 -0
  298. package/Pagination/index.d.ts +2 -0
  299. package/Pagination/index.js +3 -0
  300. package/Pagination/index.js.map +1 -0
  301. package/Pagination/usePagination.d.ts +15 -0
  302. package/Pagination/usePagination.js +46 -0
  303. package/Pagination/usePagination.js.map +1 -0
  304. package/PreOrderDateSelector/PreOrderDateSelector.d.ts +23 -0
  305. package/PreOrderDateSelector/PreOrderDateSelector.js +74 -0
  306. package/PreOrderDateSelector/PreOrderDateSelector.js.map +1 -0
  307. package/PreOrderDateSelector/index.d.ts +2 -0
  308. package/PreOrderDateSelector/index.js +3 -0
  309. package/PreOrderDateSelector/index.js.map +1 -0
  310. package/Price/Currency.d.ts +9 -0
  311. package/Price/Currency.js +11 -0
  312. package/Price/Currency.js.map +1 -0
  313. package/Price/Price.d.ts +44 -0
  314. package/Price/Price.js +74 -0
  315. package/Price/Price.js.map +1 -0
  316. package/Price/index.d.ts +1 -0
  317. package/Price/index.js +2 -0
  318. package/Price/index.js.map +1 -0
  319. package/ProductLink.d.ts +23 -0
  320. package/ProductLink.js +88 -0
  321. package/ProductLink.js.map +1 -0
  322. package/ProductList/Badges.d.ts +6 -0
  323. package/ProductList/Badges.js +56 -0
  324. package/ProductList/Badges.js.map +1 -0
  325. package/ProductList/GridProduct.d.ts +24 -0
  326. package/ProductList/GridProduct.js +58 -0
  327. package/ProductList/GridProduct.js.map +1 -0
  328. package/ProductList/ProductGrid.d.ts +16 -0
  329. package/ProductList/ProductGrid.js +30 -0
  330. package/ProductList/ProductGrid.js.map +1 -0
  331. package/ProductList/ProductImage.d.ts +12 -0
  332. package/ProductList/ProductImage.js +21 -0
  333. package/ProductList/ProductImage.js.map +1 -0
  334. package/ProductSpecifications/ProductSpecifications.d.ts +8 -0
  335. package/ProductSpecifications/ProductSpecifications.js +78 -0
  336. package/ProductSpecifications/ProductSpecifications.js.map +1 -0
  337. package/ScrollRestorationHandler/ScrollRestorationHandler.d.ts +8 -0
  338. package/ScrollRestorationHandler/ScrollRestorationHandler.js +17 -0
  339. package/ScrollRestorationHandler/ScrollRestorationHandler.js.map +1 -0
  340. package/ScrollRestorationHandler/index.d.ts +1 -0
  341. package/ScrollRestorationHandler/index.js +2 -0
  342. package/ScrollRestorationHandler/index.js.map +1 -0
  343. package/ScrollRestorationHandler/isInIgnoredRouteTypes.d.ts +8 -0
  344. package/ScrollRestorationHandler/isInIgnoredRouteTypes.js +8 -0
  345. package/ScrollRestorationHandler/isInIgnoredRouteTypes.js.map +1 -0
  346. package/ScrollRestorationHandler/useScrollRestore.d.ts +9 -0
  347. package/ScrollRestorationHandler/useScrollRestore.js +20 -0
  348. package/ScrollRestorationHandler/useScrollRestore.js.map +1 -0
  349. package/Search/SearchAutoCompleteContainer.d.ts +45 -0
  350. package/Search/SearchAutoCompleteContainer.js +172 -0
  351. package/Search/SearchAutoCompleteContainer.js.map +1 -0
  352. package/Search/SearchField.d.ts +26 -0
  353. package/Search/SearchField.js +98 -0
  354. package/Search/SearchField.js.map +1 -0
  355. package/Search/SearchPage/PageOf.d.ts +5 -0
  356. package/Search/SearchPage/PageOf.js +7 -0
  357. package/Search/SearchPage/PageOf.js.map +1 -0
  358. package/Search/SearchPage/SearchMeta.d.ts +16 -0
  359. package/Search/SearchPage/SearchMeta.js +20 -0
  360. package/Search/SearchPage/SearchMeta.js.map +1 -0
  361. package/Search/SearchPage/SearchPageBehaviour.d.ts +19 -0
  362. package/Search/SearchPage/SearchPageBehaviour.js +75 -0
  363. package/Search/SearchPage/SearchPageBehaviour.js.map +1 -0
  364. package/Search/SuggestedTerm.d.ts +16 -0
  365. package/Search/SuggestedTerm.js +35 -0
  366. package/Search/SuggestedTerm.js.map +1 -0
  367. package/Search/index.d.ts +1 -0
  368. package/Search/index.js +2 -0
  369. package/Search/index.js.map +1 -0
  370. package/Select/Components.d.ts +28 -0
  371. package/Select/Components.js +91 -0
  372. package/Select/Components.js.map +1 -0
  373. package/Select/SelectComponents/Quantity.d.ts +5 -0
  374. package/Select/SelectComponents/Quantity.js +8 -0
  375. package/Select/SelectComponents/Quantity.js.map +1 -0
  376. package/Select/index.d.ts +5 -0
  377. package/Select/index.js +2 -0
  378. package/Select/index.js.map +1 -0
  379. package/SortOrder/SortOrder.d.ts +16 -0
  380. package/SortOrder/SortOrder.js +33 -0
  381. package/SortOrder/SortOrder.js.map +1 -0
  382. package/SortOrder/SortOrderDropdown.d.ts +9 -0
  383. package/SortOrder/SortOrderDropdown.js +25 -0
  384. package/SortOrder/SortOrderDropdown.js.map +1 -0
  385. package/SortOrder/SortOrderList.d.ts +7 -0
  386. package/SortOrder/SortOrderList.js +17 -0
  387. package/SortOrder/SortOrderList.js.map +1 -0
  388. package/StartPageRenderer/StartPageRenderer.d.ts +17 -0
  389. package/StartPageRenderer/StartPageRenderer.js +52 -0
  390. package/StartPageRenderer/StartPageRenderer.js.map +1 -0
  391. package/StartPageRenderer/index.d.ts +1 -0
  392. package/StartPageRenderer/index.js +2 -0
  393. package/StartPageRenderer/index.js.map +1 -0
  394. package/Stock/StockStatusContainer.d.ts +21 -0
  395. package/Stock/StockStatusContainer.js +45 -0
  396. package/Stock/StockStatusContainer.js.map +1 -0
  397. package/Text/Text.d.ts +11 -0
  398. package/Text/Text.js +22 -0
  399. package/Text/Text.js.map +1 -0
  400. package/Text/index.d.ts +3 -0
  401. package/Text/index.js +4 -0
  402. package/Text/index.js.map +1 -0
  403. package/Theme/createTheme.d.ts +16 -0
  404. package/Theme/createTheme.js +5 -0
  405. package/Theme/createTheme.js.map +1 -0
  406. package/Theme/cssReset.d.ts +1 -0
  407. package/Theme/cssReset.js +160 -0
  408. package/Theme/cssReset.js.map +1 -0
  409. package/Theme/normalizeCss.d.ts +1 -0
  410. package/Theme/normalizeCss.js +357 -0
  411. package/Theme/normalizeCss.js.map +1 -0
  412. package/Theme/sanitizeCss.d.ts +1 -0
  413. package/Theme/sanitizeCss.js +572 -0
  414. package/Theme/sanitizeCss.js.map +1 -0
  415. package/WindowGrid/WindowGrid.d.ts +11 -0
  416. package/WindowGrid/WindowGrid.js +58 -0
  417. package/WindowGrid/WindowGrid.js.map +1 -0
  418. package/WindowGrid/index.d.ts +1 -0
  419. package/WindowGrid/index.js +2 -0
  420. package/WindowGrid/index.js.map +1 -0
  421. package/WindowGrid/useResizeObserver.d.ts +3 -0
  422. package/WindowGrid/useResizeObserver.js +14 -0
  423. package/WindowGrid/useResizeObserver.js.map +1 -0
  424. package/WindowGrid/useScrollWithWindow.d.ts +12 -0
  425. package/WindowGrid/useScrollWithWindow.js +39 -0
  426. package/WindowGrid/useScrollWithWindow.js.map +1 -0
  427. package/fuzzySearch/fuzzySearch.d.ts +8 -0
  428. package/fuzzySearch/fuzzySearch.js +43 -0
  429. package/fuzzySearch/fuzzySearch.js.map +1 -0
  430. package/fuzzySearch/index.d.ts +1 -0
  431. package/fuzzySearch/index.js +2 -0
  432. package/fuzzySearch/index.js.map +1 -0
  433. package/hooks/index.d.ts +2 -0
  434. package/hooks/index.js +3 -0
  435. package/hooks/index.js.map +1 -0
  436. package/hooks/useOnClickOutside.d.ts +6 -0
  437. package/hooks/useOnClickOutside.js +17 -0
  438. package/hooks/useOnClickOutside.js.map +1 -0
  439. package/hooks/useOnEsc.d.ts +4 -0
  440. package/hooks/useOnEsc.js +17 -0
  441. package/hooks/useOnEsc.js.map +1 -0
  442. package/package.json +3 -2
  443. package/utils/breakpoints.d.ts +23 -0
  444. package/utils/breakpoints.js +94 -0
  445. package/utils/breakpoints.js.map +1 -0
  446. package/utils/callAllEventHandlers.d.ts +5 -0
  447. package/utils/callAllEventHandlers.js +9 -0
  448. package/utils/callAllEventHandlers.js.map +1 -0
  449. package/utils/text.d.ts +1 -0
  450. package/utils/text.js +23 -0
  451. package/utils/text.js.map +1 -0
  452. package/utils/theme.d.ts +3 -0
  453. package/utils/theme.js +5 -0
  454. package/utils/theme.js.map +1 -0
  455. package/utils/useHoverIntent.d.ts +10 -0
  456. package/utils/useHoverIntent.js +78 -0
  457. package/utils/useHoverIntent.js.map +1 -0
  458. package/utils/usePropsOfType.d.ts +11 -0
  459. package/utils/usePropsOfType.js +18 -0
  460. package/utils/usePropsOfType.js.map +1 -0
  461. package/withFlightUI.d.ts +17 -0
  462. package/withFlightUI.js +20 -0
  463. package/withFlightUI.js.map +1 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ContentPageLink.js","sourceRoot":"","sources":["ContentPageLink.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,IAAI,EAAa,MAAM,kBAAkB,CAAC;AAEnD,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAWxD,MAAM,eAAe,GACnB,SAAS,eAAe,CAAC,KAAK;IAC5B,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,YAAY,GAAG,IAAI,KAAc,KAAK,EAAd,IAAI,UAAK,KAAK,EAA5D,wCAAoD,CAAQ,CAAC;IACnE,MAAM,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC;IAC9B,MAAM,EAAE,OAAO,EAAE,GAAG,eAAe,EAAE,CAAC;IACtC,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,IAAI,CAAC,CAAA,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,IAAI,CAAA,EAAE;YACvB,OAAO;SACR;QACD,OAAO,CAAC;YACN,QAAQ,EAAE,YAAY,CAAC,IAAI;YAC3B,SAAS,EAAE,MAAM;YACjB,YAAY;SACb,CAAC,CAAC;IACL,CAAC,CAAC;IACF,MAAM,CAAC,EAAE,SAAS,CAAC,GAAG,cAAc,CAAC;QACnC,OAAO,EAAE,GAAG,EAAE;YACZ,cAAc,EAAE,CAAC;QACnB,CAAC;KACF,CAAC,CAAC;IACH,OAAO,CACL,oBAAC,IAAI,kBACH,EAAE,EAAE;YACF,QAAQ,EAAE,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,IAAI;YAC5B,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACxB,EACD,QAAQ,EAAE,SAAgB,EAC1B,YAAY,EAAE,cAAc,EAC5B,YAAY,EAAE,CAAC,KAAK,EAAE,EAAE;YACtB,cAAc,EAAE,CAAC;YACjB,IAAI,OAAO,YAAY,KAAK,UAAU,EAAE;gBACtC,YAAY,CAAC,KAAK,CAAC,CAAC;aACrB;QACH,CAAC,IACG,IAAI,EACR,CACH,CAAC;AACJ,CAAC,CAAC;AAEJ,eAAe,eAAe,CAAC"}
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ import { ContentItem } from '@jetshop/core/types';
3
+ export type Components = {
4
+ [key: string]: React.FC<any>;
5
+ };
6
+ export declare function ContentRenderer({ items, components }: {
7
+ items: ContentItem[];
8
+ components: Components;
9
+ }): JSX.Element;
@@ -0,0 +1,36 @@
1
+ import React from 'react';
2
+ const convertPropsToObject = (item) => {
3
+ const props = item.properties.reduce((merged, current) => {
4
+ var _a, _b;
5
+ if ((current === null || current === void 0 ? void 0 : current.valueType) === 'SCALAR') {
6
+ merged[current.name] = {
7
+ type: current.type,
8
+ value: (_a = current === null || current === void 0 ? void 0 : current.value) === null || _a === void 0 ? void 0 : _a.value,
9
+ __typename: (_b = current === null || current === void 0 ? void 0 : current.value) === null || _b === void 0 ? void 0 : _b.__typename
10
+ };
11
+ }
12
+ else {
13
+ merged[current.name] = {
14
+ type: current.type,
15
+ value: current.value
16
+ };
17
+ }
18
+ return merged;
19
+ }, {});
20
+ return props;
21
+ };
22
+ const renderContent = ({ items, components }) => items.map((item, index) => {
23
+ const Component = components[item.type.toUpperCase()] || components[item.type];
24
+ const props = convertPropsToObject(item);
25
+ if (Component) {
26
+ return (React.createElement(Component, Object.assign({ key: `${item.type}-${index}` }, props), (item === null || item === void 0 ? void 0 : item.children) && item.children.length > 0
27
+ ? renderContent({ items: item.children, components })
28
+ : null));
29
+ }
30
+ else
31
+ return null;
32
+ });
33
+ export function ContentRenderer({ items, components }) {
34
+ return React.createElement(React.Fragment, null, renderContent({ items, components }));
35
+ }
36
+ //# sourceMappingURL=ContentRenderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ContentRenderer.js","sourceRoot":"","sources":["ContentRenderer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAa1B,MAAM,oBAAoB,GAAG,CAAC,IAAiB,EAAE,EAAE;IACjD,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE;;QACvD,IAAI,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,MAAK,QAAQ,EAAE;YACnC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG;gBACrB,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,KAAK,EAAE,MAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAiC,0CAAE,KAAK;gBACzD,UAAU,EAAE,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,0CAAE,UAAU;aACvC,CAAC;SACH;aAAM;YACL,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG;gBACrB,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,KAAK,EAAE,OAAO,CAAC,KAA2B;aAC3C,CAAC;SACH;QACD,OAAO,MAAM,CAAC;IAChB,CAAC,EAAE,EAA4G,CAAC,CAAC;IAEjH,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AACF,MAAM,aAAa,GAAG,CAAC,EACrB,KAAK,EACL,UAAU,EAIX,EAAiB,EAAE,CAClB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;IACxB,MAAM,SAAS,GACb,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAE/D,MAAM,KAAK,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC;IAEzC,IAAI,SAAS,EAAE;QACb,OAAO,CACL,oBAAC,SAAS,kBAAC,GAAG,EAAE,GAAG,IAAI,CAAC,IAAI,IAAI,KAAK,EAAE,IAAM,KAAK,GAC/C,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,QAAQ,KAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;YACzC,CAAC,CAAC,aAAa,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,UAAU,EAAE,CAAC;YACrD,CAAC,CAAC,IAAI,CACE,CACb,CAAC;KACH;;QAAM,OAAO,IAAI,CAAC;AACrB,CAAC,CAAC,CAAC;AAEL,MAAM,UAAU,eAAe,CAAC,EAC9B,KAAK,EACL,UAAU,EAIX;IACC,OAAO,0CAAG,aAAa,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,CAAI,CAAC;AACrD,CAAC"}
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ import { FlightUIProps, As } from '../withFlightUI';
3
+ declare const Button: React.FC<{} & FlightUIProps & {
4
+ /** @default 'button' */
5
+ as?: As;
6
+ }>;
7
+ export { Button };
@@ -0,0 +1,33 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React, { useRef, useEffect } from 'react';
13
+ import { DropdownMenuContext } from './DropdownMenu';
14
+ import { withFlightUI } from '../withFlightUI';
15
+ const Button = (_a) => {
16
+ var { children } = _a, rest = __rest(_a, ["children"]);
17
+ const { isOpen, setIsOpen } = React.useContext(DropdownMenuContext);
18
+ const prevOpenState = useRef(isOpen);
19
+ const buttonRef = useRef();
20
+ useEffect(() => {
21
+ if (!isOpen && prevOpenState.current === true)
22
+ buttonRef.current.focus();
23
+ prevOpenState.current = isOpen;
24
+ }, [isOpen]);
25
+ const clickHandler = (event) => {
26
+ event.stopPropagation();
27
+ setIsOpen((o) => !o);
28
+ typeof rest.onClick === 'function' && rest.onClick();
29
+ };
30
+ return withFlightUI(children, Object.assign({ as: 'button', 'data-flight-dropdown-button': '', 'aria-expanded': isOpen, 'aria-haspopup': 'menu', type: 'button', role: 'button', ref: buttonRef, onClick: clickHandler }, rest));
31
+ };
32
+ export { Button };
33
+ //# sourceMappingURL=Button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Button.js","sourceRoot":"","sources":["Button.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAqB,MAAM,iBAAiB,CAAC;AAElE,MAAM,MAAM,GAKR,CAAC,EAAqB,EAAE,EAAE;QAAzB,EAAE,QAAQ,OAAW,EAAN,IAAI,cAAnB,YAAqB,CAAF;IACtB,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;IAEpE,MAAM,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;IAErC,MAAM,SAAS,GAAG,MAAM,EAAmC,CAAC;IAE5D,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,MAAM,IAAI,aAAa,CAAC,OAAO,KAAK,IAAI;YAAE,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACzE,aAAa,CAAC,OAAO,GAAG,MAAM,CAAC;IACjC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEb,MAAM,YAAY,GAAG,CAAC,KAAmC,EAAE,EAAE;QAC3D,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACrB,OAAO,IAAI,CAAC,OAAO,KAAK,UAAU,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC,CAAC;IAEF,OAAO,YAAY,CAAC,QAAQ,kBAC1B,EAAE,EAAE,QAAQ,EACZ,6BAA6B,EAAE,EAAE,EACjC,eAAe,EAAE,MAAM,EACvB,eAAe,EAAE,MAAM,EACvB,IAAI,EAAE,QAAQ,EACd,IAAI,EAAE,QAAQ,EACd,GAAG,EAAE,SAAS,EACd,OAAO,EAAE,YAAY,IAClB,IAAI,EACP,CAAC;AACL,CAAC,CAAC;AAEF,OAAO,EAAE,MAAM,EAAE,CAAC"}
@@ -0,0 +1,21 @@
1
+ import React from 'react';
2
+ import { FlightUIProps } from '../withFlightUI';
3
+ export declare const DropdownMenuContext: React.Context<{
4
+ isOpen: boolean;
5
+ setIsOpen: React.Dispatch<React.SetStateAction<boolean>>;
6
+ itemRefs: React.RefObject<any>;
7
+ }>;
8
+ interface DropdownMenuProps extends FlightUIProps {
9
+ /** The initial open state of the dropdown menu
10
+ * @default false
11
+ * */
12
+ initialOpen?: boolean;
13
+ /** Set to true if you'd like to disable all default styling */
14
+ unstyled?: boolean;
15
+ }
16
+ export declare const DropdownMenu: React.NamedExoticComponent<DropdownMenuProps>;
17
+ export declare function useDropdownMenu(): {
18
+ isOpen: boolean;
19
+ setIsOpen: React.Dispatch<React.SetStateAction<boolean>>;
20
+ };
21
+ export {};
@@ -0,0 +1,72 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { css, cx } from 'linaria';
13
+ import React, { useContext, useRef } from 'react';
14
+ import { withFlightUI } from '../withFlightUI';
15
+ export const DropdownMenuContext = React.createContext(undefined);
16
+ css `
17
+ global([data-flight-dropdown-open='false'] [data-flight-dropdown-items]) {
18
+ display: none;
19
+ }
20
+ `;
21
+ const styles = css `
22
+ position: relative;
23
+
24
+ [data-flight-dropdown-button] {
25
+ padding: 0.5em 1em;
26
+ border: 1px solid #c0c0c0;
27
+ border-radius: 3px;
28
+ }
29
+ [data-flight-dropdown-items] {
30
+ position: absolute;
31
+ top: 100%;
32
+ left: 0;
33
+ background: white;
34
+ white-space: nowrap;
35
+ display: block;
36
+ z-index: 2;
37
+ outline: none;
38
+ }
39
+ [data-flight-dropdown-item] {
40
+ cursor: pointer;
41
+ border-top: 1px solid #c0c0c0;
42
+ white-space: nowrap;
43
+ padding: 0.5em 1em;
44
+ :hover {
45
+ color: blue;
46
+ }
47
+ }
48
+ `;
49
+ export const DropdownMenu = React.memo(function DropdownMenu(_a) {
50
+ var { initialOpen = false, unstyled, children, className } = _a, rest = __rest(_a, ["initialOpen", "unstyled", "children", "className"]);
51
+ const [isOpen, setIsOpen] = React.useState(initialOpen);
52
+ const [selectedIndex, setSelectedIndex] = React.useState(0);
53
+ const itemRefs = useRef([]);
54
+ const value = React.useMemo(() => {
55
+ return {
56
+ isOpen,
57
+ setIsOpen,
58
+ selectedIndex,
59
+ setSelectedIndex,
60
+ itemRefs
61
+ };
62
+ }, [isOpen, selectedIndex]);
63
+ return withFlightUI(React.createElement(DropdownMenuContext.Provider, { value: value }, typeof children === 'function'
64
+ ? children({ isOpen, setIsOpen })
65
+ : children), Object.assign({ as: 'div', 'data-flight-dropdown': '', 'data-flight-dropdown-open': isOpen, unstyled, className: cx(styles, className) }, rest));
66
+ });
67
+ DropdownMenu.displayName = 'withFlightUI(DropdownMenu)';
68
+ export function useDropdownMenu() {
69
+ const { isOpen, setIsOpen } = useContext(DropdownMenuContext);
70
+ return { isOpen, setIsOpen };
71
+ }
72
+ //# sourceMappingURL=DropdownMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DropdownMenu.js","sourceRoot":"","sources":["DropdownMenu.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAClD,OAAO,EAAiB,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE9D,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,CAAC,aAAa,CAInD,SAAS,CAAC,CAAC;AAEd,GAAG,CAAA;;;;CAIF,CAAC;AAEF,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2BjB,CAAC;AAWF,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,YAAY,CAAC,EAMzC;QANyC,EAC3D,WAAW,GAAG,KAAK,EACnB,QAAQ,EACR,QAAQ,EACR,SAAS,OAES,EADf,IAAI,cALoD,oDAM5D,CADQ;IAEP,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IACxD,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAE5D,MAAM,QAAQ,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;IAE5B,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QAC/B,OAAO;YACL,MAAM;YACN,SAAS;YACT,aAAa;YACb,gBAAgB;YAChB,QAAQ;SACT,CAAC;IACJ,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC;IAE5B,OAAO,YAAY,CACjB,oBAAC,mBAAmB,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,IACvC,OAAO,QAAQ,KAAK,UAAU;QAC7B,CAAC,CAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;QACjC,CAAC,CAAC,QAAQ,CACiB,kBAE7B,EAAE,EAAE,KAAK,EACT,sBAAsB,EAAE,EAAE,EAC1B,2BAA2B,EAAE,MAAM,EACnC,QAAQ,EACR,SAAS,EAAE,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,IAE7B,IAAI,EAEV,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,YAAY,CAAC,WAAW,GAAG,4BAA4B,CAAC;AAExD,MAAM,UAAU,eAAe;IAC7B,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,UAAU,CAAC,mBAAmB,CAAC,CAAC;IAE9D,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;AAC/B,CAAC"}
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ import { As, FlightUIProps } from '../withFlightUI';
3
+ export declare const Item: React.FC<{} & FlightUIProps & {
4
+ /** @default 'li' */
5
+ as?: As;
6
+ closeOnSelect?: boolean;
7
+ /** Function to call when selecting this item */
8
+ onSelect?: ({ isOpen, setIsOpen }: {
9
+ isOpen: boolean;
10
+ setIsOpen: React.Dispatch<React.SetStateAction<boolean>>;
11
+ }) => void;
12
+ disabled?: boolean;
13
+ }>;
@@ -0,0 +1,48 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React from 'react';
13
+ import { withFlightUI } from '../withFlightUI';
14
+ import { DropdownMenuContext, useDropdownMenu } from './DropdownMenu';
15
+ export const Item = function Item(_a) {
16
+ var { onSelect, closeOnSelect, children, disabled, index } = _a, rest = __rest(_a, ["onSelect", "closeOnSelect", "children", "disabled", "index"]);
17
+ const { itemRefs } = React.useContext(DropdownMenuContext);
18
+ const { isOpen, setIsOpen } = useDropdownMenu();
19
+ const itemRef = React.createRef();
20
+ itemRefs.current[index] = itemRef;
21
+ const select = () => {
22
+ closeOnSelect && setIsOpen(false);
23
+ typeof onSelect === 'function' &&
24
+ !disabled &&
25
+ onSelect({ isOpen, setIsOpen });
26
+ };
27
+ const handleKeydown = (e) => {
28
+ if (e.key === 'Enter' || e.key === 'Space' || e.key === ' ') {
29
+ e.preventDefault();
30
+ select();
31
+ }
32
+ if (e.key === 'ArrowDown') {
33
+ e.preventDefault();
34
+ if (itemRefs.current.length - 1 === index)
35
+ return;
36
+ itemRefs.current[index + 1].current.focus();
37
+ }
38
+ if (e.key === 'ArrowUp') {
39
+ e.preventDefault();
40
+ if (index === 0)
41
+ return;
42
+ itemRefs.current[index - 1].current.focus();
43
+ }
44
+ };
45
+ const focusItem = () => itemRef.current && itemRef.current.focus();
46
+ return withFlightUI(children, Object.assign({ as: 'li', ref: itemRef, tabIndex: -1, onClick: select, onKeyDown: handleKeydown, onMouseEnter: focusItem, role: 'menuitem', 'data-flight-dropdown-item': '' }, rest));
47
+ };
48
+ //# sourceMappingURL=Item.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Item.js","sourceRoot":"","sources":["Item.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAqB,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEtE,MAAM,CAAC,MAAM,IAAI,GAaV,SAAS,IAAI,CAAC,EAOpB;QAPoB,EACnB,QAAQ,EACR,aAAa,EACb,QAAQ,EACR,QAAQ,EACR,KAAK,OAEN,EADI,IAAI,cANY,8DAOpB,CADQ;IAEP,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;IAC3D,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,eAAe,EAAE,CAAC;IAEhD,MAAM,OAAO,GAAG,KAAK,CAAC,SAAS,EAAe,CAAC;IAC/C,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC;IAElC,MAAM,MAAM,GAAG,GAAG,EAAE;QAClB,aAAa,IAAI,SAAS,CAAC,KAAK,CAAC,CAAC;QAClC,OAAO,QAAQ,KAAK,UAAU;YAC5B,CAAC,QAAQ;YACT,QAAQ,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC;IACpC,CAAC,CAAC;IAEF,MAAM,aAAa,GAAG,CAAC,CAAiC,EAAE,EAAE;QAC1D,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,IAAI,CAAC,CAAC,GAAG,KAAK,GAAG,EAAE;YAC3D,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,MAAM,EAAE,CAAC;SACV;QACD,IAAI,CAAC,CAAC,GAAG,KAAK,WAAW,EAAE;YACzB,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,IAAI,QAAQ,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,KAAK,KAAK;gBAAE,OAAO;YAClD,QAAQ,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;SAC7C;QACD,IAAI,CAAC,CAAC,GAAG,KAAK,SAAS,EAAE;YACvB,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,IAAI,KAAK,KAAK,CAAC;gBAAE,OAAO;YACxB,QAAQ,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;SAC7C;IACH,CAAC,CAAC;IAEF,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IAEnE,OAAO,YAAY,CAAC,QAAQ,kBAC1B,EAAE,EAAE,IAAI,EACR,GAAG,EAAE,OAAO,EACZ,QAAQ,EAAE,CAAC,CAAC,EACZ,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,aAAa,EACxB,YAAY,EAAE,SAAS,EACvB,IAAI,EAAE,UAAU,EAChB,2BAA2B,EAAE,EAAE,IAC5B,IAAI,EACP,CAAC;AACL,CAAC,CAAC"}
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import { As, FlightUIProps } from '../withFlightUI';
3
+ export declare const Items: React.FC<{
4
+ /** By default, the items are not rendered when the dropdownMenu's `isOpen` state is `false`.
5
+ * Set this to true if you would prefer the list to be hidden with `display: none`
6
+ * @default false
7
+ */
8
+ onlyHide?: boolean;
9
+ /** Whether the menu should close when clicking outside it.
10
+ * @default true
11
+ */
12
+ closeOnClickOutside?: boolean;
13
+ } & FlightUIProps & {
14
+ /** @default 'ul' */
15
+ as?: As;
16
+ }>;
@@ -0,0 +1,53 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React, { Children, useEffect, useRef } from 'react';
13
+ import { useOnClickOutside, useOnEsc } from '../hooks';
14
+ import { withFlightUI } from '../withFlightUI';
15
+ import { DropdownMenuContext } from './DropdownMenu';
16
+ export const Items = (_a) => {
17
+ var { onlyHide, closeOnClickOutside = true, children } = _a, rest = __rest(_a, ["onlyHide", "closeOnClickOutside", "children"]);
18
+ const { setIsOpen, itemRefs, isOpen } = React.useContext(DropdownMenuContext);
19
+ const ref = useRef();
20
+ const close = () => isOpen && setIsOpen(false);
21
+ useEffect(() => {
22
+ if (!isOpen)
23
+ return;
24
+ if (itemRefs.current.length > 0) {
25
+ itemRefs.current[0].current.focus();
26
+ return;
27
+ }
28
+ ref.current.focus();
29
+ }, [isOpen, itemRefs]);
30
+ useOnClickOutside({
31
+ condition: closeOnClickOutside,
32
+ action: close,
33
+ ref
34
+ });
35
+ useOnEsc({
36
+ condition: isOpen,
37
+ action: close
38
+ });
39
+ // TODO: full keyboard interactions specified @ https://www.w3.org/TR/wai-aria-practices-1.1/#menu
40
+ const childrenWithIndex = Children.map(children, (child, index) => {
41
+ return React.cloneElement(child, {
42
+ index
43
+ });
44
+ });
45
+ const El = withFlightUI(childrenWithIndex, Object.assign({ as: 'ul', role: 'menu', ref, tabIndex: -1, 'data-flight-dropdown-items': '' }, rest));
46
+ // Return the element and rely on the CSS to hide
47
+ if (onlyHide) {
48
+ return El;
49
+ }
50
+ // Otherwise don't render anything when menu is closed
51
+ return React.createElement(React.Fragment, null, isOpen ? El : null);
52
+ };
53
+ //# sourceMappingURL=Items.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Items.js","sourceRoot":"","sources":["Items.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACvD,OAAO,EAAqB,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAErD,MAAM,CAAC,MAAM,KAAK,GAaX,CAAC,EAA2D,EAAE,EAAE;QAA/D,EAAE,QAAQ,EAAE,mBAAmB,GAAG,IAAI,EAAE,QAAQ,OAAW,EAAN,IAAI,cAAzD,+CAA2D,CAAF;IAC/D,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;IAE9E,MAAM,GAAG,GAAG,MAAM,EAAe,CAAC;IAElC,MAAM,KAAK,GAAG,GAAG,EAAE,CAAC,MAAM,IAAI,SAAS,CAAC,KAAK,CAAC,CAAC;IAE/C,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,QAAQ,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/B,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YACpC,OAAO;SACR;QAED,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IACtB,CAAC,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;IAEvB,iBAAiB,CAAC;QAChB,SAAS,EAAE,mBAAmB;QAC9B,MAAM,EAAE,KAAK;QACb,GAAG;KACJ,CAAC,CAAC;IAEH,QAAQ,CAAC;QACP,SAAS,EAAE,MAAM;QACjB,MAAM,EAAE,KAAK;KACd,CAAC,CAAC;IAEH,kGAAkG;IAElG,MAAM,iBAAiB,GAAG,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;QAChE,OAAO,KAAK,CAAC,YAAY,CAAC,KAA2B,EAAE;YACrD,KAAK;SACN,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,MAAM,EAAE,GAAG,YAAY,CAAC,iBAAiB,kBACvC,EAAE,EAAE,IAAI,EACR,IAAI,EAAE,MAAM,EACZ,GAAG,EACH,QAAQ,EAAE,CAAC,CAAC,EACZ,4BAA4B,EAAE,EAAE,IAC7B,IAAI,EACP,CAAC;IAEH,iDAAiD;IACjD,IAAI,QAAQ,EAAE;QACZ,OAAO,EAAE,CAAC;KACX;IAED,sDAAsD;IACtD,OAAO,0CAAG,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAI,CAAC;AACnC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { Button as DropdownMenuButton } from './Button';
2
+ export { DropdownMenu, useDropdownMenu } from './DropdownMenu';
3
+ export { Items as DropdownMenuItems } from './Items';
4
+ export { Item as DropdownMenuItem } from './Item';
@@ -0,0 +1,5 @@
1
+ export { Button as DropdownMenuButton } from './Button';
2
+ export { DropdownMenu, useDropdownMenu } from './DropdownMenu';
3
+ export { Items as DropdownMenuItems } from './Items';
4
+ export { Item as DropdownMenuItem } from './Item';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,kBAAkB,EAAE,MAAM,UAAU,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAE,KAAK,IAAI,iBAAiB,EAAE,MAAM,SAAS,CAAC;AACrD,OAAO,EAAE,IAAI,IAAI,gBAAgB,EAAE,MAAM,QAAQ,CAAC"}
@@ -0,0 +1,18 @@
1
+ import * as React from 'react';
2
+ export interface BoundaryErrorState {
3
+ error?: Error;
4
+ info?: React.ErrorInfo;
5
+ }
6
+ export interface BoundaryErrorProps {
7
+ component?: React.FC<BoundaryErrorState>;
8
+ extraInfo?: any;
9
+ children?: React.ReactNode;
10
+ }
11
+ export declare const DefaultError: React.FC<BoundaryErrorState>;
12
+ declare class ErrorBoundary extends React.Component<BoundaryErrorProps, BoundaryErrorState> {
13
+ state: BoundaryErrorState;
14
+ static defaultProps: Partial<BoundaryErrorProps>;
15
+ componentDidCatch(error: Error, info: React.ErrorInfo): void;
16
+ render(): string | number | boolean | Iterable<React.ReactNode> | React.JSX.Element;
17
+ }
18
+ export default ErrorBoundary;
@@ -0,0 +1,69 @@
1
+ import * as React from 'react';
2
+ import report from '@jetshop/core/errorReporting';
3
+ import { styled } from 'linaria/react';
4
+ const Wrapper = styled('section') `
5
+ width: 57ch;
6
+ max-width: 100%;
7
+ margin: 4rem auto;
8
+ padding: 1rem;
9
+ a {
10
+ display: inline-block;
11
+ margin: 1rem 0 3rem 0;
12
+ border-radius: 3px;
13
+ padding: 0.5rem;
14
+ text-decoration: none;
15
+ font-weight: 600;
16
+ background: #e2e2e2;
17
+ border: 1px solid #c3c3c3;
18
+ color: #000;
19
+ :hover {
20
+ background: #eaeaea;
21
+ }
22
+ }
23
+ h1 {
24
+ font-size: 1.5rem;
25
+ margin-bottom: 2rem;
26
+ }
27
+ pre {
28
+ font-size: 0.875rem;
29
+ line-height: 1.5;
30
+ color: #585858;
31
+ }
32
+ `;
33
+ export const DefaultError = ({ error, info }) => (React.createElement(Wrapper, null,
34
+ React.createElement("h1", null, "Something went wrong!"),
35
+ React.createElement("p", null, "Sorry! Our developers have been notified."),
36
+ React.createElement("div", null,
37
+ React.createElement("a", { href: "/" }, "Go back to the start page")),
38
+ process.env.NODE_ENV !== 'production' && (React.createElement("div", null,
39
+ error && React.createElement("p", null,
40
+ "Error: ",
41
+ error.message),
42
+ info && React.createElement("pre", null, info.componentStack)))));
43
+ class ErrorBoundary extends React.Component {
44
+ constructor() {
45
+ super(...arguments);
46
+ this.state = {
47
+ error: undefined,
48
+ info: undefined
49
+ };
50
+ }
51
+ componentDidCatch(error, info) {
52
+ const { extraInfo = {} } = this.props;
53
+ // Report to Sentry
54
+ report(error, Object.assign(Object.assign({}, extraInfo), { reactInfo: info }));
55
+ this.setState({ error, info });
56
+ }
57
+ render() {
58
+ const Comp = this.props.component;
59
+ if (!this.state.error) {
60
+ return this.props.children;
61
+ }
62
+ return React.createElement(Comp, Object.assign({}, this.state));
63
+ }
64
+ }
65
+ ErrorBoundary.defaultProps = {
66
+ component: DefaultError
67
+ };
68
+ export default ErrorBoundary;
69
+ //# sourceMappingURL=Generic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Generic.js","sourceRoot":"","sources":["Generic.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,MAAM,MAAM,8BAA8B,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAYvC,MAAM,OAAO,GAAG,MAAM,CAAC,SAAS,CAAC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4BhC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAiC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAC7E,oBAAC,OAAO;IACN,wDAA8B;IAC9B,2EAAgD;IAChD;QACE,2BAAG,IAAI,EAAC,GAAG,gCAA8B,CACrC;IACL,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,IAAI,CACxC;QACG,KAAK,IAAI;;YAAW,KAAK,CAAC,OAAO,CAAK;QACtC,IAAI,IAAI,iCAAM,IAAI,CAAC,cAAc,CAAO,CACrC,CACP,CACO,CACX,CAAC;AAEF,MAAM,aAAc,SAAQ,KAAK,CAAC,SAGjC;IAHD;;QAIE,UAAK,GAAuB;YAC1B,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,SAAS;SAChB,CAAC;IAsBJ,CAAC;IAhBC,iBAAiB,CAAC,KAAY,EAAE,IAAqB;QACnD,MAAM,EAAE,SAAS,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QACtC,mBAAmB;QACnB,MAAM,CAAC,KAAK,kCAAO,SAAS,KAAE,SAAS,EAAE,IAAI,IAAG,CAAC;QACjD,IAAI,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACjC,CAAC;IAED,MAAM;QACJ,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,SAAyC,CAAC;QAElE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE;YACrB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;SAC5B;QAED,OAAO,oBAAC,IAAI,oBAAK,IAAI,CAAC,KAAK,EAAI,CAAC;IAClC,CAAC;;AAnBM,0BAAY,GAAgC;IACjD,SAAS,EAAE,YAAY;CACxB,CAAC;AAoBJ,eAAe,aAAa,CAAC"}
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ declare const PassThrough: React.FC;
3
+ export default PassThrough;
@@ -0,0 +1,7 @@
1
+ // This should be used in cases where it is more desired to render nothing
2
+ // rather than rendering a message when an error boundary is hit.
3
+ const PassThrough = () => {
4
+ return null;
5
+ };
6
+ export default PassThrough;
7
+ //# sourceMappingURL=PassThrough.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PassThrough.js","sourceRoot":"","sources":["PassThrough.tsx"],"names":[],"mappings":"AAEA,0EAA0E;AAC1E,iEAAiE;AACjE,MAAM,WAAW,GAAa,GAAG,EAAE;IACjC,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -0,0 +1,39 @@
1
+ import { ProductImage } from '@jetshop/core/types';
2
+ import * as React from 'react';
3
+ import 'react-image-gallery/styles/css/image-gallery.css';
4
+ export interface GalleryProps {
5
+ images: ProductImage[];
6
+ /** @default null
7
+ * The aspect ratio used for the gallery images. If unknown, pass `null` */
8
+ aspect?: string;
9
+ /**
10
+ * @default [1, 1, 1, 1 / 2, 1 / 2]
11
+ * An array of sizes to be used for the img
12
+ * srcSet. Each size maps to a breakpoint */
13
+ sizes?: number[];
14
+ /**
15
+ * @default ['5rem']
16
+ */
17
+ thumbnailSizes?: number[];
18
+ /**
19
+ * @default [1, 1, 1, 1 ]
20
+ */
21
+ fullScreenSizes?: number[];
22
+ /** @default bottom
23
+ * The position of image thumbnails */
24
+ thumbnailPosition?: 'top' | 'right' | 'bottom' | 'left';
25
+ /** The desired background colour for the gallery */
26
+ backgroundColor?: string;
27
+ /** A ref to forward on to the image gallery in order to access imperative functions */
28
+ galleryRef?: {
29
+ current: any;
30
+ };
31
+ quality?: number;
32
+ thumbnailQuality?: number;
33
+ eagerlyLoad?: number[];
34
+ }
35
+ export interface GalleryState {
36
+ isFullscreen: boolean;
37
+ }
38
+ declare const Gallery: React.FC<GalleryProps>;
39
+ export default Gallery;
@@ -0,0 +1,121 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import * as React from 'react';
13
+ import { styled } from 'linaria/react';
14
+ import { css } from 'linaria';
15
+ import ImageGallery from 'react-image-gallery';
16
+ import 'react-image-gallery/styles/css/image-gallery.css';
17
+ import { constructGallery } from './constructGallery';
18
+ import Image from '@jetshop/ui/Image/Image';
19
+ import ChannelContext from '@jetshop/core/components/ChannelContext';
20
+ import { useShopConfig } from '@jetshop/core/hooks/useShopConfig';
21
+ const wrapperStyles = css `
22
+ position: relative;
23
+ img {
24
+ max-height: 100vh;
25
+ }
26
+ .image-gallery {
27
+ z-index: 3;
28
+ }
29
+ .image-gallery-image {
30
+ text-align: center;
31
+ }
32
+ .image-gallery-thumbnail-inner {
33
+ font-size: 10px;
34
+ }
35
+ .image-gallery-right-nav,
36
+ .image-gallery-left-nav,
37
+ .image-gallery-fullscreen-button {
38
+ z-index: 2;
39
+ font-size: 2rem;
40
+ display: flex;
41
+ justify-content: center;
42
+ align-items: center;
43
+ padding: 0;
44
+ height: 2.5rem;
45
+ width: 2.5rem;
46
+ border-radius: 50%;
47
+ margin: 0 0.5rem;
48
+ filter: none;
49
+ .image-gallery-svg {
50
+ color: #333333;
51
+ height: 30px;
52
+ polyline {
53
+ color: #333333;
54
+ }
55
+ }
56
+ }
57
+ .image-gallery-fullscreen-button {
58
+ margin-bottom: 0.5rem;
59
+ }
60
+ .image-gallery-fullscreen-button:before {
61
+ text-shadow: none;
62
+ font-size: 0.7em;
63
+ padding: 0;
64
+ }
65
+ .image-gallery-thumbnail.active {
66
+ border-width: 1px;
67
+ }
68
+ .image-gallery-thumbnails-wrapper.left .image-gallery-thumbnails,
69
+ .image-gallery-thumbnails-wrapper.right .image-gallery-thumbnails {
70
+ display: flex;
71
+ flex-direction: column;
72
+ justify-content: center;
73
+ }
74
+ .fullscreen {
75
+ .image-gallery-fullscreen-button {
76
+ margin: 2rem;
77
+ }
78
+ .image-gallery-right-nav,
79
+ .image-gallery-left-nav {
80
+ margin: 0 2rem;
81
+ }
82
+ img {
83
+ width: auto;
84
+ max-width: 100%;
85
+ }
86
+ .image-gallery-thumbnails-wrapper {
87
+ display: none;
88
+ }
89
+ }
90
+ .image-gallery-slide {
91
+ background-color: var(--slide-bg);
92
+ }
93
+ `;
94
+ const Overlay = styled('div') `
95
+ position: absolute;
96
+ left: 0;
97
+ top: 0;
98
+ right: 0;
99
+ bottom: 0;
100
+ pointer-events: none;
101
+ `;
102
+ const Gallery = function Gallery(props) {
103
+ const { sizes = [1, 1, 1, 1 / 2, 1 / 2], fullScreenSizes = [1, 1, 1, 1], thumbnailSizes = ['5rem'], aspect = '1:1', thumbnailPosition = 'bottom', backgroundColor = 'white', thumbnailQuality, quality, images, galleryRef, eagerlyLoad = [0] } = props, rest = __rest(props, ["sizes", "fullScreenSizes", "thumbnailSizes", "aspect", "thumbnailPosition", "backgroundColor", "thumbnailQuality", "quality", "images", "galleryRef", "eagerlyLoad"]);
104
+ const { theme: { breakpoints } } = useShopConfig();
105
+ const { selectedChannel } = React.useContext(ChannelContext);
106
+ const baseUrl = (selectedChannel === null || selectedChannel === void 0 ? void 0 : selectedChannel.url) ? String(selectedChannel.url) : null;
107
+ const [isFullscreen, setFullscreen] = React.useState(false);
108
+ const galleryImages = React.useMemo(() => constructGallery(images, fullScreenSizes, aspect, baseUrl, breakpoints), [aspect, baseUrl, breakpoints, fullScreenSizes, images]);
109
+ return (React.createElement("div", { className: wrapperStyles, style: { ['--slide-bg']: backgroundColor } },
110
+ React.createElement(ImageGallery, Object.assign({ ref: (r) => (galleryRef ? (galleryRef.current = r) : null), thumbnailPosition: thumbnailPosition, items: galleryImages, autoPlay: false, showPlayButton: false, showThumbnails: galleryImages.length > 1, useBrowserFullscreen: false, preventDefaultTouchmoveEvent: isFullscreen, onScreenChange: (el) => setFullscreen(!!el), renderItem: (item) => {
111
+ return (React.createElement("div", { className: "image-gallery-image" }, isFullscreen ? (React.createElement("img", { src: item.original, alt: item.originalAlt, srcSet: item.srcSet, sizes: item.sizes, title: item.originalTitle })) : (React.createElement(React.Fragment, null,
112
+ React.createElement(Image, { src: item.original, alt: item.originalAlt, sizes: sizes, title: item.originalTitle, aspect: aspect, quality: quality, modifiedDate: item.modifiedDate, critical: eagerlyLoad.includes(item.index) }),
113
+ props.children && React.createElement(Overlay, null, props.children)))));
114
+ }, renderThumbInner: (item) => {
115
+ return (React.createElement("div", { className: "image-gallery-thumbnail-inner" },
116
+ React.createElement(Image, { src: item.thumbnail, alt: item.thumbnailAlt, title: item.thumbnailTitle, sizes: thumbnailSizes, aspect: aspect, quality: thumbnailQuality, modifiedDate: item.modifiedDate }),
117
+ item.thumbnailLabel && (React.createElement("div", { className: "image-gallery-thumbnail-label" }, item.thumbnailLabel))));
118
+ } }, rest))));
119
+ };
120
+ export default Gallery;
121
+ //# sourceMappingURL=Gallery.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Gallery.js","sourceRoot":"","sources":["Gallery.tsx"],"names":[],"mappings":"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"}