@usereactify/search 4.4.1 → 5.0.0-beta.10

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 (244) hide show
  1. package/CHANGELOG.md +93 -0
  2. package/dist/package.json +11 -8
  3. package/dist/src/components/Example/ExampleFilterList.d.ts +4 -0
  4. package/dist/src/components/Example/ExampleFilterList.js +21 -0
  5. package/dist/src/components/Example/ExampleFilterList.js.map +1 -0
  6. package/dist/src/components/Example/ExampleFilterRange.d.ts +4 -0
  7. package/dist/src/components/Example/ExampleFilterRange.js +22 -0
  8. package/dist/src/components/Example/ExampleFilterRange.js.map +1 -0
  9. package/dist/src/components/Example/ExampleFilterSlider.d.ts +4 -0
  10. package/dist/src/components/Example/ExampleFilterSlider.js +21 -0
  11. package/dist/src/components/Example/ExampleFilterSlider.js.map +1 -0
  12. package/dist/src/components/Example/ExampleFilterStack.d.ts +4 -0
  13. package/dist/src/components/Example/ExampleFilterStack.js +13 -0
  14. package/dist/src/components/Example/ExampleFilterStack.js.map +1 -0
  15. package/dist/src/components/Example/ExampleResultCardCallout.d.ts +4 -0
  16. package/dist/src/components/Example/ExampleResultCardCallout.js +22 -0
  17. package/dist/src/components/Example/ExampleResultCardCallout.js.map +1 -0
  18. package/dist/src/components/Example/ExampleResultCardProduct.d.ts +4 -0
  19. package/dist/src/components/Example/ExampleResultCardProduct.js +19 -0
  20. package/dist/src/components/Example/ExampleResultCardProduct.js.map +1 -0
  21. package/dist/src/components/Example/ExampleResultPaginationLoadMore.d.ts +4 -0
  22. package/dist/src/components/Example/ExampleResultPaginationLoadMore.js +12 -0
  23. package/dist/src/components/Example/ExampleResultPaginationLoadMore.js.map +1 -0
  24. package/dist/src/components/Example/ExampleResultPaginationNextPrev.d.ts +4 -0
  25. package/dist/src/components/Example/ExampleResultPaginationNextPrev.js +14 -0
  26. package/dist/src/components/Example/ExampleResultPaginationNextPrev.js.map +1 -0
  27. package/dist/src/components/Example/ExampleResultPaginationNumbered.d.ts +4 -0
  28. package/dist/src/components/Example/ExampleResultPaginationNumbered.js +27 -0
  29. package/dist/src/components/Example/ExampleResultPaginationNumbered.js.map +1 -0
  30. package/dist/src/components/Example/ExampleSortby.d.ts +4 -0
  31. package/dist/src/components/Example/ExampleSortby.js +13 -0
  32. package/dist/src/components/Example/ExampleSortby.js.map +1 -0
  33. package/dist/src/components/Example/index.d.ts +10 -0
  34. package/dist/src/components/Example/index.js +23 -0
  35. package/dist/src/components/Example/index.js.map +1 -0
  36. package/dist/src/components/Filter/Filter.d.ts +20 -0
  37. package/dist/src/components/Filter/Filter.js +90 -0
  38. package/dist/src/components/Filter/Filter.js.map +1 -0
  39. package/dist/src/components/Filter/FilterStack.d.ts +7 -0
  40. package/dist/src/components/Filter/FilterStack.js +17 -0
  41. package/dist/src/components/Filter/FilterStack.js.map +1 -0
  42. package/dist/src/{filter → components/Filter}/index.d.ts +0 -1
  43. package/dist/src/{filter → components/Filter}/index.js +1 -1
  44. package/dist/src/components/Filter/index.js.map +1 -0
  45. package/dist/src/components/ReactifySearchBase/ReactifySearchBase.d.ts +42 -0
  46. package/dist/src/components/ReactifySearchBase/ReactifySearchBase.js +128 -0
  47. package/dist/src/components/ReactifySearchBase/ReactifySearchBase.js.map +1 -0
  48. package/dist/src/components/ReactifySearchBase/index.d.ts +1 -0
  49. package/dist/src/components/ReactifySearchBase/index.js +14 -0
  50. package/dist/src/components/ReactifySearchBase/index.js.map +1 -0
  51. package/dist/src/components/Result/ResultCardCallout.d.ts +12 -0
  52. package/dist/src/{result → components/Result}/ResultCardCallout.js +14 -22
  53. package/dist/src/components/Result/ResultCardCallout.js.map +1 -0
  54. package/dist/src/components/Result/ResultCardProduct.d.ts +13 -0
  55. package/dist/src/components/Result/ResultCardProduct.js +50 -0
  56. package/dist/src/components/Result/ResultCardProduct.js.map +1 -0
  57. package/dist/src/components/Result/ResultPaginationLoadMore.d.ts +7 -0
  58. package/dist/src/components/Result/ResultPaginationLoadMore.js +17 -0
  59. package/dist/src/components/Result/ResultPaginationLoadMore.js.map +1 -0
  60. package/dist/src/components/Result/ResultPaginationNextPrev.d.ts +7 -0
  61. package/dist/src/components/Result/ResultPaginationNextPrev.js +17 -0
  62. package/dist/src/components/Result/ResultPaginationNextPrev.js.map +1 -0
  63. package/dist/src/components/Result/ResultPaginationNumbered.d.ts +7 -0
  64. package/dist/src/components/Result/ResultPaginationNumbered.js +20 -0
  65. package/dist/src/components/Result/ResultPaginationNumbered.js.map +1 -0
  66. package/dist/src/components/Result/ResultStack.d.ts +40 -0
  67. package/dist/src/components/Result/ResultStack.js +108 -0
  68. package/dist/src/components/Result/ResultStack.js.map +1 -0
  69. package/dist/src/components/Result/ResultStateProvider.d.ts +6 -0
  70. package/dist/src/{result → components/Result}/ResultStateProvider.js +5 -1
  71. package/dist/src/components/Result/ResultStateProvider.js.map +1 -0
  72. package/dist/src/components/Result/index.d.ts +7 -0
  73. package/dist/src/{result → components/Result}/index.js +6 -4
  74. package/dist/src/components/Result/index.js.map +1 -0
  75. package/dist/src/components/Search/SearchInput.d.ts +8 -0
  76. package/dist/src/{search → components/Search}/SearchInput.js +3 -2
  77. package/dist/src/components/Search/SearchInput.js.map +1 -0
  78. package/dist/src/{search → components/Search}/index.d.ts +0 -0
  79. package/dist/src/{search → components/Search}/index.js +1 -0
  80. package/dist/src/components/Search/index.js.map +1 -0
  81. package/dist/src/{sensor → components/Sensor}/SensorCollection.d.ts +0 -0
  82. package/dist/src/{sensor → components/Sensor}/SensorCollection.js +9 -5
  83. package/dist/src/components/Sensor/SensorCollection.js.map +1 -0
  84. package/dist/src/{sensor → components/Sensor}/SensorInventoryAvailable.d.ts +0 -0
  85. package/dist/src/{sensor → components/Sensor}/SensorInventoryAvailable.js +3 -2
  86. package/dist/src/components/Sensor/SensorInventoryAvailable.js.map +1 -0
  87. package/dist/src/{sensor → components/Sensor}/SensorPublished.d.ts +0 -0
  88. package/dist/src/{sensor → components/Sensor}/SensorPublished.js +1 -0
  89. package/dist/src/components/Sensor/SensorPublished.js.map +1 -0
  90. package/dist/src/{sensor → components/Sensor}/SensorSearch.d.ts +0 -0
  91. package/dist/src/{sensor → components/Sensor}/SensorSearch.js +4 -3
  92. package/dist/src/components/Sensor/SensorSearch.js.map +1 -0
  93. package/dist/src/{sensor → components/Sensor}/SensorSort.d.ts +0 -0
  94. package/dist/src/{sensor → components/Sensor}/SensorSort.js +6 -24
  95. package/dist/src/components/Sensor/SensorSort.js.map +1 -0
  96. package/dist/src/{sensor → components/Sensor}/SensorSortScore.d.ts +0 -0
  97. package/dist/src/{sensor → components/Sensor}/SensorSortScore.js +1 -0
  98. package/dist/src/components/Sensor/SensorSortScore.js.map +1 -0
  99. package/dist/src/components/Sensor/SensorStack.d.ts +3 -0
  100. package/dist/src/{sensor → components/Sensor}/SensorStack.js +4 -3
  101. package/dist/src/components/Sensor/SensorStack.js.map +1 -0
  102. package/dist/src/{sensor → components/Sensor}/index.d.ts +0 -0
  103. package/dist/src/{sensor → components/Sensor}/index.js +1 -0
  104. package/dist/src/components/Sensor/index.js.map +1 -0
  105. package/dist/src/components/Sortby/Sortby.d.ts +7 -0
  106. package/dist/src/components/Sortby/Sortby.js +17 -0
  107. package/dist/src/components/Sortby/Sortby.js.map +1 -0
  108. package/dist/src/components/Sortby/index.d.ts +1 -0
  109. package/dist/src/components/Sortby/index.js +14 -0
  110. package/dist/src/components/Sortby/index.js.map +1 -0
  111. package/dist/src/{utility → components/Utility}/UtilityAuthenticatedReactiveBase.d.ts +0 -0
  112. package/dist/src/{utility → components/Utility}/UtilityAuthenticatedReactiveBase.js +5 -4
  113. package/dist/src/components/Utility/UtilityAuthenticatedReactiveBase.js.map +1 -0
  114. package/dist/src/components/Utility/index.d.ts +1 -0
  115. package/dist/src/components/Utility/index.js +14 -0
  116. package/dist/src/components/Utility/index.js.map +1 -0
  117. package/dist/src/components/index.d.ts +8 -0
  118. package/dist/src/components/index.js +21 -0
  119. package/dist/src/components/index.js.map +1 -0
  120. package/dist/src/hooks/index.d.ts +6 -5
  121. package/dist/src/hooks/index.js +7 -5
  122. package/dist/src/hooks/index.js.map +1 -0
  123. package/dist/src/hooks/reactivesearch/index.d.ts +4 -1
  124. package/dist/src/hooks/reactivesearch/index.js +5 -1
  125. package/dist/src/hooks/reactivesearch/index.js.map +1 -0
  126. package/dist/src/hooks/reactivesearch/useReactiveBaseProps.d.ts +1 -1
  127. package/dist/src/hooks/reactivesearch/useReactiveBaseProps.js +8 -7
  128. package/dist/src/hooks/reactivesearch/useReactiveBaseProps.js.map +1 -0
  129. package/dist/src/hooks/reactivesearch/useReactiveDataSearchProps.d.ts +6 -8
  130. package/dist/src/hooks/reactivesearch/useReactiveDataSearchProps.js +30 -31
  131. package/dist/src/hooks/reactivesearch/useReactiveDataSearchProps.js.map +1 -0
  132. package/dist/src/hooks/reactivesearch/useReactiveFilterListProps.d.ts +9 -4
  133. package/dist/src/hooks/reactivesearch/useReactiveFilterListProps.js +10 -94
  134. package/dist/src/hooks/reactivesearch/useReactiveFilterListProps.js.map +1 -0
  135. package/dist/src/hooks/reactivesearch/useReactiveFilterRangeProps.d.ts +70 -0
  136. package/dist/src/hooks/reactivesearch/useReactiveFilterRangeProps.js +22 -0
  137. package/dist/src/hooks/reactivesearch/useReactiveFilterRangeProps.js.map +1 -0
  138. package/dist/src/hooks/reactivesearch/useReactiveFilterSharedProps.d.ts +67 -0
  139. package/dist/src/hooks/reactivesearch/useReactiveFilterSharedProps.js +106 -0
  140. package/dist/src/hooks/reactivesearch/useReactiveFilterSharedProps.js.map +1 -0
  141. package/dist/src/hooks/reactivesearch/useReactiveFilterSliderProps.d.ts +68 -0
  142. package/dist/src/hooks/reactivesearch/useReactiveFilterSliderProps.js +22 -0
  143. package/dist/src/hooks/reactivesearch/useReactiveFilterSliderProps.js.map +1 -0
  144. package/dist/src/hooks/reactivesearch/useReactiveReactProp.js +9 -8
  145. package/dist/src/hooks/reactivesearch/useReactiveReactProp.js.map +1 -0
  146. package/dist/src/hooks/reactivesearch/{useReactiveResultListProps.d.ts → useReactiveResultStackProps.d.ts} +2 -4
  147. package/dist/src/hooks/reactivesearch/{useReactiveResultListProps.js → useReactiveResultStackProps.js} +9 -9
  148. package/dist/src/hooks/reactivesearch/useReactiveResultStackProps.js.map +1 -0
  149. package/dist/src/hooks/useAnalytics.js +7 -4
  150. package/dist/src/hooks/useAnalytics.js.map +1 -0
  151. package/dist/src/hooks/useConfig.d.ts +4 -1
  152. package/dist/src/hooks/useConfig.js +79 -2
  153. package/dist/src/hooks/useConfig.js.map +1 -0
  154. package/dist/src/hooks/useCuration.d.ts +2 -1
  155. package/dist/src/hooks/useCuration.js +62 -2
  156. package/dist/src/hooks/useCuration.js.map +1 -0
  157. package/dist/src/hooks/useDebugger.d.ts +1 -0
  158. package/dist/src/hooks/useDebugger.js +15 -0
  159. package/dist/src/hooks/useDebugger.js.map +1 -0
  160. package/dist/src/hooks/useFilterCollapsedState.js +1 -0
  161. package/dist/src/hooks/useFilterCollapsedState.js.map +1 -0
  162. package/dist/src/hooks/useFilterListProps.d.ts +4 -14
  163. package/dist/src/hooks/useFilterListProps.js +1 -0
  164. package/dist/src/hooks/useFilterListProps.js.map +1 -0
  165. package/dist/src/hooks/useFilterStack.d.ts +4 -1
  166. package/dist/src/hooks/useFilterStack.js +48 -2
  167. package/dist/src/hooks/useFilterStack.js.map +1 -0
  168. package/dist/src/hooks/useFilters.d.ts +4 -1
  169. package/dist/src/hooks/useFilters.js +16 -6
  170. package/dist/src/hooks/useFilters.js.map +1 -0
  171. package/dist/src/hooks/usePagination.d.ts +14 -0
  172. package/dist/src/hooks/{usePages.js → usePagination.js} +41 -29
  173. package/dist/src/hooks/usePagination.js.map +1 -0
  174. package/dist/src/hooks/usePaginationLoadMore.d.ts +15 -0
  175. package/dist/src/hooks/usePaginationLoadMore.js +38 -0
  176. package/dist/src/hooks/usePaginationLoadMore.js.map +1 -0
  177. package/dist/src/hooks/useProductPrice.d.ts +3 -5
  178. package/dist/src/hooks/useProductPrice.js +43 -40
  179. package/dist/src/hooks/useProductPrice.js.map +1 -0
  180. package/dist/src/hooks/useReactifySearchContext.d.ts +78 -0
  181. package/dist/src/hooks/useReactifySearchContext.js +11 -0
  182. package/dist/src/hooks/useReactifySearchContext.js.map +1 -0
  183. package/dist/src/hooks/useSearch.d.ts +5 -5
  184. package/dist/src/hooks/useSearch.js +42 -8
  185. package/dist/src/hooks/useSearch.js.map +1 -0
  186. package/dist/src/hooks/useSortby.d.ts +6 -0
  187. package/dist/src/hooks/useSortby.js +58 -0
  188. package/dist/src/hooks/useSortby.js.map +1 -0
  189. package/dist/src/index.d.ts +2 -8
  190. package/dist/src/index.js +48 -11
  191. package/dist/src/index.js.map +1 -0
  192. package/dist/src/types/config.d.ts +1 -0
  193. package/dist/src/types/config.js +1 -0
  194. package/dist/src/types/config.js.map +1 -0
  195. package/dist/src/types/elastic.js +1 -0
  196. package/dist/src/types/elastic.js.map +1 -0
  197. package/dist/src/types/firestore.js +1 -0
  198. package/dist/src/types/firestore.js.map +1 -0
  199. package/dist/src/types/graphql.js +1 -0
  200. package/dist/src/types/graphql.js.map +1 -0
  201. package/dist/src/types/index.d.ts +3 -0
  202. package/dist/src/types/index.js +16 -0
  203. package/dist/src/types/index.js.map +1 -0
  204. package/dist/src/types/reactivesearch.js +1 -0
  205. package/dist/src/types/reactivesearch.js.map +1 -0
  206. package/dist/src/types/shopify.js +1 -0
  207. package/dist/src/types/shopify.js.map +1 -0
  208. package/dist/src/utility/debug.d.ts +10 -0
  209. package/dist/src/utility/debug.js +39 -0
  210. package/dist/src/utility/debug.js.map +1 -0
  211. package/dist/src/utility/index.d.ts +1 -0
  212. package/dist/src/utility/index.js +14 -0
  213. package/dist/src/utility/index.js.map +1 -0
  214. package/package.json +11 -8
  215. package/dist/src/filter/Filter.d.ts +0 -12
  216. package/dist/src/filter/Filter.js +0 -71
  217. package/dist/src/filter/FilterList.d.ts +0 -4
  218. package/dist/src/filter/FilterList.js +0 -15
  219. package/dist/src/filter/FilterStack.d.ts +0 -11
  220. package/dist/src/filter/FilterStack.js +0 -25
  221. package/dist/src/hooks/useCollection.d.ts +0 -1
  222. package/dist/src/hooks/useCollection.js +0 -6
  223. package/dist/src/hooks/useLiveConfig.d.ts +0 -4
  224. package/dist/src/hooks/useLiveConfig.js +0 -74
  225. package/dist/src/hooks/usePages.d.ts +0 -10
  226. package/dist/src/hooks/useSort.d.ts +0 -5
  227. package/dist/src/hooks/useSort.js +0 -24
  228. package/dist/src/provider.d.ts +0 -78
  229. package/dist/src/provider.js +0 -287
  230. package/dist/src/result/ResultCard.d.ts +0 -14
  231. package/dist/src/result/ResultCard.js +0 -66
  232. package/dist/src/result/ResultCardCallout.d.ts +0 -13
  233. package/dist/src/result/ResultList.d.ts +0 -34
  234. package/dist/src/result/ResultList.js +0 -93
  235. package/dist/src/result/ResultLoadMoreButton.d.ts +0 -10
  236. package/dist/src/result/ResultLoadMoreButton.js +0 -61
  237. package/dist/src/result/ResultPagination.d.ts +0 -10
  238. package/dist/src/result/ResultPagination.js +0 -60
  239. package/dist/src/result/ResultPaginationNextPrev.d.ts +0 -8
  240. package/dist/src/result/ResultPaginationNextPrev.js +0 -30
  241. package/dist/src/result/ResultStateProvider.d.ts +0 -7
  242. package/dist/src/result/index.d.ts +0 -6
  243. package/dist/src/search/SearchInput.d.ts +0 -9
  244. package/dist/src/sensor/SensorStack.d.ts +0 -2
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import { useSortby } from "../../hooks";
3
+ export declare type SortbyProps = {
4
+ /** Render method called once for all sort options */
5
+ renderSortOptions?: React.FC<ReturnType<typeof useSortby>>;
6
+ };
7
+ export declare const Sortby: React.FC<SortbyProps>;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Sortby = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const hooks_1 = require("../../hooks");
9
+ const components_1 = require("../../components");
10
+ const Sortby = (props) => {
11
+ var _a;
12
+ const sortbyData = (0, hooks_1.useSortby)();
13
+ const RenderSortOptionsComponent = (_a = props.renderSortOptions) !== null && _a !== void 0 ? _a : components_1.ExampleSortby;
14
+ return (react_1.default.createElement(RenderSortOptionsComponent, Object.assign({}, sortbyData)));
15
+ };
16
+ exports.Sortby = Sortby;
17
+ //# sourceMappingURL=Sortby.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Sortby.js","sourceRoot":"","sources":["../../../../src/components/Sortby/Sortby.tsx"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAE1B,uCAAwC;AACxC,iDAAiD;AAO1C,MAAM,MAAM,GAA0B,CAAC,KAAK,EAAE,EAAE;;IACrD,MAAM,UAAU,GAAG,IAAA,iBAAS,GAAE,CAAC;IAE/B,MAAM,0BAA0B,GAAG,MAAA,KAAK,CAAC,iBAAiB,mCAAI,0BAAa,CAAC;IAE5E,OAAO,CACL,8BAAC,0BAA0B,oBACrB,UAAU,EACd,CACH,CAAC;AACJ,CAAC,CAAC;AAVW,QAAA,MAAM,UAUjB","sourcesContent":["import React from \"react\";\n\nimport { useSortby } from \"../../hooks\";\nimport { ExampleSortby } from \"../../components\";\n\nexport type SortbyProps = {\n /** Render method called once for all sort options */\n renderSortOptions?: React.FC<ReturnType<typeof useSortby>>;\n};\n\nexport const Sortby: React.FC<SortbyProps> = (props) => {\n const sortbyData = useSortby();\n\n const RenderSortOptionsComponent = props.renderSortOptions ?? ExampleSortby;\n\n return (\n <RenderSortOptionsComponent\n {...sortbyData}\n />\n );\n};\n"]}
@@ -0,0 +1 @@
1
+ export * from "./Sortby";
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./Sortby"), exports);
14
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/Sortby/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAyB","sourcesContent":["export * from \"./Sortby\";"]}
@@ -5,10 +5,11 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.UtilityAuthenticatedReactiveBase = void 0;
7
7
  const react_1 = __importDefault(require("react"));
8
- const useReactiveBaseProps_1 = require("../hooks/reactivesearch/useReactiveBaseProps");
8
+ const hooks_1 = require("../../hooks");
9
9
  const ReactiveBase_1 = __importDefault(require("@appbaseio/reactivesearch/lib/components/basic/ReactiveBase"));
10
- const UtilityAuthenticatedReactiveBase = ({ children }) => {
11
- const props = (0, useReactiveBaseProps_1.useReactiveBaseProps)();
12
- return react_1.default.createElement(ReactiveBase_1.default, Object.assign({}, props), children);
10
+ const UtilityAuthenticatedReactiveBase = (props) => {
11
+ const reactiveBaseProps = (0, hooks_1.useReactiveBaseProps)();
12
+ return (react_1.default.createElement(ReactiveBase_1.default, Object.assign({}, reactiveBaseProps), props.children));
13
13
  };
14
14
  exports.UtilityAuthenticatedReactiveBase = UtilityAuthenticatedReactiveBase;
15
+ //# sourceMappingURL=UtilityAuthenticatedReactiveBase.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UtilityAuthenticatedReactiveBase.js","sourceRoot":"","sources":["../../../../src/components/Utility/UtilityAuthenticatedReactiveBase.tsx"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAC1B,uCAAmD;AACnD,+GAAuF;AAEhF,MAAM,gCAAgC,GAAa,CAAC,KAAK,EAAE,EAAE;IAClE,MAAM,iBAAiB,GAAG,IAAA,4BAAoB,GAAE,CAAC;IAEjD,OAAO,CACL,8BAAC,sBAAY,oBACP,iBAAiB,GAEpB,KAAK,CAAC,QAAQ,CACF,CAChB,CAAC;AACJ,CAAC,CAAC;AAVW,QAAA,gCAAgC,oCAU3C","sourcesContent":["import React from \"react\";\nimport { useReactiveBaseProps } from \"../../hooks\";\nimport ReactiveBase from \"@appbaseio/reactivesearch/lib/components/basic/ReactiveBase\";\n\nexport const UtilityAuthenticatedReactiveBase: React.FC = (props) => {\n const reactiveBaseProps = useReactiveBaseProps();\n\n return (\n <ReactiveBase\n {...reactiveBaseProps}\n >\n {props.children}\n </ReactiveBase>\n );\n};\n"]}
@@ -0,0 +1 @@
1
+ export * from "./UtilityAuthenticatedReactiveBase";
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./UtilityAuthenticatedReactiveBase"), exports);
14
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/Utility/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qEAAmD","sourcesContent":["export * from \"./UtilityAuthenticatedReactiveBase\";"]}
@@ -0,0 +1,8 @@
1
+ export * from "./Example";
2
+ export * from "./Filter";
3
+ export * from "./ReactifySearchBase";
4
+ export * from "./Result";
5
+ export * from "./Search";
6
+ export * from "./Sensor";
7
+ export * from "./Sortby";
8
+ export * from "./Utility";
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./Example"), exports);
14
+ __exportStar(require("./Filter"), exports);
15
+ __exportStar(require("./ReactifySearchBase"), exports);
16
+ __exportStar(require("./Result"), exports);
17
+ __exportStar(require("./Search"), exports);
18
+ __exportStar(require("./Sensor"), exports);
19
+ __exportStar(require("./Sortby"), exports);
20
+ __exportStar(require("./Utility"), exports);
21
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,4CAA0B;AAC1B,2CAAyB;AACzB,uDAAqC;AACrC,2CAAyB;AACzB,2CAAyB;AACzB,2CAAyB;AACzB,2CAAyB;AACzB,4CAAyB","sourcesContent":["export * from \"./Example\";\nexport * from \"./Filter\";\nexport * from \"./ReactifySearchBase\";\nexport * from \"./Result\";\nexport * from \"./Search\";\nexport * from \"./Sensor\";\nexport * from \"./Sortby\";\nexport * from \"./Utility\""]}
@@ -1,14 +1,15 @@
1
1
  export * from "./reactivesearch";
2
- export * from "./useSort";
3
- export * from "./usePages";
4
- export * from "./useConfig";
2
+ export * from "./useDebugger";
3
+ export * from "./useSortby";
4
+ export * from "./usePagination";
5
+ export * from "./usePaginationLoadMore";
5
6
  export * from "./useSearch";
6
7
  export * from "./useFilters";
7
8
  export * from "./useCuration";
8
9
  export * from "./useAnalytics";
9
- export * from "./useCollection";
10
10
  export * from "./useFilterStack";
11
11
  export * from "./useProductPrice";
12
12
  export * from "./useFilterListProps";
13
13
  export * from "./useFilterCollapsedState";
14
- export * from "./useLiveConfig";
14
+ export * from "./useConfig";
15
+ export * from "./useReactifySearchContext";
@@ -11,16 +11,18 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
11
11
  };
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
13
  __exportStar(require("./reactivesearch"), exports);
14
- __exportStar(require("./useSort"), exports);
15
- __exportStar(require("./usePages"), exports);
16
- __exportStar(require("./useConfig"), exports);
14
+ __exportStar(require("./useDebugger"), exports);
15
+ __exportStar(require("./useSortby"), exports);
16
+ __exportStar(require("./usePagination"), exports);
17
+ __exportStar(require("./usePaginationLoadMore"), exports);
17
18
  __exportStar(require("./useSearch"), exports);
18
19
  __exportStar(require("./useFilters"), exports);
19
20
  __exportStar(require("./useCuration"), exports);
20
21
  __exportStar(require("./useAnalytics"), exports);
21
- __exportStar(require("./useCollection"), exports);
22
22
  __exportStar(require("./useFilterStack"), exports);
23
23
  __exportStar(require("./useProductPrice"), exports);
24
24
  __exportStar(require("./useFilterListProps"), exports);
25
25
  __exportStar(require("./useFilterCollapsedState"), exports);
26
- __exportStar(require("./useLiveConfig"), exports);
26
+ __exportStar(require("./useConfig"), exports);
27
+ __exportStar(require("./useReactifySearchContext"), exports);
28
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,mDAAiC;AAEjC,gDAA8B;AAC9B,8CAA4B;AAC5B,kDAAgC;AAChC,0DAAwC;AACxC,8CAA4B;AAC5B,+CAA6B;AAC7B,gDAA8B;AAC9B,iDAA+B;AAC/B,mDAAiC;AACjC,oDAAkC;AAClC,uDAAqC;AACrC,4DAA0C;AAC1C,8CAA4B;AAC5B,6DAA2C","sourcesContent":["export * from \"./reactivesearch\";\n\nexport * from \"./useDebugger\";\nexport * from \"./useSortby\";\nexport * from \"./usePagination\";\nexport * from \"./usePaginationLoadMore\";\nexport * from \"./useSearch\";\nexport * from \"./useFilters\";\nexport * from \"./useCuration\";\nexport * from \"./useAnalytics\";\nexport * from \"./useFilterStack\";\nexport * from \"./useProductPrice\";\nexport * from \"./useFilterListProps\";\nexport * from \"./useFilterCollapsedState\";\nexport * from \"./useConfig\";\nexport * from \"./useReactifySearchContext\";\n"]}
@@ -1,5 +1,8 @@
1
1
  export * from "./useReactiveBaseProps";
2
2
  export * from "./useReactiveReactProp";
3
3
  export * from "./useReactiveFilterListProps";
4
- export * from "./useReactiveResultListProps";
4
+ export * from "./useReactiveFilterRangeProps";
5
+ export * from "./useReactiveFilterSliderProps";
6
+ export * from "./useReactiveFilterSharedProps";
7
+ export * from "./useReactiveResultStackProps";
5
8
  export * from "./useReactiveDataSearchProps";
@@ -13,5 +13,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
13
13
  __exportStar(require("./useReactiveBaseProps"), exports);
14
14
  __exportStar(require("./useReactiveReactProp"), exports);
15
15
  __exportStar(require("./useReactiveFilterListProps"), exports);
16
- __exportStar(require("./useReactiveResultListProps"), exports);
16
+ __exportStar(require("./useReactiveFilterRangeProps"), exports);
17
+ __exportStar(require("./useReactiveFilterSliderProps"), exports);
18
+ __exportStar(require("./useReactiveFilterSharedProps"), exports);
19
+ __exportStar(require("./useReactiveResultStackProps"), exports);
17
20
  __exportStar(require("./useReactiveDataSearchProps"), exports);
21
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/hooks/reactivesearch/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAAuC;AACvC,yDAAuC;AACvC,+DAA6C;AAC7C,gEAA8C;AAC9C,iEAA+C;AAC/C,iEAA+C;AAC/C,gEAA8C;AAC9C,+DAA6C","sourcesContent":["export * from \"./useReactiveBaseProps\";\nexport * from \"./useReactiveReactProp\";\nexport * from \"./useReactiveFilterListProps\";\nexport * from \"./useReactiveFilterRangeProps\";\nexport * from \"./useReactiveFilterSliderProps\";\nexport * from \"./useReactiveFilterSharedProps\";\nexport * from \"./useReactiveResultStackProps\";\nexport * from \"./useReactiveDataSearchProps\";\n"]}
@@ -2,6 +2,6 @@ export declare const useReactiveBaseProps: () => {
2
2
  app: string;
3
3
  url: string;
4
4
  credentials: string;
5
- theme: import("../../provider").Theme | undefined;
5
+ theme: Record<string, unknown>;
6
6
  transformResponse: (response: any) => Promise<any>;
7
7
  };
@@ -14,14 +14,14 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
15
  exports.useReactiveBaseProps = void 0;
16
16
  const react_1 = __importDefault(require("react"));
17
- const provider_1 = require("../../provider");
17
+ const hooks_1 = require("../../hooks");
18
18
  const useReactiveBaseProps = () => {
19
- const { index, credentials, theme } = (0, provider_1.useContext)();
19
+ const { options } = (0, hooks_1.useReactifySearchContext)();
20
20
  return react_1.default.useMemo(() => ({
21
- app: index,
22
- url: credentials.endpoint,
23
- credentials: `${credentials.username}:${credentials.password}`,
24
- theme,
21
+ app: options.index,
22
+ url: options.credentials.endpoint,
23
+ credentials: `${options.credentials.username}:${options.credentials.password}`,
24
+ theme: options.theme,
25
25
  transformResponse: (response) => __awaiter(void 0, void 0, void 0, function* () {
26
26
  var _a, _b, _c, _d;
27
27
  // support filtering inside nested aggregations by moving the inner aggregation
@@ -38,6 +38,7 @@ const useReactiveBaseProps = () => {
38
38
  }
39
39
  return response;
40
40
  }),
41
- }), [credentials, theme]);
41
+ }), [options.credentials, options.theme]);
42
42
  };
43
43
  exports.useReactiveBaseProps = useReactiveBaseProps;
44
+ //# sourceMappingURL=useReactiveBaseProps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useReactiveBaseProps.js","sourceRoot":"","sources":["../../../../src/hooks/reactivesearch/useReactiveBaseProps.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,kDAA0B;AAC1B,uCAAuD;AAEhD,MAAM,oBAAoB,GAAG,GAAG,EAAE;IACvC,MAAM,EAAE,OAAO,EAAE,GAAG,IAAA,gCAAwB,GAAE,CAAC;IAE/C,OAAO,eAAK,CAAC,OAAO,CAClB,GAAG,EAAE,CAAC,CAAC;QACL,GAAG,EAAE,OAAO,CAAC,KAAK;QAClB,GAAG,EAAE,OAAO,CAAC,WAAW,CAAC,QAAQ;QACjC,WAAW,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,QAAQ,IAAI,OAAO,CAAC,WAAW,CAAC,QAAQ,EAAE;QAC9E,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,iBAAiB,EAAE,CAAO,QAAa,EAAE,EAAE;;YACzC,+EAA+E;YAC/E,uDAAuD;YACvD,EAAE;YACF,qFAAqF;YACrF,qFAAqF;YACrF,kEAAkE;YAClE,EAAE;YACF,0DAA0D;YAC1D,IACE,MAAA,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,YAAY,0CAAE,qBAAqB,0CAAE,qBAAqB,EACpE;gBACA,QAAQ,CAAC,YAAY,CAAC,qBAAqB;oBACzC,MAAA,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,YAAY,0CAAE,qBAAqB,0CAAE,qBAAqB,CAAC;aACxE;YAED,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAA;KACF,CAAC,EACF,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,CACrC,CAAC;AACJ,CAAC,CAAC;AA9BW,QAAA,oBAAoB,wBA8B/B","sourcesContent":["import React from \"react\";\nimport { useReactifySearchContext } from \"../../hooks\";\n\nexport const useReactiveBaseProps = () => {\n const { options } = useReactifySearchContext();\n\n return React.useMemo(\n () => ({\n app: options.index,\n url: options.credentials.endpoint,\n credentials: `${options.credentials.username}:${options.credentials.password}`,\n theme: options.theme,\n transformResponse: async (response: any) => {\n // support filtering inside nested aggregations by moving the inner aggregation\n // up one level such that reactivesearch understands it\n //\n // see useReactiveFilterListProps > defaultQuery to see how a filter is being applied\n // to variant aggregations to ensure that only in stock sizes are displayed as filter\n // options, this involves a nested filter, which requires this fix\n //\n // https://github.com/appbaseio/reactivesearch/issues/1530\n if (\n response?.aggregations?.reactivesearch_nested?.reactify_nested_outer\n ) {\n response.aggregations.reactivesearch_nested =\n response?.aggregations?.reactivesearch_nested?.reactify_nested_outer;\n }\n\n return response;\n },\n }),\n [options.credentials, options.theme]\n );\n};\n"]}
@@ -1,16 +1,15 @@
1
- declare type Props = {
1
+ export declare const useReactiveDataSearchProps: (options: {
2
2
  [key: string]: any;
3
- debounce?: number;
4
- placeholder?: string;
5
- inputClassName?: string;
6
- };
7
- export declare const useReactiveDataSearchProps: (props?: Props) => {
3
+ debounce?: number | undefined;
4
+ placeholder?: string | undefined;
5
+ inputClassName?: string | undefined;
6
+ }) => {
8
7
  debounce?: number | undefined;
9
8
  placeholder: string;
10
9
  inputClassName?: string | undefined;
11
10
  type: string;
12
11
  showIcon: boolean;
13
- fuzziness: 0 | 1 | 2 | "AUTO";
12
+ fuzziness: 0 | 2 | 1 | "AUTO";
14
13
  queryFormat: "and" | "or";
15
14
  autosuggest: boolean;
16
15
  value: string;
@@ -25,4 +24,3 @@ export declare const useReactiveDataSearchProps: (props?: Props) => {
25
24
  input: string | undefined;
26
25
  };
27
26
  };
28
- export {};
@@ -6,8 +6,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.useReactiveDataSearchProps = void 0;
7
7
  const react_1 = __importDefault(require("react"));
8
8
  const ahooks_1 = require("ahooks");
9
- const debug = require("debug")("reactify-search:useReactiveDataSearchProps");
10
- const __1 = require("../");
9
+ const hooks_1 = require("../../hooks");
11
10
  // default field for when zero search fields have been configured in Reactify
12
11
  const defaultSearchField = {
13
12
  id: "title",
@@ -15,25 +14,19 @@ const defaultSearchField = {
15
14
  importance: 0,
16
15
  searchType: "instant_search",
17
16
  };
18
- const useReactiveDataSearchProps = (props = {}) => {
19
- const { debounce, placeholder, inputClassName } = props;
20
- react_1.default.useEffect(() => {
21
- debug("props", props);
22
- }, [props]);
23
- const { fields } = (0, __1.useConfig)();
24
- const { searchQuery, submitSearch, setSearchQuery, setShowInstantSearchResults, } = (0, __1.useSearch)();
25
- const searchFields = react_1.default.useMemo(() => 0 < fields.length
26
- ? fields.filter((field) => ["always_search", "instant_search"].includes(field.searchType))
17
+ const useReactiveDataSearchProps = (options) => {
18
+ var _a;
19
+ const { config } = (0, hooks_1.useReactifySearchContext)();
20
+ const { searchQuery, submitSearch, setSearchQuery, setShowInstantSearchResults, } = (0, hooks_1.useSearch)();
21
+ const searchFields = react_1.default.useMemo(() => 0 < config.fields.length
22
+ ? config.fields.filter((field) => ["always_search", "instant_search"].includes(field.searchType))
27
23
  : [defaultSearchField], []);
28
- react_1.default.useEffect(() => {
29
- debug("searchFields", searchFields);
30
- }, [searchFields]);
31
24
  const handleKeyPress = react_1.default.useCallback((e) => {
32
25
  if ("Enter" !== e.key)
33
26
  return;
34
27
  submitSearch();
35
28
  }, [submitSearch]);
36
- const { track } = (0, __1.useAnalytics)();
29
+ const { track } = (0, hooks_1.useAnalytics)();
37
30
  const trackQuery = react_1.default.useCallback(() => {
38
31
  if (!searchQuery || (searchQuery && searchQuery.length < 3))
39
32
  return;
@@ -43,25 +36,30 @@ const useReactiveDataSearchProps = (props = {}) => {
43
36
  triggerQuery();
44
37
  trackQuery();
45
38
  }, {
46
- wait: debounce !== null && debounce !== void 0 ? debounce : 300,
39
+ wait: (_a = options.debounce) !== null && _a !== void 0 ? _a : 300,
47
40
  });
48
- return react_1.default.useMemo(() => (Object.assign({ type: "search", showIcon: false, fuzziness: 1, queryFormat: "and", autosuggest: false, value: searchQuery !== null && searchQuery !== void 0 ? searchQuery : "", onKeyUp: handleKeyPress, componentId: "SearchInput", placeholder: placeholder !== null && placeholder !== void 0 ? placeholder : "Search for a product...", dataField: searchFields.map((field) => field.field), fieldWeights: searchFields.map((field) => field.importance), onChange: (value, triggerQuery) => {
49
- setSearchQuery(value);
50
- if (!!value)
51
- runDebouncedTriggerQuery(triggerQuery);
52
- else
53
- cancelDebouncedTriggerQuery();
54
- }, onBlur: () => {
55
- // setTimeout ensures that results are still clickable before close
56
- setTimeout(() => setShowInstantSearchResults(false), 300);
57
- }, onFocus: () => {
58
- setShowInstantSearchResults(true);
59
- }, innerClass: {
60
- input: inputClassName,
61
- } }, props)), [
41
+ return react_1.default.useMemo(() => {
42
+ var _a;
43
+ return (Object.assign({ type: "search", showIcon: false, fuzziness: 1, queryFormat: "and", autosuggest: false, value: searchQuery !== null && searchQuery !== void 0 ? searchQuery : "", onKeyUp: handleKeyPress, componentId: "SearchInput", placeholder: (_a = options.placeholder) !== null && _a !== void 0 ? _a : "Search for a product...", dataField: searchFields.map((field) => field.field), fieldWeights: searchFields.map((field) => field.importance), onChange: (value, triggerQuery) => {
44
+ setSearchQuery(value);
45
+ if (!!value) {
46
+ runDebouncedTriggerQuery(triggerQuery);
47
+ }
48
+ else {
49
+ cancelDebouncedTriggerQuery();
50
+ }
51
+ }, onBlur: () => {
52
+ // setTimeout ensures that results are still clickable before close
53
+ setTimeout(() => setShowInstantSearchResults(false), 300);
54
+ }, onFocus: () => {
55
+ setShowInstantSearchResults(true);
56
+ }, innerClass: {
57
+ input: options.inputClassName,
58
+ } }, options));
59
+ }, [
62
60
  searchQuery,
63
61
  handleKeyPress,
64
- placeholder,
62
+ options.placeholder,
65
63
  searchFields,
66
64
  setSearchQuery,
67
65
  runDebouncedTriggerQuery,
@@ -69,3 +67,4 @@ const useReactiveDataSearchProps = (props = {}) => {
69
67
  ]);
70
68
  };
71
69
  exports.useReactiveDataSearchProps = useReactiveDataSearchProps;
70
+ //# sourceMappingURL=useReactiveDataSearchProps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useReactiveDataSearchProps.js","sourceRoot":"","sources":["../../../../src/hooks/reactivesearch/useReactiveDataSearchProps.ts"],"names":[],"mappings":"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","sourcesContent":["import React from \"react\";\nimport { useDebounceFn } from \"ahooks\";\n\nimport type { ConfigField } from \"../../types/config\";\n\nimport { useReactifySearchContext, useSearch, useAnalytics } from \"../../hooks\";\n\n// default field for when zero search fields have been configured in Reactify\nconst defaultSearchField: ConfigField = {\n id: \"title\",\n field: \"title\",\n importance: 0,\n searchType: \"instant_search\",\n};\n\nexport const useReactiveDataSearchProps = (options: {\n [key: string]: any;\n debounce?: number;\n placeholder?: string;\n inputClassName?: string;\n}) => {\n const { config } = useReactifySearchContext();\n const {\n searchQuery,\n submitSearch,\n setSearchQuery,\n setShowInstantSearchResults,\n } = useSearch();\n\n const searchFields = React.useMemo(\n () =>\n 0 < config.fields.length\n ? config.fields.filter((field) =>\n [\"always_search\", \"instant_search\"].includes(field.searchType)\n )\n : [defaultSearchField],\n []\n );\n\n const handleKeyPress = React.useCallback(\n (e) => {\n if (\"Enter\" !== e.key) return;\n submitSearch();\n },\n [submitSearch]\n );\n\n const { track } = useAnalytics();\n\n const trackQuery = React.useCallback(() => {\n if (!searchQuery || (searchQuery && searchQuery.length < 3)) return;\n track({ eventName: \"search\", payload: { searchTerm: searchQuery } });\n }, [searchQuery, track]);\n\n const { run: runDebouncedTriggerQuery, cancel: cancelDebouncedTriggerQuery } =\n useDebounceFn(\n (triggerQuery: () => void) => {\n triggerQuery();\n trackQuery();\n },\n {\n wait: options.debounce ?? 300,\n }\n );\n\n return React.useMemo(\n () => ({\n type: \"search\",\n showIcon: false,\n fuzziness: 1 as 0 | 1 | 2 | \"AUTO\",\n queryFormat: \"and\" as \"and\" | \"or\",\n autosuggest: false,\n value: searchQuery ?? \"\",\n onKeyUp: handleKeyPress,\n componentId: \"SearchInput\",\n placeholder: options.placeholder ?? \"Search for a product...\",\n dataField: searchFields.map((field) => field.field),\n fieldWeights: searchFields.map((field) => field.importance),\n onChange: (value: string, triggerQuery: () => {}) => {\n setSearchQuery(value);\n if (!!value) {\n runDebouncedTriggerQuery(triggerQuery);\n } else {\n cancelDebouncedTriggerQuery();\n }\n },\n onBlur: () => {\n // setTimeout ensures that results are still clickable before close\n setTimeout(() => setShowInstantSearchResults(false), 300);\n },\n onFocus: () => {\n setShowInstantSearchResults(true);\n },\n innerClass: {\n input: options.inputClassName,\n },\n ...options,\n }),\n [\n searchQuery,\n handleKeyPress,\n options.placeholder,\n searchFields,\n setSearchQuery,\n runDebouncedTriggerQuery,\n cancelDebouncedTriggerQuery,\n ]\n );\n};\n"]}
@@ -1,5 +1,14 @@
1
1
  import type { ConfigFilterOption } from "../../types/config";
2
+ /**
3
+ * For use with @appbaseio/reactivesearch SingleList and MultiList components
4
+ */
2
5
  export declare const useReactiveFilterListProps: (filter: ConfigFilterOption) => {
6
+ size: number | undefined;
7
+ showFilter: boolean;
8
+ showLoadMore: boolean;
9
+ showSearch: boolean;
10
+ showRadio: boolean;
11
+ showCheckbox: boolean;
3
12
  nestedField: string | undefined;
4
13
  customQuery: ((value?: string | string[] | undefined) => {
5
14
  query?: undefined;
@@ -61,8 +70,4 @@ export declare const useReactiveFilterListProps: (filter: ConfigFilterOption) =>
61
70
  react: {
62
71
  and: string[];
63
72
  };
64
- size: number | undefined;
65
- showFilter: true;
66
- showLoadMore: boolean;
67
- showSearch: boolean;
68
73
  };
@@ -5,102 +5,18 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.useReactiveFilterListProps = void 0;
7
7
  const react_1 = __importDefault(require("react"));
8
+ const useReactiveFilterSharedProps_1 = require("./useReactiveFilterSharedProps");
8
9
  const useReactiveReactProp_1 = require("./useReactiveReactProp");
10
+ /**
11
+ * For use with @appbaseio/reactivesearch SingleList and MultiList components
12
+ */
9
13
  const useReactiveFilterListProps = (filter) => {
10
14
  const reactiveReactProp = (0, useReactiveReactProp_1.useReactiveReactProp)(filter.handle);
11
- const nestedField = react_1.default.useMemo(() => {
12
- const nestedFields = ["variants"];
13
- const topField = filter.field.split(".")[0];
14
- if (nestedFields.includes(topField))
15
- return topField;
16
- return undefined;
17
- }, [filter]);
18
- // define a custom query for when settingsHideUnavailable is enabled and the target field is inside variants
19
- // customQuery defines how this filter affects *other* components like the results component
20
- const customQuery = react_1.default.useMemo(() => {
21
- if (!filter.settingsHideUnavailable ||
22
- !filter.field.startsWith("variants."))
23
- return undefined;
24
- return (value) => {
25
- if (!value)
26
- return {};
27
- // reactivesearch sometimes returns string, sometimes string[]
28
- const valueArray = "string" === typeof value ? [value] : value;
29
- if (0 === valueArray.length)
30
- return {};
31
- return {
32
- query: {
33
- nested: {
34
- path: "variants",
35
- query: {
36
- bool: {
37
- must: [
38
- {
39
- match: {
40
- "variants.available": "true",
41
- },
42
- },
43
- {
44
- terms: {
45
- [filter.field]: valueArray,
46
- },
47
- },
48
- ],
49
- },
50
- },
51
- },
52
- },
53
- };
54
- };
55
- }, [filter]);
56
- // define a default query for when settingsHideUnavailable is enabled and the target field is inside variants
57
- // defaultQuery defines how this filter affects itself i.e. the options displayed
58
- const defaultQuery = react_1.default.useMemo(() => {
59
- if (!filter.settingsHideUnavailable ||
60
- !filter.field.startsWith("variants."))
61
- return undefined;
62
- // override the aggregation query to filter the results by the variants.available attribute
63
- return () => {
64
- return {
65
- aggs: {
66
- reactivesearch_nested: {
67
- nested: { path: "variants" },
68
- aggs: {
69
- reactify_nested_outer: {
70
- filter: {
71
- match: {
72
- "variants.available": "true",
73
- },
74
- },
75
- aggs: {
76
- [filter.field]: {
77
- terms: {
78
- field: filter.field,
79
- size: 100,
80
- order: { _count: "desc" },
81
- },
82
- },
83
- },
84
- },
85
- },
86
- },
87
- },
88
- };
89
- };
90
- }, [filter]);
91
- return react_1.default.useMemo(() => ({
92
- nestedField,
93
- customQuery,
94
- defaultQuery,
95
- URLParams: true,
96
- componentId: filter.handle,
97
- dataField: filter.field,
98
- filterLabel: filter.name,
99
- react: reactiveReactProp,
100
- size: parseInt(filter.displaySize) || undefined,
101
- showFilter: filter.settingsShowFilter || true,
102
- showLoadMore: filter.settingsShowMore || false,
103
- showSearch: (filter === null || filter === void 0 ? void 0 : filter.settingsShowSearch) || false,
104
- }), [filter, reactiveReactProp]);
15
+ const reactiveFilterSharedProps = (0, useReactiveFilterSharedProps_1.useReactiveFilterSharedProps)(filter);
16
+ return react_1.default.useMemo(() => {
17
+ var _a, _b, _c;
18
+ return (Object.assign(Object.assign({}, reactiveFilterSharedProps), { size: parseInt(filter.displaySize) || undefined, showFilter: (_a = filter.settingsShowFilter) !== null && _a !== void 0 ? _a : true, showLoadMore: (_b = filter.settingsShowMore) !== null && _b !== void 0 ? _b : false, showSearch: (_c = filter.settingsShowSearch) !== null && _c !== void 0 ? _c : false, showRadio: false, showCheckbox: false }));
19
+ }, [filter, reactiveReactProp]);
105
20
  };
106
21
  exports.useReactiveFilterListProps = useReactiveFilterListProps;
22
+ //# sourceMappingURL=useReactiveFilterListProps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useReactiveFilterListProps.js","sourceRoot":"","sources":["../../../../src/hooks/reactivesearch/useReactiveFilterListProps.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAG1B,iFAA8E;AAE9E,iEAA8D;AAE9D;;GAEG;AACI,MAAM,0BAA0B,GAAG,CAAC,MAA0B,EAAE,EAAE;IACvE,MAAM,iBAAiB,GAAG,IAAA,2CAAoB,EAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC9D,MAAM,yBAAyB,GAAG,IAAA,2DAA4B,EAAC,MAAM,CAAC,CAAC;IAEvE,OAAO,eAAK,CAAC,OAAO,CAClB,GAAG,EAAE;;QAAC,OAAA,iCACD,yBAAyB,KAC5B,IAAI,EAAE,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,SAAS,EAC/C,UAAU,EAAE,MAAA,MAAM,CAAC,kBAAkB,mCAAI,IAAI,EAC7C,YAAY,EAAE,MAAA,MAAM,CAAC,gBAAgB,mCAAI,KAAK,EAC9C,UAAU,EAAE,MAAA,MAAM,CAAC,kBAAkB,mCAAI,KAAK,EAC9C,SAAS,EAAE,KAAK,EAChB,YAAY,EAAE,KAAK,IACnB,CAAA;KAAA,EACF,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAC5B,CAAC;AACJ,CAAC,CAAC;AAhBW,QAAA,0BAA0B,8BAgBrC","sourcesContent":["import React from \"react\";\n\nimport type { ConfigFilterOption } from \"../../types/config\";\nimport { useReactiveFilterSharedProps } from \"./useReactiveFilterSharedProps\";\n\nimport { useReactiveReactProp } from \"./useReactiveReactProp\";\n\n/**\n * For use with @appbaseio/reactivesearch SingleList and MultiList components\n */\nexport const useReactiveFilterListProps = (filter: ConfigFilterOption) => {\n const reactiveReactProp = useReactiveReactProp(filter.handle);\n const reactiveFilterSharedProps = useReactiveFilterSharedProps(filter);\n\n return React.useMemo(\n () => ({\n ...reactiveFilterSharedProps,\n size: parseInt(filter.displaySize) || undefined,\n showFilter: filter.settingsShowFilter ?? true,\n showLoadMore: filter.settingsShowMore ?? false,\n showSearch: filter.settingsShowSearch ?? false,\n showRadio: false,\n showCheckbox: false,\n }),\n [filter, reactiveReactProp]\n );\n};\n"]}
@@ -0,0 +1,70 @@
1
+ import type { ConfigFilterOption } from "../../types/config";
2
+ /**
3
+ * For use with @appbaseio/reactivesearch SingleRange and MultiRange components
4
+ */
5
+ export declare const useReactiveFilterRangeProps: (filter: ConfigFilterOption) => {
6
+ showFilter: boolean;
7
+ showRadio: boolean;
8
+ showCheckbox: boolean;
9
+ nestedField: string | undefined;
10
+ customQuery: ((value?: string | string[] | undefined) => {
11
+ query?: undefined;
12
+ } | {
13
+ query: {
14
+ nested: {
15
+ path: string;
16
+ query: {
17
+ bool: {
18
+ must: ({
19
+ match: {
20
+ "variants.available": string;
21
+ };
22
+ terms?: undefined;
23
+ } | {
24
+ terms: {
25
+ [x: string]: string[];
26
+ };
27
+ match?: undefined;
28
+ })[];
29
+ };
30
+ };
31
+ };
32
+ };
33
+ }) | undefined;
34
+ defaultQuery: (() => {
35
+ aggs: {
36
+ reactivesearch_nested: {
37
+ nested: {
38
+ path: string;
39
+ };
40
+ aggs: {
41
+ reactify_nested_outer: {
42
+ filter: {
43
+ match: {
44
+ "variants.available": string;
45
+ };
46
+ };
47
+ aggs: {
48
+ [x: string]: {
49
+ terms: {
50
+ field: string;
51
+ size: number;
52
+ order: {
53
+ _count: string;
54
+ };
55
+ };
56
+ };
57
+ };
58
+ };
59
+ };
60
+ };
61
+ };
62
+ }) | undefined;
63
+ URLParams: boolean;
64
+ componentId: string;
65
+ dataField: string;
66
+ filterLabel: string;
67
+ react: {
68
+ and: string[];
69
+ };
70
+ };