@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,65 @@
1
+ import * as React from 'react';
2
+ import { styled } from 'linaria/react';
3
+ const Wrapper = styled('section') `
4
+ width: 57ch;
5
+ max-width: 100%;
6
+ margin: 4rem auto;
7
+ padding: 1rem;
8
+ a {
9
+ display: inline-block;
10
+ margin: 1rem 0 3rem 0;
11
+ border-radius: 3px;
12
+ padding: 0.5rem;
13
+ text-decoration: none;
14
+ font-weight: 600;
15
+ background: #e2e2e2;
16
+ border: 1px solid #c3c3c3;
17
+ color: #000;
18
+ :hover {
19
+ background: #eaeaea;
20
+ }
21
+ }
22
+ h1 {
23
+ font-size: 1.5rem;
24
+ margin-bottom: 2rem;
25
+ }
26
+ pre {
27
+ font-size: 0.875rem;
28
+ line-height: 1.5;
29
+ color: #585858;
30
+ }
31
+ `;
32
+ export const DefaultError = ({ error, info }) => (React.createElement(Wrapper, null,
33
+ React.createElement("h1", null, "Something went wrong!"),
34
+ React.createElement("p", null, "Sorry! Our developers have been notified."),
35
+ React.createElement("div", null,
36
+ React.createElement("a", { href: "/" }, "Go back to the start page")),
37
+ process.env.NODE_ENV !== 'production' && (React.createElement("div", null,
38
+ error && React.createElement("p", null,
39
+ "Error: ",
40
+ error.message),
41
+ info && React.createElement("pre", null, info.componentStack)))));
42
+ class ErrorBoundary extends React.Component {
43
+ constructor() {
44
+ super(...arguments);
45
+ this.state = {
46
+ error: undefined,
47
+ info: undefined
48
+ };
49
+ }
50
+ componentDidCatch(error, info) {
51
+ this.setState({ error, info });
52
+ }
53
+ render() {
54
+ const Comp = this.props.component;
55
+ if (!this.state.error) {
56
+ return this.props.children;
57
+ }
58
+ return React.createElement(Comp, Object.assign({}, this.state));
59
+ }
60
+ }
61
+ ErrorBoundary.defaultProps = {
62
+ component: DefaultError
63
+ };
64
+ export default ErrorBoundary;
65
+ //# 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,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;IAmBJ,CAAC;IAbC,iBAAiB,CAAC,KAAY,EAAE,IAAqB;QACnD,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;;AAhBM,0BAAY,GAAgC;IACjD,SAAS,EAAE,YAAY;CACxB,CAAC;AAiBJ,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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"}
@@ -0,0 +1,15 @@
1
+ import { ProductImage } from '@jetshop/core/types';
2
+ export declare function constructGallery(images: ProductImage[], sizes: number[], aspect: string, baseUrl: string, breakpoints: {
3
+ [label: string]: string;
4
+ }): {
5
+ index: number;
6
+ original: string;
7
+ originalAlt: string;
8
+ originalTitle: string;
9
+ thumbnail: string;
10
+ thumbnailAlt: string;
11
+ thumbnailTitle: string;
12
+ sizes: string;
13
+ srcSet: string;
14
+ modifiedDate: string;
15
+ }[];
@@ -0,0 +1,40 @@
1
+ import { getFullUrl } from '../Image/utils/getFullUrl';
2
+ import { getImageWidths } from '../Image/utils/getImageWidths';
3
+ import { getLargestSize } from '../Image/utils/getLargestSize';
4
+ import { getSizesMap } from '../Image/utils/getSizesMap';
5
+ import { getSmallestSize } from '../Image/utils/getSmallestSize';
6
+ import { getSrcSetFromWidths } from '../Image/utils/getSrcSetFromWidths';
7
+ export function constructGallery(images, sizes, aspect, baseUrl, breakpoints) {
8
+ const calculatedSizes = getSizesMap(breakpoints, sizes);
9
+ // Get required set of image widths
10
+ const widths = getImageWidths(breakpoints, sizes);
11
+ return images.map((img, index) => {
12
+ const url = img.url || img.sizes;
13
+ let imageSrc;
14
+ let thumbSrc;
15
+ if (Array.isArray(url)) {
16
+ // maintain support for deprecated image sizes object
17
+ imageSrc = getFullUrl(getLargestSize(url), baseUrl);
18
+ thumbSrc = getFullUrl(getSmallestSize(url), baseUrl);
19
+ }
20
+ else {
21
+ imageSrc = getFullUrl(url, baseUrl);
22
+ thumbSrc = imageSrc;
23
+ }
24
+ // Generate image urls for the required image sizes
25
+ const srcSet = getSrcSetFromWidths(imageSrc, widths, aspect, { crop: false, webp: false }, img.modifiedDate);
26
+ return {
27
+ index,
28
+ original: imageSrc,
29
+ originalAlt: img.alt,
30
+ originalTitle: img.title,
31
+ thumbnail: thumbSrc,
32
+ thumbnailAlt: img.alt,
33
+ thumbnailTitle: img.title,
34
+ sizes: calculatedSizes,
35
+ srcSet,
36
+ modifiedDate: img.modifiedDate
37
+ };
38
+ });
39
+ }
40
+ //# sourceMappingURL=constructGallery.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constructGallery.js","sourceRoot":"","sources":["constructGallery.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AAEzE,MAAM,UAAU,gBAAgB,CAC9B,MAAsB,EACtB,KAAe,EACf,MAAc,EACd,OAAe,EACf,WAAwC;IAExC,MAAM,eAAe,GAAG,WAAW,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IACxD,mCAAmC;IACnC,MAAM,MAAM,GAAG,cAAc,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;IAClD,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;QAC/B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC;QAEjC,IAAI,QAAgB,CAAC;QACrB,IAAI,QAAgB,CAAC;QAErB,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACtB,qDAAqD;YACrD,QAAQ,GAAG,UAAU,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC;YACpD,QAAQ,GAAG,UAAU,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC;SACtD;aAAM;YACL,QAAQ,GAAG,UAAU,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YACpC,QAAQ,GAAG,QAAQ,CAAC;SACrB;QAED,mDAAmD;QACnD,MAAM,MAAM,GAAG,mBAAmB,CAChC,QAAQ,EACR,MAAM,EACN,MAAM,EACN,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,EAC5B,GAAG,CAAC,YAAY,CACjB,CAAC;QACF,OAAO;YACL,KAAK;YACL,QAAQ,EAAE,QAAQ;YAClB,WAAW,EAAE,GAAG,CAAC,GAAG;YACpB,aAAa,EAAE,GAAG,CAAC,KAAK;YACxB,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,GAAG,CAAC,GAAG;YACrB,cAAc,EAAE,GAAG,CAAC,KAAK;YACzB,KAAK,EAAE,eAAe;YACtB,MAAM;YACN,YAAY,EAAE,GAAG,CAAC,YAAY;SAC/B,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,39 @@
1
+ import * as React from 'react';
2
+ import { ProductImageSize } from '@jetshop/core/types';
3
+ export type ImageSrcType = string | ProductImageSize[];
4
+ export type BreakpointValues = string[];
5
+ export type ImageBreakpointSize = number | string;
6
+ export type ImageBreakpointSizes = ImageBreakpointSize | ImageBreakpointSize[];
7
+ export type AspectRatio = string | number;
8
+ export declare const transparentDataImg = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=";
9
+ export interface ImageParameters {
10
+ src: string | boolean;
11
+ sizes: string;
12
+ hasFalsySrc: boolean;
13
+ srcset: string;
14
+ webpSrcset: string;
15
+ lqip: string;
16
+ /**
17
+ * The aspect ratio of the image
18
+ * If unknown, use null to preserve original aspect ratio
19
+ */
20
+ aspect?: string;
21
+ critical?: boolean;
22
+ }
23
+ export interface ImageProps extends ImageParameters {
24
+ /** Whether or not to use `background-size: cover` */
25
+ cover?: boolean;
26
+ error?: (args: any) => React.ReactElement<any>;
27
+ alt?: string;
28
+ title?: string;
29
+ /**
30
+ * Useful for banner images. Sets the following CSS automatically:
31
+ * object-fit: cover
32
+ * padding-top: 0;
33
+ */
34
+ fillAvailableSpace?: boolean;
35
+ className?: string;
36
+ badges?: React.ReactElement<any>;
37
+ }
38
+ declare const Image: React.FC<ImageProps>;
39
+ export default Image;
@@ -0,0 +1,192 @@
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 { useInView } from 'react-intersection-observer';
14
+ import { paddingForAspectRatio } from './utils/paddingForAspectRatio';
15
+ export const transparentDataImg = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=';
16
+ const defaultImageState = {
17
+ imgLoaded: false,
18
+ error: false
19
+ };
20
+ const loadedImageState = {
21
+ imgLoaded: true,
22
+ error: false
23
+ };
24
+ let hydrated = false;
25
+ const imageCache = Object.create({});
26
+ function isInCache(src) {
27
+ return src in imageCache;
28
+ }
29
+ function cacheImage(src) {
30
+ imageCache[src] = true;
31
+ }
32
+ function imageStateReducer(_, action) {
33
+ switch (action.type) {
34
+ case 'reset':
35
+ return defaultImageState;
36
+ case 'loaded':
37
+ cacheImage(action.cacheKey);
38
+ return loadedImageState;
39
+ case 'error':
40
+ return { imgLoaded: false, error: true };
41
+ default:
42
+ console.error(`Action ${action.type} is invalid for image reducer`);
43
+ return;
44
+ }
45
+ }
46
+ function useObjectFitPolyfill(imageRefs) {
47
+ const [polyfilled, setPolyfilled] = React.useState(false);
48
+ React.useEffect(() => {
49
+ const testImg = document.createElement(`img`);
50
+ if (typeof testImg.style.objectFit === `undefined` ||
51
+ typeof testImg.style.objectPosition === `undefined`) {
52
+ import(`object-fit-images`).then(({ default: ObjectFitImages }) => {
53
+ imageRefs.forEach((imageRef) => {
54
+ imageRef.current && ObjectFitImages(imageRef.current);
55
+ });
56
+ setPolyfilled(true);
57
+ });
58
+ }
59
+ }, [imageRefs]);
60
+ return polyfilled;
61
+ }
62
+ function getTypeByExtension(src) {
63
+ // Identifying type by extension, based on common image file types
64
+ // https://developer.mozilla.org/en-US/docs/Web/Media/Formats/Image_types
65
+ const extensionRegex = /\.(jpg|jpeg|jfif|pjpeg|pjp|png|gif|bmp|webp|svg|apng|ico|cur)(?:\?.*)?$/i;
66
+ const formatMatch = extensionRegex.exec(src);
67
+ if (!formatMatch)
68
+ return null;
69
+ let type = null;
70
+ switch (formatMatch[1]) {
71
+ case 'jpg':
72
+ case 'jpeg':
73
+ case 'jfif':
74
+ case 'pjpeg':
75
+ case 'pjp':
76
+ type = 'image/jpeg';
77
+ break;
78
+ case 'png':
79
+ type = 'image/png';
80
+ break;
81
+ case 'gif':
82
+ type = 'image/gif';
83
+ break;
84
+ case 'bmp':
85
+ type = 'image/bmp';
86
+ break;
87
+ case 'webp':
88
+ type = 'image/webp';
89
+ break;
90
+ case 'svg':
91
+ type = 'image/svg+xml';
92
+ break;
93
+ case 'apng':
94
+ type = 'image/apng';
95
+ break;
96
+ case 'ico':
97
+ case 'cur':
98
+ type = 'image/x-icon';
99
+ break;
100
+ default:
101
+ break;
102
+ }
103
+ return type;
104
+ }
105
+ const Img = React.forwardRef((props, ref) => {
106
+ const { sizes, srcSet, src, style, alt, onLoad, onError, objectFit, critical } = props, otherProps = __rest(props, ["sizes", "srcSet", "src", "style", "alt", "onLoad", "onError", "objectFit", "critical"]);
107
+ const imgStyle = Object.assign({ position: 'absolute', top: 0, left: 0, width: `100%`, height: `100%`, paddingTop: 0, objectPosition: `center`, objectFit }, style);
108
+ return (React.createElement("img", Object.assign({ alt: alt, sizes: sizes, srcSet: srcSet, src: src, onLoad: onLoad, onError: onError, loading: critical ? 'eager' : 'lazy' }, otherProps, { ref: ref, style: imgStyle })));
109
+ });
110
+ const Placeholder = React.forwardRef((props, ref) => {
111
+ return (React.createElement("picture", { "data-flight-image-placeholder": "" },
112
+ React.createElement(Img, Object.assign({ loading: "lazy" }, props, { ref: ref }))));
113
+ });
114
+ const Image = function Image(_a) {
115
+ var { src, hasFalsySrc, lqip, sizes, srcset, webpSrcset, critical, aspect, cover = false, alt = '', fillAvailableSpace = false, children, error: ErrorComp, className, badges } = _a, rest = __rest(_a, ["src", "hasFalsySrc", "lqip", "sizes", "srcset", "webpSrcset", "critical", "aspect", "cover", "alt", "fillAvailableSpace", "children", "error", "className", "badges"]);
116
+ // Set up the IntersectionObserver
117
+ const [ref, inView] = useInView({ triggerOnce: true });
118
+ // Check if the browser supports loading="lazy". In that case, we don't need
119
+ // the IntersectionObserver
120
+ const nativeLazyLoading = typeof HTMLImageElement !== 'undefined' &&
121
+ 'loading' in HTMLImageElement.prototype;
122
+ const imageRef = React.createRef();
123
+ const placeholderRef = React.createRef();
124
+ useObjectFitPolyfill([imageRef, placeholderRef]);
125
+ const [{ imgLoaded, error }, dispatch] = React.useReducer(imageStateReducer, critical ? loadedImageState : defaultImageState);
126
+ const cacheKey = srcset;
127
+ const handleImgLoad = React.useCallback(function handleImgLoad() {
128
+ dispatch({ type: 'loaded', cacheKey });
129
+ }, [cacheKey]);
130
+ function handleImgError() {
131
+ dispatch({ type: 'error' });
132
+ }
133
+ // Treat critical images as always cached
134
+ const isCached = critical || isInCache(cacheKey);
135
+ React.useEffect(() => {
136
+ hydrated = true;
137
+ }, []);
138
+ React.useEffect(() => {
139
+ dispatch({ type: 'reset' });
140
+ }, [src]);
141
+ React.useEffect(() => {
142
+ // Handle case where image onLoad fires during SSR
143
+ if (imageRef.current && imageRef.current.complete && !isCached) {
144
+ handleImgLoad();
145
+ }
146
+ }, [handleImgLoad, imageRef, isCached]);
147
+ // Render nothing if src is boolean
148
+ if (typeof src === 'boolean' && !src) {
149
+ return null;
150
+ }
151
+ const loaded = imgLoaded || hasFalsySrc || isCached;
152
+ const objectFit = cover || fillAvailableSpace ? 'cover' : 'contain';
153
+ const objectFitPolyfillStyles = { fontFamily: `"object-fit: ${objectFit}"` };
154
+ const type = getTypeByExtension(src);
155
+ return (React.createElement(React.Fragment, null,
156
+ React.createElement("div", Object.assign({ key: src, ref:
157
+ // If we have native lazyloading, by not applying the `ref` from
158
+ // useInView we don't use IntersectionObserver at all
159
+ nativeLazyLoading ? undefined : ref, "data-flight-image-container": "", "data-flight-image-loaded": loaded, className: className }, rest, { style: {
160
+ position: `relative`,
161
+ overflow: `hidden`,
162
+ width: `100%`,
163
+ height: fillAvailableSpace ? '100%' : 'auto',
164
+ paddingBottom: fillAvailableSpace
165
+ ? 0
166
+ : !aspect
167
+ ? '100%'
168
+ : paddingForAspectRatio(aspect)
169
+ } }),
170
+ error ? (React.createElement(ErrorComp, null)) : (React.createElement(React.Fragment, null,
171
+ React.createElement(Placeholder, { src: critical ? transparentDataImg : lqip || transparentDataImg, ref: placeholderRef, alt: "", "aria-hidden": "true", style: Object.assign({ objectFit, opacity: loaded ? 0 : 0.6, transitionDelay: `500ms` }, objectFitPolyfillStyles) }),
172
+ (inView || nativeLazyLoading || !hydrated || isCached) && (React.createElement("picture", { "data-flight-image": "" },
173
+ React.createElement("source", { type: "image/webp", srcSet: webpSrcset, sizes: sizes }),
174
+ React.createElement("source", { type: type, srcSet: srcset, sizes: sizes }),
175
+ React.createElement(Img, { srcSet: srcset, src: src || transparentDataImg, sizes: sizes, onLoad: handleImgLoad, onError: handleImgError, alt: alt, ref: imageRef, style: Object.assign({ objectFit, opacity: loaded ? 1 : 0, transition: `opacity 500ms` }, objectFitPolyfillStyles), critical: critical, fetchpriority: critical ? 'high' : 'auto' }))),
176
+ React.createElement("noscript", null,
177
+ React.createElement("picture", null,
178
+ React.createElement(Img, { srcSet: srcset, src: src, sizes: sizes, alt: alt, style: {
179
+ objectFit
180
+ }, critical: critical, fetchpriority: critical ? 'high' : 'auto' }))))),
181
+ children && (React.createElement("div", { "data-flight-image-children": "", style: {
182
+ position: 'relative',
183
+ zIndex: 2,
184
+ width: '100%',
185
+ height: '100%'
186
+ } }, children)),
187
+ badges && (React.createElement("div", { "data-flight-image-badges": "", style: {
188
+ zIndex: 2
189
+ } }, badges)))));
190
+ };
191
+ export default Image;
192
+ //# sourceMappingURL=BaseImage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BaseImage.js","sourceRoot":"","sources":["BaseImage.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AAStE,MAAM,CAAC,MAAM,kBAAkB,GAC7B,oHAAoH,CAAC;AAmCvH,MAAM,iBAAiB,GAAG;IACxB,SAAS,EAAE,KAAK;IAChB,KAAK,EAAE,KAAK;CACb,CAAC;AACF,MAAM,gBAAgB,GAAG;IACvB,SAAS,EAAE,IAAI;IACf,KAAK,EAAE,KAAK;CACb,CAAC;AAIF,IAAI,QAAQ,GAAG,KAAK,CAAC;AACrB,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;AAErC,SAAS,SAAS,CAAC,GAAW;IAC5B,OAAO,GAAG,IAAI,UAAU,CAAC;AAC3B,CAAC;AAED,SAAS,UAAU,CAAC,GAAW;IAC7B,UAAU,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;AACzB,CAAC;AAED,SAAS,iBAAiB,CACxB,CAAa,EACb,MAAiE;IAEjE,QAAQ,MAAM,CAAC,IAAI,EAAE;QACnB,KAAK,OAAO;YACV,OAAO,iBAAiB,CAAC;QAC3B,KAAK,QAAQ;YACX,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YAC5B,OAAO,gBAAgB,CAAC;QAC1B,KAAK,OAAO;YACV,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAC3C;YACE,OAAO,CAAC,KAAK,CAAC,UAAU,MAAM,CAAC,IAAI,+BAA+B,CAAC,CAAC;YACpE,OAAO;KACV;AACH,CAAC;AAED,SAAS,oBAAoB,CAAC,SAA8C;IAC1E,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE1D,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9C,IACE,OAAO,OAAO,CAAC,KAAK,CAAC,SAAS,KAAK,WAAW;YAC9C,OAAO,OAAO,CAAC,KAAK,CAAC,cAAc,KAAK,WAAW,EACnD;YACA,MAAM,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,eAAe,EAAE,EAAE,EAAE;gBAChE,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;oBAC7B,QAAQ,CAAC,OAAO,IAAI,eAAe,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;gBACxD,CAAC,CAAC,CAAC;gBACH,aAAa,CAAC,IAAI,CAAC,CAAC;YACtB,CAAC,CAAC,CAAC;SACJ;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAEhB,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,SAAS,kBAAkB,CAAC,GAAW;IACrC,kEAAkE;IAClE,yEAAyE;IACzE,MAAM,cAAc,GAClB,0EAA0E,CAAC;IAC7E,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAE7C,IAAI,CAAC,WAAW;QAAE,OAAO,IAAI,CAAC;IAE9B,IAAI,IAAI,GAAG,IAAI,CAAC;IAEhB,QAAQ,WAAW,CAAC,CAAC,CAAC,EAAE;QACtB,KAAK,KAAK,CAAC;QACX,KAAK,MAAM,CAAC;QACZ,KAAK,MAAM,CAAC;QACZ,KAAK,OAAO,CAAC;QACb,KAAK,KAAK;YACR,IAAI,GAAG,YAAY,CAAC;YACpB,MAAM;QACR,KAAK,KAAK;YACR,IAAI,GAAG,WAAW,CAAC;YACnB,MAAM;QACR,KAAK,KAAK;YACR,IAAI,GAAG,WAAW,CAAC;YACnB,MAAM;QACR,KAAK,KAAK;YACR,IAAI,GAAG,WAAW,CAAC;YACnB,MAAM;QACR,KAAK,MAAM;YACT,IAAI,GAAG,YAAY,CAAC;YACpB,MAAM;QACR,KAAK,KAAK;YACR,IAAI,GAAG,eAAe,CAAC;YACvB,MAAM;QACR,KAAK,MAAM;YACT,IAAI,GAAG,YAAY,CAAC;YACpB,MAAM;QACR,KAAK,KAAK,CAAC;QACX,KAAK,KAAK;YACR,IAAI,GAAG,cAAc,CAAC;YACtB,MAAM;QACR;YACE,MAAM;KACT;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAQD,MAAM,GAAG,GAAG,KAAK,CAAC,UAAU,CAC1B,CACE,KAAmE,EACnE,GAAgC,EAChC,EAAE;IACF,MAAM,EACJ,KAAK,EACL,MAAM,EACN,GAAG,EACH,KAAK,EACL,GAAG,EACH,MAAM,EACN,OAAO,EACP,SAAS,EACT,QAAQ,KAEN,KAAK,EADJ,UAAU,UACX,KAAK,EAXH,wFAWL,CAAQ,CAAC;IAEV,MAAM,QAAQ,mBACZ,QAAQ,EAAE,UAA6C,EACvD,GAAG,EAAE,CAAC,EACN,IAAI,EAAE,CAAC,EACP,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,CAAC,EACb,cAAc,EAAE,QAAQ,EACxB,SAAS,IACN,KAAK,CACT,CAAC;IAEF,OAAO,CACL,2CACE,GAAG,EAAE,GAAG,EACR,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,OAAO,EAChB,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,IAChC,UAAU,IACd,GAAG,EAAE,GAAG,EACR,KAAK,EAAE,QAAQ,IACf,CACH,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,MAAM,WAAW,GAAG,KAAK,CAAC,UAAU,CAClC,CAAC,KAAU,EAAE,GAAgC,EAAE,EAAE;IAC/C,OAAO,CACL,kEAAuC,EAAE;QACvC,oBAAC,GAAG,kBAAC,OAAO,EAAC,MAAM,IAAK,KAAK,IAAE,GAAG,EAAE,GAAG,IAAI,CACnC,CACX,CAAC;AACJ,CAAC,CACF,CAAC;AAEF,MAAM,KAAK,GAAyB,SAAS,KAAK,CAAC,EAiBlD;QAjBkD,EACjD,GAAG,EACH,WAAW,EACX,IAAI,EACJ,KAAK,EACL,MAAM,EACN,UAAU,EACV,QAAQ,EACR,MAAM,EACN,KAAK,GAAG,KAAK,EACb,GAAG,GAAG,EAAE,EACR,kBAAkB,GAAG,KAAK,EAC1B,QAAQ,EACR,KAAK,EAAE,SAAS,EAChB,SAAS,EACT,MAAM,OAEP,EADI,IAAI,cAhB0C,uKAiBlD,CADQ;IAEP,kCAAkC;IAClC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC;IACvD,4EAA4E;IAC5E,2BAA2B;IAC3B,MAAM,iBAAiB,GACrB,OAAO,gBAAgB,KAAK,WAAW;QACvC,SAAS,IAAI,gBAAgB,CAAC,SAAS,CAAC;IAE1C,MAAM,QAAQ,GAAG,KAAK,CAAC,SAAS,EAAoB,CAAC;IACrD,MAAM,cAAc,GAAG,KAAK,CAAC,SAAS,EAAoB,CAAC;IAC3D,oBAAoB,CAAC,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC,CAAC;IAEjD,MAAM,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,QAAQ,CAAC,GAAG,KAAK,CAAC,UAAU,CACvD,iBAAiB,EACjB,QAAQ,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,iBAAiB,CAChD,CAAC;IAEF,MAAM,QAAQ,GAAG,MAAM,CAAC;IAExB,MAAM,aAAa,GAAG,KAAK,CAAC,WAAW,CACrC,SAAS,aAAa;QACpB,QAAQ,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;IACzC,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAC;IAEF,SAAS,cAAc;QACrB,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,yCAAyC;IACzC,MAAM,QAAQ,GAAG,QAAQ,IAAI,SAAS,CAAC,QAAQ,CAAC,CAAC;IAEjD,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,QAAQ,GAAG,IAAI,CAAC;IAClB,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;IAC9B,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAEV,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,kDAAkD;QAClD,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,OAAO,CAAC,QAAQ,IAAI,CAAC,QAAQ,EAAE;YAC9D,aAAa,EAAE,CAAC;SACjB;IACH,CAAC,EAAE,CAAC,aAAa,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC;IAExC,mCAAmC;IACnC,IAAI,OAAO,GAAG,KAAK,SAAS,IAAI,CAAC,GAAG,EAAE;QACpC,OAAO,IAAI,CAAC;KACb;IAED,MAAM,MAAM,GAAG,SAAS,IAAI,WAAW,IAAI,QAAQ,CAAC;IAEpD,MAAM,SAAS,GAAG,KAAK,IAAI,kBAAkB,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC;IACpE,MAAM,uBAAuB,GAAG,EAAE,UAAU,EAAE,gBAAgB,SAAS,GAAG,EAAE,CAAC;IAE7E,MAAM,IAAI,GAAG,kBAAkB,CAAC,GAAa,CAAC,CAAC;IAE/C,OAAO,CACL;QACE,2CACE,GAAG,EAAE,GAAa,EAClB,GAAG;YACD,gEAAgE;YAChE,qDAAqD;YACrD,iBAAiB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,iCAET,EAAE,8BACJ,MAAM,EAChC,SAAS,EAAE,SAAS,IAChB,IAAI,IACR,KAAK,EAAE;gBACL,QAAQ,EAAE,UAAU;gBACpB,QAAQ,EAAE,QAAQ;gBAClB,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,kBAAkB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;gBAC5C,aAAa,EAAE,kBAAkB;oBAC/B,CAAC,CAAC,CAAC;oBACH,CAAC,CAAC,CAAC,MAAM;wBACT,CAAC,CAAC,MAAM;wBACR,CAAC,CAAC,qBAAqB,CAAC,MAAM,CAAC;aAClC;YAEA,KAAK,CAAC,CAAC,CAAC,CACP,oBAAC,SAAS,OAAG,CACd,CAAC,CAAC,CAAC,CACF;gBACE,oBAAC,WAAW,IACV,GAAG,EAAE,QAAQ,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,IAAI,kBAAkB,EAC/D,GAAG,EAAE,cAAc,EACnB,GAAG,EAAC,EAAE,iBACM,MAAM,EAClB,KAAK,kBACH,SAAS,EACT,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EACzB,eAAe,EAAE,OAAO,IACrB,uBAAuB,IAE5B;gBAED,CAAC,MAAM,IAAI,iBAAiB,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,IAAI,CACzD,sDAA2B,EAAE;oBAC3B,gCAAQ,IAAI,EAAC,YAAY,EAAC,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,GAAI;oBAC9D,gCAAQ,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAI;oBACpD,oBAAC,GAAG,IACF,MAAM,EAAE,MAAM,EACd,GAAG,EAAG,GAAc,IAAI,kBAAkB,EAC1C,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,aAAa,EACrB,OAAO,EAAE,cAAc,EACvB,GAAG,EAAE,GAAG,EACR,GAAG,EAAE,QAAQ,EACb,KAAK,kBACH,SAAS,EACT,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACvB,UAAU,EAAE,eAAe,IACxB,uBAAuB,GAE5B,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,GACzC,CACM,CACX;gBAED;oBACE;wBACE,oBAAC,GAAG,IACF,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,GAAa,EAClB,KAAK,EAAE,KAAK,EACZ,GAAG,EAAE,GAAG,EACR,KAAK,EAAE;gCACL,SAAS;6BACV,EACD,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,GACzC,CACM,CACD,CACV,CACJ;YAEA,QAAQ,IAAI,CACX,2DAC6B,EAAE,EAC7B,KAAK,EAAE;oBACL,QAAQ,EAAE,UAAU;oBACpB,MAAM,EAAE,CAAC;oBACT,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,MAAM;iBACf,IAEA,QAAQ,CACL,CACP;YACA,MAAM,IAAI,CACT,yDAC2B,EAAE,EAC3B,KAAK,EAAE;oBACL,MAAM,EAAE,CAAC;iBACV,IAEA,MAAM,CACH,CACP,CACG,CACL,CACJ,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,KAAK,CAAC"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ /** Display this if JS is disabled. */
3
+ export declare const Fallback: ({ children }: {
4
+ children: React.ReactElement<{}>;
5
+ }) => React.JSX.Element;
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ /** Display this if JS is disabled. */
3
+ export const Fallback = ({ children }) => React.createElement("noscript", null, children);
4
+ //# sourceMappingURL=Fallback.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Fallback.js","sourceRoot":"","sources":["Fallback.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,sCAAsC;AAEtC,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EACvB,QAAQ,EAGT,EAAE,EAAE,CAAC,sCAAW,QAAQ,CAAY,CAAC"}
@@ -0,0 +1,51 @@
1
+ import React from 'react';
2
+ import { ProductImageSize } from '@jetshop/core/types';
3
+ export type ImageSrcType = string | ProductImageSize[];
4
+ export type ImageBreakpointSize = number | string;
5
+ export type ImageBreakpointSizes = ImageBreakpointSize | ImageBreakpointSize[];
6
+ export type AspectRatio = string | number;
7
+ export type Gravity = 'north' | 'south' | 'west' | 'east' | 'centre' | 'smart';
8
+ export declare const transparentDataImg = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=";
9
+ interface ImageParameters {
10
+ /** The image src
11
+ * Also accepts an array of objects with `url` keys (deprecated image field)
12
+ */
13
+ src: ImageSrcType;
14
+ /**
15
+ * Whether to crop the image instead of resizing it when aspect ratio is provided
16
+ * @default false
17
+ */
18
+ crop?: boolean;
19
+ gravity?: Gravity;
20
+ quality?: number;
21
+ /** An array of image sizes, will be mapped against breakpoints.
22
+ * @see https://docs.dev.jetshop.se/ui/image#the-sizes-prop
23
+ */
24
+ sizes: ImageBreakpointSizes;
25
+ /**
26
+ * The aspect ratio of the image
27
+ * If unknown, use null to preserve original aspect ratio
28
+ */
29
+ aspect?: string;
30
+ critical?: boolean;
31
+ modifiedDate?: string;
32
+ focalPointX?: number;
33
+ focalPointY?: number;
34
+ }
35
+ interface ImageProps extends ImageParameters {
36
+ /** Whether or not to use `background-size: cover` */
37
+ cover?: boolean;
38
+ error?: (args: any) => React.ReactElement<any>;
39
+ alt?: string;
40
+ title?: string;
41
+ /**
42
+ * Useful for banner images. Sets the following CSS automatically:
43
+ * object-fit: cover
44
+ * padding-top: 0;
45
+ */
46
+ fillAvailableSpace?: boolean;
47
+ className?: string;
48
+ badges?: React.ReactElement<any>;
49
+ }
50
+ declare function FlightImage(props: ImageProps): React.JSX.Element;
51
+ export default FlightImage;