@jetshop/ui 6.3.8-alpha.20 → 6.3.8-alpha.30

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 (461) 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 +39 -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 +51 -0
  86. package/CloudflareImage/FlightImage.js +61 -0
  87. package/CloudflareImage/FlightImage.js.map +1 -0
  88. package/CloudflareImage/FlightImage.test.js +277 -0
  89. package/CloudflareImage/Image.d.ts +2 -0
  90. package/CloudflareImage/Image.js +3 -0
  91. package/CloudflareImage/Image.js.map +1 -0
  92. package/CloudflareImage/index.d.ts +1 -0
  93. package/CloudflareImage/index.js +2 -0
  94. package/CloudflareImage/index.js.map +1 -0
  95. package/CloudflareImage/useConstructImage.d.ts +49 -0
  96. package/CloudflareImage/useConstructImage.js +122 -0
  97. package/CloudflareImage/useConstructImage.js.map +1 -0
  98. package/CloudflareImage/utils/aspectRatioToFraction.d.ts +2 -0
  99. package/CloudflareImage/utils/aspectRatioToFraction.js +11 -0
  100. package/CloudflareImage/utils/aspectRatioToFraction.js.map +1 -0
  101. package/CloudflareImage/utils/getFullUrl.d.ts +6 -0
  102. package/CloudflareImage/utils/getFullUrl.js +18 -0
  103. package/CloudflareImage/utils/getFullUrl.js.map +1 -0
  104. package/CloudflareImage/utils/getImageWidth.d.ts +1 -0
  105. package/CloudflareImage/utils/getImageWidth.js +12 -0
  106. package/CloudflareImage/utils/getImageWidth.js.map +1 -0
  107. package/CloudflareImage/utils/getImageWidths.d.ts +2 -0
  108. package/CloudflareImage/utils/getImageWidths.js +21 -0
  109. package/CloudflareImage/utils/getImageWidths.js.map +1 -0
  110. package/CloudflareImage/utils/getLQIP.d.ts +8 -0
  111. package/CloudflareImage/utils/getLQIP.js +21 -0
  112. package/CloudflareImage/utils/getLQIP.js.map +1 -0
  113. package/CloudflareImage/utils/getLargestSize.d.ts +7 -0
  114. package/CloudflareImage/utils/getLargestSize.js +17 -0
  115. package/CloudflareImage/utils/getLargestSize.js.map +1 -0
  116. package/CloudflareImage/utils/getSizeForBreakpoint.d.ts +2 -0
  117. package/CloudflareImage/utils/getSizeForBreakpoint.js +16 -0
  118. package/CloudflareImage/utils/getSizeForBreakpoint.js.map +1 -0
  119. package/CloudflareImage/utils/getSizesMap.d.ts +2 -0
  120. package/CloudflareImage/utils/getSizesMap.js +35 -0
  121. package/CloudflareImage/utils/getSizesMap.js.map +1 -0
  122. package/CloudflareImage/utils/getSmallestSize.d.ts +2 -0
  123. package/CloudflareImage/utils/getSmallestSize.js +12 -0
  124. package/CloudflareImage/utils/getSmallestSize.js.map +1 -0
  125. package/CloudflareImage/utils/getSrcSetFromWidths.d.ts +10 -0
  126. package/CloudflareImage/utils/getSrcSetFromWidths.js +10 -0
  127. package/CloudflareImage/utils/getSrcSetFromWidths.js.map +1 -0
  128. package/CloudflareImage/utils/getSrcWithParams.d.ts +3 -0
  129. package/CloudflareImage/utils/getSrcWithParams.js +30 -0
  130. package/CloudflareImage/utils/getSrcWithParams.js.map +1 -0
  131. package/CloudflareImage/utils/paddingForAspectRatio.d.ts +1 -0
  132. package/CloudflareImage/utils/paddingForAspectRatio.js +6 -0
  133. package/CloudflareImage/utils/paddingForAspectRatio.js.map +1 -0
  134. package/CloudflareImage/utils/remToPx.d.ts +1 -0
  135. package/CloudflareImage/utils/remToPx.js +2 -0
  136. package/CloudflareImage/utils/remToPx.js.map +1 -0
  137. package/CloudflareImage/utils/sizeToNumber.d.ts +2 -0
  138. package/CloudflareImage/utils/sizeToNumber.js +27 -0
  139. package/CloudflareImage/utils/sizeToNumber.js.map +1 -0
  140. package/ContentPageLink.d.ts +11 -0
  141. package/ContentPageLink.js +46 -0
  142. package/ContentPageLink.js.map +1 -0
  143. package/ContentRenderer.d.ts +9 -0
  144. package/ContentRenderer.js +36 -0
  145. package/ContentRenderer.js.map +1 -0
  146. package/DropdownMenu/Button.d.ts +7 -0
  147. package/DropdownMenu/Button.js +33 -0
  148. package/DropdownMenu/Button.js.map +1 -0
  149. package/DropdownMenu/DropdownMenu.d.ts +21 -0
  150. package/DropdownMenu/DropdownMenu.js +72 -0
  151. package/DropdownMenu/DropdownMenu.js.map +1 -0
  152. package/DropdownMenu/Item.d.ts +13 -0
  153. package/DropdownMenu/Item.js +48 -0
  154. package/DropdownMenu/Item.js.map +1 -0
  155. package/DropdownMenu/Items.d.ts +16 -0
  156. package/DropdownMenu/Items.js +53 -0
  157. package/DropdownMenu/Items.js.map +1 -0
  158. package/DropdownMenu/index.d.ts +4 -0
  159. package/DropdownMenu/index.js +5 -0
  160. package/DropdownMenu/index.js.map +1 -0
  161. package/ErrorBoundary/Generic.d.ts +18 -0
  162. package/ErrorBoundary/Generic.js +65 -0
  163. package/ErrorBoundary/Generic.js.map +1 -0
  164. package/ErrorBoundary/PassThrough.d.ts +3 -0
  165. package/ErrorBoundary/PassThrough.js +7 -0
  166. package/ErrorBoundary/PassThrough.js.map +1 -0
  167. package/Gallery/Gallery.d.ts +39 -0
  168. package/Gallery/Gallery.js +121 -0
  169. package/Gallery/Gallery.js.map +1 -0
  170. package/Gallery/constructGallery.d.ts +15 -0
  171. package/Gallery/constructGallery.js +40 -0
  172. package/Gallery/constructGallery.js.map +1 -0
  173. package/Image/BaseImage.d.ts +39 -0
  174. package/Image/BaseImage.js +192 -0
  175. package/Image/BaseImage.js.map +1 -0
  176. package/Image/Fallback.d.ts +5 -0
  177. package/Image/Fallback.js +4 -0
  178. package/Image/Fallback.js.map +1 -0
  179. package/Image/FlightImage.d.ts +51 -0
  180. package/Image/FlightImage.js +59 -0
  181. package/Image/FlightImage.js.map +1 -0
  182. package/Image/Image.d.ts +2 -0
  183. package/Image/Image.js +3 -0
  184. package/Image/Image.js.map +1 -0
  185. package/Image/index.d.ts +1 -0
  186. package/Image/index.js +2 -0
  187. package/Image/index.js.map +1 -0
  188. package/Image/useConstructImage.d.ts +49 -0
  189. package/Image/useConstructImage.js +122 -0
  190. package/Image/useConstructImage.js.map +1 -0
  191. package/Image/utils/aspectRatioToFraction.d.ts +2 -0
  192. package/Image/utils/aspectRatioToFraction.js +11 -0
  193. package/Image/utils/aspectRatioToFraction.js.map +1 -0
  194. package/Image/utils/getFullUrl.d.ts +6 -0
  195. package/Image/utils/getFullUrl.js +18 -0
  196. package/Image/utils/getFullUrl.js.map +1 -0
  197. package/Image/utils/getImageWidth.d.ts +1 -0
  198. package/Image/utils/getImageWidth.js +12 -0
  199. package/Image/utils/getImageWidth.js.map +1 -0
  200. package/Image/utils/getImageWidths.d.ts +2 -0
  201. package/Image/utils/getImageWidths.js +21 -0
  202. package/Image/utils/getImageWidths.js.map +1 -0
  203. package/Image/utils/getLQIP.d.ts +8 -0
  204. package/Image/utils/getLQIP.js +20 -0
  205. package/Image/utils/getLQIP.js.map +1 -0
  206. package/Image/utils/getLargestSize.d.ts +7 -0
  207. package/Image/utils/getLargestSize.js +17 -0
  208. package/Image/utils/getLargestSize.js.map +1 -0
  209. package/Image/utils/getSizeForBreakpoint.d.ts +2 -0
  210. package/Image/utils/getSizeForBreakpoint.js +16 -0
  211. package/Image/utils/getSizeForBreakpoint.js.map +1 -0
  212. package/Image/utils/getSizesMap.d.ts +2 -0
  213. package/Image/utils/getSizesMap.js +35 -0
  214. package/Image/utils/getSizesMap.js.map +1 -0
  215. package/Image/utils/getSmallestSize.d.ts +2 -0
  216. package/Image/utils/getSmallestSize.js +12 -0
  217. package/Image/utils/getSmallestSize.js.map +1 -0
  218. package/Image/utils/getSrcSetFromWidths.d.ts +10 -0
  219. package/Image/utils/getSrcSetFromWidths.js +9 -0
  220. package/Image/utils/getSrcSetFromWidths.js.map +1 -0
  221. package/Image/utils/getSrcWithParams.d.ts +3 -0
  222. package/Image/utils/getSrcWithParams.js +29 -0
  223. package/Image/utils/getSrcWithParams.js.map +1 -0
  224. package/Image/utils/paddingForAspectRatio.d.ts +1 -0
  225. package/Image/utils/paddingForAspectRatio.js +6 -0
  226. package/Image/utils/paddingForAspectRatio.js.map +1 -0
  227. package/Image/utils/remToPx.d.ts +1 -0
  228. package/Image/utils/remToPx.js +2 -0
  229. package/Image/utils/remToPx.js.map +1 -0
  230. package/Image/utils/sizeToNumber.d.ts +2 -0
  231. package/Image/utils/sizeToNumber.js +27 -0
  232. package/Image/utils/sizeToNumber.js.map +1 -0
  233. package/Input/Input.d.ts +6 -0
  234. package/Input/Input.js +45 -0
  235. package/Input/Input.js.map +1 -0
  236. package/Input/index.d.ts +3 -0
  237. package/Input/index.js +4 -0
  238. package/Input/index.js.map +1 -0
  239. package/JetshopText.d.ts +3 -0
  240. package/JetshopText.js +13 -0
  241. package/JetshopText.js.map +1 -0
  242. package/Loading/LoadingBar.d.ts +8 -0
  243. package/Loading/LoadingBar.js +58 -0
  244. package/Loading/LoadingBar.js.map +1 -0
  245. package/Loading/LoadingLine.d.ts +31 -0
  246. package/Loading/LoadingLine.js +26 -0
  247. package/Loading/LoadingLine.js.map +1 -0
  248. package/Loading/NetworkStatusNotifier.d.ts +6 -0
  249. package/Loading/NetworkStatusNotifier.js +8 -0
  250. package/Loading/NetworkStatusNotifier.js.map +1 -0
  251. package/Menu/MenuContainer.d.ts +28 -0
  252. package/Menu/MenuContainer.js +46 -0
  253. package/Menu/MenuContainer.js.map +1 -0
  254. package/Menu/RecursiveTree.d.ts +28 -0
  255. package/Menu/RecursiveTree.js +91 -0
  256. package/Menu/RecursiveTree.js.map +1 -0
  257. package/Modal/Drawer/Drawer.d.ts +12 -0
  258. package/Modal/Drawer/Drawer.js +31 -0
  259. package/Modal/Drawer/Drawer.js.map +1 -0
  260. package/Modal/Drawer/DrawerTarget.d.ts +6 -0
  261. package/Modal/Drawer/DrawerTarget.js +12 -0
  262. package/Modal/Drawer/DrawerTarget.js.map +1 -0
  263. package/Modal/Drawer/DrawerTrigger.d.ts +11 -0
  264. package/Modal/Drawer/DrawerTrigger.js +16 -0
  265. package/Modal/Drawer/DrawerTrigger.js.map +1 -0
  266. package/Modal/Drawer/index.d.ts +3 -0
  267. package/Modal/Drawer/index.js +4 -0
  268. package/Modal/Drawer/index.js.map +1 -0
  269. package/Modal/Flyout/FlyoutTarget.d.ts +10 -0
  270. package/Modal/Flyout/FlyoutTarget.js +15 -0
  271. package/Modal/Flyout/FlyoutTarget.js.map +1 -0
  272. package/Modal/Flyout/FlyoutTrigger.d.ts +15 -0
  273. package/Modal/Flyout/FlyoutTrigger.js +18 -0
  274. package/Modal/Flyout/FlyoutTrigger.js.map +1 -0
  275. package/Modal/Flyout/index.d.ts +2 -0
  276. package/Modal/Flyout/index.js +3 -0
  277. package/Modal/Flyout/index.js.map +1 -0
  278. package/Modal/ModalContext.d.ts +26 -0
  279. package/Modal/ModalContext.js +9 -0
  280. package/Modal/ModalContext.js.map +1 -0
  281. package/Modal/ModalProvider.d.ts +5 -0
  282. package/Modal/ModalProvider.js +83 -0
  283. package/Modal/ModalProvider.js.map +1 -0
  284. package/Modal/ModalRoot.d.ts +3 -0
  285. package/Modal/ModalRoot.js +44 -0
  286. package/Modal/ModalRoot.js.map +1 -0
  287. package/Modal/ModalTrigger.d.ts +9 -0
  288. package/Modal/ModalTrigger.js +9 -0
  289. package/Modal/ModalTrigger.js.map +1 -0
  290. package/Pagination/Pagination.d.ts +7 -0
  291. package/Pagination/Pagination.js +23 -0
  292. package/Pagination/Pagination.js.map +1 -0
  293. package/Pagination/PaginationBehaviour.d.ts +52 -0
  294. package/Pagination/PaginationBehaviour.js +68 -0
  295. package/Pagination/PaginationBehaviour.js.map +1 -0
  296. package/Pagination/index.d.ts +2 -0
  297. package/Pagination/index.js +3 -0
  298. package/Pagination/index.js.map +1 -0
  299. package/Pagination/usePagination.d.ts +15 -0
  300. package/Pagination/usePagination.js +46 -0
  301. package/Pagination/usePagination.js.map +1 -0
  302. package/PreOrderDateSelector/PreOrderDateSelector.d.ts +23 -0
  303. package/PreOrderDateSelector/PreOrderDateSelector.js +74 -0
  304. package/PreOrderDateSelector/PreOrderDateSelector.js.map +1 -0
  305. package/PreOrderDateSelector/index.d.ts +2 -0
  306. package/PreOrderDateSelector/index.js +3 -0
  307. package/PreOrderDateSelector/index.js.map +1 -0
  308. package/Price/Currency.d.ts +9 -0
  309. package/Price/Currency.js +11 -0
  310. package/Price/Currency.js.map +1 -0
  311. package/Price/Price.d.ts +44 -0
  312. package/Price/Price.js +74 -0
  313. package/Price/Price.js.map +1 -0
  314. package/Price/index.d.ts +1 -0
  315. package/Price/index.js +2 -0
  316. package/Price/index.js.map +1 -0
  317. package/ProductLink.d.ts +23 -0
  318. package/ProductLink.js +88 -0
  319. package/ProductLink.js.map +1 -0
  320. package/ProductList/Badges.d.ts +6 -0
  321. package/ProductList/Badges.js +56 -0
  322. package/ProductList/Badges.js.map +1 -0
  323. package/ProductList/GridProduct.d.ts +24 -0
  324. package/ProductList/GridProduct.js +58 -0
  325. package/ProductList/GridProduct.js.map +1 -0
  326. package/ProductList/ProductGrid.d.ts +16 -0
  327. package/ProductList/ProductGrid.js +30 -0
  328. package/ProductList/ProductGrid.js.map +1 -0
  329. package/ProductList/ProductImage.d.ts +12 -0
  330. package/ProductList/ProductImage.js +21 -0
  331. package/ProductList/ProductImage.js.map +1 -0
  332. package/ProductSpecifications/ProductSpecifications.d.ts +8 -0
  333. package/ProductSpecifications/ProductSpecifications.js +78 -0
  334. package/ProductSpecifications/ProductSpecifications.js.map +1 -0
  335. package/ScrollRestorationHandler/ScrollRestorationHandler.d.ts +8 -0
  336. package/ScrollRestorationHandler/ScrollRestorationHandler.js +17 -0
  337. package/ScrollRestorationHandler/ScrollRestorationHandler.js.map +1 -0
  338. package/ScrollRestorationHandler/index.d.ts +1 -0
  339. package/ScrollRestorationHandler/index.js +2 -0
  340. package/ScrollRestorationHandler/index.js.map +1 -0
  341. package/ScrollRestorationHandler/isInIgnoredRouteTypes.d.ts +8 -0
  342. package/ScrollRestorationHandler/isInIgnoredRouteTypes.js +8 -0
  343. package/ScrollRestorationHandler/isInIgnoredRouteTypes.js.map +1 -0
  344. package/ScrollRestorationHandler/useScrollRestore.d.ts +9 -0
  345. package/ScrollRestorationHandler/useScrollRestore.js +20 -0
  346. package/ScrollRestorationHandler/useScrollRestore.js.map +1 -0
  347. package/Search/SearchAutoCompleteContainer.d.ts +45 -0
  348. package/Search/SearchAutoCompleteContainer.js +172 -0
  349. package/Search/SearchAutoCompleteContainer.js.map +1 -0
  350. package/Search/SearchField.d.ts +26 -0
  351. package/Search/SearchField.js +98 -0
  352. package/Search/SearchField.js.map +1 -0
  353. package/Search/SearchPage/PageOf.d.ts +5 -0
  354. package/Search/SearchPage/PageOf.js +7 -0
  355. package/Search/SearchPage/PageOf.js.map +1 -0
  356. package/Search/SearchPage/SearchMeta.d.ts +16 -0
  357. package/Search/SearchPage/SearchMeta.js +20 -0
  358. package/Search/SearchPage/SearchMeta.js.map +1 -0
  359. package/Search/SearchPage/SearchPageBehaviour.d.ts +19 -0
  360. package/Search/SearchPage/SearchPageBehaviour.js +75 -0
  361. package/Search/SearchPage/SearchPageBehaviour.js.map +1 -0
  362. package/Search/SuggestedTerm.d.ts +16 -0
  363. package/Search/SuggestedTerm.js +35 -0
  364. package/Search/SuggestedTerm.js.map +1 -0
  365. package/Search/index.d.ts +1 -0
  366. package/Search/index.js +2 -0
  367. package/Search/index.js.map +1 -0
  368. package/Select/Components.d.ts +28 -0
  369. package/Select/Components.js +91 -0
  370. package/Select/Components.js.map +1 -0
  371. package/Select/SelectComponents/Quantity.d.ts +5 -0
  372. package/Select/SelectComponents/Quantity.js +8 -0
  373. package/Select/SelectComponents/Quantity.js.map +1 -0
  374. package/Select/index.d.ts +5 -0
  375. package/Select/index.js +2 -0
  376. package/Select/index.js.map +1 -0
  377. package/SortOrder/SortOrder.d.ts +16 -0
  378. package/SortOrder/SortOrder.js +33 -0
  379. package/SortOrder/SortOrder.js.map +1 -0
  380. package/SortOrder/SortOrderDropdown.d.ts +9 -0
  381. package/SortOrder/SortOrderDropdown.js +25 -0
  382. package/SortOrder/SortOrderDropdown.js.map +1 -0
  383. package/SortOrder/SortOrderList.d.ts +7 -0
  384. package/SortOrder/SortOrderList.js +17 -0
  385. package/SortOrder/SortOrderList.js.map +1 -0
  386. package/StartPageRenderer/StartPageRenderer.d.ts +17 -0
  387. package/StartPageRenderer/StartPageRenderer.js +52 -0
  388. package/StartPageRenderer/StartPageRenderer.js.map +1 -0
  389. package/StartPageRenderer/index.d.ts +1 -0
  390. package/StartPageRenderer/index.js +2 -0
  391. package/StartPageRenderer/index.js.map +1 -0
  392. package/Stock/StockStatusContainer.d.ts +21 -0
  393. package/Stock/StockStatusContainer.js +45 -0
  394. package/Stock/StockStatusContainer.js.map +1 -0
  395. package/Text/Text.d.ts +11 -0
  396. package/Text/Text.js +22 -0
  397. package/Text/Text.js.map +1 -0
  398. package/Text/index.d.ts +3 -0
  399. package/Text/index.js +4 -0
  400. package/Text/index.js.map +1 -0
  401. package/Theme/createTheme.d.ts +16 -0
  402. package/Theme/createTheme.js +5 -0
  403. package/Theme/createTheme.js.map +1 -0
  404. package/Theme/cssReset.d.ts +1 -0
  405. package/Theme/cssReset.js +160 -0
  406. package/Theme/cssReset.js.map +1 -0
  407. package/Theme/normalizeCss.d.ts +1 -0
  408. package/Theme/normalizeCss.js +357 -0
  409. package/Theme/normalizeCss.js.map +1 -0
  410. package/Theme/sanitizeCss.d.ts +1 -0
  411. package/Theme/sanitizeCss.js +572 -0
  412. package/Theme/sanitizeCss.js.map +1 -0
  413. package/WindowGrid/WindowGrid.d.ts +11 -0
  414. package/WindowGrid/WindowGrid.js +58 -0
  415. package/WindowGrid/WindowGrid.js.map +1 -0
  416. package/WindowGrid/index.d.ts +1 -0
  417. package/WindowGrid/index.js +2 -0
  418. package/WindowGrid/index.js.map +1 -0
  419. package/WindowGrid/useResizeObserver.d.ts +3 -0
  420. package/WindowGrid/useResizeObserver.js +14 -0
  421. package/WindowGrid/useResizeObserver.js.map +1 -0
  422. package/WindowGrid/useScrollWithWindow.d.ts +12 -0
  423. package/WindowGrid/useScrollWithWindow.js +39 -0
  424. package/WindowGrid/useScrollWithWindow.js.map +1 -0
  425. package/fuzzySearch/fuzzySearch.d.ts +8 -0
  426. package/fuzzySearch/fuzzySearch.js +43 -0
  427. package/fuzzySearch/fuzzySearch.js.map +1 -0
  428. package/fuzzySearch/index.d.ts +1 -0
  429. package/fuzzySearch/index.js +2 -0
  430. package/fuzzySearch/index.js.map +1 -0
  431. package/hooks/index.d.ts +2 -0
  432. package/hooks/index.js +3 -0
  433. package/hooks/index.js.map +1 -0
  434. package/hooks/useOnClickOutside.d.ts +6 -0
  435. package/hooks/useOnClickOutside.js +17 -0
  436. package/hooks/useOnClickOutside.js.map +1 -0
  437. package/hooks/useOnEsc.d.ts +4 -0
  438. package/hooks/useOnEsc.js +17 -0
  439. package/hooks/useOnEsc.js.map +1 -0
  440. package/package.json +2 -2
  441. package/utils/breakpoints.d.ts +23 -0
  442. package/utils/breakpoints.js +94 -0
  443. package/utils/breakpoints.js.map +1 -0
  444. package/utils/callAllEventHandlers.d.ts +5 -0
  445. package/utils/callAllEventHandlers.js +9 -0
  446. package/utils/callAllEventHandlers.js.map +1 -0
  447. package/utils/text.d.ts +1 -0
  448. package/utils/text.js +23 -0
  449. package/utils/text.js.map +1 -0
  450. package/utils/theme.d.ts +3 -0
  451. package/utils/theme.js +5 -0
  452. package/utils/theme.js.map +1 -0
  453. package/utils/useHoverIntent.d.ts +10 -0
  454. package/utils/useHoverIntent.js +78 -0
  455. package/utils/useHoverIntent.js.map +1 -0
  456. package/utils/usePropsOfType.d.ts +11 -0
  457. package/utils/usePropsOfType.js +18 -0
  458. package/utils/usePropsOfType.js.map +1 -0
  459. package/withFlightUI.d.ts +17 -0
  460. package/withFlightUI.js +20 -0
  461. package/withFlightUI.js.map +1 -0
@@ -0,0 +1,16 @@
1
+ import { sizeToNumber } from './sizeToNumber';
2
+ export const getSizeForBreakpoint = (sizes, offset) => {
3
+ if (Array.isArray(sizes)) {
4
+ do {
5
+ if (sizes[offset]) {
6
+ return sizeToNumber(sizes[offset]);
7
+ }
8
+ offset--;
9
+ } while (offset >= 0);
10
+ }
11
+ else {
12
+ return sizeToNumber(sizes);
13
+ }
14
+ return 1;
15
+ };
16
+ //# sourceMappingURL=getSizeForBreakpoint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSizeForBreakpoint.js","sourceRoot":"","sources":["getSizeForBreakpoint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAClC,KAA2B,EAC3B,MAAc,EACd,EAAE;IACF,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;QACxB,GAAG;YACD,IAAI,KAAK,CAAC,MAAM,CAAC,EAAE;gBACjB,OAAO,YAAY,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;aACpC;YACD,MAAM,EAAE,CAAC;SACV,QAAQ,MAAM,IAAI,CAAC,EAAE;KACvB;SAAM;QACL,OAAO,YAAY,CAAC,KAAK,CAAC,CAAC;KAC5B;IACD,OAAO,CAAC,CAAC;AACX,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { ImageBreakpointSizes } from '../Image';
2
+ export declare const getSizesMap: (breakpoints: Record<string, string>, sizes: ImageBreakpointSizes, mobile?: boolean) => string;
@@ -0,0 +1,35 @@
1
+ import { getSizeForBreakpoint } from './getSizeForBreakpoint';
2
+ export const getSizesMap = (breakpoints, sizes, mobile = false) => {
3
+ const breakpointArray = Object.entries(breakpoints).map(([key, value]) => ({
4
+ key,
5
+ value
6
+ }));
7
+ const breakpointWidths = [];
8
+ for (let i = 0; i < breakpointArray.length; i++) {
9
+ breakpointWidths.push(breakpointArray[i].value);
10
+ if (mobile && breakpointArray[i].key === 'sm') {
11
+ break;
12
+ }
13
+ }
14
+ return breakpointWidths
15
+ .map((breakpoint, i) => {
16
+ const size = getSizeForBreakpoint(sizes, i);
17
+ let width;
18
+ if (size > 2) {
19
+ // Size is absolute value in px
20
+ width = size + 'px';
21
+ }
22
+ else {
23
+ // Size is already a fraction (or unset). Convert it to vw (percentage
24
+ // of viewport width)
25
+ width = Math.round(100 * (size || 1)) + 'vw';
26
+ }
27
+ // Include a media query for all but the last size
28
+ if (i + 1 < breakpointWidths.length) {
29
+ return `(max-width: ${breakpoint}) ${width}`;
30
+ }
31
+ return width;
32
+ })
33
+ .join(', ');
34
+ };
35
+ //# sourceMappingURL=getSizesMap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSizesMap.js","sourceRoot":"","sources":["getSizesMap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAG9D,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,WAAmC,EACnC,KAA2B,EAC3B,MAAM,GAAG,KAAK,EACd,EAAE;IACF,MAAM,eAAe,GAAG,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QACzE,GAAG;QACH,KAAK;KACN,CAAC,CAAC,CAAC;IAEJ,MAAM,gBAAgB,GAAa,EAAE,CAAC;IAEtC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,eAAe,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC/C,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAEhD,IAAI,MAAM,IAAI,eAAe,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,EAAE;YAC7C,MAAM;SACP;KACF;IAED,OAAO,gBAAgB;SACpB,GAAG,CAAC,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE;QACrB,MAAM,IAAI,GAAG,oBAAoB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAC5C,IAAI,KAAK,CAAC;QACV,IAAI,IAAI,GAAG,CAAC,EAAE;YACZ,+BAA+B;YAC/B,KAAK,GAAG,IAAI,GAAG,IAAI,CAAC;SACrB;aAAM;YACL,sEAAsE;YACtE,qBAAqB;YACrB,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;SAC9C;QACD,kDAAkD;QAClD,IAAI,CAAC,GAAG,CAAC,GAAG,gBAAgB,CAAC,MAAM,EAAE;YACnC,OAAO,eAAe,UAAU,KAAK,KAAK,EAAE,CAAC;SAC9C;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC;SACD,IAAI,CAAC,IAAI,CAAC,CAAC;AAChB,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { ImageSrcType } from '../Image';
2
+ export declare const getSmallestSize: (sizes: ImageSrcType) => any;
@@ -0,0 +1,12 @@
1
+ export const getSmallestSize = (sizes) => {
2
+ if (Array.isArray(sizes)) {
3
+ if (sizes.length === 0) {
4
+ throw new Error('Sizes must not be an empty array');
5
+ }
6
+ return sizes[0].url;
7
+ }
8
+ else {
9
+ return sizes.toString();
10
+ }
11
+ };
12
+ //# sourceMappingURL=getSmallestSize.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSmallestSize.js","sourceRoot":"","sources":["getSmallestSize.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,KAAmB,EAAE,EAAE;IACrD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;QACxB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;SACrD;QACD,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;KACrB;SAAM;QACL,OAAO,KAAK,CAAC,QAAQ,EAAE,CAAC;KACzB;AACH,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { AspectRatio, Gravity } from '../Image';
2
+ export interface ImageParamOptions {
3
+ crop: boolean;
4
+ gravity?: Gravity;
5
+ quality?: number;
6
+ webp?: boolean;
7
+ focalPointX?: number;
8
+ focalPointY?: number;
9
+ }
10
+ export declare const getSrcSetFromWidths: (src: string, widths: number[], aspect: AspectRatio, options?: ImageParamOptions, modifiedDate?: string) => string;
@@ -0,0 +1,10 @@
1
+ import { createSrcWithProperties } from './getSrcWithParams';
2
+ export const getSrcSetFromWidths = (src, widths, aspect, options = { crop: false, webp: false }, modifiedDate) => {
3
+ const p = [];
4
+ for (const w of widths) {
5
+ const prop = createSrcWithProperties(w, aspect, src, true, options, modifiedDate);
6
+ p.push(`/cdn-cgi/image/${prop}/${src}${modifiedDate ? `?timestamp=${modifiedDate}` : ''}`);
7
+ }
8
+ return p.join(', ');
9
+ };
10
+ //# sourceMappingURL=getSrcSetFromWidths.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSrcSetFromWidths.js","sourceRoot":"","sources":["getSrcSetFromWidths.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,uBAAuB,EAAE,MAAM,oBAAoB,CAAC;AAW7D,MAAM,CAAC,MAAM,mBAAmB,GAAG,CACjC,GAAW,EACX,MAAgB,EAChB,MAAmB,EACnB,UAA6B,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,EACzD,YAAqB,EACrB,EAAE;IACF,MAAM,CAAC,GAAG,EAAE,CAAC;IAEb,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE;QACtB,MAAM,IAAI,GAAG,uBAAuB,CAClC,CAAC,EACD,MAAM,EACN,GAAG,EACH,IAAI,EACJ,OAAO,EACP,YAAY,CACb,CAAC;QACF,CAAC,CAAC,IAAI,CACJ,kBAAkB,IAAI,IAAI,GAAG,GAC3B,YAAY,CAAC,CAAC,CAAC,cAAc,YAAY,EAAE,CAAC,CAAC,CAAC,EAChD,EAAE,CACH,CAAC;KACH;IAED,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACtB,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { AspectRatio } from '../Image';
2
+ import { ImageParamOptions } from './getSrcSetFromWidths';
3
+ export declare function createSrcWithProperties(width: number, aspect: AspectRatio, src: string, includeViewportSize?: boolean, options?: ImageParamOptions, timestamp?: string): string;
@@ -0,0 +1,30 @@
1
+ import { aspectRatioToFraction } from './aspectRatioToFraction';
2
+ // <img src="/cdn-cgi/image/width=80,quality=75/uploads/avatar1.jpg" />
3
+ export function createSrcWithProperties(width, aspect,
4
+ // @ts-ignore
5
+ src,
6
+ // @ts-ignore
7
+ includeViewportSize = true, options = { crop: false, webp: false },
8
+ // @ts-ignore
9
+ timestamp) {
10
+ const resizeMethod = options.crop ? 'crop' : 'contain';
11
+ const quality = options.quality;
12
+ const height = aspect
13
+ ? Math.round(width * aspectRatioToFraction(aspect))
14
+ : null;
15
+ const properties = [];
16
+ if (height) {
17
+ properties.push(`width=${width},height=${height},fit=${resizeMethod}`);
18
+ }
19
+ else {
20
+ properties.push(`width=${width},fit=${resizeMethod}`);
21
+ }
22
+ if (quality) {
23
+ properties.push(`quality=${quality}`);
24
+ }
25
+ if (options.webp) {
26
+ properties.push('format=webp');
27
+ }
28
+ return properties.toString();
29
+ }
30
+ //# sourceMappingURL=getSrcWithParams.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSrcWithParams.js","sourceRoot":"","sources":["getSrcWithParams.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAIhE,uEAAuE;AAEvE,MAAM,UAAU,uBAAuB,CACrC,KAAa,EACb,MAAmB;AACnB,aAAa;AACb,GAAW;AACX,aAAa;AACb,mBAAmB,GAAG,IAAI,EAC1B,UAA6B,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE;AACzD,aAAa;AACb,SAAkB;IAElB,MAAM,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;IACvD,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAChC,MAAM,MAAM,GAAG,MAAM;QACnB,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;QACnD,CAAC,CAAC,IAAI,CAAC;IAET,MAAM,UAAU,GAAG,EAAE,CAAC;IAEtB,IAAI,MAAM,EAAE;QACV,UAAU,CAAC,IAAI,CAAC,SAAS,KAAK,WAAW,MAAM,QAAQ,YAAY,EAAE,CAAC,CAAC;KACxE;SAAM;QACL,UAAU,CAAC,IAAI,CAAC,SAAS,KAAK,QAAQ,YAAY,EAAE,CAAC,CAAC;KACvD;IAED,IAAI,OAAO,EAAE;QACX,UAAU,CAAC,IAAI,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;KACvC;IACD,IAAI,OAAO,CAAC,IAAI,EAAE;QAChB,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;KAChC;IAED,OAAO,UAAU,CAAC,QAAQ,EAAE,CAAC;AAC/B,CAAC"}
@@ -0,0 +1 @@
1
+ export declare const paddingForAspectRatio: (aspect?: string) => string;
@@ -0,0 +1,6 @@
1
+ export const paddingForAspectRatio = (aspect = '1:1') => {
2
+ const numbers = aspect.split(/[^\d]/).map(Number);
3
+ const ratio = numbers[1] / numbers[0];
4
+ return `${(ratio * 100).toFixed(4)}%`;
5
+ };
6
+ //# sourceMappingURL=paddingForAspectRatio.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paddingForAspectRatio.js","sourceRoot":"","sources":["paddingForAspectRatio.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,MAAM,GAAG,KAAK,EAAE,EAAE;IACtD,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAClD,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;IACtC,OAAO,GAAG,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;AACxC,CAAC,CAAC"}
@@ -0,0 +1 @@
1
+ export declare const remToPx: (rems: string, base?: number) => number;
@@ -0,0 +1,2 @@
1
+ export const remToPx = (rems, base = 16) => parseInt(rems) * base;
2
+ //# sourceMappingURL=remToPx.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"remToPx.js","sourceRoot":"","sources":["remToPx.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,IAAY,EAAE,IAAI,GAAG,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { ImageBreakpointSize } from '../Image';
2
+ export declare const sizeToNumber: (size: ImageBreakpointSize) => number;
@@ -0,0 +1,27 @@
1
+ import { remToPx } from './remToPx';
2
+ const sizeRegexp = new RegExp(/(\d+)\s?(\w+)?/g);
3
+ export const sizeToNumber = (size) => {
4
+ if (typeof size === 'string') {
5
+ try {
6
+ sizeRegexp.lastIndex = 0;
7
+ const matches = sizeRegexp.exec(size.toLowerCase().trim());
8
+ const num = matches && matches[1];
9
+ const unit = matches && matches[2];
10
+ if ((!unit || unit === 'px') && num) {
11
+ return +num;
12
+ }
13
+ else if (unit === 'rem') {
14
+ return remToPx(num);
15
+ }
16
+ else {
17
+ throw Error('Unknown unit ' + unit);
18
+ }
19
+ }
20
+ catch (e) {
21
+ console.error('Responsive Image: Unit conversion failed for', size, e);
22
+ return 1;
23
+ }
24
+ }
25
+ return size;
26
+ };
27
+ //# sourceMappingURL=sizeToNumber.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sizeToNumber.js","sourceRoot":"","sources":["sizeToNumber.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,MAAM,UAAU,GAAG,IAAI,MAAM,CAAC,iBAAiB,CAAC,CAAC;AACjD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,IAAyB,EAAE,EAAE;IACxD,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;QAC5B,IAAI;YACF,UAAU,CAAC,SAAS,GAAG,CAAC,CAAC;YACzB,MAAM,OAAO,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;YAC3D,MAAM,GAAG,GAAG,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC;YAClC,MAAM,IAAI,GAAG,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC;YACnC,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,KAAK,IAAI,CAAC,IAAI,GAAG,EAAE;gBACnC,OAAO,CAAC,GAAG,CAAC;aACb;iBAAM,IAAI,IAAI,KAAK,KAAK,EAAE;gBACzB,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC;aACrB;iBAAM;gBACL,MAAM,KAAK,CAAC,eAAe,GAAG,IAAI,CAAC,CAAC;aACrC;SACF;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,CAAC,KAAK,CAAC,8CAA8C,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;YACvE,OAAO,CAAC,CAAC;SACV;KACF;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC"}
@@ -0,0 +1,11 @@
1
+ import * as React from 'react';
2
+ import { LinkProps } from 'react-router-dom';
3
+ import { Page } from '@jetshop/core/types';
4
+ export interface ContentPageLinkProps extends Partial<LinkProps> {
5
+ page: Page;
6
+ className?: string;
7
+ preloadRoute?: boolean;
8
+ onMouseEnter?: (event: React.MouseEvent<HTMLAnchorElement, MouseEvent>) => any;
9
+ }
10
+ declare const ContentPageLink: React.FC<ContentPageLinkProps>;
11
+ export default ContentPageLink;
@@ -0,0 +1,46 @@
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 { Link } from 'react-router-dom';
14
+ import { useRoutePreload } from '@jetshop/core/hooks/useRoutePreload';
15
+ import { useHoverIntent } from './utils/useHoverIntent';
16
+ const ContentPageLink = function ContentPageLink(props) {
17
+ const { page, onMouseEnter, preloadRoute = true } = props, rest = __rest(props, ["page", "onMouseEnter", "preloadRoute"]);
18
+ const { primaryRoute } = page;
19
+ const { preload } = useRoutePreload();
20
+ const contentPreload = () => {
21
+ if (!(primaryRoute === null || primaryRoute === void 0 ? void 0 : primaryRoute.path)) {
22
+ return;
23
+ }
24
+ preload({
25
+ pathname: primaryRoute.path,
26
+ routeType: 'Page',
27
+ preloadRoute
28
+ });
29
+ };
30
+ const [, intentRef] = useHoverIntent({
31
+ onHover: () => {
32
+ contentPreload();
33
+ }
34
+ });
35
+ return (React.createElement(Link, Object.assign({ to: {
36
+ pathname: primaryRoute === null || primaryRoute === void 0 ? void 0 : primaryRoute.path,
37
+ state: { type: 'Page' }
38
+ }, innerRef: intentRef, onTouchStart: contentPreload, onMouseEnter: (event) => {
39
+ contentPreload();
40
+ if (typeof onMouseEnter === 'function') {
41
+ onMouseEnter(event);
42
+ }
43
+ } }, rest)));
44
+ };
45
+ export default ContentPageLink;
46
+ //# sourceMappingURL=ContentPageLink.js.map
@@ -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"}