@blaze-cms/react-page-builder 0.124.0-alpha.9 → 0.124.1-alpha.2

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 (440) hide show
  1. package/CHANGELOG.md +325 -0
  2. package/README.md +8 -0
  3. package/lib/BannerContext/index.js.map +1 -1
  4. package/lib/HOC/withInfiniteScroll.js.map +1 -1
  5. package/lib/HOC/withTitle.js.map +1 -1
  6. package/lib/PBContext/index.js.map +1 -1
  7. package/lib/application/query/index.js +8 -2
  8. package/lib/application/query/index.js.map +1 -1
  9. package/lib/components/BackToTop/BackToTop.js.map +1 -1
  10. package/lib/components/Banner/AdSlotRender.js.map +1 -1
  11. package/lib/components/Banner/Banner.js.map +1 -1
  12. package/lib/components/Banner/BannerRender.js.map +1 -1
  13. package/lib/components/Banner/helpers.js.map +1 -1
  14. package/lib/components/Banner/index.js.map +1 -1
  15. package/lib/components/BlazeLink.js.map +1 -1
  16. package/lib/components/Breadcrumb/Breadcrumb.js.map +1 -1
  17. package/lib/components/Button.js +18 -5
  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 -301
  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 +18 -67
  155. package/lib/components/SearchFilter/SearchFilter/SearchFilter.js.map +1 -1
  156. package/lib/components/SearchFilter/SearchFilterContainer.js +97 -22
  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 +23 -6
  161. package/lib/components/SearchFilter/components/Range.js.map +1 -1
  162. package/lib/components/SearchFilter/components/Select.js +27 -11
  163. package/lib/components/SearchFilter/components/Select.js.map +1 -1
  164. package/lib/components/SearchFilter/components/TextSearch.js +1 -5
  165. package/lib/components/SearchFilter/components/TextSearch.js.map +1 -1
  166. package/lib/components/SearchFilter/helpers/build-filters-query.js +110 -0
  167. package/lib/components/SearchFilter/helpers/build-filters-query.js.map +1 -0
  168. package/lib/components/SearchFilter/helpers/build-query.js +1 -1
  169. package/lib/components/SearchFilter/helpers/build-query.js.map +1 -1
  170. package/lib/components/SearchFilter/helpers/build-raw-query-stringified.js +15 -8
  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 +16 -1
  176. package/lib/components/SearchFilter/helpers/get-initial-filter-values.js.map +1 -1
  177. package/lib/components/SearchFilter/helpers/get-intersected-prop.js.map +1 -1
  178. package/lib/components/SearchFilter/helpers/get-range-value.js +4 -2
  179. package/lib/components/SearchFilter/helpers/get-range-value.js.map +1 -1
  180. package/lib/components/SearchFilter/helpers/get-responsive-filter-classnames.js.map +1 -1
  181. package/lib/components/SearchFilter/helpers/get-select-options.js.map +1 -1
  182. package/lib/components/SearchFilter/helpers/index.js +8 -0
  183. package/lib/components/SearchFilter/helpers/index.js.map +1 -1
  184. package/lib/components/SearchFilter/helpers/parse-filter-value.js +3 -7
  185. package/lib/components/SearchFilter/helpers/parse-filter-value.js.map +1 -1
  186. package/lib/components/SearchFilterSort/SearchFilterSort.js.map +1 -1
  187. package/lib/components/SearchFilterSort/helpers/handle-sort-update.js.map +1 -1
  188. package/lib/components/SearchFilterSort/helpers/update-sort.js.map +1 -1
  189. package/lib/components/SocialFollow/SFItem.js.map +1 -1
  190. package/lib/components/SocialFollow/SocialFollow.js.map +1 -1
  191. package/lib/components/SocialFollow/SocialFollowRender.js.map +1 -1
  192. package/lib/components/SubMenu/SubMenu.js.map +1 -1
  193. package/lib/components/TextBlock/TextBlockRender.js.map +1 -1
  194. package/lib/components/TextBlock/index.js.map +1 -1
  195. package/lib/components/Video/Video.js.map +1 -1
  196. package/lib/components/Video/VideoModal.js.map +1 -1
  197. package/lib/components/Video/VideoRender.js.map +1 -1
  198. package/lib/components/Video/providers/Default.js.map +1 -1
  199. package/lib/components/Video/providers/JWPlayer/JWPlayerProvider.js.map +1 -1
  200. package/lib/components/Video/providers/YouTube/YouTubeProvider.js.map +1 -1
  201. package/lib/components/Video/providers/YouTube/YoutubeEmbeded.js.map +1 -1
  202. package/lib/components/Video/providers/get-provider.js.map +1 -1
  203. package/lib/components/Wrapper.js.map +1 -1
  204. package/lib/components/index.js +16 -1
  205. package/lib/components/index.js.map +1 -1
  206. package/lib/constants/index.js +3 -1
  207. package/lib/constants/index.js.map +1 -1
  208. package/lib/helpers/build-inherited-filters.js.map +1 -1
  209. package/lib/helpers/build-raw-query-base.js.map +1 -1
  210. package/lib/helpers/build-raw-query.js.map +1 -1
  211. package/lib/helpers/build-search-values-checkbox-select.js.map +1 -1
  212. package/lib/helpers/check-props-to-use.js.map +1 -1
  213. package/lib/helpers/get-entities-with-banner.js.map +1 -1
  214. package/lib/helpers/get-entity-data.js.map +1 -1
  215. package/lib/helpers/get-entity-render-props.js.map +1 -1
  216. package/lib/helpers/get-filter-props.js.map +1 -1
  217. package/lib/helpers/get-generic-props.js.map +1 -1
  218. package/lib/helpers/get-generic-render-variables.js.map +1 -1
  219. package/lib/helpers/get-image-ids.js.map +1 -1
  220. package/lib/helpers/get-parsed-prop-values.js.map +1 -1
  221. package/lib/helpers/get-prop-values.js.map +1 -1
  222. package/lib/helpers/get-query-filters.js.map +1 -1
  223. package/lib/helpers/get-query-props.js.map +1 -1
  224. package/lib/helpers/get-updated-filter-by.js.map +1 -1
  225. package/lib/helpers/inject-banner.js.map +1 -1
  226. package/lib/helpers/inject-banners-to-entities.js.map +1 -1
  227. package/lib/helpers/inject-multiple-banners/get-banners-for-entities/get-banners-for-entities.js.map +1 -1
  228. package/lib/helpers/inject-multiple-banners/get-banners-for-nodes/get-banners-for-nodes.js.map +1 -1
  229. package/lib/helpers/inject-multiple-banners/get-banners-for-nodes/helpers/group-node-entities.js.map +1 -1
  230. package/lib/helpers/inject-multiple-banners/inject-multiple-banners.js.map +1 -1
  231. package/lib/helpers/is-filter-entitys-id.js.map +1 -1
  232. package/lib/helpers/parse-TextBlock.js.map +1 -1
  233. package/lib/helpers/parse-props-to-display.js.map +1 -1
  234. package/lib/helpers/render-children.js.map +1 -1
  235. package/lib/helpers/sort-response-data.js.map +1 -1
  236. package/lib/hooks/helpers/RenderComponent.js.map +1 -1
  237. package/lib/hooks/helpers/append-gtm-classname.js +1 -0
  238. package/lib/hooks/helpers/append-gtm-classname.js.map +1 -1
  239. package/lib/hooks/helpers/buildPBComponents.js.map +1 -1
  240. package/lib/hooks/helpers/getComponent.js.map +1 -1
  241. package/lib/hooks/helpers/inject-element-banners.js.map +1 -1
  242. package/lib/hooks/helpers/inject-textblock-banners.js.map +1 -1
  243. package/lib/hooks/helpers/insert-banners.js.map +1 -1
  244. package/lib/hooks/helpers/update-targetings.js.map +1 -1
  245. package/lib/hooks/use-banner-insertion.js.map +1 -1
  246. package/lib/hooks/use-check-mobile-screen.js.map +1 -1
  247. package/lib/hooks/use-get-entity-schema.js.map +1 -1
  248. package/lib/hooks/use-get-entity-schemas-as-obj.js.map +1 -1
  249. package/lib/hooks/use-get-image-id-from-relation.js.map +1 -1
  250. package/lib/hooks/use-get-images.js.map +1 -1
  251. package/lib/hooks/use-get-single-entity-schema.js.map +1 -1
  252. package/lib/hooks/use-page-builder.js.map +1 -1
  253. package/lib/utils/get-class-modifiers.js.map +1 -1
  254. package/lib/utils/get-image-data.js.map +1 -1
  255. package/lib-es/application/query/index.js +45 -1
  256. package/lib-es/application/query/index.js.map +1 -1
  257. package/lib-es/components/Button.js +18 -6
  258. package/lib-es/components/Button.js.map +1 -1
  259. package/lib-es/components/Card/CardContainer.js +3 -7
  260. package/lib-es/components/Card/CardContainer.js.map +1 -1
  261. package/lib-es/components/Card/CardFactory.js +7 -4
  262. package/lib-es/components/Card/CardFactory.js.map +1 -1
  263. package/lib-es/components/CarouselWrapper.js +2 -2
  264. package/lib-es/components/CarouselWrapper.js.map +1 -1
  265. package/lib-es/components/Image/ImageRender.js +4 -1
  266. package/lib-es/components/Image/ImageRender.js.map +1 -1
  267. package/lib-es/components/ItemList/ItemListButton/ItemListButton.js +111 -0
  268. package/lib-es/components/ItemList/ItemListButton/ItemListButton.js.map +1 -0
  269. package/lib-es/components/ItemList/ItemListButton/index.js +3 -0
  270. package/lib-es/components/ItemList/ItemListButton/index.js.map +1 -0
  271. package/lib-es/components/ItemList/ItemListCounter/ItemListCounter.js +60 -0
  272. package/lib-es/components/ItemList/ItemListCounter/ItemListCounter.js.map +1 -0
  273. package/lib-es/components/ItemList/ItemListCounter/index.js +3 -0
  274. package/lib-es/components/ItemList/ItemListCounter/index.js.map +1 -0
  275. package/lib-es/components/ItemList/ItemListNew/ItemListNew.js +64 -0
  276. package/lib-es/components/ItemList/ItemListNew/ItemListNew.js.map +1 -0
  277. package/lib-es/components/ItemList/ItemListNew/index.js +3 -0
  278. package/lib-es/components/ItemList/ItemListNew/index.js.map +1 -0
  279. package/lib-es/components/ItemList/constants.js +6 -0
  280. package/lib-es/components/ItemList/constants.js.map +1 -0
  281. package/lib-es/components/ItemList/helpers/get-item-list-data.js +7 -0
  282. package/lib-es/components/ItemList/helpers/get-item-list-data.js.map +1 -0
  283. package/lib-es/components/ItemList/helpers/get-item-list-id.js +11 -0
  284. package/lib-es/components/ItemList/helpers/get-item-list-id.js.map +1 -0
  285. package/lib-es/components/ItemList/helpers/get-item-list-ids.js +13 -0
  286. package/lib-es/components/ItemList/helpers/get-item-list-ids.js.map +1 -0
  287. package/lib-es/components/ItemList/helpers/index.js +6 -0
  288. package/lib-es/components/ItemList/helpers/index.js.map +1 -0
  289. package/lib-es/components/ItemList/helpers/set-item-list-id.js +10 -0
  290. package/lib-es/components/ItemList/helpers/set-item-list-id.js.map +1 -0
  291. package/lib-es/components/ItemList/helpers/set-param-and-redirect.js +20 -0
  292. package/lib-es/components/ItemList/helpers/set-param-and-redirect.js.map +1 -0
  293. package/lib-es/components/ItemList/hooks/index.js +2 -0
  294. package/lib-es/components/ItemList/hooks/index.js.map +1 -0
  295. package/lib-es/components/ItemList/hooks/use-item-list-id.js +26 -0
  296. package/lib-es/components/ItemList/hooks/use-item-list-id.js.map +1 -0
  297. package/lib-es/components/LazyImage/LazyImage.js +4 -1
  298. package/lib-es/components/LazyImage/LazyImage.js.map +1 -1
  299. package/lib-es/components/List/ListBuilder.js +12 -6
  300. package/lib-es/components/List/ListBuilder.js.map +1 -1
  301. package/lib-es/components/List/ListFactory.js +33 -9
  302. package/lib-es/components/List/ListFactory.js.map +1 -1
  303. package/lib-es/components/List/helpers/has-required-item-list-details.js +20 -0
  304. package/lib-es/components/List/helpers/has-required-item-list-details.js.map +1 -0
  305. package/lib-es/components/List/helpers/index.js +1 -0
  306. package/lib-es/components/List/helpers/index.js.map +1 -1
  307. package/lib-es/components/Menu/Menu.js +54 -46
  308. package/lib-es/components/Menu/Menu.js.map +1 -1
  309. package/lib-es/components/Menu/MenuContext.js +6 -0
  310. package/lib-es/components/Menu/MenuContext.js.map +1 -0
  311. package/lib-es/components/MenuItem/MenuItem.js +24 -9
  312. package/lib-es/components/MenuItem/MenuItem.js.map +1 -1
  313. package/lib-es/components/SearchContent/SearchContent.js +129 -0
  314. package/lib-es/components/SearchContent/SearchContent.js.map +1 -0
  315. package/lib-es/components/SearchContent/SearchContentItems.js +33 -0
  316. package/lib-es/components/SearchContent/SearchContentItems.js.map +1 -0
  317. package/lib-es/components/SearchContent/SearchContentResults.js +31 -0
  318. package/lib-es/components/SearchContent/SearchContentResults.js.map +1 -0
  319. package/lib-es/components/SearchContent/SearchContentToggleIcon.js +30 -0
  320. package/lib-es/components/SearchContent/SearchContentToggleIcon.js.map +1 -0
  321. package/lib-es/components/SearchContent/index.js +1 -205
  322. package/lib-es/components/SearchContent/index.js.map +1 -1
  323. package/lib-es/components/SearchFilter/SearchFilter/FiltersList.js +2 -4
  324. package/lib-es/components/SearchFilter/SearchFilter/FiltersList.js.map +1 -1
  325. package/lib-es/components/SearchFilter/SearchFilter/SearchFilter.js +12 -44
  326. package/lib-es/components/SearchFilter/SearchFilter/SearchFilter.js.map +1 -1
  327. package/lib-es/components/SearchFilter/SearchFilterContainer.js +77 -15
  328. package/lib-es/components/SearchFilter/SearchFilterContainer.js.map +1 -1
  329. package/lib-es/components/SearchFilter/components/Checkbox.js +18 -9
  330. package/lib-es/components/SearchFilter/components/Checkbox.js.map +1 -1
  331. package/lib-es/components/SearchFilter/components/Range.js +19 -6
  332. package/lib-es/components/SearchFilter/components/Range.js.map +1 -1
  333. package/lib-es/components/SearchFilter/components/Select.js +23 -8
  334. package/lib-es/components/SearchFilter/components/Select.js.map +1 -1
  335. package/lib-es/components/SearchFilter/components/TextSearch.js +1 -5
  336. package/lib-es/components/SearchFilter/components/TextSearch.js.map +1 -1
  337. package/lib-es/components/SearchFilter/helpers/build-filters-query.js +73 -0
  338. package/lib-es/components/SearchFilter/helpers/build-filters-query.js.map +1 -0
  339. package/lib-es/components/SearchFilter/helpers/build-query.js +1 -1
  340. package/lib-es/components/SearchFilter/helpers/build-query.js.map +1 -1
  341. package/lib-es/components/SearchFilter/helpers/build-raw-query-stringified.js +15 -9
  342. package/lib-es/components/SearchFilter/helpers/build-raw-query-stringified.js.map +1 -1
  343. package/lib-es/components/SearchFilter/helpers/get-initial-filter-values.js +14 -1
  344. package/lib-es/components/SearchFilter/helpers/get-initial-filter-values.js.map +1 -1
  345. package/lib-es/components/SearchFilter/helpers/get-range-value.js +2 -2
  346. package/lib-es/components/SearchFilter/helpers/get-range-value.js.map +1 -1
  347. package/lib-es/components/SearchFilter/helpers/index.js +2 -1
  348. package/lib-es/components/SearchFilter/helpers/index.js.map +1 -1
  349. package/lib-es/components/SearchFilter/helpers/parse-filter-value.js +3 -3
  350. package/lib-es/components/SearchFilter/helpers/parse-filter-value.js.map +1 -1
  351. package/lib-es/components/index.js +10 -1
  352. package/lib-es/components/index.js.map +1 -1
  353. package/lib-es/constants/index.js +2 -1
  354. package/lib-es/constants/index.js.map +1 -1
  355. package/lib-es/helpers/build-raw-query.js.map +1 -1
  356. package/lib-es/hooks/helpers/append-gtm-classname.js +1 -0
  357. package/lib-es/hooks/helpers/append-gtm-classname.js.map +1 -1
  358. package/package.json +5 -4
  359. package/src/application/query/index.js +51 -1
  360. package/src/components/Button.js +27 -5
  361. package/src/components/Card/CardContainer.js +2 -6
  362. package/src/components/Card/CardFactory.js +5 -3
  363. package/src/components/CarouselWrapper.js +2 -2
  364. package/src/components/Image/ImageRender.js +3 -0
  365. package/src/components/ItemList/ItemListButton/ItemListButton.js +94 -0
  366. package/src/components/ItemList/ItemListButton/index.js +3 -0
  367. package/src/components/ItemList/ItemListCounter/ItemListCounter.js +52 -0
  368. package/src/components/ItemList/ItemListCounter/index.js +3 -0
  369. package/src/components/ItemList/ItemListNew/ItemListNew.js +51 -0
  370. package/src/components/ItemList/ItemListNew/index.js +3 -0
  371. package/src/components/ItemList/constants.js +5 -0
  372. package/src/components/ItemList/helpers/get-item-list-data.js +6 -0
  373. package/src/components/ItemList/helpers/get-item-list-id.js +11 -0
  374. package/src/components/ItemList/helpers/get-item-list-ids.js +10 -0
  375. package/src/components/ItemList/helpers/index.js +5 -0
  376. package/src/components/ItemList/helpers/set-item-list-id.js +9 -0
  377. package/src/components/ItemList/helpers/set-param-and-redirect.js +20 -0
  378. package/src/components/ItemList/hooks/index.js +1 -0
  379. package/src/components/ItemList/hooks/use-item-list-id.js +27 -0
  380. package/src/components/LazyImage/LazyImage.js +11 -1
  381. package/src/components/List/ListBuilder.js +10 -5
  382. package/src/components/List/ListFactory.js +48 -12
  383. package/src/components/List/helpers/has-required-item-list-details.js +14 -0
  384. package/src/components/List/helpers/index.js +1 -0
  385. package/src/components/Menu/Menu.js +61 -54
  386. package/src/components/Menu/MenuContext.js +5 -0
  387. package/src/components/MenuItem/MenuItem.js +39 -14
  388. package/src/components/SearchContent/SearchContent.js +136 -0
  389. package/src/components/SearchContent/SearchContentItems.js +28 -0
  390. package/src/components/SearchContent/SearchContentResults.js +27 -0
  391. package/src/components/SearchContent/SearchContentToggleIcon.js +27 -0
  392. package/src/components/SearchContent/index.js +1 -217
  393. package/src/components/SearchFilter/SearchFilter/FiltersList.js +30 -37
  394. package/src/components/SearchFilter/SearchFilter/SearchFilter.js +12 -26
  395. package/src/components/SearchFilter/SearchFilterContainer.js +72 -16
  396. package/src/components/SearchFilter/components/Checkbox.js +23 -8
  397. package/src/components/SearchFilter/components/Range.js +11 -5
  398. package/src/components/SearchFilter/components/Select.js +18 -11
  399. package/src/components/SearchFilter/components/TextSearch.js +1 -3
  400. package/src/components/SearchFilter/helpers/build-filters-query.js +60 -0
  401. package/src/components/SearchFilter/helpers/build-query.js +3 -1
  402. package/src/components/SearchFilter/helpers/build-raw-query-stringified.js +17 -11
  403. package/src/components/SearchFilter/helpers/get-initial-filter-values.js +15 -1
  404. package/src/components/SearchFilter/helpers/get-range-value.js +2 -2
  405. package/src/components/SearchFilter/helpers/index.js +3 -1
  406. package/src/components/SearchFilter/helpers/parse-filter-value.js +3 -3
  407. package/src/components/index.js +10 -1
  408. package/src/constants/index.js +2 -0
  409. package/src/helpers/build-raw-query.js +1 -0
  410. package/src/hooks/helpers/append-gtm-classname.js +3 -0
  411. package/tests/unit/src/components/Button.test.js +55 -1
  412. package/tests/unit/src/components/ItemList/ItemListButton.test.js +175 -0
  413. package/tests/unit/src/components/ItemList/ItemListCounter.test.js +65 -0
  414. package/tests/unit/src/components/ItemList/ItemListNew.test.js +164 -0
  415. package/tests/unit/src/components/ItemList/__snapshots__/ItemListButton.test.js.snap +107 -0
  416. package/tests/unit/src/components/ItemList/__snapshots__/ItemListCounter.test.js.snap +31 -0
  417. package/tests/unit/src/components/ItemList/__snapshots__/ItemListNew.test.js.snap +27 -0
  418. package/tests/unit/src/components/ItemList/helpers/get-item-list-data.test.js +28 -0
  419. package/tests/unit/src/components/ItemList/helpers/get-item-list-id.test.js +20 -0
  420. package/tests/unit/src/components/ItemList/helpers/get-item-list-ids.test.js +19 -0
  421. package/tests/unit/src/components/ItemList/helpers/set-item-list-id.test.js +13 -0
  422. package/tests/unit/src/components/ItemList/helpers/set-param-and-redirect.test.js +30 -0
  423. package/tests/unit/src/components/ItemList/hooks/use-item-list-id.test.js +32 -0
  424. package/tests/unit/src/components/List/helpers/has-required-item-list-details.test.js +30 -0
  425. package/tests/unit/src/components/Menu/Menu.test.js +9 -3
  426. package/tests/unit/src/components/Menu/__snapshots__/Menu.test.js.snap +12 -11
  427. package/tests/unit/src/components/MenuItem/MenuItem.test.js +1 -1
  428. package/tests/unit/src/components/MenuItem/SubMenu.test.js +5 -1
  429. package/tests/unit/src/components/MenuItem/__snapshots__/MenuItem.test.js.snap +54 -10
  430. package/tests/unit/src/components/SearchContent/SearchContent.test.js +29 -0
  431. package/tests/unit/src/components/SearchContent/__snapshots__/SearchContent.test.js.snap +9 -0
  432. package/tests/unit/src/components/SearchFilter/SearchFilter/SearchFilter.test.js +3 -6
  433. package/tests/unit/src/components/SearchFilter/components/Range.test.js +24 -0
  434. package/tests/unit/src/components/SearchFilter/components/__snapshots__/Checkbox.test.js.snap +2 -0
  435. package/tests/unit/src/components/SearchFilter/components/__snapshots__/Range.test.js.snap +3 -3
  436. package/tests/unit/src/components/SearchFilter/components/__snapshots__/Select.test.js.snap +4 -0
  437. package/tests/unit/src/components/SearchFilter/helpers/build-query.test.js +2 -2
  438. package/tests/unit/src/components/SearchFilter/helpers/get-initial-filter-values.test.js +31 -11
  439. package/tests/unit/src/components/SearchFilter/helpers/parse-filter-value.test.js +1 -1
  440. package/tests/unit/src/components/__snapshots__/index.test.js.snap +12 -0
@@ -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,219 +1,3 @@
1
- import React, { useState } from 'react';
2
- import PropTypes from 'prop-types';
3
- import { gql, useApolloClient } from '@apollo/client';
4
-
5
- import { useRouter } from 'next/router';
6
- import { getPublishedContent } from '../../application/query';
7
- import BlazeLink from '../BlazeLink';
8
-
9
- const logError = error => error;
10
-
11
- const SearchContent = ({
12
- entities,
13
- searchInputAlignment,
14
- searchInputWrapperMobile,
15
- searchInputWrapperDesktop,
16
- collapsible,
17
- isMobile,
18
- placeholder
19
- }) => {
20
- const [collapsed, setCollapsed] = useState(collapsible);
21
- const [searchTerm, setSearchTerm] = useState(null);
22
- const [data, setData] = useState([]);
23
-
24
- const router = useRouter();
25
- const client = useApolloClient();
26
-
27
- const capitalize = s => {
28
- if (typeof s !== 'string') return '';
29
- return s.charAt(0).toUpperCase() + s.slice(1);
30
- };
31
-
32
- React.useEffect(() => {
33
- if (data && data.length !== 0) return;
34
-
35
- const promises = entities.map(entity => {
36
- const [a, b] = entity.split('_');
37
-
38
- const entityName = capitalize(a) + capitalize(b);
39
-
40
- const rawQueryStringified = JSON.stringify({
41
- size: 0,
42
- query: {
43
- bool: {
44
- should: [
45
- {
46
- match: {
47
- docType: entity
48
- }
49
- }
50
- ],
51
- minimum_should_match: 1
52
- }
53
- }
54
- });
55
-
56
- const query = gql`
57
- ${getPublishedContent(entityName)}
58
- `;
59
-
60
- try {
61
- return client.query({
62
- query,
63
- variables: {
64
- rawQueryStringified,
65
- offset: 0,
66
- limit: 5
67
- }
68
- });
69
- } catch (e) {
70
- return [];
71
- }
72
- });
73
-
74
- try {
75
- (async () => {
76
- try {
77
- const fetchResults = await Promise.all(promises);
78
- const searchResults = fetchResults
79
- .map(result => {
80
- const { data: resultData } = result;
81
- return resultData.searchPublishedContent.results;
82
- })
83
- .flat();
84
-
85
- setData(searchResults);
86
- } catch (e) {
87
- logError(e);
88
- }
89
- })();
90
- } catch (e) {
91
- logError(e);
92
- }
93
- });
94
-
95
- const handleClick = (e, url) => {
96
- e.preventDefault();
97
- router.push(url);
98
- };
99
-
100
- const handleKeyPress = e => {
101
- if (e.key === 'Enter' && e.target.value !== '') {
102
- router.push(`/search?search_term=${e.target.value}`);
103
- }
104
- };
105
-
106
- const renderResults = () =>
107
- // eslint-disable-next-line no-undef
108
- data?.map(dataItem => {
109
- const { name, image, url } = dataItem;
110
-
111
- if (searchTerm && searchTerm !== '') {
112
- if (name.includes(searchTerm)) {
113
- return (
114
- <BlazeLink href={url} onClick={e => handleClick(e, url)}>
115
- <div className="mt-2 mb-1">
116
- <div className="flex justify-start items-center">
117
- {image.url ? <img src={image.url} alt={name} className="w-20 h-14" /> : null}
118
- <span className="ml-2">{name}</span>
119
- </div>
120
- </div>
121
- </BlazeLink>
122
- );
123
- }
124
-
125
- return null;
126
- }
127
- });
128
-
129
- const searchResultsMessage = searchTerm ? `Search results for: ${searchTerm}` : '';
130
-
131
- return collapsed ? (
132
- <div className={isMobile ? searchInputWrapperMobile : searchInputWrapperDesktop}>
133
- <div className="search-content--collapse__wrapper">
134
- <label className="search-content--collapse__label">
135
- <span className="search-content--collapse__icon_wrapper">
136
- <svg className="search-content--collapse__icon" viewBox="0 0 20 20">
137
- <path
138
- fillRule="evenodd"
139
- 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"
140
- clipRule="evenodd"
141
- />
142
- </svg>
143
- </span>
144
- <input
145
- onFocus={() => setCollapsed(false)}
146
- onChange={e => setSearchTerm(e.target.value)}
147
- type="text"
148
- name="search"
149
- value=""
150
- className="search-content--collapse__input"
151
- />
152
- </label>
153
- </div>
154
- </div>
155
- ) : (
156
- <>
157
- <div className={`${isMobile ? searchInputWrapperMobile : searchInputWrapperDesktop}`}>
158
- <div className="search-content--expanded__wrapper">
159
- <label className="search-content--expanded__label">
160
- <span className="search-content--expanded__icon_wrapper">
161
- <svg className="search-content--expanded__icon" viewBox="0 0 20 20">
162
- <path
163
- fillRule="evenodd"
164
- 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"
165
- clipRule="evenodd"
166
- />
167
- </svg>
168
- </span>
169
- <input
170
- type="text"
171
- name="search"
172
- onChange={e => setSearchTerm(e.target.value)}
173
- onKeyPress={handleKeyPress}
174
- className="search-content--expanded__input"
175
- placeholder={placeholder}
176
- onBlur={() => {
177
- if (!collapsible) return;
178
- if (!searchTerm || searchTerm === '') setCollapsed(true);
179
- }}
180
- />
181
- </label>
182
- </div>
183
- {data &&
184
- searchResultsMessage !== '' && (
185
- <div className="search-content--results__wrapper">
186
- <div className="search-content--results__wrapper--message">
187
- <div className="text-sm pt-2">{searchResultsMessage}</div>
188
-
189
- <div className="search-content--results__message">
190
- <div className="search-content--results__content">{renderResults()}</div>
191
- </div>
192
- </div>
193
- </div>
194
- )}
195
- </div>
196
- </>
197
- );
198
- };
199
-
200
- SearchContent.propTypes = {
201
- searchInputAlignment: PropTypes.string,
202
- searchInputWrapperMobile: PropTypes.string,
203
- searchInputWrapperDesktop: PropTypes.string,
204
- placeholder: PropTypes.string,
205
- isMobile: PropTypes.bool,
206
- collapsible: PropTypes.bool,
207
- entities: PropTypes.array.isRequired
208
- };
209
-
210
- SearchContent.defaultProps = {
211
- searchInputAlignment: '',
212
- searchInputWrapperMobile: '',
213
- searchInputWrapperDesktop: '',
214
- placeholder: '',
215
- isMobile: false,
216
- collapsible: false
217
- };
1
+ import SearchContent from './SearchContent';
218
2
 
219
3
  export default SearchContent;
@@ -17,13 +17,10 @@ const FiltersList = ({
17
17
 
18
18
  return filters.map(({ type, label, propsToDisplay, elementTitle, ...otherProps }, index) => {
19
19
  if (!propsToDisplay && !propsToDisplay.length) return null;
20
-
21
20
  const dynamicKey = [itemId, index].join('-');
22
21
  const isDataAvailable = !!data && Object.keys(data).length;
23
22
  const dataAggregations = isDataAvailable ? data : null;
24
23
  const areAggregationsAvailable = isDataAvailable && !!dataAggregations;
25
- const results = areAggregationsAvailable && dataAggregations[propsToDisplay[0]];
26
- const shouldDisplayFilter = results && results.buckets && results.buckets.length;
27
24
 
28
25
  switch (type) {
29
26
  case TEXT_SEARCH:
@@ -43,43 +40,39 @@ const FiltersList = ({
43
40
  );
44
41
  case CHECKBOX:
45
42
  return (
46
- !!shouldDisplayFilter && (
47
- <div
48
- key={dynamicKey}
49
- className="filter__section filter__section--search-refine filter__section--checkboxes">
50
- <Checkbox
51
- {...otherProps}
52
- data={data}
53
- prop={propsToDisplay[0]}
54
- label={label}
55
- elementTitle={elementTitle}
56
- hasUrl={hasUrl}
57
- filterValues={filterValues}
58
- updateFilterValues={updateFilterValues}
59
- shouldSearch={shouldSearch}
60
- />
61
- </div>
62
- )
43
+ <div
44
+ key={dynamicKey}
45
+ className="filter__section filter__section--search-refine filter__section--checkboxes">
46
+ <Checkbox
47
+ {...otherProps}
48
+ data={data}
49
+ prop={propsToDisplay[0]}
50
+ label={label}
51
+ elementTitle={elementTitle}
52
+ hasUrl={hasUrl}
53
+ filterValues={filterValues}
54
+ updateFilterValues={updateFilterValues}
55
+ shouldSearch={shouldSearch}
56
+ />
57
+ </div>
63
58
  );
64
59
  case SELECT:
65
60
  return (
66
- !!shouldDisplayFilter && (
67
- <div
68
- key={dynamicKey}
69
- className="filter__section filter__section--search-refine filter__section--selects">
70
- <SelectFilter
71
- {...otherProps}
72
- data={data}
73
- prop={propsToDisplay[0]}
74
- label={label}
75
- elementTitle={elementTitle}
76
- hasUrl={hasUrl}
77
- filterValues={filterValues}
78
- updateFilterValues={updateFilterValues}
79
- shouldSearch={shouldSearch}
80
- />
81
- </div>
82
- )
61
+ <div
62
+ key={dynamicKey}
63
+ className="filter__section filter__section--search-refine filter__section--selects">
64
+ <SelectFilter
65
+ {...otherProps}
66
+ data={data}
67
+ prop={propsToDisplay[0]}
68
+ label={label}
69
+ elementTitle={elementTitle}
70
+ hasUrl={hasUrl}
71
+ filterValues={filterValues}
72
+ updateFilterValues={updateFilterValues}
73
+ shouldSearch={shouldSearch}
74
+ />
75
+ </div>
83
76
  );
84
77
  case RANGE:
85
78
  return (
@@ -1,4 +1,4 @@
1
- import React, { useState, useEffect, useReducer } from 'react';
1
+ import React, { useState, useEffect } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import classnames from 'classnames';
4
4
  import debounce from 'lodash.debounce';
@@ -14,21 +14,6 @@ import ResetDesktopForm from './ResetDesktopForm';
14
14
  import MobileFormToolbar from './MobileFormToolbar';
15
15
  import { SEARCH, REFINE, MORE_FILTERS_CLASSES } from '../constants';
16
16
 
17
- const reducer = (state, action) => {
18
- const { newValues, type, shouldSearch = true } = action;
19
-
20
- switch (type) {
21
- case 'update':
22
- return { ...state, ...newValues, shouldSearch };
23
- case 'resetSearch':
24
- return { ...state, shouldSearch: false };
25
- case 'reset':
26
- return { ...newValues, shouldSearch };
27
- default:
28
- throw new Error();
29
- }
30
- };
31
-
32
17
  const SearchFilter = ({
33
18
  searchFilterRef,
34
19
  data,
@@ -40,13 +25,13 @@ const SearchFilter = ({
40
25
  isCollapsedOnResponsive,
41
26
  displaySearchFilter,
42
27
  setDisplaySearchFilter,
43
- initialFilterValues,
44
28
  groupAfterDesktop,
45
- groupAfterMobile
29
+ groupAfterMobile,
30
+ filterValues,
31
+ setAppliedFilters
46
32
  }) => {
47
33
  const [moreFiltersMobileCollapsed, setMoreFiltersMobileCollapsed] = useState(true);
48
34
  const [moreFiltersDesktopCollapsed, setMoreFiltersDesktopCollapsed] = useState(true);
49
- const [filterValues, dispatch] = useReducer(reducer, initialFilterValues);
50
35
 
51
36
  const doSubmit = (newValues = filterValues) => {
52
37
  const newQuery = buildQuery(newValues, filters);
@@ -63,10 +48,10 @@ const SearchFilter = ({
63
48
  () => {
64
49
  if (filterValues.shouldSearch) {
65
50
  handleSubmit(filterValues);
66
- dispatch({ type: 'resetSearch' });
51
+ setAppliedFilters({ type: 'resetSearch' });
67
52
  }
68
53
  },
69
- [filterValues, handleSubmit]
54
+ [filterValues, handleSubmit, setAppliedFilters]
70
55
  );
71
56
 
72
57
  const formClass = classnames('filter__form filter__form--initial', {
@@ -84,13 +69,13 @@ const SearchFilter = ({
84
69
  const formId = `filter-${name}-form`;
85
70
 
86
71
  const handleReset = () => {
87
- const newValues = getInitialFilterValues(data, filters, {});
88
-
89
- dispatch({ newValues, type: 'reset' });
72
+ const newValues = getInitialFilterValues(null, filters, {});
73
+ setAppliedFilters({ newValues, type: 'reset' });
74
+ doSubmit(newValues);
90
75
  };
91
76
 
92
77
  const updateFilterValues = (newValues, shouldSubmit) => {
93
- dispatch({ newValues, shouldSearch: shouldSubmit, type: 'update' });
78
+ setAppliedFilters({ newValues, shouldSearch: shouldSubmit, type: 'update' });
94
79
  };
95
80
 
96
81
  const shouldGroup = !!(groupAfterDesktop || groupAfterMobile);
@@ -248,7 +233,8 @@ SearchFilter.propTypes = {
248
233
  isCollapsedOnResponsive: PropTypes.bool.isRequired,
249
234
  groupAfterDesktop: PropTypes.number.isRequired,
250
235
  groupAfterMobile: PropTypes.number.isRequired,
251
- initialFilterValues: PropTypes.object.isRequired
236
+ filterValues: PropTypes.object.isRequired,
237
+ setAppliedFilters: PropTypes.func.isRequired
252
238
  };
253
239
 
254
240
  export default SearchFilter;