react-instantsearch-core 7.25.0 → 7.26.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (140) hide show
  1. package/dist/cjs/components/Configure.js +11 -17
  2. package/dist/cjs/components/DynamicWidgets.js +46 -53
  3. package/dist/cjs/components/Index.js +19 -22
  4. package/dist/cjs/components/InstantSearch.js +34 -36
  5. package/dist/cjs/components/InstantSearchSSRProvider.js +31 -41
  6. package/dist/cjs/components/InstantSearchServerContext.js +6 -10
  7. package/dist/cjs/connectors/useAutocomplete.js +8 -10
  8. package/dist/cjs/connectors/useBreadcrumb.js +8 -10
  9. package/dist/cjs/connectors/useChat.js +8 -10
  10. package/dist/cjs/connectors/useClearRefinements.js +8 -10
  11. package/dist/cjs/connectors/useConfigure.js +10 -12
  12. package/dist/cjs/connectors/useCurrentRefinements.js +8 -10
  13. package/dist/cjs/connectors/useDynamicWidgets.js +14 -20
  14. package/dist/cjs/connectors/useFilterSuggestions.js +8 -10
  15. package/dist/cjs/connectors/useFrequentlyBoughtTogether.js +8 -10
  16. package/dist/cjs/connectors/useGeoSearch.js +8 -10
  17. package/dist/cjs/connectors/useHierarchicalMenu.js +8 -10
  18. package/dist/cjs/connectors/useHits.js +8 -10
  19. package/dist/cjs/connectors/useHitsPerPage.js +8 -10
  20. package/dist/cjs/connectors/useInfiniteHits.js +8 -10
  21. package/dist/cjs/connectors/useLookingSimilar.js +8 -10
  22. package/dist/cjs/connectors/useMenu.js +8 -10
  23. package/dist/cjs/connectors/useNumericMenu.js +8 -10
  24. package/dist/cjs/connectors/usePagination.js +8 -10
  25. package/dist/cjs/connectors/usePoweredBy.js +18 -19
  26. package/dist/cjs/connectors/useQueryRules.js +8 -10
  27. package/dist/cjs/connectors/useRange.js +8 -10
  28. package/dist/cjs/connectors/useRefinementList.js +8 -10
  29. package/dist/cjs/connectors/useRelatedProducts.js +8 -10
  30. package/dist/cjs/connectors/useSearchBox.js +8 -10
  31. package/dist/cjs/connectors/useSortBy.js +8 -10
  32. package/dist/cjs/connectors/useStats.js +8 -10
  33. package/dist/cjs/connectors/useToggleRefinement.js +8 -10
  34. package/dist/cjs/connectors/useTrendingItems.js +8 -10
  35. package/dist/cjs/hooks/useConnector.js +123 -139
  36. package/dist/cjs/hooks/useInstantSearch.js +59 -59
  37. package/dist/cjs/index.js +90 -519
  38. package/dist/cjs/lib/IndexContext.js +6 -10
  39. package/dist/cjs/lib/InstantSearchContext.js +6 -10
  40. package/dist/cjs/lib/InstantSearchRSCContext.js +11 -12
  41. package/dist/cjs/lib/InstantSearchSSRContext.js +6 -10
  42. package/dist/cjs/lib/createSearchResults.js +24 -25
  43. package/dist/cjs/lib/dequal.js +33 -40
  44. package/dist/cjs/lib/getIndexSearchResults.js +23 -30
  45. package/dist/cjs/lib/invariant.js +11 -17
  46. package/dist/cjs/lib/noop.js +8 -6
  47. package/dist/cjs/lib/use.js +26 -11
  48. package/dist/cjs/lib/useAppIdAndApiKey.js +10 -12
  49. package/dist/cjs/lib/useForceUpdate.js +12 -21
  50. package/dist/cjs/lib/useIndex.js +40 -37
  51. package/dist/cjs/lib/useIndexContext.js +11 -12
  52. package/dist/cjs/lib/useInstantSearchApi.js +174 -197
  53. package/dist/cjs/lib/useInstantSearchContext.js +11 -12
  54. package/dist/cjs/lib/useInstantSearchSSRContext.js +8 -9
  55. package/dist/cjs/lib/useInstantSearchServerContext.js +8 -9
  56. package/dist/cjs/lib/useIsomorphicLayoutEffect.js +6 -8
  57. package/dist/cjs/lib/useRSCContext.js +8 -9
  58. package/dist/cjs/lib/useSearchResults.js +54 -62
  59. package/dist/cjs/lib/useSearchState.js +53 -60
  60. package/dist/cjs/lib/useStableValue.js +15 -24
  61. package/dist/cjs/lib/useWidget.js +99 -95
  62. package/dist/cjs/lib/warn.js +11 -35
  63. package/dist/cjs/lib/wrapPromiseWithState.js +23 -26
  64. package/dist/cjs/package.json +4 -1
  65. package/dist/cjs/server/getServerState.js +81 -91
  66. package/dist/cjs/server/index.js +6 -15
  67. package/dist/cjs/version.js +6 -6
  68. package/dist/es/components/Configure.js +11 -13
  69. package/dist/es/components/DynamicWidgets.js +45 -47
  70. package/dist/es/components/Index.js +19 -17
  71. package/dist/es/components/InstantSearch.js +33 -29
  72. package/dist/es/components/InstantSearchSSRProvider.js +30 -35
  73. package/dist/es/components/InstantSearchServerContext.js +4 -4
  74. package/dist/es/connectors/useAutocomplete.js +8 -5
  75. package/dist/es/connectors/useBreadcrumb.js +8 -5
  76. package/dist/es/connectors/useChat.js +8 -5
  77. package/dist/es/connectors/useClearRefinements.js +8 -5
  78. package/dist/es/connectors/useConfigure.js +10 -7
  79. package/dist/es/connectors/useCurrentRefinements.js +8 -5
  80. package/dist/es/connectors/useDynamicWidgets.js +14 -15
  81. package/dist/es/connectors/useFilterSuggestions.js +8 -5
  82. package/dist/es/connectors/useFrequentlyBoughtTogether.js +8 -5
  83. package/dist/es/connectors/useGeoSearch.js +8 -5
  84. package/dist/es/connectors/useHierarchicalMenu.js +8 -5
  85. package/dist/es/connectors/useHits.js +8 -5
  86. package/dist/es/connectors/useHitsPerPage.js +8 -5
  87. package/dist/es/connectors/useInfiniteHits.js +8 -5
  88. package/dist/es/connectors/useLookingSimilar.js +8 -5
  89. package/dist/es/connectors/useMenu.js +8 -5
  90. package/dist/es/connectors/useNumericMenu.js +8 -5
  91. package/dist/es/connectors/usePagination.js +8 -5
  92. package/dist/es/connectors/usePoweredBy.js +18 -15
  93. package/dist/es/connectors/useQueryRules.js +8 -5
  94. package/dist/es/connectors/useRange.js +8 -5
  95. package/dist/es/connectors/useRefinementList.js +8 -5
  96. package/dist/es/connectors/useRelatedProducts.js +8 -5
  97. package/dist/es/connectors/useSearchBox.js +8 -5
  98. package/dist/es/connectors/useSortBy.js +8 -5
  99. package/dist/es/connectors/useStats.js +8 -5
  100. package/dist/es/connectors/useToggleRefinement.js +8 -5
  101. package/dist/es/connectors/useTrendingItems.js +8 -5
  102. package/dist/es/hooks/useConnector.js +122 -134
  103. package/dist/es/hooks/useInstantSearch.js +58 -54
  104. package/dist/es/index.js +43 -43
  105. package/dist/es/lib/IndexContext.js +4 -4
  106. package/dist/es/lib/InstantSearchContext.js +4 -4
  107. package/dist/es/lib/InstantSearchRSCContext.js +10 -7
  108. package/dist/es/lib/InstantSearchSSRContext.js +4 -4
  109. package/dist/es/lib/createSearchResults.js +23 -19
  110. package/dist/es/lib/dequal.js +33 -36
  111. package/dist/es/lib/getIndexSearchResults.js +23 -26
  112. package/dist/es/lib/invariant.js +10 -12
  113. package/dist/es/lib/noop.js +7 -1
  114. package/dist/es/lib/use.js +4 -2
  115. package/dist/es/lib/useAppIdAndApiKey.js +9 -7
  116. package/dist/es/lib/useForceUpdate.js +9 -15
  117. package/dist/es/lib/useIndex.js +39 -31
  118. package/dist/es/lib/useIndexContext.js +10 -7
  119. package/dist/es/lib/useInstantSearchApi.js +174 -191
  120. package/dist/es/lib/useInstantSearchContext.js +10 -7
  121. package/dist/es/lib/useInstantSearchSSRContext.js +7 -4
  122. package/dist/es/lib/useInstantSearchServerContext.js +7 -4
  123. package/dist/es/lib/useIsomorphicLayoutEffect.js +4 -3
  124. package/dist/es/lib/useRSCContext.js +7 -4
  125. package/dist/es/lib/useSearchResults.js +53 -57
  126. package/dist/es/lib/useSearchState.js +52 -55
  127. package/dist/es/lib/useStableValue.js +14 -19
  128. package/dist/es/lib/useWidget.js +98 -90
  129. package/dist/es/lib/warn.js +9 -29
  130. package/dist/es/lib/wrapPromiseWithState.js +23 -22
  131. package/dist/es/package.json +4 -0
  132. package/dist/es/server/getServerState.js +80 -85
  133. package/dist/es/server/index.js +1 -1
  134. package/dist/es/version.d.ts +1 -1
  135. package/dist/es/version.js +3 -1
  136. package/dist/umd/ReactInstantSearchCore.js +17449 -22297
  137. package/dist/umd/ReactInstantSearchCore.min.js +3 -3
  138. package/package.json +7 -11
  139. package/dist/umd/ReactInstantSearchCore.js.map +0 -1
  140. package/dist/umd/ReactInstantSearchCore.min.js.map +0 -1
@@ -1,144 +1,128 @@
1
- "use strict";
1
+ 'use strict';
2
2
 
3
- function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.useConnector = useConnector;
8
- var _react = require("react");
9
- var _dequal = require("../lib/dequal");
10
- var _getIndexSearchResults = require("../lib/getIndexSearchResults");
11
- var _useIndexContext = require("../lib/useIndexContext");
12
- var _useInstantSearchContext = require("../lib/useInstantSearchContext");
13
- var _useInstantSearchServerContext = require("../lib/useInstantSearchServerContext");
14
- var _useInstantSearchSSRContext = require("../lib/useInstantSearchSSRContext");
15
- var _useStableValue = require("../lib/useStableValue");
16
- var _useWidget = require("../lib/useWidget");
17
- var _excluded = ["skipSuspense"],
18
- _excluded2 = ["instantSearchInstance", "widgetParams"],
19
- _excluded3 = ["widgetParams"];
20
- function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
21
- function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
22
- function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
23
- function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
24
- function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
25
- function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
26
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
27
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
28
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
29
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
30
- function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
31
- function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
32
- function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
33
- function useConnector(connector) {
34
- var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
35
- var _ref = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {},
36
- _ref$skipSuspense = _ref.skipSuspense,
37
- skipSuspense = _ref$skipSuspense === void 0 ? false : _ref$skipSuspense,
38
- additionalWidgetProperties = _objectWithoutProperties(_ref, _excluded);
39
- var serverContext = (0, _useInstantSearchServerContext.useInstantSearchServerContext)();
40
- var ssrContext = (0, _useInstantSearchSSRContext.useInstantSearchSSRContext)();
41
- var search = (0, _useInstantSearchContext.useInstantSearchContext)();
42
- var parentIndex = (0, _useIndexContext.useIndexContext)();
43
- var stableProps = (0, _useStableValue.useStableValue)(props);
44
- var stableAdditionalWidgetProperties = (0, _useStableValue.useStableValue)(additionalWidgetProperties);
45
- var shouldSetStateRef = (0, _react.useRef)(true);
46
- var previousRenderStateRef = (0, _react.useRef)(null);
47
- var previousStatusRef = (0, _react.useRef)(search.status);
48
- var widget = (0, _react.useMemo)(function () {
49
- var createWidget = connector(function (connectorState, isFirstRender) {
50
- // We skip the `init` widget render because:
51
- // - We rely on `getWidgetRenderState` to compute the initial state before
52
- // the InstantSearch.js lifecycle starts.
53
- // - It prevents UI flashes when updating the widget props.
54
- if (isFirstRender) {
55
- shouldSetStateRef.current = true;
56
- return;
57
- }
58
-
59
- // There are situations where InstantSearch.js may render widgets slightly
60
- // after they're removed by React, and thus try to update the React state
61
- // on unmounted components. React 16 and 17 consider them as memory leaks
62
- // and display a warning.
63
- // This happens in <DynamicWidgets> when `attributesToRender` contains a
64
- // value without an attribute previously mounted. React will unmount the
65
- // component controlled by that attribute, but InstantSearch.js will stay
66
- // unaware of this change until the render pass finishes, and therefore
67
- // notifies of a state change.
68
- // This ref lets us track this situation and ignore these state updates.
69
- if (shouldSetStateRef.current) {
70
- var instantSearchInstance = connectorState.instantSearchInstance,
71
- widgetParams = connectorState.widgetParams,
72
- renderState = _objectWithoutProperties(connectorState, _excluded2);
3
+ var _object_spread = require('@swc/helpers/_/_object_spread');
4
+ var _object_without_properties = require('@swc/helpers/_/_object_without_properties');
5
+ var _sliced_to_array = require('@swc/helpers/_/_sliced_to_array');
6
+ var _to_array = require('@swc/helpers/_/_to_array');
7
+ var React = require('react');
8
+ var dequal = require('../lib/dequal.js');
9
+ var getIndexSearchResults = require('../lib/getIndexSearchResults.js');
10
+ var useIndexContext = require('../lib/useIndexContext.js');
11
+ var useInstantSearchContext = require('../lib/useInstantSearchContext.js');
12
+ var useInstantSearchServerContext = require('../lib/useInstantSearchServerContext.js');
13
+ var useInstantSearchSSRContext = require('../lib/useInstantSearchSSRContext.js');
14
+ var useStableValue = require('../lib/useStableValue.js');
15
+ var useWidget = require('../lib/useWidget.js');
73
16
 
74
- // We only update the state when a widget render state param changes,
75
- // except for functions. We ignore function reference changes to avoid
76
- // infinite loops. It's safe to omit them because they get updated
77
- // every time another render param changes.
78
- if (!(0, _dequal.dequal)(renderState, previousRenderStateRef.current, function (a, b) {
79
- return (a === null || a === void 0 ? void 0 : a.constructor) === Function && (b === null || b === void 0 ? void 0 : b.constructor) === Function;
80
- }) || instantSearchInstance.status !== previousStatusRef.current) {
81
- // eslint-disable-next-line @typescript-eslint/no-use-before-define
82
- setState(renderState);
83
- previousRenderStateRef.current = renderState;
84
- previousStatusRef.current = instantSearchInstance.status;
17
+ function useConnector(connector) {
18
+ var _1 = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : void 0, _2 = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : void 0;
19
+ var _ref = [
20
+ _1,
21
+ _2
22
+ ], _ref1 = _to_array._(_ref), tmp = _ref1[0], props = tmp === void 0 ? {} : tmp, _rest = _ref1.slice(1), _rest1 = _sliced_to_array._(_rest, 1), tmp1 = _rest1[0], _ref2 = tmp1 === void 0 ? {} : tmp1, _ref_skipSuspense = _ref2.skipSuspense, skipSuspense = _ref_skipSuspense === void 0 ? false : _ref_skipSuspense, additionalWidgetProperties = _object_without_properties._(_ref2, [
23
+ "skipSuspense"
24
+ ]);
25
+ var serverContext = useInstantSearchServerContext.useInstantSearchServerContext();
26
+ var ssrContext = useInstantSearchSSRContext.useInstantSearchSSRContext();
27
+ var search = useInstantSearchContext.useInstantSearchContext();
28
+ var parentIndex = useIndexContext.useIndexContext();
29
+ var stableProps = useStableValue.useStableValue(props);
30
+ var stableAdditionalWidgetProperties = useStableValue.useStableValue(additionalWidgetProperties);
31
+ var shouldSetStateRef = React.useRef(true);
32
+ var previousRenderStateRef = React.useRef(null);
33
+ var previousStatusRef = React.useRef(search.status);
34
+ var widget = React.useMemo(function() {
35
+ var createWidget = connector(function(connectorState, isFirstRender) {
36
+ // We skip the `init` widget render because:
37
+ // - We rely on `getWidgetRenderState` to compute the initial state before
38
+ // the InstantSearch.js lifecycle starts.
39
+ // - It prevents UI flashes when updating the widget props.
40
+ if (isFirstRender) {
41
+ shouldSetStateRef.current = true;
42
+ return;
43
+ }
44
+ // There are situations where InstantSearch.js may render widgets slightly
45
+ // after they're removed by React, and thus try to update the React state
46
+ // on unmounted components. React 16 and 17 consider them as memory leaks
47
+ // and display a warning.
48
+ // This happens in <DynamicWidgets> when `attributesToRender` contains a
49
+ // value without an attribute previously mounted. React will unmount the
50
+ // component controlled by that attribute, but InstantSearch.js will stay
51
+ // unaware of this change until the render pass finishes, and therefore
52
+ // notifies of a state change.
53
+ // This ref lets us track this situation and ignore these state updates.
54
+ if (shouldSetStateRef.current) {
55
+ var instantSearchInstance = connectorState.instantSearchInstance; connectorState.widgetParams; var renderState = _object_without_properties._(connectorState, [
56
+ "instantSearchInstance",
57
+ "widgetParams"
58
+ ]);
59
+ // We only update the state when a widget render state param changes,
60
+ // except for functions. We ignore function reference changes to avoid
61
+ // infinite loops. It's safe to omit them because they get updated
62
+ // every time another render param changes.
63
+ if (!dequal.dequal(renderState, previousRenderStateRef.current, function(a, b) {
64
+ return (a === null || a === void 0 ? void 0 : a.constructor) === Function && (b === null || b === void 0 ? void 0 : b.constructor) === Function;
65
+ }) || instantSearchInstance.status !== previousStatusRef.current) {
66
+ // eslint-disable-next-line @typescript-eslint/no-use-before-define
67
+ setState(renderState);
68
+ previousRenderStateRef.current = renderState;
69
+ previousStatusRef.current = instantSearchInstance.status;
70
+ }
71
+ }
72
+ }, function() {
73
+ // We'll ignore the next state update until we know for sure that
74
+ // InstantSearch.js re-inits the component.
75
+ shouldSetStateRef.current = false;
76
+ });
77
+ return _object_spread._({}, createWidget(stableProps), stableAdditionalWidgetProperties);
78
+ }, [
79
+ connector,
80
+ stableProps,
81
+ stableAdditionalWidgetProperties
82
+ ]);
83
+ var _useState = _sliced_to_array._(React.useState(function() {
84
+ if (widget.getWidgetRenderState) {
85
+ var _widget_getWidgetSearchParameters;
86
+ // The helper exists because we've started InstantSearch.
87
+ var helper = parentIndex.getHelper();
88
+ var uiState = parentIndex.getWidgetUiState({})[parentIndex.getIndexId()];
89
+ helper.state = ((_widget_getWidgetSearchParameters = widget.getWidgetSearchParameters) === null || _widget_getWidgetSearchParameters === void 0 ? void 0 : _widget_getWidgetSearchParameters.call(widget, helper.state, {
90
+ uiState: uiState
91
+ })) || helper.state;
92
+ var _getIndexSearchResults = getIndexSearchResults.getIndexSearchResults(parentIndex), results = _getIndexSearchResults.results, scopedResults = _getIndexSearchResults.scopedResults, recommendResults = _getIndexSearchResults.recommendResults;
93
+ // We get the widget render state by providing the same parameters as
94
+ // InstantSearch provides to the widget's `render` method.
95
+ // See https://github.com/algolia/instantsearch/blob/019cd18d0de6dd320284aa4890541b7fe2198c65/src/widgets/index/index.ts#L604-L617
96
+ var _widget_getWidgetRenderState = widget.getWidgetRenderState({
97
+ helper: helper,
98
+ parent: parentIndex,
99
+ instantSearchInstance: search,
100
+ results: widget.dependsOn === 'recommend' && recommendResults && ssrContext ? recommendResults[ssrContext.recommendIdx.current++] : results,
101
+ scopedResults: scopedResults,
102
+ state: helper.state,
103
+ renderState: search.renderState,
104
+ templatesConfig: search.templatesConfig,
105
+ createURL: parentIndex.createURL,
106
+ searchMetadata: {
107
+ isSearchStalled: search.status === 'stalled'
108
+ },
109
+ status: search.status,
110
+ error: search.error
111
+ }); _widget_getWidgetRenderState.widgetParams; var renderState = _object_without_properties._(_widget_getWidgetRenderState, [
112
+ "widgetParams"
113
+ ]);
114
+ return renderState;
85
115
  }
86
- }
87
- }, function () {
88
- // We'll ignore the next state update until we know for sure that
89
- // InstantSearch.js re-inits the component.
90
- shouldSetStateRef.current = false;
116
+ return {};
117
+ }), 2), state = _useState[0], setState = _useState[1];
118
+ useWidget.useWidget({
119
+ widget: widget,
120
+ parentIndex: parentIndex,
121
+ props: stableProps,
122
+ shouldSsr: Boolean(serverContext),
123
+ skipSuspense: skipSuspense
91
124
  });
92
- return _objectSpread(_objectSpread({}, createWidget(stableProps)), stableAdditionalWidgetProperties);
93
- }, [connector, stableProps, stableAdditionalWidgetProperties]);
94
- var _useState = (0, _react.useState)(function () {
95
- if (widget.getWidgetRenderState) {
96
- var _widget$getWidgetSear;
97
- // The helper exists because we've started InstantSearch.
98
- var helper = parentIndex.getHelper();
99
- var uiState = parentIndex.getWidgetUiState({})[parentIndex.getIndexId()];
100
- helper.state = ((_widget$getWidgetSear = widget.getWidgetSearchParameters) === null || _widget$getWidgetSear === void 0 ? void 0 : _widget$getWidgetSear.call(widget, helper.state, {
101
- uiState: uiState
102
- })) || helper.state;
103
- var _getIndexSearchResult = (0, _getIndexSearchResults.getIndexSearchResults)(parentIndex),
104
- results = _getIndexSearchResult.results,
105
- scopedResults = _getIndexSearchResult.scopedResults,
106
- recommendResults = _getIndexSearchResult.recommendResults;
125
+ return state;
126
+ }
107
127
 
108
- // We get the widget render state by providing the same parameters as
109
- // InstantSearch provides to the widget's `render` method.
110
- // See https://github.com/algolia/instantsearch/blob/019cd18d0de6dd320284aa4890541b7fe2198c65/src/widgets/index/index.ts#L604-L617
111
- var _widget$getWidgetRend = widget.getWidgetRenderState({
112
- helper: helper,
113
- parent: parentIndex,
114
- instantSearchInstance: search,
115
- results: widget.dependsOn === 'recommend' && recommendResults && ssrContext ? recommendResults[ssrContext.recommendIdx.current++] : results,
116
- scopedResults: scopedResults,
117
- state: helper.state,
118
- renderState: search.renderState,
119
- templatesConfig: search.templatesConfig,
120
- createURL: parentIndex.createURL,
121
- searchMetadata: {
122
- isSearchStalled: search.status === 'stalled'
123
- },
124
- status: search.status,
125
- error: search.error
126
- }),
127
- widgetParams = _widget$getWidgetRend.widgetParams,
128
- renderState = _objectWithoutProperties(_widget$getWidgetRend, _excluded3);
129
- return renderState;
130
- }
131
- return {};
132
- }),
133
- _useState2 = _slicedToArray(_useState, 2),
134
- state = _useState2[0],
135
- setState = _useState2[1];
136
- (0, _useWidget.useWidget)({
137
- widget: widget,
138
- parentIndex: parentIndex,
139
- props: stableProps,
140
- shouldSsr: Boolean(serverContext),
141
- skipSuspense: skipSuspense
142
- });
143
- return state;
144
- }
128
+ exports.useConnector = useConnector;
@@ -1,62 +1,62 @@
1
- "use strict";
1
+ 'use strict';
2
+
3
+ var _to_consumable_array = require('@swc/helpers/_/_to_consumable_array');
4
+ var React = require('react');
5
+ var useInstantSearchContext = require('../lib/useInstantSearchContext.js');
6
+ var useIsomorphicLayoutEffect = require('../lib/useIsomorphicLayoutEffect.js');
7
+ var useSearchResults = require('../lib/useSearchResults.js');
8
+ var useSearchState = require('../lib/useSearchState.js');
2
9
 
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.useInstantSearch = useInstantSearch;
7
- var _react = require("react");
8
- var _useInstantSearchContext = require("../lib/useInstantSearchContext");
9
- var _useIsomorphicLayoutEffect = require("../lib/useIsomorphicLayoutEffect");
10
- var _useSearchResults2 = require("../lib/useSearchResults");
11
- var _useSearchState2 = require("../lib/useSearchState");
12
10
  function useInstantSearch() {
13
- var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
14
- catchError = _ref.catchError;
15
- var search = (0, _useInstantSearchContext.useInstantSearchContext)();
16
- var _useSearchState = (0, _useSearchState2.useSearchState)(),
17
- uiState = _useSearchState.uiState,
18
- setUiState = _useSearchState.setUiState,
19
- indexUiState = _useSearchState.indexUiState,
20
- setIndexUiState = _useSearchState.setIndexUiState,
21
- renderState = _useSearchState.renderState,
22
- indexRenderState = _useSearchState.indexRenderState;
23
- var _useSearchResults = (0, _useSearchResults2.useSearchResults)(),
24
- results = _useSearchResults.results,
25
- scopedResults = _useSearchResults.scopedResults;
26
- var addMiddlewares = (0, _react.useCallback)(function () {
27
- for (var _len = arguments.length, middlewares = new Array(_len), _key = 0; _key < _len; _key++) {
28
- middlewares[_key] = arguments[_key];
29
- }
30
- search.use.apply(search, middlewares);
31
- return function () {
32
- search.unuse.apply(search, middlewares);
11
+ var catchError = (arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}).catchError;
12
+ var search = useInstantSearchContext.useInstantSearchContext();
13
+ var _useSearchState = useSearchState.useSearchState(), uiState = _useSearchState.uiState, setUiState = _useSearchState.setUiState, indexUiState = _useSearchState.indexUiState, setIndexUiState = _useSearchState.setIndexUiState, renderState = _useSearchState.renderState, indexRenderState = _useSearchState.indexRenderState;
14
+ var _useSearchResults = useSearchResults.useSearchResults(), results = _useSearchResults.results, scopedResults = _useSearchResults.scopedResults;
15
+ var addMiddlewares = React.useCallback(function() {
16
+ for(var _len = arguments.length, middlewares = new Array(_len), _key = 0; _key < _len; _key++){
17
+ middlewares[_key] = arguments[_key];
18
+ }
19
+ var _search;
20
+ (_search = search).use.apply(_search, _to_consumable_array._(middlewares));
21
+ return function() {
22
+ var _search;
23
+ (_search = search).unuse.apply(_search, _to_consumable_array._(middlewares));
24
+ };
25
+ }, [
26
+ search
27
+ ]);
28
+ var refresh = React.useCallback(function() {
29
+ search.refresh();
30
+ }, [
31
+ search
32
+ ]);
33
+ useIsomorphicLayoutEffect.useIsomorphicLayoutEffect(function() {
34
+ if (catchError) {
35
+ var onError = function onError() {};
36
+ search.addListener('error', onError);
37
+ return function() {
38
+ return search.removeListener('error', onError);
39
+ };
40
+ }
41
+ return function() {};
42
+ }, [
43
+ search,
44
+ catchError
45
+ ]);
46
+ return {
47
+ results: results,
48
+ scopedResults: scopedResults,
49
+ uiState: uiState,
50
+ setUiState: setUiState,
51
+ indexUiState: indexUiState,
52
+ setIndexUiState: setIndexUiState,
53
+ renderState: renderState,
54
+ indexRenderState: indexRenderState,
55
+ addMiddlewares: addMiddlewares,
56
+ refresh: refresh,
57
+ status: search.status,
58
+ error: search.error
33
59
  };
34
- }, [search]);
35
- var refresh = (0, _react.useCallback)(function () {
36
- search.refresh();
37
- }, [search]);
38
- (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () {
39
- if (catchError) {
40
- var onError = function onError() {};
41
- search.addListener('error', onError);
42
- return function () {
43
- return search.removeListener('error', onError);
44
- };
45
- }
46
- return function () {};
47
- }, [search, catchError]);
48
- return {
49
- results: results,
50
- scopedResults: scopedResults,
51
- uiState: uiState,
52
- setUiState: setUiState,
53
- indexUiState: indexUiState,
54
- setIndexUiState: setIndexUiState,
55
- renderState: renderState,
56
- indexRenderState: indexRenderState,
57
- addMiddlewares: addMiddlewares,
58
- refresh: refresh,
59
- status: search.status,
60
- error: search.error
61
- };
62
- }
60
+ }
61
+
62
+ exports.useInstantSearch = useInstantSearch;