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.
- package/dist/cjs/components/Configure.js +11 -17
- package/dist/cjs/components/DynamicWidgets.js +46 -53
- package/dist/cjs/components/Index.js +19 -22
- package/dist/cjs/components/InstantSearch.js +34 -36
- package/dist/cjs/components/InstantSearchSSRProvider.js +31 -41
- package/dist/cjs/components/InstantSearchServerContext.js +6 -10
- package/dist/cjs/connectors/useAutocomplete.js +8 -10
- package/dist/cjs/connectors/useBreadcrumb.js +8 -10
- package/dist/cjs/connectors/useChat.js +8 -10
- package/dist/cjs/connectors/useClearRefinements.js +8 -10
- package/dist/cjs/connectors/useConfigure.js +10 -12
- package/dist/cjs/connectors/useCurrentRefinements.js +8 -10
- package/dist/cjs/connectors/useDynamicWidgets.js +14 -20
- package/dist/cjs/connectors/useFilterSuggestions.js +8 -10
- package/dist/cjs/connectors/useFrequentlyBoughtTogether.js +8 -10
- package/dist/cjs/connectors/useGeoSearch.js +8 -10
- package/dist/cjs/connectors/useHierarchicalMenu.js +8 -10
- package/dist/cjs/connectors/useHits.js +8 -10
- package/dist/cjs/connectors/useHitsPerPage.js +8 -10
- package/dist/cjs/connectors/useInfiniteHits.js +8 -10
- package/dist/cjs/connectors/useLookingSimilar.js +8 -10
- package/dist/cjs/connectors/useMenu.js +8 -10
- package/dist/cjs/connectors/useNumericMenu.js +8 -10
- package/dist/cjs/connectors/usePagination.js +8 -10
- package/dist/cjs/connectors/usePoweredBy.js +18 -19
- package/dist/cjs/connectors/useQueryRules.js +8 -10
- package/dist/cjs/connectors/useRange.js +8 -10
- package/dist/cjs/connectors/useRefinementList.js +8 -10
- package/dist/cjs/connectors/useRelatedProducts.js +8 -10
- package/dist/cjs/connectors/useSearchBox.js +8 -10
- package/dist/cjs/connectors/useSortBy.js +8 -10
- package/dist/cjs/connectors/useStats.js +8 -10
- package/dist/cjs/connectors/useToggleRefinement.js +8 -10
- package/dist/cjs/connectors/useTrendingItems.js +8 -10
- package/dist/cjs/hooks/useConnector.js +123 -139
- package/dist/cjs/hooks/useInstantSearch.js +59 -59
- package/dist/cjs/index.js +90 -519
- package/dist/cjs/lib/IndexContext.js +6 -10
- package/dist/cjs/lib/InstantSearchContext.js +6 -10
- package/dist/cjs/lib/InstantSearchRSCContext.js +11 -12
- package/dist/cjs/lib/InstantSearchSSRContext.js +6 -10
- package/dist/cjs/lib/createSearchResults.js +24 -25
- package/dist/cjs/lib/dequal.js +33 -40
- package/dist/cjs/lib/getIndexSearchResults.js +23 -30
- package/dist/cjs/lib/invariant.js +11 -17
- package/dist/cjs/lib/noop.js +8 -6
- package/dist/cjs/lib/use.js +26 -11
- package/dist/cjs/lib/useAppIdAndApiKey.js +10 -12
- package/dist/cjs/lib/useForceUpdate.js +12 -21
- package/dist/cjs/lib/useIndex.js +40 -37
- package/dist/cjs/lib/useIndexContext.js +11 -12
- package/dist/cjs/lib/useInstantSearchApi.js +174 -197
- package/dist/cjs/lib/useInstantSearchContext.js +11 -12
- package/dist/cjs/lib/useInstantSearchSSRContext.js +8 -9
- package/dist/cjs/lib/useInstantSearchServerContext.js +8 -9
- package/dist/cjs/lib/useIsomorphicLayoutEffect.js +6 -8
- package/dist/cjs/lib/useRSCContext.js +8 -9
- package/dist/cjs/lib/useSearchResults.js +54 -62
- package/dist/cjs/lib/useSearchState.js +53 -60
- package/dist/cjs/lib/useStableValue.js +15 -24
- package/dist/cjs/lib/useWidget.js +99 -95
- package/dist/cjs/lib/warn.js +11 -35
- package/dist/cjs/lib/wrapPromiseWithState.js +23 -26
- package/dist/cjs/package.json +4 -1
- package/dist/cjs/server/getServerState.js +81 -91
- package/dist/cjs/server/index.js +6 -15
- package/dist/cjs/version.js +6 -6
- package/dist/es/components/Configure.js +11 -13
- package/dist/es/components/DynamicWidgets.js +45 -47
- package/dist/es/components/Index.js +19 -17
- package/dist/es/components/InstantSearch.js +33 -29
- package/dist/es/components/InstantSearchSSRProvider.js +30 -35
- package/dist/es/components/InstantSearchServerContext.js +4 -4
- package/dist/es/connectors/useAutocomplete.js +8 -5
- package/dist/es/connectors/useBreadcrumb.js +8 -5
- package/dist/es/connectors/useChat.js +8 -5
- package/dist/es/connectors/useClearRefinements.js +8 -5
- package/dist/es/connectors/useConfigure.js +10 -7
- package/dist/es/connectors/useCurrentRefinements.js +8 -5
- package/dist/es/connectors/useDynamicWidgets.js +14 -15
- package/dist/es/connectors/useFilterSuggestions.js +8 -5
- package/dist/es/connectors/useFrequentlyBoughtTogether.js +8 -5
- package/dist/es/connectors/useGeoSearch.js +8 -5
- package/dist/es/connectors/useHierarchicalMenu.js +8 -5
- package/dist/es/connectors/useHits.js +8 -5
- package/dist/es/connectors/useHitsPerPage.js +8 -5
- package/dist/es/connectors/useInfiniteHits.js +8 -5
- package/dist/es/connectors/useLookingSimilar.js +8 -5
- package/dist/es/connectors/useMenu.js +8 -5
- package/dist/es/connectors/useNumericMenu.js +8 -5
- package/dist/es/connectors/usePagination.js +8 -5
- package/dist/es/connectors/usePoweredBy.js +18 -15
- package/dist/es/connectors/useQueryRules.js +8 -5
- package/dist/es/connectors/useRange.js +8 -5
- package/dist/es/connectors/useRefinementList.js +8 -5
- package/dist/es/connectors/useRelatedProducts.js +8 -5
- package/dist/es/connectors/useSearchBox.js +8 -5
- package/dist/es/connectors/useSortBy.js +8 -5
- package/dist/es/connectors/useStats.js +8 -5
- package/dist/es/connectors/useToggleRefinement.js +8 -5
- package/dist/es/connectors/useTrendingItems.js +8 -5
- package/dist/es/hooks/useConnector.js +122 -134
- package/dist/es/hooks/useInstantSearch.js +58 -54
- package/dist/es/index.js +43 -43
- package/dist/es/lib/IndexContext.js +4 -4
- package/dist/es/lib/InstantSearchContext.js +4 -4
- package/dist/es/lib/InstantSearchRSCContext.js +10 -7
- package/dist/es/lib/InstantSearchSSRContext.js +4 -4
- package/dist/es/lib/createSearchResults.js +23 -19
- package/dist/es/lib/dequal.js +33 -36
- package/dist/es/lib/getIndexSearchResults.js +23 -26
- package/dist/es/lib/invariant.js +10 -12
- package/dist/es/lib/noop.js +7 -1
- package/dist/es/lib/use.js +4 -2
- package/dist/es/lib/useAppIdAndApiKey.js +9 -7
- package/dist/es/lib/useForceUpdate.js +9 -15
- package/dist/es/lib/useIndex.js +39 -31
- package/dist/es/lib/useIndexContext.js +10 -7
- package/dist/es/lib/useInstantSearchApi.js +174 -191
- package/dist/es/lib/useInstantSearchContext.js +10 -7
- package/dist/es/lib/useInstantSearchSSRContext.js +7 -4
- package/dist/es/lib/useInstantSearchServerContext.js +7 -4
- package/dist/es/lib/useIsomorphicLayoutEffect.js +4 -3
- package/dist/es/lib/useRSCContext.js +7 -4
- package/dist/es/lib/useSearchResults.js +53 -57
- package/dist/es/lib/useSearchState.js +52 -55
- package/dist/es/lib/useStableValue.js +14 -19
- package/dist/es/lib/useWidget.js +98 -90
- package/dist/es/lib/warn.js +9 -29
- package/dist/es/lib/wrapPromiseWithState.js +23 -22
- package/dist/es/package.json +4 -0
- package/dist/es/server/getServerState.js +80 -85
- package/dist/es/server/index.js +1 -1
- package/dist/es/version.d.ts +1 -1
- package/dist/es/version.js +3 -1
- package/dist/umd/ReactInstantSearchCore.js +17449 -22297
- package/dist/umd/ReactInstantSearchCore.min.js +3 -3
- package/package.json +7 -11
- package/dist/umd/ReactInstantSearchCore.js.map +0 -1
- package/dist/umd/ReactInstantSearchCore.min.js.map +0 -1
|
@@ -1,144 +1,128 @@
|
|
|
1
|
-
|
|
1
|
+
'use strict';
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
var
|
|
9
|
-
var
|
|
10
|
-
var
|
|
11
|
-
var
|
|
12
|
-
var
|
|
13
|
-
var
|
|
14
|
-
var
|
|
15
|
-
var
|
|
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
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
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
|
-
},
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
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
|
|
93
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
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
|
-
|
|
35
|
-
|
|
36
|
-
|
|
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;
|