@jetshop/ui 6.3.9-alpha.1 → 6.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (463) hide show
  1. package/Accordion/Accordion.d.ts +33 -0
  2. package/Accordion/Accordion.js +59 -0
  3. package/Accordion/Accordion.js.map +1 -0
  4. package/Auth/FormFields/CountriesInput.d.ts +16 -0
  5. package/Auth/FormFields/CountriesInput.js +28 -0
  6. package/Auth/FormFields/CountriesInput.js.map +1 -0
  7. package/Auth/LogInBehavior.d.ts +22 -0
  8. package/Auth/LogInBehavior.js +24 -0
  9. package/Auth/LogInBehavior.js.map +1 -0
  10. package/Auth/LogInFormProvider.d.ts +7 -0
  11. package/Auth/LogInFormProvider.js +70 -0
  12. package/Auth/LogInFormProvider.js.map +1 -0
  13. package/Auth/LogOut.d.ts +10 -0
  14. package/Auth/LogOut.js +24 -0
  15. package/Auth/LogOut.js.map +1 -0
  16. package/Auth/logInValidator.d.ts +10 -0
  17. package/Auth/logInValidator.js +16 -0
  18. package/Auth/logInValidator.js.map +1 -0
  19. package/Breadcrumbs/Breadcrumbs.d.ts +14 -0
  20. package/Breadcrumbs/Breadcrumbs.js +84 -0
  21. package/Breadcrumbs/Breadcrumbs.js.map +1 -0
  22. package/Breadcrumbs/getParentsOrCanonicalRoute.d.ts +3 -0
  23. package/Breadcrumbs/getParentsOrCanonicalRoute.js +14 -0
  24. package/Breadcrumbs/getParentsOrCanonicalRoute.js.map +1 -0
  25. package/Breadcrumbs/index.d.ts +1 -0
  26. package/Breadcrumbs/index.js +2 -0
  27. package/Breadcrumbs/index.js.map +1 -0
  28. package/Breakpoints.d.ts +12 -0
  29. package/Breakpoints.js +36 -0
  30. package/Breakpoints.js.map +1 -0
  31. package/Button/Button.d.ts +14 -0
  32. package/Button/Button.js +60 -0
  33. package/Button/Button.js.map +1 -0
  34. package/Button/SecondaryButton.d.ts +2 -0
  35. package/Button/SecondaryButton.js +9 -0
  36. package/Button/SecondaryButton.js.map +1 -0
  37. package/Button/TrendButton.d.ts +2 -0
  38. package/Button/TrendButton.js +8 -0
  39. package/Button/TrendButton.js.map +1 -0
  40. package/Button/index.d.ts +4 -0
  41. package/Button/index.js +5 -0
  42. package/Button/index.js.map +1 -0
  43. package/CategoryLink.d.ts +11 -0
  44. package/CategoryLink.js +49 -0
  45. package/CategoryLink.js.map +1 -0
  46. package/ChannelSelector/ChannelListItem.d.ts +10 -0
  47. package/ChannelSelector/ChannelListItem.js +51 -0
  48. package/ChannelSelector/ChannelListItem.js.map +1 -0
  49. package/ChannelSelector/ChannelSelector.d.ts +63 -0
  50. package/ChannelSelector/ChannelSelector.js +80 -0
  51. package/ChannelSelector/ChannelSelector.js.map +1 -0
  52. package/ChannelSelector/ChannelSelectorButtons.d.ts +2 -0
  53. package/ChannelSelector/ChannelSelectorButtons.js +20 -0
  54. package/ChannelSelector/ChannelSelectorButtons.js.map +1 -0
  55. package/ChannelSelector/Channels.d.ts +17 -0
  56. package/ChannelSelector/Channels.js +12 -0
  57. package/ChannelSelector/Channels.js.map +1 -0
  58. package/ChannelSelector/LargeSelector.d.ts +3 -0
  59. package/ChannelSelector/LargeSelector.js +67 -0
  60. package/ChannelSelector/LargeSelector.js.map +1 -0
  61. package/ChannelSelector/MiniSelector.d.ts +4 -0
  62. package/ChannelSelector/MiniSelector.js +58 -0
  63. package/ChannelSelector/MiniSelector.js.map +1 -0
  64. package/ChannelSelector/Region.d.ts +28 -0
  65. package/ChannelSelector/Region.js +21 -0
  66. package/ChannelSelector/Region.js.map +1 -0
  67. package/ChannelSelector/groupBy.d.ts +7 -0
  68. package/ChannelSelector/groupBy.js +16 -0
  69. package/ChannelSelector/groupBy.js.map +1 -0
  70. package/Checkbox/Checkbox.d.ts +14 -0
  71. package/Checkbox/Checkbox.js +70 -0
  72. package/Checkbox/Checkbox.js.map +1 -0
  73. package/Checkbox/CheckboxGroup.d.ts +27 -0
  74. package/Checkbox/CheckboxGroup.js +22 -0
  75. package/Checkbox/CheckboxGroup.js.map +1 -0
  76. package/Checkbox/index.d.ts +2 -0
  77. package/Checkbox/index.js +3 -0
  78. package/Checkbox/index.js.map +1 -0
  79. package/CloudflareImage/BaseImage.d.ts +41 -0
  80. package/CloudflareImage/BaseImage.js +192 -0
  81. package/CloudflareImage/BaseImage.js.map +1 -0
  82. package/CloudflareImage/Fallback.d.ts +5 -0
  83. package/CloudflareImage/Fallback.js +4 -0
  84. package/CloudflareImage/Fallback.js.map +1 -0
  85. package/CloudflareImage/FlightImage.d.ts +73 -0
  86. package/CloudflareImage/FlightImage.js +61 -0
  87. package/CloudflareImage/FlightImage.js.map +1 -0
  88. package/CloudflareImage/Image.d.ts +2 -0
  89. package/CloudflareImage/Image.js +3 -0
  90. package/CloudflareImage/Image.js.map +1 -0
  91. package/CloudflareImage/index.d.ts +1 -0
  92. package/CloudflareImage/index.js +2 -0
  93. package/CloudflareImage/index.js.map +1 -0
  94. package/CloudflareImage/useConstructImage.d.ts +49 -0
  95. package/CloudflareImage/useConstructImage.js +122 -0
  96. package/CloudflareImage/useConstructImage.js.map +1 -0
  97. package/CloudflareImage/utils/aspectRatioToFraction.d.ts +2 -0
  98. package/CloudflareImage/utils/aspectRatioToFraction.js +11 -0
  99. package/CloudflareImage/utils/aspectRatioToFraction.js.map +1 -0
  100. package/CloudflareImage/utils/getFullUrl.d.ts +6 -0
  101. package/CloudflareImage/utils/getFullUrl.js +18 -0
  102. package/CloudflareImage/utils/getFullUrl.js.map +1 -0
  103. package/CloudflareImage/utils/getImageWidth.d.ts +1 -0
  104. package/CloudflareImage/utils/getImageWidth.js +12 -0
  105. package/CloudflareImage/utils/getImageWidth.js.map +1 -0
  106. package/CloudflareImage/utils/getImageWidths.d.ts +2 -0
  107. package/CloudflareImage/utils/getImageWidths.js +21 -0
  108. package/CloudflareImage/utils/getImageWidths.js.map +1 -0
  109. package/CloudflareImage/utils/getLQIP.d.ts +8 -0
  110. package/CloudflareImage/utils/getLQIP.js +28 -0
  111. package/CloudflareImage/utils/getLQIP.js.map +1 -0
  112. package/CloudflareImage/utils/getLargestSize.d.ts +7 -0
  113. package/CloudflareImage/utils/getLargestSize.js +17 -0
  114. package/CloudflareImage/utils/getLargestSize.js.map +1 -0
  115. package/CloudflareImage/utils/getSizeForBreakpoint.d.ts +2 -0
  116. package/CloudflareImage/utils/getSizeForBreakpoint.js +16 -0
  117. package/CloudflareImage/utils/getSizeForBreakpoint.js.map +1 -0
  118. package/CloudflareImage/utils/getSizesMap.d.ts +2 -0
  119. package/CloudflareImage/utils/getSizesMap.js +35 -0
  120. package/CloudflareImage/utils/getSizesMap.js.map +1 -0
  121. package/CloudflareImage/utils/getSmallestSize.d.ts +2 -0
  122. package/CloudflareImage/utils/getSmallestSize.js +12 -0
  123. package/CloudflareImage/utils/getSmallestSize.js.map +1 -0
  124. package/CloudflareImage/utils/getSrcSetFromWidths.d.ts +10 -0
  125. package/CloudflareImage/utils/getSrcSetFromWidths.js +10 -0
  126. package/CloudflareImage/utils/getSrcSetFromWidths.js.map +1 -0
  127. package/CloudflareImage/utils/getSrcWithParams.d.ts +3 -0
  128. package/CloudflareImage/utils/getSrcWithParams.js +61 -0
  129. package/CloudflareImage/utils/getSrcWithParams.js.map +1 -0
  130. package/CloudflareImage/utils/paddingForAspectRatio.d.ts +1 -0
  131. package/CloudflareImage/utils/paddingForAspectRatio.js +6 -0
  132. package/CloudflareImage/utils/paddingForAspectRatio.js.map +1 -0
  133. package/CloudflareImage/utils/remToPx.d.ts +1 -0
  134. package/CloudflareImage/utils/remToPx.js +2 -0
  135. package/CloudflareImage/utils/remToPx.js.map +1 -0
  136. package/CloudflareImage/utils/sizeToNumber.d.ts +2 -0
  137. package/CloudflareImage/utils/sizeToNumber.js +27 -0
  138. package/CloudflareImage/utils/sizeToNumber.js.map +1 -0
  139. package/ContentPageLink.d.ts +11 -0
  140. package/ContentPageLink.js +46 -0
  141. package/ContentPageLink.js.map +1 -0
  142. package/ContentRenderer.d.ts +9 -0
  143. package/ContentRenderer.js +36 -0
  144. package/ContentRenderer.js.map +1 -0
  145. package/DropdownMenu/Button.d.ts +7 -0
  146. package/DropdownMenu/Button.js +33 -0
  147. package/DropdownMenu/Button.js.map +1 -0
  148. package/DropdownMenu/DropdownMenu.d.ts +21 -0
  149. package/DropdownMenu/DropdownMenu.js +72 -0
  150. package/DropdownMenu/DropdownMenu.js.map +1 -0
  151. package/DropdownMenu/Item.d.ts +13 -0
  152. package/DropdownMenu/Item.js +48 -0
  153. package/DropdownMenu/Item.js.map +1 -0
  154. package/DropdownMenu/Items.d.ts +16 -0
  155. package/DropdownMenu/Items.js +53 -0
  156. package/DropdownMenu/Items.js.map +1 -0
  157. package/DropdownMenu/index.d.ts +4 -0
  158. package/DropdownMenu/index.js +5 -0
  159. package/DropdownMenu/index.js.map +1 -0
  160. package/ErrorBoundary/Generic.d.ts +18 -0
  161. package/ErrorBoundary/Generic.js +69 -0
  162. package/ErrorBoundary/Generic.js.map +1 -0
  163. package/ErrorBoundary/PassThrough.d.ts +3 -0
  164. package/ErrorBoundary/PassThrough.js +7 -0
  165. package/ErrorBoundary/PassThrough.js.map +1 -0
  166. package/Gallery/Gallery.d.ts +39 -0
  167. package/Gallery/Gallery.js +121 -0
  168. package/Gallery/Gallery.js.map +1 -0
  169. package/Gallery/constructGallery.d.ts +15 -0
  170. package/Gallery/constructGallery.js +40 -0
  171. package/Gallery/constructGallery.js.map +1 -0
  172. package/Image/BaseImage.d.ts +40 -0
  173. package/Image/BaseImage.js +192 -0
  174. package/Image/BaseImage.js.map +1 -0
  175. package/Image/DispatchFlightImage.d.ts +7 -0
  176. package/Image/DispatchFlightImage.js +11 -0
  177. package/Image/DispatchFlightImage.js.map +1 -0
  178. package/Image/Fallback.d.ts +5 -0
  179. package/Image/Fallback.js +4 -0
  180. package/Image/Fallback.js.map +1 -0
  181. package/Image/FlightImage.d.ts +51 -0
  182. package/Image/FlightImage.js +59 -0
  183. package/Image/FlightImage.js.map +1 -0
  184. package/Image/Image.d.ts +2 -0
  185. package/Image/Image.js +3 -0
  186. package/Image/Image.js.map +1 -0
  187. package/Image/index.d.ts +2 -0
  188. package/Image/index.js +3 -0
  189. package/Image/index.js.map +1 -0
  190. package/Image/useConstructImage.d.ts +49 -0
  191. package/Image/useConstructImage.js +122 -0
  192. package/Image/useConstructImage.js.map +1 -0
  193. package/Image/utils/aspectRatioToFraction.d.ts +2 -0
  194. package/Image/utils/aspectRatioToFraction.js +11 -0
  195. package/Image/utils/aspectRatioToFraction.js.map +1 -0
  196. package/Image/utils/getFullUrl.d.ts +6 -0
  197. package/Image/utils/getFullUrl.js +18 -0
  198. package/Image/utils/getFullUrl.js.map +1 -0
  199. package/Image/utils/getImageWidth.d.ts +1 -0
  200. package/Image/utils/getImageWidth.js +12 -0
  201. package/Image/utils/getImageWidth.js.map +1 -0
  202. package/Image/utils/getImageWidths.d.ts +2 -0
  203. package/Image/utils/getImageWidths.js +21 -0
  204. package/Image/utils/getImageWidths.js.map +1 -0
  205. package/Image/utils/getLQIP.d.ts +8 -0
  206. package/Image/utils/getLQIP.js +20 -0
  207. package/Image/utils/getLQIP.js.map +1 -0
  208. package/Image/utils/getLargestSize.d.ts +7 -0
  209. package/Image/utils/getLargestSize.js +17 -0
  210. package/Image/utils/getLargestSize.js.map +1 -0
  211. package/Image/utils/getSizeForBreakpoint.d.ts +2 -0
  212. package/Image/utils/getSizeForBreakpoint.js +16 -0
  213. package/Image/utils/getSizeForBreakpoint.js.map +1 -0
  214. package/Image/utils/getSizesMap.d.ts +2 -0
  215. package/Image/utils/getSizesMap.js +35 -0
  216. package/Image/utils/getSizesMap.js.map +1 -0
  217. package/Image/utils/getSmallestSize.d.ts +2 -0
  218. package/Image/utils/getSmallestSize.js +12 -0
  219. package/Image/utils/getSmallestSize.js.map +1 -0
  220. package/Image/utils/getSrcSetFromWidths.d.ts +10 -0
  221. package/Image/utils/getSrcSetFromWidths.js +9 -0
  222. package/Image/utils/getSrcSetFromWidths.js.map +1 -0
  223. package/Image/utils/getSrcWithParams.d.ts +3 -0
  224. package/Image/utils/getSrcWithParams.js +29 -0
  225. package/Image/utils/getSrcWithParams.js.map +1 -0
  226. package/Image/utils/paddingForAspectRatio.d.ts +1 -0
  227. package/Image/utils/paddingForAspectRatio.js +6 -0
  228. package/Image/utils/paddingForAspectRatio.js.map +1 -0
  229. package/Image/utils/remToPx.d.ts +1 -0
  230. package/Image/utils/remToPx.js +2 -0
  231. package/Image/utils/remToPx.js.map +1 -0
  232. package/Image/utils/sizeToNumber.d.ts +2 -0
  233. package/Image/utils/sizeToNumber.js +27 -0
  234. package/Image/utils/sizeToNumber.js.map +1 -0
  235. package/Input/Input.d.ts +6 -0
  236. package/Input/Input.js +45 -0
  237. package/Input/Input.js.map +1 -0
  238. package/Input/index.d.ts +3 -0
  239. package/Input/index.js +4 -0
  240. package/Input/index.js.map +1 -0
  241. package/JetshopText.d.ts +3 -0
  242. package/JetshopText.js +13 -0
  243. package/JetshopText.js.map +1 -0
  244. package/Loading/LoadingBar.d.ts +8 -0
  245. package/Loading/LoadingBar.js +58 -0
  246. package/Loading/LoadingBar.js.map +1 -0
  247. package/Loading/LoadingLine.d.ts +31 -0
  248. package/Loading/LoadingLine.js +26 -0
  249. package/Loading/LoadingLine.js.map +1 -0
  250. package/Loading/NetworkStatusNotifier.d.ts +6 -0
  251. package/Loading/NetworkStatusNotifier.js +8 -0
  252. package/Loading/NetworkStatusNotifier.js.map +1 -0
  253. package/Menu/MenuContainer.d.ts +28 -0
  254. package/Menu/MenuContainer.js +46 -0
  255. package/Menu/MenuContainer.js.map +1 -0
  256. package/Menu/RecursiveTree.d.ts +28 -0
  257. package/Menu/RecursiveTree.js +91 -0
  258. package/Menu/RecursiveTree.js.map +1 -0
  259. package/Modal/Drawer/Drawer.d.ts +12 -0
  260. package/Modal/Drawer/Drawer.js +31 -0
  261. package/Modal/Drawer/Drawer.js.map +1 -0
  262. package/Modal/Drawer/DrawerTarget.d.ts +6 -0
  263. package/Modal/Drawer/DrawerTarget.js +12 -0
  264. package/Modal/Drawer/DrawerTarget.js.map +1 -0
  265. package/Modal/Drawer/DrawerTrigger.d.ts +11 -0
  266. package/Modal/Drawer/DrawerTrigger.js +16 -0
  267. package/Modal/Drawer/DrawerTrigger.js.map +1 -0
  268. package/Modal/Drawer/index.d.ts +3 -0
  269. package/Modal/Drawer/index.js +4 -0
  270. package/Modal/Drawer/index.js.map +1 -0
  271. package/Modal/Flyout/FlyoutTarget.d.ts +10 -0
  272. package/Modal/Flyout/FlyoutTarget.js +15 -0
  273. package/Modal/Flyout/FlyoutTarget.js.map +1 -0
  274. package/Modal/Flyout/FlyoutTrigger.d.ts +15 -0
  275. package/Modal/Flyout/FlyoutTrigger.js +18 -0
  276. package/Modal/Flyout/FlyoutTrigger.js.map +1 -0
  277. package/Modal/Flyout/index.d.ts +2 -0
  278. package/Modal/Flyout/index.js +3 -0
  279. package/Modal/Flyout/index.js.map +1 -0
  280. package/Modal/ModalContext.d.ts +26 -0
  281. package/Modal/ModalContext.js +9 -0
  282. package/Modal/ModalContext.js.map +1 -0
  283. package/Modal/ModalProvider.d.ts +5 -0
  284. package/Modal/ModalProvider.js +83 -0
  285. package/Modal/ModalProvider.js.map +1 -0
  286. package/Modal/ModalRoot.d.ts +3 -0
  287. package/Modal/ModalRoot.js +44 -0
  288. package/Modal/ModalRoot.js.map +1 -0
  289. package/Modal/ModalTrigger.d.ts +9 -0
  290. package/Modal/ModalTrigger.js +9 -0
  291. package/Modal/ModalTrigger.js.map +1 -0
  292. package/Pagination/Pagination.d.ts +7 -0
  293. package/Pagination/Pagination.js +23 -0
  294. package/Pagination/Pagination.js.map +1 -0
  295. package/Pagination/PaginationBehaviour.d.ts +52 -0
  296. package/Pagination/PaginationBehaviour.js +68 -0
  297. package/Pagination/PaginationBehaviour.js.map +1 -0
  298. package/Pagination/index.d.ts +2 -0
  299. package/Pagination/index.js +3 -0
  300. package/Pagination/index.js.map +1 -0
  301. package/Pagination/usePagination.d.ts +15 -0
  302. package/Pagination/usePagination.js +46 -0
  303. package/Pagination/usePagination.js.map +1 -0
  304. package/PreOrderDateSelector/PreOrderDateSelector.d.ts +23 -0
  305. package/PreOrderDateSelector/PreOrderDateSelector.js +74 -0
  306. package/PreOrderDateSelector/PreOrderDateSelector.js.map +1 -0
  307. package/PreOrderDateSelector/index.d.ts +2 -0
  308. package/PreOrderDateSelector/index.js +3 -0
  309. package/PreOrderDateSelector/index.js.map +1 -0
  310. package/Price/Currency.d.ts +9 -0
  311. package/Price/Currency.js +11 -0
  312. package/Price/Currency.js.map +1 -0
  313. package/Price/Price.d.ts +44 -0
  314. package/Price/Price.js +74 -0
  315. package/Price/Price.js.map +1 -0
  316. package/Price/index.d.ts +1 -0
  317. package/Price/index.js +2 -0
  318. package/Price/index.js.map +1 -0
  319. package/ProductLink.d.ts +23 -0
  320. package/ProductLink.js +88 -0
  321. package/ProductLink.js.map +1 -0
  322. package/ProductList/Badges.d.ts +6 -0
  323. package/ProductList/Badges.js +56 -0
  324. package/ProductList/Badges.js.map +1 -0
  325. package/ProductList/GridProduct.d.ts +24 -0
  326. package/ProductList/GridProduct.js +58 -0
  327. package/ProductList/GridProduct.js.map +1 -0
  328. package/ProductList/ProductGrid.d.ts +16 -0
  329. package/ProductList/ProductGrid.js +30 -0
  330. package/ProductList/ProductGrid.js.map +1 -0
  331. package/ProductList/ProductImage.d.ts +12 -0
  332. package/ProductList/ProductImage.js +21 -0
  333. package/ProductList/ProductImage.js.map +1 -0
  334. package/ProductSpecifications/ProductSpecifications.d.ts +8 -0
  335. package/ProductSpecifications/ProductSpecifications.js +78 -0
  336. package/ProductSpecifications/ProductSpecifications.js.map +1 -0
  337. package/ScrollRestorationHandler/ScrollRestorationHandler.d.ts +8 -0
  338. package/ScrollRestorationHandler/ScrollRestorationHandler.js +17 -0
  339. package/ScrollRestorationHandler/ScrollRestorationHandler.js.map +1 -0
  340. package/ScrollRestorationHandler/index.d.ts +1 -0
  341. package/ScrollRestorationHandler/index.js +2 -0
  342. package/ScrollRestorationHandler/index.js.map +1 -0
  343. package/ScrollRestorationHandler/isInIgnoredRouteTypes.d.ts +8 -0
  344. package/ScrollRestorationHandler/isInIgnoredRouteTypes.js +8 -0
  345. package/ScrollRestorationHandler/isInIgnoredRouteTypes.js.map +1 -0
  346. package/ScrollRestorationHandler/useScrollRestore.d.ts +9 -0
  347. package/ScrollRestorationHandler/useScrollRestore.js +20 -0
  348. package/ScrollRestorationHandler/useScrollRestore.js.map +1 -0
  349. package/Search/SearchAutoCompleteContainer.d.ts +45 -0
  350. package/Search/SearchAutoCompleteContainer.js +172 -0
  351. package/Search/SearchAutoCompleteContainer.js.map +1 -0
  352. package/Search/SearchField.d.ts +26 -0
  353. package/Search/SearchField.js +98 -0
  354. package/Search/SearchField.js.map +1 -0
  355. package/Search/SearchPage/PageOf.d.ts +5 -0
  356. package/Search/SearchPage/PageOf.js +7 -0
  357. package/Search/SearchPage/PageOf.js.map +1 -0
  358. package/Search/SearchPage/SearchMeta.d.ts +16 -0
  359. package/Search/SearchPage/SearchMeta.js +20 -0
  360. package/Search/SearchPage/SearchMeta.js.map +1 -0
  361. package/Search/SearchPage/SearchPageBehaviour.d.ts +19 -0
  362. package/Search/SearchPage/SearchPageBehaviour.js +75 -0
  363. package/Search/SearchPage/SearchPageBehaviour.js.map +1 -0
  364. package/Search/SuggestedTerm.d.ts +16 -0
  365. package/Search/SuggestedTerm.js +35 -0
  366. package/Search/SuggestedTerm.js.map +1 -0
  367. package/Search/index.d.ts +1 -0
  368. package/Search/index.js +2 -0
  369. package/Search/index.js.map +1 -0
  370. package/Select/Components.d.ts +28 -0
  371. package/Select/Components.js +91 -0
  372. package/Select/Components.js.map +1 -0
  373. package/Select/SelectComponents/Quantity.d.ts +5 -0
  374. package/Select/SelectComponents/Quantity.js +8 -0
  375. package/Select/SelectComponents/Quantity.js.map +1 -0
  376. package/Select/index.d.ts +5 -0
  377. package/Select/index.js +2 -0
  378. package/Select/index.js.map +1 -0
  379. package/SortOrder/SortOrder.d.ts +16 -0
  380. package/SortOrder/SortOrder.js +33 -0
  381. package/SortOrder/SortOrder.js.map +1 -0
  382. package/SortOrder/SortOrderDropdown.d.ts +9 -0
  383. package/SortOrder/SortOrderDropdown.js +25 -0
  384. package/SortOrder/SortOrderDropdown.js.map +1 -0
  385. package/SortOrder/SortOrderList.d.ts +7 -0
  386. package/SortOrder/SortOrderList.js +17 -0
  387. package/SortOrder/SortOrderList.js.map +1 -0
  388. package/StartPageRenderer/StartPageRenderer.d.ts +17 -0
  389. package/StartPageRenderer/StartPageRenderer.js +52 -0
  390. package/StartPageRenderer/StartPageRenderer.js.map +1 -0
  391. package/StartPageRenderer/index.d.ts +1 -0
  392. package/StartPageRenderer/index.js +2 -0
  393. package/StartPageRenderer/index.js.map +1 -0
  394. package/Stock/StockStatusContainer.d.ts +21 -0
  395. package/Stock/StockStatusContainer.js +45 -0
  396. package/Stock/StockStatusContainer.js.map +1 -0
  397. package/Text/Text.d.ts +11 -0
  398. package/Text/Text.js +22 -0
  399. package/Text/Text.js.map +1 -0
  400. package/Text/index.d.ts +3 -0
  401. package/Text/index.js +4 -0
  402. package/Text/index.js.map +1 -0
  403. package/Theme/createTheme.d.ts +16 -0
  404. package/Theme/createTheme.js +5 -0
  405. package/Theme/createTheme.js.map +1 -0
  406. package/Theme/cssReset.d.ts +1 -0
  407. package/Theme/cssReset.js +160 -0
  408. package/Theme/cssReset.js.map +1 -0
  409. package/Theme/normalizeCss.d.ts +1 -0
  410. package/Theme/normalizeCss.js +357 -0
  411. package/Theme/normalizeCss.js.map +1 -0
  412. package/Theme/sanitizeCss.d.ts +1 -0
  413. package/Theme/sanitizeCss.js +572 -0
  414. package/Theme/sanitizeCss.js.map +1 -0
  415. package/WindowGrid/WindowGrid.d.ts +11 -0
  416. package/WindowGrid/WindowGrid.js +58 -0
  417. package/WindowGrid/WindowGrid.js.map +1 -0
  418. package/WindowGrid/index.d.ts +1 -0
  419. package/WindowGrid/index.js +2 -0
  420. package/WindowGrid/index.js.map +1 -0
  421. package/WindowGrid/useResizeObserver.d.ts +3 -0
  422. package/WindowGrid/useResizeObserver.js +14 -0
  423. package/WindowGrid/useResizeObserver.js.map +1 -0
  424. package/WindowGrid/useScrollWithWindow.d.ts +12 -0
  425. package/WindowGrid/useScrollWithWindow.js +39 -0
  426. package/WindowGrid/useScrollWithWindow.js.map +1 -0
  427. package/fuzzySearch/fuzzySearch.d.ts +8 -0
  428. package/fuzzySearch/fuzzySearch.js +43 -0
  429. package/fuzzySearch/fuzzySearch.js.map +1 -0
  430. package/fuzzySearch/index.d.ts +1 -0
  431. package/fuzzySearch/index.js +2 -0
  432. package/fuzzySearch/index.js.map +1 -0
  433. package/hooks/index.d.ts +2 -0
  434. package/hooks/index.js +3 -0
  435. package/hooks/index.js.map +1 -0
  436. package/hooks/useOnClickOutside.d.ts +6 -0
  437. package/hooks/useOnClickOutside.js +17 -0
  438. package/hooks/useOnClickOutside.js.map +1 -0
  439. package/hooks/useOnEsc.d.ts +4 -0
  440. package/hooks/useOnEsc.js +17 -0
  441. package/hooks/useOnEsc.js.map +1 -0
  442. package/package.json +3 -2
  443. package/utils/breakpoints.d.ts +23 -0
  444. package/utils/breakpoints.js +94 -0
  445. package/utils/breakpoints.js.map +1 -0
  446. package/utils/callAllEventHandlers.d.ts +5 -0
  447. package/utils/callAllEventHandlers.js +9 -0
  448. package/utils/callAllEventHandlers.js.map +1 -0
  449. package/utils/text.d.ts +1 -0
  450. package/utils/text.js +23 -0
  451. package/utils/text.js.map +1 -0
  452. package/utils/theme.d.ts +3 -0
  453. package/utils/theme.js +5 -0
  454. package/utils/theme.js.map +1 -0
  455. package/utils/useHoverIntent.d.ts +10 -0
  456. package/utils/useHoverIntent.js +78 -0
  457. package/utils/useHoverIntent.js.map +1 -0
  458. package/utils/usePropsOfType.d.ts +11 -0
  459. package/utils/usePropsOfType.js +18 -0
  460. package/utils/usePropsOfType.js.map +1 -0
  461. package/withFlightUI.d.ts +17 -0
  462. package/withFlightUI.js +20 -0
  463. package/withFlightUI.js.map +1 -0
@@ -0,0 +1,9 @@
1
+ import { Location } from 'history';
2
+ import { routeType } from './ScrollRestorationHandler';
3
+ export declare function useScrollRestore({ location, ignoreForRouteTypes, prevLocation }: {
4
+ location: Location<{
5
+ type?: any;
6
+ }>;
7
+ prevLocation: Location;
8
+ ignoreForRouteTypes?: routeType[];
9
+ }): void;
@@ -0,0 +1,20 @@
1
+ import { useEffect } from 'react';
2
+ import { isInIgnoredRouteTypes } from './isInIgnoredRouteTypes';
3
+ export function useScrollRestore({ location, ignoreForRouteTypes, prevLocation }) {
4
+ useEffect(() => {
5
+ if (ignoreForRouteTypes &&
6
+ isInIgnoredRouteTypes({ location, routeTypes: ignoreForRouteTypes })) {
7
+ return;
8
+ }
9
+ if (!prevLocation && location.hash !== '') {
10
+ return;
11
+ }
12
+ if (prevLocation &&
13
+ prevLocation.pathname === location.pathname &&
14
+ prevLocation.search === location.search) {
15
+ return;
16
+ }
17
+ window.scrollTo(0, 0);
18
+ }, [ignoreForRouteTypes, location, prevLocation]);
19
+ }
20
+ //# sourceMappingURL=useScrollRestore.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useScrollRestore.js","sourceRoot":"","sources":["useScrollRestore.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAElC,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAEhE,MAAM,UAAU,gBAAgB,CAAC,EAC/B,QAAQ,EACR,mBAAmB,EACnB,YAAY,EAKb;IACC,SAAS,CAAC,GAAG,EAAE;QACb,IACE,mBAAmB;YACnB,qBAAqB,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,mBAAmB,EAAE,CAAC,EACpE;YACA,OAAO;SACR;QAED,IAAI,CAAC,YAAY,IAAI,QAAQ,CAAC,IAAI,KAAK,EAAE,EAAE;YACzC,OAAO;SACR;QAED,IACE,YAAY;YACZ,YAAY,CAAC,QAAQ,KAAK,QAAQ,CAAC,QAAQ;YAC3C,YAAY,CAAC,MAAM,KAAK,QAAQ,CAAC,MAAM,EACvC;YACA,OAAO;SACR;QAED,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxB,CAAC,EAAE,CAAC,mBAAmB,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC;AACpD,CAAC"}
@@ -0,0 +1,45 @@
1
+ import { SearchResult } from '@jetshop/core/types';
2
+ import { DocumentNode } from 'graphql';
3
+ import * as React from 'react';
4
+ import { RouteComponentProps } from 'react-router-dom';
5
+ export interface Events {
6
+ onClick?: React.MouseEventHandler<HTMLElement>;
7
+ onBlur?: React.FocusEventHandler<FocusEvent>;
8
+ onFocus?: React.FocusEventHandler<FocusEvent>;
9
+ }
10
+ export interface RenderFnProps extends SearchFieldState {
11
+ getInputProps: (args?: Pick<Events, 'onBlur' | 'onFocus'>) => {};
12
+ getCancelProps: (args?: Pick<Events, 'onClick'>) => {};
13
+ getFlyoutProps: (args?: any) => {};
14
+ updateFocus: (args: 'focus' | 'blur') => void;
15
+ result: SearchResult;
16
+ loading: boolean;
17
+ inputRef: React.Ref<HTMLInputElement>;
18
+ triggerSearch(term: string): void;
19
+ }
20
+ export interface SearchFieldProps {
21
+ /** Initial value for the search field */
22
+ initialValue: string;
23
+ /** Optional function to call when cancel button is clicked */
24
+ onCancel?: () => void;
25
+ /** Optional function to call when the search is submitted */
26
+ onSubmit?: (term: string) => void;
27
+ /** Whether to focus the search input on first mount */
28
+ focusOnLoad?: boolean;
29
+ /** Query to perform the autocomplete search */
30
+ autocompleteQuery: DocumentNode;
31
+ /** Internals */
32
+ children: (args: RenderFnProps) => JSX.Element;
33
+ }
34
+ export interface SearchFieldState {
35
+ /** Whether or not the search term has been edited since render */
36
+ isDirty: boolean;
37
+ /** The search term string */
38
+ term: string;
39
+ /** The debounced search term string used for the query */
40
+ debouncedTerm: string;
41
+ /** Whether the search field is open */
42
+ isOpen: boolean;
43
+ }
44
+ declare const _default: React.ComponentClass<Pick<SearchFieldProps & RouteComponentProps<{}, import("react-router").StaticContext, unknown>, keyof SearchFieldProps>, any> & import("react-router").WithRouterStatics<(props: SearchFieldProps & RouteComponentProps<{}, import("react-router").StaticContext, unknown>) => React.JSX.Element>;
45
+ export default _default;
@@ -0,0 +1,172 @@
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 { useShopConfig } from '@jetshop/core/hooks/useShopConfig';
13
+ import debounce from 'lodash.debounce';
14
+ import * as React from 'react';
15
+ import { Query } from '@apollo/client/react/components';
16
+ import { withRouter } from 'react-router-dom';
17
+ import { callAllEventHandlers } from '../utils/callAllEventHandlers';
18
+ class SearchFieldBehaviour extends React.Component {
19
+ constructor() {
20
+ super(...arguments);
21
+ this.inputRef = React.createRef();
22
+ this.flyoutRef = React.createRef();
23
+ this.cleanup = () => { };
24
+ this._isMounted = false;
25
+ this.initialState = {
26
+ isDirty: false,
27
+ term: this.props.initialValue,
28
+ debouncedTerm: this.props.initialValue,
29
+ isOpen: false
30
+ };
31
+ this.environment = typeof window === 'undefined' ? null : window;
32
+ this.state = this.initialState;
33
+ this.getInputProps = (_a = {}) => {
34
+ var { onBlur, onFocus, refKey = 'ref' } = _a, rest = __rest(_a, ["onBlur", "onFocus", "refKey"]);
35
+ const { updateSearch, handleBlur, handleFocus, handleEnterSubmit, inputRef } = this;
36
+ const { term } = this.state;
37
+ return Object.assign({ onChange: updateSearch, onBlur: callAllEventHandlers(onBlur, handleBlur), onFocus: callAllEventHandlers(onFocus, handleFocus), onKeyDown: callAllEventHandlers(handleEnterSubmit), [refKey]: inputRef, autoComplete: 'off', value: term, type: 'search' }, rest
38
+ // TODO: add an ID via props or generate one
39
+ // TODO: add ARIA labels
40
+ );
41
+ };
42
+ this.getFlyoutProps = ({ refKey = 'ref', rest } = {}) => {
43
+ const { flyoutRef } = this;
44
+ return Object.assign({ [refKey]: flyoutRef }, rest);
45
+ };
46
+ this.getCancelProps = (_a = {}) => {
47
+ var { onClick } = _a, rest = __rest(_a, ["onClick"]);
48
+ const { clearSearch } = this;
49
+ const { onCancel } = this.props;
50
+ return Object.assign({ onClick: callAllEventHandlers(onClick, onCancel, clearSearch) }, rest);
51
+ };
52
+ this.resetIfEmpty = (e) => {
53
+ if (e.currentTarget.value === this.props.initialValue) {
54
+ this.clearSearch();
55
+ }
56
+ };
57
+ this.handleBlur = (e, cb) => {
58
+ this.resetIfEmpty(e);
59
+ cb && typeof cb === 'function' && cb();
60
+ return true;
61
+ };
62
+ this.handleEnterSubmit = (e) => {
63
+ // First check that the key pressed was Enter, and then
64
+ // call the onSubmit callback. We always call triggerSearch,
65
+ // but the user has an opportunity to pass an onSubmit handler
66
+ // as a prop
67
+ const { term } = this.state;
68
+ if (e.key === 'Enter') {
69
+ this.triggerSearch(term);
70
+ }
71
+ };
72
+ this.triggerSearch = (term = this.state.term) => {
73
+ // Blur the input, close the search and navigate to the search page
74
+ this.setState({ isOpen: false });
75
+ this.debouncedUpdateTerm.cancel();
76
+ if (typeof this.props.onSubmit === 'function')
77
+ this.props.onSubmit(term);
78
+ this.props.history.push(`${this.props.routes.search.path}/?term=${term}`);
79
+ this.updateFocus('blur');
80
+ };
81
+ this.handleFocus = (_e, cb) => {
82
+ this.setState({ isOpen: true });
83
+ cb && typeof cb === 'function' && cb();
84
+ return true;
85
+ };
86
+ this.updateFocus = (focusState) => {
87
+ if (!['blur', 'focus'].includes(focusState)) {
88
+ throw new Error("updateFocus must be called with one of 'blur' | 'focus'");
89
+ }
90
+ const shouldHaveFocus = focusState === 'focus';
91
+ const DOMElementHasFocus = document.activeElement === this.inputRef.current;
92
+ // Trigger a blur or focus on the input
93
+ shouldHaveFocus && !DOMElementHasFocus && this.inputRef.current.focus();
94
+ !shouldHaveFocus && DOMElementHasFocus && this.inputRef.current.blur();
95
+ return true;
96
+ };
97
+ this.debouncedUpdateTerm = debounce((term) => this._isMounted && this.setState({ debouncedTerm: term }), 200);
98
+ this.updateSearch = (e) => {
99
+ const term = e.currentTarget.value;
100
+ const isDirty = term !== this.props.initialValue;
101
+ this.debouncedUpdateTerm(term);
102
+ this.setState({
103
+ term,
104
+ isDirty
105
+ });
106
+ };
107
+ this.clearSearch = () => {
108
+ this.setState(this.initialState);
109
+ };
110
+ }
111
+ componentDidMount() {
112
+ this._isMounted = true;
113
+ const targetIsInside = (target) => [this.flyoutRef, this.inputRef].some((node) => node &&
114
+ node.current &&
115
+ (node.current === target || node.current.contains(target)));
116
+ const onMouseUp = (event) => {
117
+ if (!targetIsInside(event.target)) {
118
+ this.handleBlur(event);
119
+ this.setState({ isOpen: false });
120
+ }
121
+ };
122
+ const onTouchStart = (event) => {
123
+ if (!targetIsInside(event.target)) {
124
+ this.handleBlur(event);
125
+ this.setState({ isOpen: false });
126
+ }
127
+ };
128
+ if (this.environment) {
129
+ this.environment.addEventListener('mouseup', onMouseUp);
130
+ this.environment.addEventListener('touchstart', onTouchStart);
131
+ }
132
+ if (this.props.focusOnLoad) {
133
+ this.updateFocus('focus');
134
+ }
135
+ this.cleanup = () => {
136
+ if (this.environment) {
137
+ this.environment.removeEventListener('mouseup', onMouseUp);
138
+ this.environment.removeEventListener('touchstart', onTouchStart);
139
+ }
140
+ };
141
+ }
142
+ componentWillUnmount() {
143
+ this._isMounted = false;
144
+ this.cleanup();
145
+ }
146
+ componentDidUpdate(prevProps) {
147
+ const { pathname } = this.props.location;
148
+ const locationPath = pathname.substr(-1) !== '/'
149
+ ? pathname
150
+ : pathname.substr(0, pathname.length - 1);
151
+ if (this.props.location.pathname !== prevProps.location.pathname &&
152
+ locationPath !== this.props.routes.search.path)
153
+ this.props.onCancel();
154
+ }
155
+ render() {
156
+ return (React.createElement(Query, { context: { useApolloNetworkStatus: false }, skip: !this.state.isDirty ||
157
+ this.state.debouncedTerm === this.props.initialValue, variables: { term: this.state.debouncedTerm }, errorPolicy: "ignore", query: this.props.autocompleteQuery }, ({ loading, data }) => {
158
+ return this.props.children(Object.assign({ getInputProps: this.getInputProps, getCancelProps: this.getCancelProps, getFlyoutProps: this.getFlyoutProps, loading: loading || this.state.term !== this.state.debouncedTerm, isOpen: this.state.isOpen, updateFocus: this.updateFocus, result: data === null || data === void 0 ? void 0 : data.searchAutoComplete, inputRef: this.inputRef, triggerSearch: this.triggerSearch }, this.state));
159
+ }));
160
+ }
161
+ }
162
+ SearchFieldBehaviour.defaultProps = {
163
+ initialValue: '',
164
+ focusOnLoad: false
165
+ };
166
+ // If SearchFieldBehaviour is refactored to use hooks, then this can be moved inside there
167
+ const SearchFieldBehaviourWrapper = (props) => {
168
+ const { routes } = useShopConfig();
169
+ return React.createElement(SearchFieldBehaviour, Object.assign({}, props, { routes: routes }));
170
+ };
171
+ export default withRouter(SearchFieldBehaviourWrapper);
172
+ //# sourceMappingURL=SearchAutoCompleteContainer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SearchAutoCompleteContainer.js","sourceRoot":"","sources":["SearchAutoCompleteContainer.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import { DocumentNode } from 'graphql';
2
+ import * as React from 'react';
3
+ export interface SearchFieldProps {
4
+ initialValue: string;
5
+ className?: string;
6
+ placeholder?: string;
7
+ autocompleteQuery: DocumentNode;
8
+ focusOnLoad?: boolean;
9
+ }
10
+ export interface SearchFieldCompound {
11
+ Flyout?: React.ReactNode;
12
+ Wrapper?: React.ReactNode;
13
+ Cancel?: React.ReactNode;
14
+ }
15
+ declare const _default: React.SFC<SearchFieldProps> & SearchFieldCompound & {
16
+ Flyout: import("linaria/lib/StyledMeta").StyledMeta & React.FunctionComponent<React.ClassAttributes<HTMLDivElement> & React.HTMLAttributes<HTMLDivElement> & {
17
+ as?: React.ElementType<any>;
18
+ }>;
19
+ Wrapper: import("linaria/lib/StyledMeta").StyledMeta & React.FunctionComponent<React.ClassAttributes<HTMLDivElement> & React.HTMLAttributes<HTMLDivElement> & {
20
+ as?: React.ElementType<any>;
21
+ }>;
22
+ Cancel: import("linaria/lib/StyledMeta").StyledMeta & React.FunctionComponent<React.ClassAttributes<HTMLButtonElement> & React.ButtonHTMLAttributes<HTMLButtonElement> & {
23
+ as?: React.ElementType<any>;
24
+ }>;
25
+ };
26
+ export default _default;
@@ -0,0 +1,98 @@
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 throwErrorInDev from '@jetshop/core/helpers/throwErrorInDev';
13
+ import t from '@jetshop/intl';
14
+ import { FlyoutTarget, FlyoutTrigger } from '@jetshop/ui/Modal/Flyout';
15
+ import SuggestedTerm from '@jetshop/ui/Search/SuggestedTerm';
16
+ import * as React from 'react';
17
+ import { styled } from 'linaria/react';
18
+ import { css } from 'linaria';
19
+ import SearchAutoCompleteContainer from './SearchAutoCompleteContainer';
20
+ const Wrapper = styled('div') `
21
+ display: flex;
22
+ margin: 0 auto;
23
+ justify-content: center;
24
+ align-items: center;
25
+ `;
26
+ const SearchFieldWrapper = styled('div') `
27
+ width: 12rem;
28
+ position: relative;
29
+ font-size: 16px;
30
+ font-weight: normal;
31
+ `;
32
+ const Flyout = styled('div') `
33
+ position: absolute;
34
+ background: white;
35
+ z-index: 999;
36
+ border: 1px solid #e8e8e8;
37
+ width: 100%;
38
+ top: 2rem;
39
+ left: 0;
40
+ `;
41
+ const CancelButton = styled('button') `
42
+ font-size: 0.875rem;
43
+ border: 0;
44
+ background: transparent;
45
+ color: #878787;
46
+ margin-left: 1rem;
47
+ `;
48
+ const resultStyles = css `
49
+ ul + h2 {
50
+ margin-top: 1em;
51
+ }
52
+ `;
53
+ const SearchResults = ({ term, result, loading, onClick }) => {
54
+ const products = result === null || result === void 0 ? void 0 : result.products;
55
+ const categories = result === null || result === void 0 ? void 0 : result.categories;
56
+ if (!loading &&
57
+ (products === null || products === void 0 ? void 0 : products.result.length) === 0 &&
58
+ (categories === null || categories === void 0 ? void 0 : categories.result.length) === 0) {
59
+ return null;
60
+ }
61
+ return (React.createElement("div", { className: resultStyles },
62
+ (products === null || products === void 0 ? void 0 : products.result.length) > 0 && (React.createElement(React.Fragment, null,
63
+ React.createElement("h2", null, t('Products')),
64
+ React.createElement("ul", { style: loading ? { opacity: 0.5 } : null }, products.result.map((item) => (React.createElement(SuggestedTerm, { term: term, onClick: onClick, key: item.id, item: item })))))),
65
+ (categories === null || categories === void 0 ? void 0 : categories.result.length) > 0 && (React.createElement(React.Fragment, null,
66
+ React.createElement("h2", null, t('Categories')),
67
+ React.createElement("ul", { style: loading ? { opacity: 0.5 } : null }, categories.result.map((item) => (React.createElement(SuggestedTerm, { term: term, onClick: onClick, key: item.id, item: item }))))))));
68
+ };
69
+ const SearchField = (_a) => {
70
+ var { initialValue, className, placeholder = '', autocompleteQuery, focusOnLoad = true } = _a, rest = __rest(_a, ["initialValue", "className", "placeholder", "autocompleteQuery", "focusOnLoad"]);
71
+ throwErrorInDev(!autocompleteQuery, `You forgot to pass 'autocompleteQuery' to SearchField`);
72
+ return (React.createElement(SearchAutoCompleteContainer, Object.assign({ autocompleteQuery: autocompleteQuery, initialValue: initialValue, focusOnLoad: focusOnLoad }, rest), (searchField) => (React.createElement(Wrapper, { className: className, "data-flight-searchfield": "" },
73
+ React.createElement(SearchFieldWrapper, null,
74
+ React.createElement(FlyoutTrigger, { showCover: false, id: "searchFlyout" }, ({ showTarget, hideTarget }) => (React.createElement(React.Fragment, null,
75
+ React.createElement("input", Object.assign({ placeholder: placeholder }, searchField.getInputProps({
76
+ onFocus: showTarget
77
+ }), { "data-flight-search-autocomplete-field": "" })),
78
+ React.createElement(CancelButton, Object.assign({}, searchField.getCancelProps({ onClick: hideTarget }), { "data-flight-searchfield-cancel": true }), t('Cancel'))))),
79
+ React.createElement(FlyoutTarget, { id: "searchFlyout" }, (flyout) => {
80
+ var _a, _b, _c, _d;
81
+ const hasResults = ((_b = (_a = searchField.result) === null || _a === void 0 ? void 0 : _a.products) === null || _b === void 0 ? void 0 : _b.result.length) > 0 ||
82
+ ((_d = (_c = searchField.result) === null || _c === void 0 ? void 0 : _c.categories) === null || _d === void 0 ? void 0 : _d.result.length) > 0;
83
+ const { loading, isDirty, isOpen } = searchField;
84
+ const showFlyout = isDirty && !loading && hasResults && isOpen && flyout.isOpen;
85
+ if (showFlyout) {
86
+ return (React.createElement(Flyout, { "data-flight-searchfield-flyout": true },
87
+ React.createElement("div", Object.assign({}, searchField.getFlyoutProps()), searchField.isDirty && (React.createElement(React.Fragment, null,
88
+ React.createElement(SearchResults, { term: searchField.term, result: searchField.result, onClick: flyout.hideTarget, loading: searchField.loading }))))));
89
+ }
90
+ return null;
91
+ }))))));
92
+ };
93
+ export default Object.assign(SearchField, {
94
+ Flyout,
95
+ Wrapper: SearchFieldWrapper,
96
+ Cancel: CancelButton
97
+ });
98
+ //# sourceMappingURL=SearchField.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SearchField.js","sourceRoot":"","sources":["SearchField.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ export declare const PageOf: ({ page, pages }: {
3
+ page: number;
4
+ pages: number;
5
+ }) => React.JSX.Element;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ export const PageOf = ({ page, pages }) => (React.createElement("div", null,
3
+ "Page ",
4
+ page,
5
+ " of ",
6
+ pages));
7
+ //# sourceMappingURL=PageOf.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PageOf.js","sourceRoot":"","sources":["PageOf.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAmC,EAAE,EAAE,CAAC,CAC1E;;IACQ,IAAI;;IAAM,KAAK,CACjB,CACP,CAAC"}
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ export interface ISearchMetaProps {
3
+ total: number;
4
+ page: number;
5
+ pages: number;
6
+ className?: string;
7
+ }
8
+ export declare const SearchMetaWrapper: import("linaria/lib/StyledMeta").StyledMeta & React.FunctionComponent<React.ClassAttributes<HTMLElement> & React.HTMLAttributes<HTMLElement> & {
9
+ as?: React.ElementType<any>;
10
+ }>;
11
+ declare class SearchMeta extends React.PureComponent<ISearchMetaProps & {
12
+ className?: string;
13
+ }, any> {
14
+ render(): React.JSX.Element;
15
+ }
16
+ export default SearchMeta;
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import { styled } from 'linaria/react';
3
+ import { PageOf } from './PageOf';
4
+ export const SearchMetaWrapper = styled('aside') `
5
+ display: flex;
6
+ justify-content: space-between;
7
+ padding: 1rem 0;
8
+ `;
9
+ class SearchMeta extends React.PureComponent {
10
+ render() {
11
+ const { total, page, pages, className = '' } = this.props;
12
+ return (React.createElement(SearchMetaWrapper, { className: className },
13
+ React.createElement("header", null,
14
+ total,
15
+ " items"),
16
+ React.createElement(PageOf, { page: page, pages: pages })));
17
+ }
18
+ }
19
+ export default SearchMeta;
20
+ //# sourceMappingURL=SearchMeta.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SearchMeta.js","sourceRoot":"","sources":["SearchMeta.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AASlC,MAAM,CAAC,MAAM,iBAAiB,GAAG,MAAM,CAAC,OAAO,CAAC,CAAA;;;;CAI/C,CAAC;AAEF,MAAM,UAAW,SAAQ,KAAK,CAAC,aAG9B;IACQ,MAAM;QACX,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QAE1D,OAAO,CACL,oBAAC,iBAAiB,IAAC,SAAS,EAAE,SAAS;YACrC;gBAAS,KAAK;yBAAgB;YAC9B,oBAAC,MAAM,IAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,GAAI,CAClB,CACrB,CAAC;IACJ,CAAC;CACF;AAED,eAAe,UAAU,CAAC"}
@@ -0,0 +1,19 @@
1
+ import { ApolloError } from '@apollo/client';
2
+ import { DocumentNode } from 'graphql';
3
+ import * as React from 'react';
4
+ export interface SearchPageRenderProps {
5
+ result: object;
6
+ filters: object;
7
+ total: number;
8
+ term: string;
9
+ loading: boolean;
10
+ error: ApolloError;
11
+ }
12
+ export interface SearchPageProps {
13
+ children(props: SearchPageRenderProps): React.ReactElement;
14
+ /** Query to perform the search */
15
+ searchQuery: DocumentNode;
16
+ location: Location;
17
+ }
18
+ declare const SearchPageBehaviour: React.FC<SearchPageProps>;
19
+ export default SearchPageBehaviour;
@@ -0,0 +1,75 @@
1
+ import ActiveFiltersQuery from '@jetshop/core/components/DynamicRoute/ActiveFiltersQuery.gql';
2
+ import PaginationContext from '@jetshop/core/components/Pagination/PaginationContext';
3
+ import PaginationProvider, { usePagination } from '@jetshop/core/components/Pagination/PaginationProvider';
4
+ import throwErrorInDev from '@jetshop/core/helpers/throwErrorInDev';
5
+ import { useFilters } from '@jetshop/core/hooks/Filters/useFilters';
6
+ import qs from 'qs';
7
+ import * as React from 'react';
8
+ import { Query } from '@apollo/client/react/components';
9
+ import { useQuery } from '@apollo/client';
10
+ const SearchPageBehaviour = (props) => {
11
+ var _a, _b;
12
+ const pagination = usePagination();
13
+ const { location, searchQuery, children } = props;
14
+ const { offset, perPage } = React.useContext(PaginationContext);
15
+ const activeSearchTerm = React.useRef();
16
+ // Track the previous offset. If it has changed, we're paginating. If it
17
+ // hasn't, we're just applying filters.
18
+ const activeOffset = React.useRef(0);
19
+ const { clearAllFilters } = useFilters();
20
+ throwErrorInDev(!searchQuery, `You did not pass 'searchQuery' to SearchPageBehaviour`);
21
+ const activeFilterQuery = useQuery(ActiveFiltersQuery, {
22
+ fetchPolicy: 'cache-only'
23
+ });
24
+ const searchTerm = React.useMemo(() => qs.parse(location.search, { ignoreQueryPrefix: true }).term, [location]);
25
+ React.useEffect(() => {
26
+ if (activeSearchTerm.current && activeSearchTerm.current !== searchTerm) {
27
+ clearAllFilters();
28
+ }
29
+ activeSearchTerm.current = searchTerm;
30
+ }, [clearAllFilters, searchTerm]);
31
+ React.useEffect(() => {
32
+ activeOffset.current = offset;
33
+ }, [offset]);
34
+ if (pagination === undefined) {
35
+ return (React.createElement(PaginationProvider, null,
36
+ React.createElement(SearchPageBehaviour, Object.assign({}, props))));
37
+ }
38
+ const filters = ((_a = activeFilterQuery.data) === null || _a === void 0 ? void 0 : _a.activeFilters)
39
+ ? Object.assign({}, (_b = activeFilterQuery.data) === null || _b === void 0 ? void 0 : _b.activeFilters) : null;
40
+ filters && delete filters.__typename;
41
+ // Ideally this component would use the data from usePagination, but due to
42
+ // how the shouldComponentUpdate method in FilterContainer works it prevents
43
+ // rendering if we don't do it this way.
44
+ return searchTerm ? (React.createElement(Query, { variables: {
45
+ term: searchTerm,
46
+ first: perPage,
47
+ limit: perPage,
48
+ filters,
49
+ offset: activeOffset.current === offset ? 0 : offset,
50
+ client: !__IN_SERVER__
51
+ }, query: searchQuery, fetchPolicy: "cache-and-network" }, (result) => {
52
+ var _a, _b, _c, _d, _e, _f;
53
+ const totalResults = (_c = (_b = (_a = ((result === null || result === void 0 ? void 0 : result.data) || (result === null || result === void 0 ? void 0 : result.previousData))) === null || _a === void 0 ? void 0 : _a.search) === null || _b === void 0 ? void 0 : _b.products) === null || _c === void 0 ? void 0 : _c.totalResults;
54
+ const filters = (_f = (_e = (_d = ((result === null || result === void 0 ? void 0 : result.data) || (result === null || result === void 0 ? void 0 : result.previousData))) === null || _d === void 0 ? void 0 : _d.search) === null || _e === void 0 ? void 0 : _e.products) === null || _f === void 0 ? void 0 : _f.filters;
55
+ return (React.createElement(React.Fragment, null, children({
56
+ result: Object.assign(Object.assign({}, result), {
57
+ // We want to show the previous data to avoid unnecessary loading states
58
+ data: result.data || result.previousData }),
59
+ total: totalResults,
60
+ filters,
61
+ term: searchTerm,
62
+ loading: result.loading,
63
+ error: result.error
64
+ })));
65
+ })) : (children({
66
+ term: searchTerm,
67
+ loading: false,
68
+ error: null,
69
+ total: 0,
70
+ result: {},
71
+ filters: {}
72
+ }));
73
+ };
74
+ export default SearchPageBehaviour;
75
+ //# sourceMappingURL=SearchPageBehaviour.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SearchPageBehaviour.js","sourceRoot":"","sources":["SearchPageBehaviour.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import { Product, Category } from '@jetshop/core/types';
3
+ export interface SuggestedTermProps {
4
+ className?: string;
5
+ term: string;
6
+ /** Function to call when a search term is clicked */
7
+ onClick?: () => void;
8
+ }
9
+ interface SuggestedProduct extends SuggestedTermProps {
10
+ item: Product;
11
+ }
12
+ interface SuggestedCategory extends SuggestedTermProps {
13
+ item: Category;
14
+ }
15
+ declare const SuggestedTerm: (props: SuggestedProduct | SuggestedCategory) => React.JSX.Element;
16
+ export default SuggestedTerm;
@@ -0,0 +1,35 @@
1
+ import React from 'react';
2
+ import ProductLink from '@jetshop/ui/ProductLink';
3
+ import CategoryLink from '@jetshop/ui/CategoryLink';
4
+ const SuggestedTerm = (props) => {
5
+ const { term = '', className = '', onClick = () => null } = props;
6
+ if (isProduct(props)) {
7
+ const { item } = props;
8
+ return (React.createElement("li", { className: className, onClick: onClick, "data-flight-search-autocomplete-result": "product" }, item.primaryRoute ? (React.createElement(ProductLink, { product: item }, getHighlightedText(item.name, term))) : (item.name)));
9
+ }
10
+ else {
11
+ const { item } = props;
12
+ const displayText = item.primaryRoute.breadcrumbs.join(' > ');
13
+ return (React.createElement("li", { className: className, onClick: onClick, "data-flight-search-autocomplete-result": "category" }, item.primaryRoute ? (React.createElement(CategoryLink, { category: item }, getHighlightedText(displayText, term))) : (item.name)));
14
+ }
15
+ };
16
+ function isProduct(props) {
17
+ return props.item.__typename === 'Product';
18
+ }
19
+ function getHighlightedText(text, highlight) {
20
+ // Split on higlight term and include term into parts, ignore case
21
+ const parts = text.split(new RegExp(`(${escapeRegExp(highlight).split(' ').join('|')})`, 'gi'));
22
+ const highlightArray = highlight.split(' ');
23
+ const toHighlightLower = highlightArray.map((word) => word.toLowerCase());
24
+ return parts.reduce((prev, curr, index) => {
25
+ return [
26
+ ...prev,
27
+ toHighlightLower.includes(curr.toLowerCase()) ? (React.createElement("strong", { style: { fontWeight: 600 }, key: index }, curr)) : (curr)
28
+ ];
29
+ }, []);
30
+ }
31
+ function escapeRegExp(string) {
32
+ return string.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
33
+ }
34
+ export default SuggestedTerm;
35
+ //# sourceMappingURL=SuggestedTerm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SuggestedTerm.js","sourceRoot":"","sources":["SuggestedTerm.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,WAAW,MAAM,yBAAyB,CAAC;AAElD,OAAO,YAAY,MAAM,0BAA0B,CAAC;AAiBpD,MAAM,aAAa,GAAG,CAAC,KAA2C,EAAE,EAAE;IACpE,MAAM,EAAE,IAAI,GAAG,EAAE,EAAE,SAAS,GAAG,EAAE,EAAE,OAAO,GAAG,GAAG,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,CAAC;IAElE,IAAI,SAAS,CAAC,KAAK,CAAC,EAAE;QACpB,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;QACvB,OAAO,CACL,4BACE,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,4CACuB,SAAS,IAE/C,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CACnB,oBAAC,WAAW,IAAC,OAAO,EAAE,IAAI,IACvB,kBAAkB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CACxB,CACf,CAAC,CAAC,CAAC,CACF,IAAI,CAAC,IAAI,CACV,CACE,CACN,CAAC;KACH;SAAM;QACL,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK,CAAC;QAEvB,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE9D,OAAO,CACL,4BACE,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,4CACuB,UAAU,IAEhD,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CACnB,oBAAC,YAAY,IAAC,QAAQ,EAAE,IAAI,IACzB,kBAAkB,CAAC,WAAW,EAAE,IAAI,CAAC,CACzB,CAChB,CAAC,CAAC,CAAC,CACF,IAAI,CAAC,IAAI,CACV,CACE,CACN,CAAC;KACH;AACH,CAAC,CAAC;AAEF,SAAS,SAAS,CAChB,KAA2C;IAE3C,OAAQ,KAA0B,CAAC,IAAI,CAAC,UAAU,KAAK,SAAS,CAAC;AACnE,CAAC;AAED,SAAS,kBAAkB,CAAC,IAAY,EAAE,SAAiB;IACzD,kEAAkE;IAClE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CACtB,IAAI,MAAM,CAAC,IAAI,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,CACtE,CAAC;IACF,MAAM,cAAc,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC5C,MAAM,gBAAgB,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAE1E,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE;QACxC,OAAO;YACL,GAAG,IAAI;YACP,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAC9C,gCAAQ,KAAK,EAAE,EAAE,UAAU,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,KAAK,IAC3C,IAAI,CACE,CACV,CAAC,CAAC,CAAC,CACF,IAAI,CACL;SACF,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;AACT,CAAC;AAED,SAAS,YAAY,CAAC,MAAc;IAClC,OAAO,MAAM,CAAC,OAAO,CAAC,qBAAqB,EAAE,MAAM,CAAC,CAAC;AACvD,CAAC;AAED,eAAe,aAAa,CAAC"}
@@ -0,0 +1 @@
1
+ export { default as SearchField } from './SearchField';
@@ -0,0 +1,2 @@
1
+ export { default as SearchField } from './SearchField';
2
+ //# sourceMappingURL=index.js.map