@blaze-cms/react-page-builder 0.124.0-alpha.4 → 0.124.0-alpha.40

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 (419) hide show
  1. package/CHANGELOG.md +320 -0
  2. package/README.md +9 -0
  3. package/example.env +1 -0
  4. package/lib/BannerContext/index.js.map +1 -1
  5. package/lib/HOC/withInfiniteScroll.js.map +1 -1
  6. package/lib/HOC/withTitle.js.map +1 -1
  7. package/lib/PBContext/index.js.map +1 -1
  8. package/lib/application/query/index.js +9 -3
  9. package/lib/application/query/index.js.map +1 -1
  10. package/lib/components/BackToTop/BackToTop.js.map +1 -1
  11. package/lib/components/Banner/AdSlotRender.js.map +1 -1
  12. package/lib/components/Banner/Banner.js.map +1 -1
  13. package/lib/components/Banner/BannerRender.js.map +1 -1
  14. package/lib/components/Banner/helpers.js.map +1 -1
  15. package/lib/components/Banner/index.js.map +1 -1
  16. package/lib/components/BlazeLink.js.map +1 -1
  17. package/lib/components/Breadcrumb/Breadcrumb.js.map +1 -1
  18. package/lib/components/Button.js.map +1 -1
  19. package/lib/components/Card/Card.js.map +1 -1
  20. package/lib/components/Card/CardContainer.js +3 -7
  21. package/lib/components/Card/CardContainer.js.map +1 -1
  22. package/lib/components/Card/CardFactory.js +6 -3
  23. package/lib/components/Card/CardFactory.js.map +1 -1
  24. package/lib/components/Card/CardRender.js.map +1 -1
  25. package/lib/components/Card/helpers/filter-query-setup.js.map +1 -1
  26. package/lib/components/Card/helpers/filters-setup.js.map +1 -1
  27. package/lib/components/Card/helpers/get-dynamic-grid-classes.js.map +1 -1
  28. package/lib/components/Carousel/Carousel.js.map +1 -1
  29. package/lib/components/Carousel/CarouselImage/CarouselImage.js.map +1 -1
  30. package/lib/components/Carousel/CarouselRender/CarouselRender.js.map +1 -1
  31. package/lib/components/CarouselWrapper.js +2 -2
  32. package/lib/components/CarouselWrapper.js.map +1 -1
  33. package/lib/components/ClickWrapper.js.map +1 -1
  34. package/lib/components/Code/Code.js.map +1 -1
  35. package/lib/components/Code/ScriptTag.js.map +1 -1
  36. package/lib/components/Code/helpers/wrap-script-tags.js.map +1 -1
  37. package/lib/components/DataSummary/DataSummaryFactory.js.map +1 -1
  38. package/lib/components/DataSummary/DataSummaryRender.js.map +1 -1
  39. package/lib/components/DataSummary/DataSummaryTypes/HeadingLargeSummary/HeadingLargeSummary.js.map +1 -1
  40. package/lib/components/DataSummary/DataSummaryTypes/HeadingLargeSummary/HeadingLargeSummaryContent.js.map +1 -1
  41. package/lib/components/DataSummary/DataSummaryTypes/ItemDetailsSummary/ItemDetailsSummary.js.map +1 -1
  42. package/lib/components/DataSummary/DataSummaryTypes/ItemDetailsSummary/ItemDetailsSummaryContent.js.map +1 -1
  43. package/lib/components/DataSummary/DataSummaryTypes/LargeSummary/LargeSummary.js.map +1 -1
  44. package/lib/components/DataSummary/DataSummaryTypes/LargeSummary/LargeSummaryContent.js.map +1 -1
  45. package/lib/components/DataSummary/DataSummaryTypes/ListSummary/ListSummary.js.map +1 -1
  46. package/lib/components/DataSummary/DataSummaryTypes/ListSummary/ListSummaryContent.js.map +1 -1
  47. package/lib/components/DataSummary/DataSummaryTypes/TextSummary/TextSummary.js.map +1 -1
  48. package/lib/components/DataSummary/DataSummaryTypes/TextSummary/TextSummaryContent.js.map +1 -1
  49. package/lib/components/DataSummary/DataSummaryTypes/index.js.map +1 -1
  50. package/lib/components/DataSummary/helpers/build-loop-props-content.js.map +1 -1
  51. package/lib/components/DataSummary/helpers/build-props-to-display-with-content.js.map +1 -1
  52. package/lib/components/DataSummary/helpers/get-data-summary-query.js.map +1 -1
  53. package/lib/components/DataSummary/helpers/get-link-based-on-value.js.map +1 -1
  54. package/lib/components/DataSummary/helpers/get-prop-value.js.map +1 -1
  55. package/lib/components/DataSummary/helpers/get-value-from-array.js.map +1 -1
  56. package/lib/components/DataSummary/helpers/strip-summary-props-content.js.map +1 -1
  57. package/lib/components/EmailConfirm/EmailConfirm.js.map +1 -1
  58. package/lib/components/Image/GlobalLightbox/GlobalLightbox.js.map +1 -1
  59. package/lib/components/Image/GlobalLightbox/NavButton.js.map +1 -1
  60. package/lib/components/Image/GlobalLightbox/index.js.map +1 -1
  61. package/lib/components/Image/Image.js.map +1 -1
  62. package/lib/components/Image/ImageDetails.js.map +1 -1
  63. package/lib/components/Image/ImageFactory.js.map +1 -1
  64. package/lib/components/Image/ImageRender.js +5 -1
  65. package/lib/components/Image/ImageRender.js.map +1 -1
  66. package/lib/components/Image/Lightbox/Lightbox.js.map +1 -1
  67. package/lib/components/ItemList/ItemListButton/ItemListButton.js +161 -0
  68. package/lib/components/ItemList/ItemListButton/ItemListButton.js.map +1 -0
  69. package/lib/components/ItemList/ItemListButton/index.js +16 -0
  70. package/lib/components/ItemList/ItemListButton/index.js.map +1 -0
  71. package/lib/components/ItemList/ItemListCounter/ItemListCounter.js +83 -0
  72. package/lib/components/ItemList/ItemListCounter/ItemListCounter.js.map +1 -0
  73. package/lib/components/ItemList/ItemListCounter/index.js +16 -0
  74. package/lib/components/ItemList/ItemListCounter/index.js.map +1 -0
  75. package/lib/components/ItemList/ItemListNew/ItemListNew.js +87 -0
  76. package/lib/components/ItemList/ItemListNew/ItemListNew.js.map +1 -0
  77. package/lib/components/ItemList/ItemListNew/index.js +16 -0
  78. package/lib/components/ItemList/ItemListNew/index.js.map +1 -0
  79. package/lib/components/ItemList/constants.js +19 -0
  80. package/lib/components/ItemList/constants.js.map +1 -0
  81. package/lib/components/ItemList/helpers/get-item-list-data.js +17 -0
  82. package/lib/components/ItemList/helpers/get-item-list-data.js.map +1 -0
  83. package/lib/components/ItemList/helpers/get-item-list-id.js +23 -0
  84. package/lib/components/ItemList/helpers/get-item-list-id.js.map +1 -0
  85. package/lib/components/ItemList/helpers/get-item-list-ids.js +28 -0
  86. package/lib/components/ItemList/helpers/get-item-list-ids.js.map +1 -0
  87. package/lib/components/ItemList/helpers/index.js +50 -0
  88. package/lib/components/ItemList/helpers/index.js.map +1 -0
  89. package/lib/components/ItemList/helpers/set-item-list-id.js +22 -0
  90. package/lib/components/ItemList/helpers/set-item-list-id.js.map +1 -0
  91. package/lib/components/ItemList/helpers/set-param-and-redirect.js +51 -0
  92. package/lib/components/ItemList/helpers/set-param-and-redirect.js.map +1 -0
  93. package/lib/components/ItemList/hooks/index.js +18 -0
  94. package/lib/components/ItemList/hooks/index.js.map +1 -0
  95. package/lib/components/ItemList/hooks/use-item-list-id.js +45 -0
  96. package/lib/components/ItemList/hooks/use-item-list-id.js.map +1 -0
  97. package/lib/components/Layout/Layout.js.map +1 -1
  98. package/lib/components/Layout/helpers/check-if-row-has-columns.js.map +1 -1
  99. package/lib/components/LazyImage/LazyImage.js +5 -1
  100. package/lib/components/LazyImage/LazyImage.js.map +1 -1
  101. package/lib/components/LazyImage/index.js.map +1 -1
  102. package/lib/components/List/ListBuilder.js +12 -6
  103. package/lib/components/List/ListBuilder.js.map +1 -1
  104. package/lib/components/List/ListFactory.js +34 -7
  105. package/lib/components/List/ListFactory.js.map +1 -1
  106. package/lib/components/List/ListRender.js.map +1 -1
  107. package/lib/components/List/components/Cards/CardRenderWithInfiniteScroll.js.map +1 -1
  108. package/lib/components/List/components/Cards/CardsRender.js.map +1 -1
  109. package/lib/components/List/components/Cards/CardsRenderItem.js.map +1 -1
  110. package/lib/components/List/components/Cards/CardsRenderWrapper.js.map +1 -1
  111. package/lib/components/List/components/Full/FullRender.js.map +1 -1
  112. package/lib/components/List/components/Full/FullRenderItem.js.map +1 -1
  113. package/lib/components/List/components/Full/FullRenderWithInfiniteScroll.js.map +1 -1
  114. package/lib/components/List/components/Header/ListHeader.js.map +1 -1
  115. package/lib/components/List/components/Pagination/Classic.js.map +1 -1
  116. package/lib/components/List/components/Pagination/ListPagination.js.map +1 -1
  117. package/lib/components/List/components/Pagination/LoadMore.js.map +1 -1
  118. package/lib/components/List/helpers/build-az-aggregations.js.map +1 -1
  119. package/lib/components/List/helpers/build-az-url.js.map +1 -1
  120. package/lib/components/List/helpers/build-pagination-items.js.map +1 -1
  121. package/lib/components/List/helpers/build-pagination-url.js.map +1 -1
  122. package/lib/components/List/helpers/has-required-item-list-details.js +29 -0
  123. package/lib/components/List/helpers/has-required-item-list-details.js.map +1 -0
  124. package/lib/components/List/helpers/index.js +8 -0
  125. package/lib/components/List/helpers/index.js.map +1 -1
  126. package/lib/components/Login/LoggedInMessage.js.map +1 -1
  127. package/lib/components/Login/Login.js.map +1 -1
  128. package/lib/components/Login/LoginForm.js.map +1 -1
  129. package/lib/components/Menu/Menu.js +41 -28
  130. package/lib/components/Menu/Menu.js.map +1 -1
  131. package/lib/components/Menu/MenuContext.js +20 -0
  132. package/lib/components/Menu/MenuContext.js.map +1 -0
  133. package/lib/components/MenuItem/MenuItem.js +26 -7
  134. package/lib/components/MenuItem/MenuItem.js.map +1 -1
  135. package/lib/components/Modal/Modal.js.map +1 -1
  136. package/lib/components/PasswordReset/PasswordReset.js.map +1 -1
  137. package/lib/components/PasswordReset/helpers/validatePassword.js.map +1 -1
  138. package/lib/components/PasswordResetRequest/PasswordResetRequest.js.map +1 -1
  139. package/lib/components/SearchContent/SearchContent.js +183 -0
  140. package/lib/components/SearchContent/SearchContent.js.map +1 -0
  141. package/lib/components/SearchContent/SearchContentItems.js +51 -0
  142. package/lib/components/SearchContent/SearchContentItems.js.map +1 -0
  143. package/lib/components/SearchContent/SearchContentResults.js +45 -0
  144. package/lib/components/SearchContent/SearchContentResults.js.map +1 -0
  145. package/lib/components/SearchContent/SearchContentToggleIcon.js +42 -0
  146. package/lib/components/SearchContent/SearchContentToggleIcon.js.map +1 -0
  147. package/lib/components/SearchContent/index.js +2 -233
  148. package/lib/components/SearchContent/index.js.map +1 -1
  149. package/lib/components/SearchFilter/SearchFilter/CloseMobileForm.js.map +1 -1
  150. package/lib/components/SearchFilter/SearchFilter/FiltersList.js +2 -4
  151. package/lib/components/SearchFilter/SearchFilter/FiltersList.js.map +1 -1
  152. package/lib/components/SearchFilter/SearchFilter/MobileFormToolbar.js.map +1 -1
  153. package/lib/components/SearchFilter/SearchFilter/ResetDesktopForm.js.map +1 -1
  154. package/lib/components/SearchFilter/SearchFilter/SearchFilter.js +27 -69
  155. package/lib/components/SearchFilter/SearchFilter/SearchFilter.js.map +1 -1
  156. package/lib/components/SearchFilter/SearchFilterContainer.js +87 -23
  157. package/lib/components/SearchFilter/SearchFilterContainer.js.map +1 -1
  158. package/lib/components/SearchFilter/components/Checkbox.js +19 -9
  159. package/lib/components/SearchFilter/components/Checkbox.js.map +1 -1
  160. package/lib/components/SearchFilter/components/Range.js.map +1 -1
  161. package/lib/components/SearchFilter/components/Select.js +27 -11
  162. package/lib/components/SearchFilter/components/Select.js.map +1 -1
  163. package/lib/components/SearchFilter/components/TextSearch.js +1 -5
  164. package/lib/components/SearchFilter/components/TextSearch.js.map +1 -1
  165. package/lib/components/SearchFilter/constants.js +1 -1
  166. package/lib/components/SearchFilter/constants.js.map +1 -1
  167. package/lib/components/SearchFilter/helpers/build-filters-query.js +87 -0
  168. package/lib/components/SearchFilter/helpers/build-filters-query.js.map +1 -0
  169. package/lib/components/SearchFilter/helpers/build-query.js.map +1 -1
  170. package/lib/components/SearchFilter/helpers/build-raw-query-stringified.js +2 -1
  171. package/lib/components/SearchFilter/helpers/build-raw-query-stringified.js.map +1 -1
  172. package/lib/components/SearchFilter/helpers/calculate-min-max.js.map +1 -1
  173. package/lib/components/SearchFilter/helpers/check-if-range-updated.js.map +1 -1
  174. package/lib/components/SearchFilter/helpers/get-filter-value-from-query.js.map +1 -1
  175. package/lib/components/SearchFilter/helpers/get-initial-filter-values.js.map +1 -1
  176. package/lib/components/SearchFilter/helpers/get-intersected-prop.js.map +1 -1
  177. package/lib/components/SearchFilter/helpers/get-range-value.js.map +1 -1
  178. package/lib/components/SearchFilter/helpers/get-responsive-filter-classnames.js.map +1 -1
  179. package/lib/components/SearchFilter/helpers/get-select-options.js.map +1 -1
  180. package/lib/components/SearchFilter/helpers/index.js +8 -0
  181. package/lib/components/SearchFilter/helpers/index.js.map +1 -1
  182. package/lib/components/SearchFilterSort/SearchFilterSort.js.map +1 -1
  183. package/lib/components/SearchFilterSort/helpers/handle-sort-update.js.map +1 -1
  184. package/lib/components/SearchFilterSort/helpers/update-sort.js.map +1 -1
  185. package/lib/components/SocialFollow/SFItem.js.map +1 -1
  186. package/lib/components/SocialFollow/SocialFollow.js.map +1 -1
  187. package/lib/components/SocialFollow/SocialFollowRender.js.map +1 -1
  188. package/lib/components/SubMenu/SubMenu.js.map +1 -1
  189. package/lib/components/TextBlock/TextBlockRender.js.map +1 -1
  190. package/lib/components/TextBlock/index.js.map +1 -1
  191. package/lib/components/Video/Video.js.map +1 -1
  192. package/lib/components/Video/VideoModal.js.map +1 -1
  193. package/lib/components/Video/VideoRender.js.map +1 -1
  194. package/lib/components/Video/providers/Default.js.map +1 -1
  195. package/lib/components/Video/providers/JWPlayer/JWPlayerProvider.js.map +1 -1
  196. package/lib/components/Video/providers/YouTube/YouTubeProvider.js.map +1 -1
  197. package/lib/components/Video/providers/YouTube/YoutubeEmbeded.js.map +1 -1
  198. package/lib/components/Video/providers/get-provider.js.map +1 -1
  199. package/lib/components/Wrapper.js.map +1 -1
  200. package/lib/components/index.js +16 -1
  201. package/lib/components/index.js.map +1 -1
  202. package/lib/constants/index.js +3 -1
  203. package/lib/constants/index.js.map +1 -1
  204. package/lib/helpers/build-inherited-filters.js.map +1 -1
  205. package/lib/helpers/build-raw-query-base.js.map +1 -1
  206. package/lib/helpers/build-raw-query.js.map +1 -1
  207. package/lib/helpers/build-search-values-checkbox-select.js.map +1 -1
  208. package/lib/helpers/check-props-to-use.js.map +1 -1
  209. package/lib/helpers/get-entities-with-banner.js.map +1 -1
  210. package/lib/helpers/get-entity-data.js.map +1 -1
  211. package/lib/helpers/get-entity-render-props.js.map +1 -1
  212. package/lib/helpers/get-filter-props.js.map +1 -1
  213. package/lib/helpers/get-generic-props.js.map +1 -1
  214. package/lib/helpers/get-generic-render-variables.js.map +1 -1
  215. package/lib/helpers/get-image-ids.js.map +1 -1
  216. package/lib/helpers/get-parsed-prop-values.js.map +1 -1
  217. package/lib/helpers/get-prop-values.js.map +1 -1
  218. package/lib/helpers/get-query-filters.js.map +1 -1
  219. package/lib/helpers/get-query-props.js.map +1 -1
  220. package/lib/helpers/get-updated-filter-by.js.map +1 -1
  221. package/lib/helpers/inject-banner.js.map +1 -1
  222. package/lib/helpers/inject-banners-to-entities.js.map +1 -1
  223. package/lib/helpers/inject-multiple-banners/get-banners-for-entities/get-banners-for-entities.js.map +1 -1
  224. package/lib/helpers/inject-multiple-banners/get-banners-for-nodes/get-banners-for-nodes.js.map +1 -1
  225. package/lib/helpers/inject-multiple-banners/get-banners-for-nodes/helpers/group-node-entities.js.map +1 -1
  226. package/lib/helpers/inject-multiple-banners/inject-multiple-banners.js.map +1 -1
  227. package/lib/helpers/is-filter-entitys-id.js.map +1 -1
  228. package/lib/helpers/parse-TextBlock.js.map +1 -1
  229. package/lib/helpers/parse-props-to-display.js.map +1 -1
  230. package/lib/helpers/render-children.js.map +1 -1
  231. package/lib/helpers/sort-response-data.js.map +1 -1
  232. package/lib/hooks/helpers/RenderComponent.js.map +1 -1
  233. package/lib/hooks/helpers/append-gtm-classname.js +1 -0
  234. package/lib/hooks/helpers/append-gtm-classname.js.map +1 -1
  235. package/lib/hooks/helpers/buildPBComponents.js.map +1 -1
  236. package/lib/hooks/helpers/getComponent.js.map +1 -1
  237. package/lib/hooks/helpers/inject-element-banners.js.map +1 -1
  238. package/lib/hooks/helpers/inject-textblock-banners.js.map +1 -1
  239. package/lib/hooks/helpers/insert-banners.js.map +1 -1
  240. package/lib/hooks/helpers/update-targetings.js.map +1 -1
  241. package/lib/hooks/use-banner-insertion.js.map +1 -1
  242. package/lib/hooks/use-check-mobile-screen.js.map +1 -1
  243. package/lib/hooks/use-get-entity-schema.js.map +1 -1
  244. package/lib/hooks/use-get-entity-schemas-as-obj.js.map +1 -1
  245. package/lib/hooks/use-get-image-id-from-relation.js.map +1 -1
  246. package/lib/hooks/use-get-images.js.map +1 -1
  247. package/lib/hooks/use-get-single-entity-schema.js.map +1 -1
  248. package/lib/hooks/use-page-builder.js.map +1 -1
  249. package/lib/utils/get-class-modifiers.js.map +1 -1
  250. package/lib/utils/get-image-data.js.map +1 -1
  251. package/lib-es/application/query/index.js +49 -1
  252. package/lib-es/application/query/index.js.map +1 -1
  253. package/lib-es/components/Card/CardContainer.js +3 -7
  254. package/lib-es/components/Card/CardContainer.js.map +1 -1
  255. package/lib-es/components/Card/CardFactory.js +7 -4
  256. package/lib-es/components/Card/CardFactory.js.map +1 -1
  257. package/lib-es/components/CarouselWrapper.js +2 -2
  258. package/lib-es/components/CarouselWrapper.js.map +1 -1
  259. package/lib-es/components/Image/ImageRender.js +4 -1
  260. package/lib-es/components/Image/ImageRender.js.map +1 -1
  261. package/lib-es/components/ItemList/ItemListButton/ItemListButton.js +111 -0
  262. package/lib-es/components/ItemList/ItemListButton/ItemListButton.js.map +1 -0
  263. package/lib-es/components/ItemList/ItemListButton/index.js +3 -0
  264. package/lib-es/components/ItemList/ItemListButton/index.js.map +1 -0
  265. package/lib-es/components/ItemList/ItemListCounter/ItemListCounter.js +60 -0
  266. package/lib-es/components/ItemList/ItemListCounter/ItemListCounter.js.map +1 -0
  267. package/lib-es/components/ItemList/ItemListCounter/index.js +3 -0
  268. package/lib-es/components/ItemList/ItemListCounter/index.js.map +1 -0
  269. package/lib-es/components/ItemList/ItemListNew/ItemListNew.js +64 -0
  270. package/lib-es/components/ItemList/ItemListNew/ItemListNew.js.map +1 -0
  271. package/lib-es/components/ItemList/ItemListNew/index.js +3 -0
  272. package/lib-es/components/ItemList/ItemListNew/index.js.map +1 -0
  273. package/lib-es/components/ItemList/constants.js +6 -0
  274. package/lib-es/components/ItemList/constants.js.map +1 -0
  275. package/lib-es/components/ItemList/helpers/get-item-list-data.js +7 -0
  276. package/lib-es/components/ItemList/helpers/get-item-list-data.js.map +1 -0
  277. package/lib-es/components/ItemList/helpers/get-item-list-id.js +11 -0
  278. package/lib-es/components/ItemList/helpers/get-item-list-id.js.map +1 -0
  279. package/lib-es/components/ItemList/helpers/get-item-list-ids.js +13 -0
  280. package/lib-es/components/ItemList/helpers/get-item-list-ids.js.map +1 -0
  281. package/lib-es/components/ItemList/helpers/index.js +6 -0
  282. package/lib-es/components/ItemList/helpers/index.js.map +1 -0
  283. package/lib-es/components/ItemList/helpers/set-item-list-id.js +10 -0
  284. package/lib-es/components/ItemList/helpers/set-item-list-id.js.map +1 -0
  285. package/lib-es/components/ItemList/helpers/set-param-and-redirect.js +20 -0
  286. package/lib-es/components/ItemList/helpers/set-param-and-redirect.js.map +1 -0
  287. package/lib-es/components/ItemList/hooks/index.js +2 -0
  288. package/lib-es/components/ItemList/hooks/index.js.map +1 -0
  289. package/lib-es/components/ItemList/hooks/use-item-list-id.js +26 -0
  290. package/lib-es/components/ItemList/hooks/use-item-list-id.js.map +1 -0
  291. package/lib-es/components/LazyImage/LazyImage.js +4 -1
  292. package/lib-es/components/LazyImage/LazyImage.js.map +1 -1
  293. package/lib-es/components/List/ListBuilder.js +12 -6
  294. package/lib-es/components/List/ListBuilder.js.map +1 -1
  295. package/lib-es/components/List/ListFactory.js +33 -9
  296. package/lib-es/components/List/ListFactory.js.map +1 -1
  297. package/lib-es/components/List/helpers/has-required-item-list-details.js +20 -0
  298. package/lib-es/components/List/helpers/has-required-item-list-details.js.map +1 -0
  299. package/lib-es/components/List/helpers/index.js +1 -0
  300. package/lib-es/components/List/helpers/index.js.map +1 -1
  301. package/lib-es/components/Menu/Menu.js +54 -46
  302. package/lib-es/components/Menu/Menu.js.map +1 -1
  303. package/lib-es/components/Menu/MenuContext.js +6 -0
  304. package/lib-es/components/Menu/MenuContext.js.map +1 -0
  305. package/lib-es/components/MenuItem/MenuItem.js +24 -9
  306. package/lib-es/components/MenuItem/MenuItem.js.map +1 -1
  307. package/lib-es/components/SearchContent/SearchContent.js +129 -0
  308. package/lib-es/components/SearchContent/SearchContent.js.map +1 -0
  309. package/lib-es/components/SearchContent/SearchContentItems.js +33 -0
  310. package/lib-es/components/SearchContent/SearchContentItems.js.map +1 -0
  311. package/lib-es/components/SearchContent/SearchContentResults.js +31 -0
  312. package/lib-es/components/SearchContent/SearchContentResults.js.map +1 -0
  313. package/lib-es/components/SearchContent/SearchContentToggleIcon.js +30 -0
  314. package/lib-es/components/SearchContent/SearchContentToggleIcon.js.map +1 -0
  315. package/lib-es/components/SearchContent/index.js +1 -172
  316. package/lib-es/components/SearchContent/index.js.map +1 -1
  317. package/lib-es/components/SearchFilter/SearchFilter/FiltersList.js +2 -4
  318. package/lib-es/components/SearchFilter/SearchFilter/FiltersList.js.map +1 -1
  319. package/lib-es/components/SearchFilter/SearchFilter/SearchFilter.js +21 -46
  320. package/lib-es/components/SearchFilter/SearchFilter/SearchFilter.js.map +1 -1
  321. package/lib-es/components/SearchFilter/SearchFilterContainer.js +70 -15
  322. package/lib-es/components/SearchFilter/SearchFilterContainer.js.map +1 -1
  323. package/lib-es/components/SearchFilter/components/Checkbox.js +18 -9
  324. package/lib-es/components/SearchFilter/components/Checkbox.js.map +1 -1
  325. package/lib-es/components/SearchFilter/components/Select.js +23 -8
  326. package/lib-es/components/SearchFilter/components/Select.js.map +1 -1
  327. package/lib-es/components/SearchFilter/components/TextSearch.js +1 -5
  328. package/lib-es/components/SearchFilter/components/TextSearch.js.map +1 -1
  329. package/lib-es/components/SearchFilter/constants.js +1 -1
  330. package/lib-es/components/SearchFilter/constants.js.map +1 -1
  331. package/lib-es/components/SearchFilter/helpers/build-filters-query.js +54 -0
  332. package/lib-es/components/SearchFilter/helpers/build-filters-query.js.map +1 -0
  333. package/lib-es/components/SearchFilter/helpers/build-raw-query-stringified.js +2 -1
  334. package/lib-es/components/SearchFilter/helpers/build-raw-query-stringified.js.map +1 -1
  335. package/lib-es/components/SearchFilter/helpers/get-initial-filter-values.js.map +1 -1
  336. package/lib-es/components/SearchFilter/helpers/index.js +2 -1
  337. package/lib-es/components/SearchFilter/helpers/index.js.map +1 -1
  338. package/lib-es/components/index.js +10 -1
  339. package/lib-es/components/index.js.map +1 -1
  340. package/lib-es/constants/index.js +2 -1
  341. package/lib-es/constants/index.js.map +1 -1
  342. package/lib-es/helpers/build-raw-query.js.map +1 -1
  343. package/lib-es/hooks/helpers/append-gtm-classname.js +1 -0
  344. package/lib-es/hooks/helpers/append-gtm-classname.js.map +1 -1
  345. package/package.json +5 -4
  346. package/src/application/query/index.js +55 -1
  347. package/src/components/Card/CardContainer.js +2 -6
  348. package/src/components/Card/CardFactory.js +5 -3
  349. package/src/components/CarouselWrapper.js +2 -2
  350. package/src/components/Image/ImageRender.js +3 -0
  351. package/src/components/ItemList/ItemListButton/ItemListButton.js +94 -0
  352. package/src/components/ItemList/ItemListButton/index.js +3 -0
  353. package/src/components/ItemList/ItemListCounter/ItemListCounter.js +52 -0
  354. package/src/components/ItemList/ItemListCounter/index.js +3 -0
  355. package/src/components/ItemList/ItemListNew/ItemListNew.js +51 -0
  356. package/src/components/ItemList/ItemListNew/index.js +3 -0
  357. package/src/components/ItemList/constants.js +5 -0
  358. package/src/components/ItemList/helpers/get-item-list-data.js +6 -0
  359. package/src/components/ItemList/helpers/get-item-list-id.js +11 -0
  360. package/src/components/ItemList/helpers/get-item-list-ids.js +10 -0
  361. package/src/components/ItemList/helpers/index.js +5 -0
  362. package/src/components/ItemList/helpers/set-item-list-id.js +9 -0
  363. package/src/components/ItemList/helpers/set-param-and-redirect.js +20 -0
  364. package/src/components/ItemList/hooks/index.js +1 -0
  365. package/src/components/ItemList/hooks/use-item-list-id.js +27 -0
  366. package/src/components/LazyImage/LazyImage.js +11 -1
  367. package/src/components/List/ListBuilder.js +10 -5
  368. package/src/components/List/ListFactory.js +48 -12
  369. package/src/components/List/helpers/has-required-item-list-details.js +14 -0
  370. package/src/components/List/helpers/index.js +1 -0
  371. package/src/components/Menu/Menu.js +61 -54
  372. package/src/components/Menu/MenuContext.js +5 -0
  373. package/src/components/MenuItem/MenuItem.js +39 -14
  374. package/src/components/SearchContent/SearchContent.js +136 -0
  375. package/src/components/SearchContent/SearchContentItems.js +28 -0
  376. package/src/components/SearchContent/SearchContentResults.js +27 -0
  377. package/src/components/SearchContent/SearchContentToggleIcon.js +27 -0
  378. package/src/components/SearchContent/index.js +1 -177
  379. package/src/components/SearchFilter/SearchFilter/FiltersList.js +30 -37
  380. package/src/components/SearchFilter/SearchFilter/SearchFilter.js +20 -28
  381. package/src/components/SearchFilter/SearchFilterContainer.js +58 -16
  382. package/src/components/SearchFilter/components/Checkbox.js +23 -8
  383. package/src/components/SearchFilter/components/Select.js +18 -11
  384. package/src/components/SearchFilter/components/TextSearch.js +1 -3
  385. package/src/components/SearchFilter/constants.js +1 -1
  386. package/src/components/SearchFilter/helpers/build-filters-query.js +40 -0
  387. package/src/components/SearchFilter/helpers/build-raw-query-stringified.js +2 -1
  388. package/src/components/SearchFilter/helpers/get-initial-filter-values.js +1 -0
  389. package/src/components/SearchFilter/helpers/index.js +3 -1
  390. package/src/components/index.js +10 -1
  391. package/src/constants/index.js +2 -0
  392. package/src/helpers/build-raw-query.js +1 -0
  393. package/src/hooks/helpers/append-gtm-classname.js +3 -0
  394. package/tests/helpers/mocks.js +4 -4
  395. package/tests/unit/src/components/ItemList/ItemListButton.test.js +175 -0
  396. package/tests/unit/src/components/ItemList/ItemListCounter.test.js +65 -0
  397. package/tests/unit/src/components/ItemList/ItemListNew.test.js +164 -0
  398. package/tests/unit/src/components/ItemList/__snapshots__/ItemListButton.test.js.snap +107 -0
  399. package/tests/unit/src/components/ItemList/__snapshots__/ItemListCounter.test.js.snap +31 -0
  400. package/tests/unit/src/components/ItemList/__snapshots__/ItemListNew.test.js.snap +27 -0
  401. package/tests/unit/src/components/ItemList/helpers/get-item-list-data.test.js +28 -0
  402. package/tests/unit/src/components/ItemList/helpers/get-item-list-id.test.js +20 -0
  403. package/tests/unit/src/components/ItemList/helpers/get-item-list-ids.test.js +19 -0
  404. package/tests/unit/src/components/ItemList/helpers/set-item-list-id.test.js +13 -0
  405. package/tests/unit/src/components/ItemList/helpers/set-param-and-redirect.test.js +30 -0
  406. package/tests/unit/src/components/ItemList/hooks/use-item-list-id.test.js +32 -0
  407. package/tests/unit/src/components/List/helpers/has-required-item-list-details.test.js +30 -0
  408. package/tests/unit/src/components/Menu/Menu.test.js +9 -3
  409. package/tests/unit/src/components/Menu/__snapshots__/Menu.test.js.snap +12 -11
  410. package/tests/unit/src/components/MenuItem/MenuItem.test.js +1 -1
  411. package/tests/unit/src/components/MenuItem/SubMenu.test.js +5 -1
  412. package/tests/unit/src/components/MenuItem/__snapshots__/MenuItem.test.js.snap +54 -10
  413. package/tests/unit/src/components/SearchContent/SearchContent.test.js +29 -0
  414. package/tests/unit/src/components/SearchContent/__snapshots__/SearchContent.test.js.snap +9 -0
  415. package/tests/unit/src/components/SearchFilter/SearchFilter/SearchFilter.test.js +26 -7
  416. package/tests/unit/src/components/SearchFilter/SearchFilter/__snapshots__/SearchFilter.test.js.snap +4 -0
  417. package/tests/unit/src/components/SearchFilter/components/__snapshots__/Checkbox.test.js.snap +2 -0
  418. package/tests/unit/src/components/SearchFilter/components/__snapshots__/Select.test.js.snap +4 -0
  419. package/tests/unit/src/components/__snapshots__/index.test.js.snap +12 -0
@@ -1,9 +1,11 @@
1
- import React, { useState } from 'react';
1
+ import React, { useState, useEffect } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import BlazeButton from '@blaze-react/button';
4
+ import classnames from 'classnames';
5
+ import { useRouter } from 'next/router';
4
6
  import { MdMenu, MdClose } from 'react-icons/md';
5
- import { useCheckMobileScreen } from '../../hooks';
6
- import { HIDDEN } from '../../constants';
7
+ import { Link } from '@blaze-cms/nextjs-components';
8
+ import MenuContext from './MenuContext';
7
9
 
8
10
  const Menu = ({
9
11
  children,
@@ -21,65 +23,68 @@ const Menu = ({
21
23
  logoOnMobileModifier,
22
24
  logoOnDesktopModifier,
23
25
  logoOnDesktopAlignment,
24
- closeIconModifier,
25
- ...rest
26
+ closeIconModifier
26
27
  }) => {
27
- const isMobile = useCheckMobileScreen();
28
+ const router = useRouter();
28
29
  const [showMobileMenu, setShowMobileMenu] = useState(false);
29
30
 
30
- const shouldDisplayCollapsed = collapse && isMobile;
31
- const mobileButtonClass = shouldDisplayCollapsed && isMobile ? mobileButtonModifier : HIDDEN;
32
- const shouldDisplayChildren = shouldDisplayCollapsed ? showMobileMenu : true;
33
- const childrenDesktopModifier =
34
- shouldDisplayChildren && !isMobile ? modifier : `${modifier} ${HIDDEN}`;
31
+ useEffect(
32
+ () => {
33
+ const handleRouteChange = () => setShowMobileMenu(false);
34
+ router.events.on('routeChangeStart', handleRouteChange);
35
35
 
36
- const childrenMobileModifier =
37
- shouldDisplayChildren && isMobile ? `${mobileMenuChildrenModifier}` : ` ${HIDDEN}`;
36
+ return () => {
37
+ router.events.off('routeChangeStart', handleRouteChange);
38
+ };
39
+ },
40
+ [router.events]
41
+ );
42
+
43
+ const shouldDisplayChildren = collapse ? showMobileMenu : true;
44
+
45
+ const childModifiers = classnames({
46
+ [mobileMenuChildrenModifier]: shouldDisplayChildren,
47
+ [modifier]: !showMobileMenu
48
+ });
38
49
 
39
50
  const isMobileMenuExpanded = showMobileMenu ? `${mobileMenuModifier}` : '';
51
+ const menuWrapperClasses = classnames('menu--wrapper', {
52
+ 'menu--wrapper--mobile-open': showMobileMenu,
53
+ 'menu--wrapper--mobile-closed': collapse && !showMobileMenu
54
+ });
40
55
 
41
56
  return (
42
- <>
43
- {collapse && (
44
- <div className="menu--mobile-wrapper">
45
- <div
46
- className={`flex w-screen z-50 justify-${mobileIconAlignment} ${isMobileMenuExpanded}`}>
47
- <BlazeButton
48
- className={mobileButtonClass}
49
- onClick={() => setShowMobileMenu(!showMobileMenu)}>
50
- <i>
51
- {showMobileMenu ? (
52
- <MdClose className={closeIconModifier} />
53
- ) : (
54
- <MdMenu className={hamburgerIconModifier} />
55
- )}
56
- </i>
57
- </BlazeButton>
57
+ <MenuContext.Provider value={{ showMobileMenu }}>
58
+ <div className={menuWrapperClasses}>
59
+ {collapse && (
60
+ <div className="menu--mobile-wrapper">
61
+ <div
62
+ className={`flex w-screen z-50 justify-${mobileIconAlignment} ${isMobileMenuExpanded}`}>
63
+ <BlazeButton
64
+ className={`menu--mobile-button ${mobileButtonModifier}`}
65
+ onClick={() => setShowMobileMenu(!showMobileMenu)}>
66
+ <i>
67
+ {showMobileMenu ? (
68
+ <MdClose className={closeIconModifier} />
69
+ ) : (
70
+ <MdMenu className={hamburgerIconModifier} />
71
+ )}
72
+ </i>
73
+ </BlazeButton>
74
+ </div>
58
75
  </div>
59
- </div>
60
- )}
61
- {logoOnMobile && (
62
- <a href="/">
63
- <img src={logoOnMobileUrl} alt={logoOnMobileAlt} className={logoOnMobileModifier} />
64
- </a>
65
- )}
76
+ )}
77
+ {logoOnMobile &&
78
+ !showMobileMenu && (
79
+ <Link href="/">
80
+ <img src={logoOnMobileUrl} alt={logoOnMobileAlt} className={logoOnMobileModifier} />
81
+ </Link>
82
+ )}
66
83
 
67
- <div className="menu--desktop-wrapper">
68
- <ul className={isMobile ? childrenMobileModifier : childrenDesktopModifier}>
69
- {logoOnDesktop &&
70
- logoOnDesktopAlignment === 'left' && (
71
- <a href="/" className="menu--desktop__logo-wrapper">
72
- <img
73
- src={logoOnMobileUrl}
74
- alt={logoOnMobileAlt}
75
- className={logoOnDesktopModifier}
76
- />
77
- </a>
78
- )}
79
- {children}
80
- {logoOnDesktop &&
81
- logoOnDesktopAlignment === 'right' && (
82
- <a href="/" className="menu--desktop__logo-wrapper">
84
+ <div className="menu--desktop-wrapper">
85
+ <ul className={childModifiers}>
86
+ {logoOnDesktop && (
87
+ <a href="/" className="">
83
88
  <img
84
89
  src={logoOnMobileUrl}
85
90
  alt={logoOnMobileAlt}
@@ -87,9 +92,11 @@ const Menu = ({
87
92
  />
88
93
  </a>
89
94
  )}
90
- </ul>
95
+ {children}
96
+ </ul>
97
+ </div>
91
98
  </div>
92
- </>
99
+ </MenuContext.Provider>
93
100
  );
94
101
  };
95
102
 
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+
3
+ const MenuContext = React.createContext({ showMobileMenu: false });
4
+
5
+ export default MenuContext;
@@ -1,35 +1,60 @@
1
- import React, { useState } from 'react';
1
+ import React, { useState, useContext, useEffect } from 'react';
2
2
  import PropTypes from 'prop-types';
3
- import { HOVER, MOUSE_ENTER, MOUSE_LEAVE, CLICK, HIDDEN } from '../../constants';
3
+ import { FaChevronDown, FaChevronUp } from 'react-icons/fa';
4
+ import { HOVER, MOUSE_ENTER, MOUSE_LEAVE, HIDDEN } from '../../constants';
4
5
  import { hasChildren } from '../../helpers';
5
6
  import BlazeLink from '../BlazeLink';
7
+ import MenuContext from '../Menu/MenuContext';
6
8
 
7
9
  const MenuItem = ({ children, eventType, text, modifier, url }) => {
8
10
  const [displayChildren, setDisplayChildren] = useState(false);
11
+ const { showMobileMenu } = useContext(MenuContext);
12
+
13
+ useEffect(
14
+ () => {
15
+ if (!showMobileMenu) setDisplayChildren(false);
16
+ },
17
+ [showMobileMenu]
18
+ );
19
+
9
20
  const isHoverEvent = eventType === HOVER;
10
21
  const childrenDisplayClass = displayChildren ? '' : HIDDEN;
11
22
 
12
23
  const handleItemEvent = ({ type }) => {
13
24
  if (isHoverEvent) {
14
- if (type === MOUSE_ENTER) setDisplayChildren(true);
15
- if (type === MOUSE_LEAVE) setDisplayChildren(false);
16
- }
17
- if (type === CLICK && eventType === CLICK && !url) {
18
- setDisplayChildren(!displayChildren);
25
+ if (type === MOUSE_ENTER) {
26
+ setDisplayChildren(true);
27
+ }
28
+ if (type === MOUSE_LEAVE) {
29
+ setDisplayChildren(false);
30
+ }
19
31
  }
20
32
  };
21
33
  const hasValidChildren = hasChildren(children);
22
34
 
23
35
  return (
24
36
  <li className={modifier} onMouseEnter={handleItemEvent} onMouseLeave={handleItemEvent}>
25
- {url ? (
26
- <BlazeLink href={url}>{text}</BlazeLink>
27
- ) : (
28
- <span role="button" onClick={handleItemEvent}>
29
- {text}
30
- </span>
37
+ <div className="menu--item--link">
38
+ {url ? (
39
+ <BlazeLink href={url}>{text}</BlazeLink>
40
+ ) : (
41
+ <span role="button" onClick={handleItemEvent}>
42
+ {text}
43
+ </span>
44
+ )}
45
+ {hasValidChildren && (
46
+ <i
47
+ role="button"
48
+ className="menu--item--link--icon"
49
+ onClick={() => setDisplayChildren(!displayChildren)}>
50
+ {displayChildren ? <FaChevronUp /> : <FaChevronDown />}
51
+ </i>
52
+ )}
53
+ </div>
54
+
55
+ {hasValidChildren && (
56
+ <div className={`menu--item-children ${childrenDisplayClass}`}>{children}</div>
31
57
  )}
32
- {hasValidChildren && <div className={childrenDisplayClass}>{children}</div>}
33
58
  </li>
34
59
  );
35
60
  };
@@ -0,0 +1,136 @@
1
+ import React, { useState, useEffect } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { useRouter } from 'next/router';
4
+ import { useDebounceSearch } from '@blaze-cms/plugin-search-ui';
5
+ import SearchContentResults from './SearchContentResults';
6
+ import SearchContentToggleIcon from './SearchContentToggleIcon';
7
+
8
+ const SearchContent = ({
9
+ entities,
10
+ searchInputAlignment,
11
+ searchInputWrapperMobile,
12
+ searchInputWrapperDesktop,
13
+ collapsible,
14
+ isMobile,
15
+ placeholder,
16
+ modifier
17
+ }) => {
18
+ const [collapsed, setCollapsed] = useState(collapsible);
19
+ const router = useRouter();
20
+
21
+ const { results, searchTerm, setSearchTerm, debouncedSearchTerm } = useDebounceSearch({
22
+ entities,
23
+ initialSearchTerm: '',
24
+ resultKeys: 'id, name, image { url }, url'
25
+ });
26
+
27
+ useEffect(
28
+ () => {
29
+ const handleRouteChange = () => setSearchTerm('');
30
+ router.events.on('routeChangeStart', handleRouteChange);
31
+
32
+ return () => {
33
+ router.events.off('routeChangeStart', handleRouteChange);
34
+ };
35
+ },
36
+ [router.events, setSearchTerm]
37
+ );
38
+
39
+ const responsiveClasses = isMobile ? searchInputWrapperMobile : searchInputWrapperDesktop;
40
+
41
+ const handleClick = (e, url) => {
42
+ e.preventDefault();
43
+ router.push(url);
44
+ };
45
+
46
+ const handleKeyPress = e => {
47
+ if (e.key === 'Enter' && e.target.value !== '') {
48
+ router.push(`/search?search_term=${e.target.value}`);
49
+ }
50
+ };
51
+
52
+ const handleOnBlur = () => {
53
+ if (!collapsible) return;
54
+ if (!debouncedSearchTerm || debouncedSearchTerm === '') setCollapsed(true);
55
+ };
56
+
57
+ const handleClearSearchResults = () => {
58
+ setSearchTerm('');
59
+ };
60
+
61
+ const className = ['search-content', modifier, responsiveClasses].filter(Boolean).join(' ');
62
+ return collapsed ? (
63
+ <div className={className}>
64
+ <div className="search-content--collapse__wrapper">
65
+ <label className="search-content--collapse__label">
66
+ <span className="search-content--collapse__icon_wrapper">
67
+ <svg className="search-content--collapse__icon" viewBox="0 0 20 20">
68
+ <path
69
+ fillRule="evenodd"
70
+ d="M8 4a4 4 0 100 8 4 4 0 000-8zM2 8a6 6 0 1110.89 3.476l4.817 4.817a1 1 0 01-1.414 1.414l-4.816-4.816A6 6 0 012 8z"
71
+ clipRule="evenodd"
72
+ />
73
+ </svg>
74
+ </span>
75
+ <input
76
+ onFocus={() => setCollapsed(false)}
77
+ onChange={e => setSearchTerm(e.target.value)}
78
+ type="text"
79
+ name="search"
80
+ className="search-content--collapse__input"
81
+ />
82
+ </label>
83
+ </div>
84
+ </div>
85
+ ) : (
86
+ <>
87
+ <div className={className}>
88
+ <div className="search-content--expanded__wrapper">
89
+ <label className="search-content--expanded__label">
90
+ <span className="search-content--expanded__icon_wrapper">
91
+ <SearchContentToggleIcon results={results} onClear={handleClearSearchResults} />
92
+ </span>
93
+ <input
94
+ type="text"
95
+ name="search"
96
+ onChange={e => setSearchTerm(e.target.value)}
97
+ onKeyPress={handleKeyPress}
98
+ className="search-content--expanded__input"
99
+ placeholder={placeholder}
100
+ value={searchTerm}
101
+ onBlur={handleOnBlur}
102
+ />
103
+ </label>
104
+ </div>
105
+ <SearchContentResults
106
+ results={results}
107
+ debouncedSearchTerm={debouncedSearchTerm}
108
+ handleClick={handleClick}
109
+ />
110
+ </div>
111
+ </>
112
+ );
113
+ };
114
+
115
+ SearchContent.propTypes = {
116
+ searchInputAlignment: PropTypes.string,
117
+ searchInputWrapperMobile: PropTypes.string,
118
+ searchInputWrapperDesktop: PropTypes.string,
119
+ placeholder: PropTypes.string,
120
+ isMobile: PropTypes.bool,
121
+ collapsible: PropTypes.bool,
122
+ entities: PropTypes.array.isRequired,
123
+ modifier: PropTypes.string
124
+ };
125
+
126
+ SearchContent.defaultProps = {
127
+ searchInputAlignment: '',
128
+ searchInputWrapperMobile: '',
129
+ searchInputWrapperDesktop: '',
130
+ placeholder: '',
131
+ isMobile: false,
132
+ collapsible: false,
133
+ modifier: ''
134
+ };
135
+
136
+ export default SearchContent;
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+ import BlazeLink from '../BlazeLink';
3
+ import LazyImage from '../LazyImage';
4
+
5
+ const SearchContentItems = ({ results = [], onClick }) =>
6
+ results.map(item => {
7
+ if (!item.url) return null;
8
+
9
+ const { id, name, image, url } = item;
10
+
11
+ return (
12
+ <BlazeLink href={url} onClick={onClick} key={id}>
13
+ <div className="search-content--results__wrapper">
14
+ {image?.url ? (
15
+ <LazyImage
16
+ src={image.url}
17
+ alt={name}
18
+ className="search-content--results__image"
19
+ sizeKey="search-result"
20
+ />
21
+ ) : null}
22
+ <span className="search-content--results__title">{name}</span>
23
+ </div>
24
+ </BlazeLink>
25
+ );
26
+ });
27
+
28
+ export default SearchContentItems;
@@ -0,0 +1,27 @@
1
+ import React from 'react';
2
+ import BlazeLink from '../BlazeLink';
3
+ import SearchContentItems from './SearchContentItems';
4
+
5
+ const SearchContentResults = ({ results, debouncedSearchTerm, onClick }) => {
6
+ if (debouncedSearchTerm !== '') {
7
+ return (
8
+ <div className="search-content--results__wrapper">
9
+ <div className="search-content--results__wrapper--message">
10
+ <div className="search-content--results__content">
11
+ {results.length === 0 && (
12
+ <div className="search-content--results__message">
13
+ <BlazeLink href={`/search?search_term=${debouncedSearchTerm}`}>
14
+ {`Search all results for: ${debouncedSearchTerm}`}
15
+ </BlazeLink>
16
+ </div>
17
+ )}
18
+ {results.length > 0 && <SearchContentItems results={results} onClick={onClick} />}
19
+ </div>
20
+ </div>
21
+ </div>
22
+ );
23
+ }
24
+ return null;
25
+ };
26
+
27
+ export default SearchContentResults;
@@ -0,0 +1,27 @@
1
+ import React from 'react';
2
+
3
+ const SearchContentToggleIcon = ({ results, onClear }) => {
4
+ if (results && results.length > 0) {
5
+ return (
6
+ <svg className="search-content--expanded__icon" viewBox="0 0 20 20" onClick={onClear}>
7
+ <path
8
+ fillRule="evenodd"
9
+ d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z"
10
+ clipRule="evenodd"
11
+ />
12
+ </svg>
13
+ );
14
+ }
15
+
16
+ return (
17
+ <svg className="search-content--expanded__icon" viewBox="0 0 20 20">
18
+ <path
19
+ fillRule="evenodd"
20
+ d="M8 4a4 4 0 100 8 4 4 0 000-8zM2 8a6 6 0 1110.89 3.476l4.817 4.817a1 1 0 01-1.414 1.414l-4.816-4.816A6 6 0 012 8z"
21
+ clipRule="evenodd"
22
+ />
23
+ </svg>
24
+ );
25
+ };
26
+
27
+ export default SearchContentToggleIcon;
@@ -1,179 +1,3 @@
1
- import React, { useState } from 'react';
2
- import PropTypes from 'prop-types';
3
- import { gql, useQuery } from '@apollo/client';
4
- import { useRouter } from 'next/router';
5
- import { getPublishedContent } from '../../application/query';
6
- import BlazeLink from '../BlazeLink';
7
-
8
- const SearchContent = ({
9
- entity,
10
- searchInputAlignment,
11
- searchInputWrapperMobile,
12
- searchInputWrapperDesktop,
13
- collapsible,
14
- isMobile,
15
- placeholder
16
- }) => {
17
- const [collapsed, setCollapsed] = useState(collapsible);
18
- const [searchTerm, setSearchTerm] = useState(null);
19
- const router = useRouter();
20
-
21
- const capitalize = s => {
22
- if (typeof s !== 'string') return '';
23
- return s.charAt(0).toUpperCase() + s.slice(1);
24
- };
25
-
26
- const [a, b] = entity.split('_');
27
-
28
- const entityName = capitalize(a) + capitalize(b);
29
-
30
- const rawQueryStringified = JSON.stringify({
31
- size: 0,
32
- query: {
33
- bool: {
34
- should: [
35
- {
36
- match: {
37
- docType: entity
38
- }
39
- }
40
- ],
41
- minimum_should_match: 1
42
- }
43
- }
44
- });
45
-
46
- const query = gql`
47
- ${getPublishedContent(entityName)}
48
- `;
49
-
50
- const { loading, error, data } = useQuery(query, {
51
- variables: { rawQueryStringified, offset: 0, limit: 5 }
52
- });
53
-
54
- if (loading) return null;
55
- if (error) return null;
56
-
57
- const handleClick = (e, url) => {
58
- e.preventDefault();
59
- router.push(url);
60
- };
61
-
62
- const handleKeyPress = e => {
63
- if (e.key === 'Enter' && e.target.value !== '') {
64
- router.push(`/search?search_term=${e.target.value}`);
65
- }
66
- };
67
-
68
- const renderResults = () => {
69
- // eslint-disable-next-line no-undef
70
- const { results } = data?.searchPublishedContent;
71
-
72
- if (results && searchTerm && searchTerm !== '') {
73
- return results.map(({ name, url }) => {
74
- if (name.includes(searchTerm)) {
75
- return (
76
- <BlazeLink href={url} onClick={e => handleClick(e, url)}>
77
- {name}
78
- </BlazeLink>
79
- );
80
- }
81
-
82
- return null;
83
- });
84
- }
85
-
86
- return [];
87
- };
88
-
89
- const searchResultsMessage = searchTerm ? `Search results for: ${searchTerm}` : '';
90
-
91
- return collapsed ? (
92
- <div className={isMobile ? searchInputWrapperMobile : searchInputWrapperDesktop}>
93
- <div className="search-content--collapse__wrapper">
94
- <label className="search-content--collapse__label">
95
- <span className="search-content--collapse__icon_wrapper">
96
- <svg className="search-content--collapse__icon" viewBox="0 0 20 20">
97
- <path
98
- fillRule="evenodd"
99
- d="M8 4a4 4 0 100 8 4 4 0 000-8zM2 8a6 6 0 1110.89 3.476l4.817 4.817a1 1 0 01-1.414 1.414l-4.816-4.816A6 6 0 012 8z"
100
- clipRule="evenodd"
101
- />
102
- </svg>
103
- </span>
104
- <input
105
- onFocus={() => setCollapsed(false)}
106
- onChange={e => setSearchTerm(e.target.value)}
107
- type="text"
108
- name="search"
109
- value=""
110
- className="search-content--collapse__input"
111
- />
112
- </label>
113
- </div>
114
- </div>
115
- ) : (
116
- <>
117
- <div className={`${isMobile ? searchInputWrapperMobile : searchInputWrapperDesktop}`}>
118
- <div className="search-content--expanded__wrapper">
119
- <label className="search-content--expanded__label">
120
- <span className="search-content--expanded__icon_wrapper">
121
- <svg className="search-content--expanded__icon" viewBox="0 0 20 20">
122
- <path
123
- fillRule="evenodd"
124
- d="M8 4a4 4 0 100 8 4 4 0 000-8zM2 8a6 6 0 1110.89 3.476l4.817 4.817a1 1 0 01-1.414 1.414l-4.816-4.816A6 6 0 012 8z"
125
- clipRule="evenodd"
126
- />
127
- </svg>
128
- </span>
129
- <input
130
- type="text"
131
- name="search"
132
- onChange={e => setSearchTerm(e.target.value)}
133
- onKeyPress={handleKeyPress}
134
- className="search-content--expanded__input"
135
- placeholder={placeholder}
136
- onBlur={() => {
137
- if (!collapsible) return;
138
- if (!searchTerm || searchTerm === '') setCollapsed(true);
139
- }}
140
- />
141
- </label>
142
- </div>
143
- {data &&
144
- searchResultsMessage !== '' && (
145
- <div className="search-content--results__wrapper">
146
- <div className="search-content--results__wrapper--message">
147
- <div className="text-sm pt-2">{searchResultsMessage}</div>
148
-
149
- <div className="search-content--results__message">
150
- <div className="search-content--results__content">{renderResults()}</div>
151
- </div>
152
- </div>
153
- </div>
154
- )}
155
- </div>
156
- </>
157
- );
158
- };
159
-
160
- SearchContent.propTypes = {
161
- searchInputAlignment: PropTypes.string,
162
- searchInputWrapperMobile: PropTypes.string,
163
- searchInputWrapperDesktop: PropTypes.string,
164
- placeholder: PropTypes.string,
165
- isMobile: PropTypes.bool,
166
- collapsible: PropTypes.bool,
167
- entity: PropTypes.string.isRequired
168
- };
169
-
170
- SearchContent.defaultProps = {
171
- searchInputAlignment: '',
172
- searchInputWrapperMobile: '',
173
- searchInputWrapperDesktop: '',
174
- placeholder: '',
175
- isMobile: false,
176
- collapsible: false
177
- };
1
+ import SearchContent from './SearchContent';
178
2
 
179
3
  export default SearchContent;