instantsearch.js 4.68.1 → 4.70.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/cjs/connectors/frequently-bought-together/connectFrequentlyBoughtTogether.js +93 -0
- package/cjs/connectors/index.js +28 -0
- package/cjs/connectors/looking-similar/connectLookingSimilar.js +94 -0
- package/cjs/connectors/related-products/connectRelatedProducts.js +94 -0
- package/cjs/connectors/trending-items/connectTrendingItems.js +90 -0
- package/cjs/lib/InstantSearch.js +10 -1
- package/cjs/lib/server.js +28 -9
- package/cjs/lib/utils/addWidgetId.js +17 -0
- package/cjs/lib/utils/hydrateRecommendCache.js +23 -0
- package/cjs/lib/utils/hydrateSearchClient.js +7 -3
- package/cjs/lib/utils/index.js +22 -0
- package/cjs/lib/utils/render-args.js +3 -3
- package/cjs/lib/version.js +1 -1
- package/cjs/widgets/frequently-bought-together/frequently-bought-together.js +120 -0
- package/cjs/widgets/index/index.js +89 -20
- package/cjs/widgets/index.js +28 -0
- package/cjs/widgets/looking-similar/looking-similar.js +122 -0
- package/cjs/widgets/related-products/related-products.js +122 -0
- package/cjs/widgets/trending-items/trending-items.js +126 -0
- package/dist/instantsearch.development.d.ts +411 -12
- package/dist/instantsearch.development.js +1702 -265
- package/dist/instantsearch.development.js.map +1 -1
- package/dist/instantsearch.production.d.ts +411 -12
- package/dist/instantsearch.production.min.d.ts +411 -12
- package/dist/instantsearch.production.min.js +2 -2
- package/dist/instantsearch.production.min.js.map +1 -1
- package/es/connectors/frequently-bought-together/connectFrequentlyBoughtTogether.d.ts +45 -0
- package/es/connectors/frequently-bought-together/connectFrequentlyBoughtTogether.js +86 -0
- package/es/connectors/index.d.ts +4 -0
- package/es/connectors/index.js +5 -1
- package/es/connectors/looking-similar/connectLookingSimilar.d.ts +49 -0
- package/es/connectors/looking-similar/connectLookingSimilar.js +87 -0
- package/es/connectors/related-products/connectRelatedProducts.d.ts +49 -0
- package/es/connectors/related-products/connectRelatedProducts.js +87 -0
- package/es/connectors/trending-items/connectTrendingItems.d.ts +57 -0
- package/es/connectors/trending-items/connectTrendingItems.js +83 -0
- package/es/lib/InstantSearch.d.ts +2 -0
- package/es/lib/InstantSearch.js +11 -2
- package/es/lib/server.d.ts +1 -1
- package/es/lib/server.js +28 -9
- package/es/lib/templating/renderTemplate.d.ts +1 -1
- package/es/lib/utils/addWidgetId.d.ts +3 -0
- package/es/lib/utils/addWidgetId.js +10 -0
- package/es/lib/utils/hydrateRecommendCache.d.ts +3 -0
- package/es/lib/utils/hydrateRecommendCache.js +17 -0
- package/es/lib/utils/hydrateSearchClient.js +7 -3
- package/es/lib/utils/index.d.ts +2 -0
- package/es/lib/utils/index.js +2 -0
- package/es/lib/utils/render-args.d.ts +3 -3
- package/es/lib/utils/render-args.js +3 -3
- package/es/lib/version.d.ts +1 -1
- package/es/lib/version.js +1 -1
- package/es/types/results.d.ts +7 -3
- package/es/types/templates.d.ts +1 -1
- package/es/types/widget.d.ts +16 -9
- package/es/widgets/frequently-bought-together/frequently-bought-together.d.ts +41 -0
- package/es/widgets/frequently-bought-together/frequently-bought-together.js +112 -0
- package/es/widgets/index/index.d.ts +2 -1
- package/es/widgets/index/index.js +89 -20
- package/es/widgets/index.d.ts +4 -0
- package/es/widgets/index.js +5 -1
- package/es/widgets/looking-similar/looking-similar.d.ts +41 -0
- package/es/widgets/looking-similar/looking-similar.js +114 -0
- package/es/widgets/related-products/related-products.d.ts +41 -0
- package/es/widgets/related-products/related-products.js +114 -0
- package/es/widgets/trending-items/trending-items.d.ts +41 -0
- package/es/widgets/trending-items/trending-items.js +118 -0
- package/package.json +7 -7
|
@@ -24,8 +24,8 @@ function createInitArgs(instantSearchInstance, parent, uiState) {
|
|
|
24
24
|
error: instantSearchInstance.error
|
|
25
25
|
};
|
|
26
26
|
}
|
|
27
|
-
function createRenderArgs(instantSearchInstance, parent) {
|
|
28
|
-
var results = parent.
|
|
27
|
+
function createRenderArgs(instantSearchInstance, parent, widget) {
|
|
28
|
+
var results = parent.getResultsForWidget(widget);
|
|
29
29
|
var helper = parent.getHelper();
|
|
30
30
|
return {
|
|
31
31
|
helper: helper,
|
|
@@ -33,7 +33,7 @@ function createRenderArgs(instantSearchInstance, parent) {
|
|
|
33
33
|
instantSearchInstance: instantSearchInstance,
|
|
34
34
|
results: results,
|
|
35
35
|
scopedResults: parent.getScopedResults(),
|
|
36
|
-
state: results ? results._state : helper.state,
|
|
36
|
+
state: results && '_state' in results ? results._state : helper.state,
|
|
37
37
|
renderState: instantSearchInstance.renderState,
|
|
38
38
|
templatesConfig: instantSearchInstance.templatesConfig,
|
|
39
39
|
createURL: parent.createURL,
|
package/cjs/lib/version.js
CHANGED
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _instantsearchUiComponents = require("instantsearch-ui-components");
|
|
9
|
+
var _preact = require("preact");
|
|
10
|
+
var _Template = _interopRequireDefault(require("../../components/Template/Template"));
|
|
11
|
+
var _connectFrequentlyBoughtTogether = _interopRequireDefault(require("../../connectors/frequently-bought-together/connectFrequentlyBoughtTogether"));
|
|
12
|
+
var _templating = require("../../lib/templating");
|
|
13
|
+
var _utils = require("../../lib/utils");
|
|
14
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
15
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
16
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
17
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
18
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
19
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
20
|
+
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
21
|
+
var withUsage = (0, _utils.createDocumentationMessageGenerator)({
|
|
22
|
+
name: 'frequently-bought-together'
|
|
23
|
+
});
|
|
24
|
+
var FrequentlyBoughtTogether = (0, _instantsearchUiComponents.createFrequentlyBoughtTogetherComponent)({
|
|
25
|
+
createElement: _preact.h,
|
|
26
|
+
Fragment: _preact.Fragment
|
|
27
|
+
});
|
|
28
|
+
var renderer = function renderer(_ref) {
|
|
29
|
+
var renderState = _ref.renderState,
|
|
30
|
+
cssClasses = _ref.cssClasses,
|
|
31
|
+
containerNode = _ref.containerNode,
|
|
32
|
+
templates = _ref.templates;
|
|
33
|
+
return function (_ref2, isFirstRendering) {
|
|
34
|
+
var items = _ref2.items,
|
|
35
|
+
results = _ref2.results,
|
|
36
|
+
instantSearchInstance = _ref2.instantSearchInstance;
|
|
37
|
+
if (isFirstRendering) {
|
|
38
|
+
renderState.templateProps = (0, _templating.prepareTemplateProps)({
|
|
39
|
+
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
|
|
40
|
+
defaultTemplates: {},
|
|
41
|
+
templatesConfig: instantSearchInstance.templatesConfig,
|
|
42
|
+
templates: templates
|
|
43
|
+
});
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
var headerComponent = templates.header ? function (data) {
|
|
47
|
+
return (0, _preact.h)(_Template.default, _extends({}, renderState.templateProps, {
|
|
48
|
+
templateKey: "header",
|
|
49
|
+
rootTagName: "fragment",
|
|
50
|
+
data: {
|
|
51
|
+
cssClasses: data.classNames,
|
|
52
|
+
items: data.items
|
|
53
|
+
}
|
|
54
|
+
}));
|
|
55
|
+
} : undefined;
|
|
56
|
+
var itemComponent = templates.item ? function (_ref3) {
|
|
57
|
+
var item = _ref3.item;
|
|
58
|
+
return (0, _preact.h)(_Template.default, _extends({}, renderState.templateProps, {
|
|
59
|
+
templateKey: "item",
|
|
60
|
+
rootTagName: "fragment",
|
|
61
|
+
data: item
|
|
62
|
+
}));
|
|
63
|
+
} : undefined;
|
|
64
|
+
var emptyComponent = templates.empty ? function () {
|
|
65
|
+
return (0, _preact.h)(_Template.default, _extends({}, renderState.templateProps, {
|
|
66
|
+
templateKey: "empty",
|
|
67
|
+
rootTagName: "fragment",
|
|
68
|
+
data: results
|
|
69
|
+
}));
|
|
70
|
+
} : undefined;
|
|
71
|
+
(0, _preact.render)((0, _preact.h)(FrequentlyBoughtTogether, {
|
|
72
|
+
items: items,
|
|
73
|
+
headerComponent: headerComponent,
|
|
74
|
+
itemComponent: itemComponent,
|
|
75
|
+
sendEvent: function sendEvent() {},
|
|
76
|
+
classNames: cssClasses,
|
|
77
|
+
emptyComponent: emptyComponent,
|
|
78
|
+
status: instantSearchInstance.status
|
|
79
|
+
}), containerNode);
|
|
80
|
+
};
|
|
81
|
+
};
|
|
82
|
+
var frequentlyBoughtTogether = function frequentlyBoughtTogether(widgetParams) {
|
|
83
|
+
var _ref4 = widgetParams || {},
|
|
84
|
+
container = _ref4.container,
|
|
85
|
+
objectIDs = _ref4.objectIDs,
|
|
86
|
+
limit = _ref4.limit,
|
|
87
|
+
queryParameters = _ref4.queryParameters,
|
|
88
|
+
threshold = _ref4.threshold,
|
|
89
|
+
escapeHTML = _ref4.escapeHTML,
|
|
90
|
+
transformItems = _ref4.transformItems,
|
|
91
|
+
_ref4$templates = _ref4.templates,
|
|
92
|
+
templates = _ref4$templates === void 0 ? {} : _ref4$templates,
|
|
93
|
+
_ref4$cssClasses = _ref4.cssClasses,
|
|
94
|
+
cssClasses = _ref4$cssClasses === void 0 ? {} : _ref4$cssClasses;
|
|
95
|
+
if (!container) {
|
|
96
|
+
throw new Error(withUsage('The `container` option is required.'));
|
|
97
|
+
}
|
|
98
|
+
var containerNode = (0, _utils.getContainerNode)(container);
|
|
99
|
+
var specializedRenderer = renderer({
|
|
100
|
+
containerNode: containerNode,
|
|
101
|
+
cssClasses: cssClasses,
|
|
102
|
+
renderState: {},
|
|
103
|
+
templates: templates
|
|
104
|
+
});
|
|
105
|
+
var makeWidget = (0, _connectFrequentlyBoughtTogether.default)(specializedRenderer, function () {
|
|
106
|
+
return (0, _preact.render)(null, containerNode);
|
|
107
|
+
});
|
|
108
|
+
return _objectSpread(_objectSpread({}, makeWidget({
|
|
109
|
+
objectIDs: objectIDs,
|
|
110
|
+
limit: limit,
|
|
111
|
+
queryParameters: queryParameters,
|
|
112
|
+
threshold: threshold,
|
|
113
|
+
escapeHTML: escapeHTML,
|
|
114
|
+
transformItems: transformItems
|
|
115
|
+
})), {}, {
|
|
116
|
+
$$widgetType: 'ais.frequentlyBoughtTogether'
|
|
117
|
+
});
|
|
118
|
+
};
|
|
119
|
+
var _default = frequentlyBoughtTogether;
|
|
120
|
+
exports.default = _default;
|
|
@@ -7,6 +7,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
exports.default = void 0;
|
|
8
8
|
var _algoliasearchHelper = _interopRequireDefault(require("algoliasearch-helper"));
|
|
9
9
|
var _utils = require("../../lib/utils");
|
|
10
|
+
var _addWidgetId = require("../../lib/utils/addWidgetId");
|
|
10
11
|
var _excluded = ["initialSearchParameters"],
|
|
11
12
|
_excluded2 = ["initialRecommendParameters"];
|
|
12
13
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
@@ -130,6 +131,8 @@ var index = function index(widgetParams) {
|
|
|
130
131
|
var helper = null;
|
|
131
132
|
var derivedHelper = null;
|
|
132
133
|
var lastValidSearchParameters = null;
|
|
134
|
+
var hasRecommendWidget = false;
|
|
135
|
+
var hasSearchWidget = false;
|
|
133
136
|
return {
|
|
134
137
|
$$type: 'ais.index',
|
|
135
138
|
$$widgetType: 'ais.index',
|
|
@@ -154,6 +157,16 @@ var index = function index(widgetParams) {
|
|
|
154
157
|
derivedHelper.lastResults._state = helper.state;
|
|
155
158
|
return derivedHelper.lastResults;
|
|
156
159
|
},
|
|
160
|
+
getResultsForWidget: function getResultsForWidget(widget) {
|
|
161
|
+
var _helper;
|
|
162
|
+
if (widget.dependsOn !== 'recommend' || (0, _utils.isIndexWidget)(widget) || widget.$$id === undefined) {
|
|
163
|
+
return this.getResults();
|
|
164
|
+
}
|
|
165
|
+
if (!((_helper = helper) !== null && _helper !== void 0 && _helper.lastRecommendResults)) {
|
|
166
|
+
return null;
|
|
167
|
+
}
|
|
168
|
+
return helper.lastRecommendResults[widget.$$id];
|
|
169
|
+
},
|
|
157
170
|
getPreviousState: function getPreviousState() {
|
|
158
171
|
return lastValidSearchParameters;
|
|
159
172
|
},
|
|
@@ -198,6 +211,21 @@ var index = function index(widgetParams) {
|
|
|
198
211
|
})) {
|
|
199
212
|
throw new Error(withUsage('The widget definition expects a `render` and/or an `init` method.'));
|
|
200
213
|
}
|
|
214
|
+
widgets.forEach(function (widget) {
|
|
215
|
+
if ((0, _utils.isIndexWidget)(widget)) {
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
if (localInstantSearchInstance && widget.dependsOn === 'recommend') {
|
|
219
|
+
localInstantSearchInstance._hasRecommendWidget = true;
|
|
220
|
+
} else if (localInstantSearchInstance) {
|
|
221
|
+
localInstantSearchInstance._hasSearchWidget = true;
|
|
222
|
+
} else if (widget.dependsOn === 'recommend') {
|
|
223
|
+
hasRecommendWidget = true;
|
|
224
|
+
} else {
|
|
225
|
+
hasSearchWidget = true;
|
|
226
|
+
}
|
|
227
|
+
(0, _addWidgetId.addWidgetId)(widget);
|
|
228
|
+
});
|
|
201
229
|
localWidgets = localWidgets.concat(widgets);
|
|
202
230
|
if (localInstantSearchInstance && Boolean(widgets.length)) {
|
|
203
231
|
privateHelperSetState(helper, {
|
|
@@ -247,16 +275,41 @@ var index = function index(widgetParams) {
|
|
|
247
275
|
localWidgets = localWidgets.filter(function (widget) {
|
|
248
276
|
return widgets.indexOf(widget) === -1;
|
|
249
277
|
});
|
|
278
|
+
localWidgets.forEach(function (widget) {
|
|
279
|
+
if ((0, _utils.isIndexWidget)(widget)) {
|
|
280
|
+
return;
|
|
281
|
+
}
|
|
282
|
+
if (localInstantSearchInstance && widget.dependsOn === 'recommend') {
|
|
283
|
+
localInstantSearchInstance._hasRecommendWidget = true;
|
|
284
|
+
} else if (localInstantSearchInstance) {
|
|
285
|
+
localInstantSearchInstance._hasSearchWidget = true;
|
|
286
|
+
} else if (widget.dependsOn === 'recommend') {
|
|
287
|
+
hasRecommendWidget = true;
|
|
288
|
+
} else {
|
|
289
|
+
hasSearchWidget = true;
|
|
290
|
+
}
|
|
291
|
+
});
|
|
250
292
|
if (localInstantSearchInstance && Boolean(widgets.length)) {
|
|
251
|
-
var
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
293
|
+
var _widgets$reduce = widgets.reduce(function (states, widget) {
|
|
294
|
+
// the `dispose` method exists at this point we already assert it
|
|
295
|
+
var next = widget.dispose({
|
|
296
|
+
helper: helper,
|
|
297
|
+
state: states.cleanedSearchState,
|
|
298
|
+
recommendState: states.cleanedRecommendState,
|
|
299
|
+
parent: _this2
|
|
300
|
+
});
|
|
301
|
+
if (next instanceof _algoliasearchHelper.default.RecommendParameters) {
|
|
302
|
+
states.cleanedRecommendState = next;
|
|
303
|
+
} else if (next) {
|
|
304
|
+
states.cleanedSearchState = next;
|
|
305
|
+
}
|
|
306
|
+
return states;
|
|
307
|
+
}, {
|
|
308
|
+
cleanedSearchState: helper.state,
|
|
309
|
+
cleanedRecommendState: helper.recommendState
|
|
310
|
+
}),
|
|
311
|
+
cleanedSearchState = _widgets$reduce.cleanedSearchState,
|
|
312
|
+
cleanedRecommendState = _widgets$reduce.cleanedRecommendState;
|
|
260
313
|
var newState = localInstantSearchInstance.future.preserveSharedStateOnUnmount ? getLocalWidgetsSearchParameters(localWidgets, {
|
|
261
314
|
uiState: localUiState,
|
|
262
315
|
initialSearchParameters: new _algoliasearchHelper.default.SearchParameters({
|
|
@@ -264,16 +317,17 @@ var index = function index(widgetParams) {
|
|
|
264
317
|
})
|
|
265
318
|
}) : getLocalWidgetsSearchParameters(localWidgets, {
|
|
266
319
|
uiState: getLocalWidgetsUiState(localWidgets, {
|
|
267
|
-
searchParameters:
|
|
320
|
+
searchParameters: cleanedSearchState,
|
|
268
321
|
helper: helper
|
|
269
322
|
}),
|
|
270
|
-
initialSearchParameters:
|
|
323
|
+
initialSearchParameters: cleanedSearchState
|
|
271
324
|
});
|
|
272
325
|
localUiState = getLocalWidgetsUiState(localWidgets, {
|
|
273
326
|
searchParameters: newState,
|
|
274
327
|
helper: helper
|
|
275
328
|
});
|
|
276
329
|
helper.setState(newState);
|
|
330
|
+
helper.recommendState = cleanedRecommendState;
|
|
277
331
|
if (localWidgets.length) {
|
|
278
332
|
localInstantSearchInstance.scheduleSearch();
|
|
279
333
|
}
|
|
@@ -349,13 +403,20 @@ var index = function index(widgetParams) {
|
|
|
349
403
|
return _this3.getHelper().recommendState;
|
|
350
404
|
});
|
|
351
405
|
var indexInitialResults = (_instantSearchInstanc = instantSearchInstance._initialResults) === null || _instantSearchInstanc === void 0 ? void 0 : _instantSearchInstanc[this.getIndexId()];
|
|
352
|
-
if (indexInitialResults) {
|
|
406
|
+
if (indexInitialResults !== null && indexInitialResults !== void 0 && indexInitialResults.results) {
|
|
353
407
|
// We restore the shape of the results provided to the instance to respect
|
|
354
408
|
// the helper's structure.
|
|
355
409
|
var results = new _algoliasearchHelper.default.SearchResults(new _algoliasearchHelper.default.SearchParameters(indexInitialResults.state), indexInitialResults.results);
|
|
356
410
|
derivedHelper.lastResults = results;
|
|
357
411
|
helper.lastResults = results;
|
|
358
412
|
}
|
|
413
|
+
if (indexInitialResults !== null && indexInitialResults !== void 0 && indexInitialResults.recommendResults) {
|
|
414
|
+
var recommendResults = new _algoliasearchHelper.default.RecommendResults(new _algoliasearchHelper.default.RecommendParameters({
|
|
415
|
+
params: indexInitialResults.recommendResults.params
|
|
416
|
+
}), indexInitialResults.recommendResults.results);
|
|
417
|
+
derivedHelper.lastRecommendResults = recommendResults;
|
|
418
|
+
helper.lastRecommendResults = recommendResults;
|
|
419
|
+
}
|
|
359
420
|
|
|
360
421
|
// Subscribe to the Helper state changes for the page before widgets
|
|
361
422
|
// are initialized. This behavior mimics the original one of the Helper.
|
|
@@ -459,9 +520,16 @@ var index = function index(widgetParams) {
|
|
|
459
520
|
// schedule a render that will render the results injected on the helper.
|
|
460
521
|
instantSearchInstance.scheduleRender();
|
|
461
522
|
}
|
|
523
|
+
if (hasRecommendWidget) {
|
|
524
|
+
instantSearchInstance._hasRecommendWidget = true;
|
|
525
|
+
}
|
|
526
|
+
if (hasSearchWidget) {
|
|
527
|
+
instantSearchInstance._hasSearchWidget = true;
|
|
528
|
+
}
|
|
462
529
|
},
|
|
463
530
|
render: function render(_ref6) {
|
|
464
|
-
var
|
|
531
|
+
var _derivedHelper2,
|
|
532
|
+
_this4 = this;
|
|
465
533
|
var instantSearchInstance = _ref6.instantSearchInstance;
|
|
466
534
|
// we can't attach a listener to the error event of search, as the error
|
|
467
535
|
// then would no longer be thrown for global handlers.
|
|
@@ -471,7 +539,7 @@ var index = function index(widgetParams) {
|
|
|
471
539
|
|
|
472
540
|
// We only render index widgets if there are no results.
|
|
473
541
|
// This makes sure `render` is never called with `results` being `null`.
|
|
474
|
-
var widgetsToRender = this.getResults() ? localWidgets : localWidgets.filter(_utils.isIndexWidget);
|
|
542
|
+
var widgetsToRender = this.getResults() || (_derivedHelper2 = derivedHelper) !== null && _derivedHelper2 !== void 0 && _derivedHelper2.lastRecommendResults ? localWidgets : localWidgets.filter(_utils.isIndexWidget);
|
|
475
543
|
widgetsToRender = widgetsToRender.filter(function (widget) {
|
|
476
544
|
if (!widget.shouldRender) {
|
|
477
545
|
return true;
|
|
@@ -482,7 +550,7 @@ var index = function index(widgetParams) {
|
|
|
482
550
|
});
|
|
483
551
|
widgetsToRender.forEach(function (widget) {
|
|
484
552
|
if (widget.getRenderState) {
|
|
485
|
-
var renderState = widget.getRenderState(instantSearchInstance.renderState[_this4.getIndexId()] || {}, (0, _utils.createRenderArgs)(instantSearchInstance, _this4));
|
|
553
|
+
var renderState = widget.getRenderState(instantSearchInstance.renderState[_this4.getIndexId()] || {}, (0, _utils.createRenderArgs)(instantSearchInstance, _this4, widget));
|
|
486
554
|
storeRenderState({
|
|
487
555
|
renderState: renderState,
|
|
488
556
|
instantSearchInstance: instantSearchInstance,
|
|
@@ -499,14 +567,14 @@ var index = function index(widgetParams) {
|
|
|
499
567
|
// not have results yet.
|
|
500
568
|
|
|
501
569
|
if (widget.render) {
|
|
502
|
-
widget.render((0, _utils.createRenderArgs)(instantSearchInstance, _this4));
|
|
570
|
+
widget.render((0, _utils.createRenderArgs)(instantSearchInstance, _this4, widget));
|
|
503
571
|
}
|
|
504
572
|
});
|
|
505
573
|
},
|
|
506
574
|
dispose: function dispose() {
|
|
507
575
|
var _this5 = this,
|
|
508
|
-
|
|
509
|
-
|
|
576
|
+
_helper2,
|
|
577
|
+
_derivedHelper3;
|
|
510
578
|
localWidgets.forEach(function (widget) {
|
|
511
579
|
if (widget.dispose && helper) {
|
|
512
580
|
// The dispose function is always called once the instance is started
|
|
@@ -518,15 +586,16 @@ var index = function index(widgetParams) {
|
|
|
518
586
|
widget.dispose({
|
|
519
587
|
helper: helper,
|
|
520
588
|
state: helper.state,
|
|
589
|
+
recommendState: helper.recommendState,
|
|
521
590
|
parent: _this5
|
|
522
591
|
});
|
|
523
592
|
}
|
|
524
593
|
});
|
|
525
594
|
localInstantSearchInstance = null;
|
|
526
595
|
localParent = null;
|
|
527
|
-
(
|
|
596
|
+
(_helper2 = helper) === null || _helper2 === void 0 ? void 0 : _helper2.removeAllListeners();
|
|
528
597
|
helper = null;
|
|
529
|
-
(
|
|
598
|
+
(_derivedHelper3 = derivedHelper) === null || _derivedHelper3 === void 0 ? void 0 : _derivedHelper3.detach();
|
|
530
599
|
derivedHelper = null;
|
|
531
600
|
},
|
|
532
601
|
getWidgetUiState: function getWidgetUiState(uiState) {
|
package/cjs/widgets/index.js
CHANGED
|
@@ -47,6 +47,12 @@ Object.defineProperty(exports, "dynamicWidgets", {
|
|
|
47
47
|
return _dynamicWidgets.default;
|
|
48
48
|
}
|
|
49
49
|
});
|
|
50
|
+
Object.defineProperty(exports, "frequentlyBoughtTogether", {
|
|
51
|
+
enumerable: true,
|
|
52
|
+
get: function get() {
|
|
53
|
+
return _frequentlyBoughtTogether.default;
|
|
54
|
+
}
|
|
55
|
+
});
|
|
50
56
|
Object.defineProperty(exports, "geoSearch", {
|
|
51
57
|
enumerable: true,
|
|
52
58
|
get: function get() {
|
|
@@ -83,6 +89,12 @@ Object.defineProperty(exports, "infiniteHits", {
|
|
|
83
89
|
return _infiniteHits.default;
|
|
84
90
|
}
|
|
85
91
|
});
|
|
92
|
+
Object.defineProperty(exports, "lookingSimilar", {
|
|
93
|
+
enumerable: true,
|
|
94
|
+
get: function get() {
|
|
95
|
+
return _lookingSimilar.default;
|
|
96
|
+
}
|
|
97
|
+
});
|
|
86
98
|
Object.defineProperty(exports, "menu", {
|
|
87
99
|
enumerable: true,
|
|
88
100
|
get: function get() {
|
|
@@ -161,6 +173,12 @@ Object.defineProperty(exports, "refinementList", {
|
|
|
161
173
|
return _refinementList.default;
|
|
162
174
|
}
|
|
163
175
|
});
|
|
176
|
+
Object.defineProperty(exports, "relatedProducts", {
|
|
177
|
+
enumerable: true,
|
|
178
|
+
get: function get() {
|
|
179
|
+
return _relatedProducts.default;
|
|
180
|
+
}
|
|
181
|
+
});
|
|
164
182
|
Object.defineProperty(exports, "relevantSort", {
|
|
165
183
|
enumerable: true,
|
|
166
184
|
get: function get() {
|
|
@@ -191,6 +209,12 @@ Object.defineProperty(exports, "toggleRefinement", {
|
|
|
191
209
|
return _toggleRefinement.default;
|
|
192
210
|
}
|
|
193
211
|
});
|
|
212
|
+
Object.defineProperty(exports, "trendingItems", {
|
|
213
|
+
enumerable: true,
|
|
214
|
+
get: function get() {
|
|
215
|
+
return _trendingItems.default;
|
|
216
|
+
}
|
|
217
|
+
});
|
|
194
218
|
Object.defineProperty(exports, "voiceSearch", {
|
|
195
219
|
enumerable: true,
|
|
196
220
|
get: function get() {
|
|
@@ -221,6 +245,7 @@ var _places = _interopRequireDefault(require("./places/places"));
|
|
|
221
245
|
var _poweredBy = _interopRequireDefault(require("./powered-by/powered-by"));
|
|
222
246
|
var _queryRuleContext = _interopRequireDefault(require("./query-rule-context/query-rule-context"));
|
|
223
247
|
var _queryRuleCustomData = _interopRequireDefault(require("./query-rule-custom-data/query-rule-custom-data"));
|
|
248
|
+
var _relatedProducts = _interopRequireDefault(require("./related-products/related-products"));
|
|
224
249
|
var _rangeInput = _interopRequireDefault(require("./range-input/range-input"));
|
|
225
250
|
var _rangeSlider = _interopRequireDefault(require("./range-slider/range-slider"));
|
|
226
251
|
var _ratingMenu = _interopRequireDefault(require("./rating-menu/rating-menu"));
|
|
@@ -230,7 +255,10 @@ var _searchBox = _interopRequireDefault(require("./search-box/search-box"));
|
|
|
230
255
|
var _sortBy = _interopRequireDefault(require("./sort-by/sort-by"));
|
|
231
256
|
var _stats = _interopRequireDefault(require("./stats/stats"));
|
|
232
257
|
var _toggleRefinement = _interopRequireDefault(require("./toggle-refinement/toggle-refinement"));
|
|
258
|
+
var _trendingItems = _interopRequireDefault(require("./trending-items/trending-items"));
|
|
233
259
|
var _voiceSearch = _interopRequireDefault(require("./voice-search/voice-search"));
|
|
260
|
+
var _frequentlyBoughtTogether = _interopRequireDefault(require("./frequently-bought-together/frequently-bought-together"));
|
|
261
|
+
var _lookingSimilar = _interopRequireDefault(require("./looking-similar/looking-similar"));
|
|
234
262
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
235
263
|
/** @deprecated answers is no longer supported */
|
|
236
264
|
var EXPERIMENTAL_answers = (0, _utils.deprecate)(_answers.default, 'answers is no longer supported');
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _instantsearchUiComponents = require("instantsearch-ui-components");
|
|
9
|
+
var _preact = require("preact");
|
|
10
|
+
var _Template = _interopRequireDefault(require("../../components/Template/Template"));
|
|
11
|
+
var _connectLookingSimilar = _interopRequireDefault(require("../../connectors/looking-similar/connectLookingSimilar"));
|
|
12
|
+
var _templating = require("../../lib/templating");
|
|
13
|
+
var _utils = require("../../lib/utils");
|
|
14
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
15
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
16
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
17
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
18
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
19
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
20
|
+
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
21
|
+
var withUsage = (0, _utils.createDocumentationMessageGenerator)({
|
|
22
|
+
name: 'looking-similar'
|
|
23
|
+
});
|
|
24
|
+
var LookingSimilar = (0, _instantsearchUiComponents.createLookingSimilarComponent)({
|
|
25
|
+
createElement: _preact.h,
|
|
26
|
+
Fragment: _preact.Fragment
|
|
27
|
+
});
|
|
28
|
+
var renderer = function renderer(_ref) {
|
|
29
|
+
var renderState = _ref.renderState,
|
|
30
|
+
cssClasses = _ref.cssClasses,
|
|
31
|
+
containerNode = _ref.containerNode,
|
|
32
|
+
templates = _ref.templates;
|
|
33
|
+
return function (_ref2, isFirstRendering) {
|
|
34
|
+
var items = _ref2.items,
|
|
35
|
+
results = _ref2.results,
|
|
36
|
+
instantSearchInstance = _ref2.instantSearchInstance;
|
|
37
|
+
if (isFirstRendering) {
|
|
38
|
+
renderState.templateProps = (0, _templating.prepareTemplateProps)({
|
|
39
|
+
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
|
|
40
|
+
defaultTemplates: {},
|
|
41
|
+
templatesConfig: instantSearchInstance.templatesConfig,
|
|
42
|
+
templates: templates
|
|
43
|
+
});
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
var headerComponent = templates.header ? function (data) {
|
|
47
|
+
return (0, _preact.h)(_Template.default, _extends({}, renderState.templateProps, {
|
|
48
|
+
templateKey: "header",
|
|
49
|
+
rootTagName: "fragment",
|
|
50
|
+
data: {
|
|
51
|
+
cssClasses: data.classNames,
|
|
52
|
+
items: data.items
|
|
53
|
+
}
|
|
54
|
+
}));
|
|
55
|
+
} : undefined;
|
|
56
|
+
var itemComponent = templates.item ? function (_ref3) {
|
|
57
|
+
var item = _ref3.item;
|
|
58
|
+
return (0, _preact.h)(_Template.default, _extends({}, renderState.templateProps, {
|
|
59
|
+
templateKey: "item",
|
|
60
|
+
rootTagName: "fragment",
|
|
61
|
+
data: item
|
|
62
|
+
}));
|
|
63
|
+
} : undefined;
|
|
64
|
+
var emptyComponent = templates.empty ? function () {
|
|
65
|
+
return (0, _preact.h)(_Template.default, _extends({}, renderState.templateProps, {
|
|
66
|
+
templateKey: "empty",
|
|
67
|
+
rootTagName: "fragment",
|
|
68
|
+
data: results
|
|
69
|
+
}));
|
|
70
|
+
} : undefined;
|
|
71
|
+
(0, _preact.render)((0, _preact.h)(LookingSimilar, {
|
|
72
|
+
items: items,
|
|
73
|
+
headerComponent: headerComponent,
|
|
74
|
+
itemComponent: itemComponent,
|
|
75
|
+
sendEvent: function sendEvent() {},
|
|
76
|
+
classNames: cssClasses,
|
|
77
|
+
emptyComponent: emptyComponent,
|
|
78
|
+
status: instantSearchInstance.status
|
|
79
|
+
}), containerNode);
|
|
80
|
+
};
|
|
81
|
+
};
|
|
82
|
+
var lookingSimilar = function lookingSimilar(widgetParams) {
|
|
83
|
+
var _ref4 = widgetParams || {},
|
|
84
|
+
container = _ref4.container,
|
|
85
|
+
objectIDs = _ref4.objectIDs,
|
|
86
|
+
limit = _ref4.limit,
|
|
87
|
+
queryParameters = _ref4.queryParameters,
|
|
88
|
+
fallbackParameters = _ref4.fallbackParameters,
|
|
89
|
+
threshold = _ref4.threshold,
|
|
90
|
+
escapeHTML = _ref4.escapeHTML,
|
|
91
|
+
transformItems = _ref4.transformItems,
|
|
92
|
+
_ref4$templates = _ref4.templates,
|
|
93
|
+
templates = _ref4$templates === void 0 ? {} : _ref4$templates,
|
|
94
|
+
_ref4$cssClasses = _ref4.cssClasses,
|
|
95
|
+
cssClasses = _ref4$cssClasses === void 0 ? {} : _ref4$cssClasses;
|
|
96
|
+
if (!container) {
|
|
97
|
+
throw new Error(withUsage('The `container` option is required.'));
|
|
98
|
+
}
|
|
99
|
+
var containerNode = (0, _utils.getContainerNode)(container);
|
|
100
|
+
var specializedRenderer = renderer({
|
|
101
|
+
containerNode: containerNode,
|
|
102
|
+
cssClasses: cssClasses,
|
|
103
|
+
renderState: {},
|
|
104
|
+
templates: templates
|
|
105
|
+
});
|
|
106
|
+
var makeWidget = (0, _connectLookingSimilar.default)(specializedRenderer, function () {
|
|
107
|
+
return (0, _preact.render)(null, containerNode);
|
|
108
|
+
});
|
|
109
|
+
return _objectSpread(_objectSpread({}, makeWidget({
|
|
110
|
+
objectIDs: objectIDs,
|
|
111
|
+
limit: limit,
|
|
112
|
+
queryParameters: queryParameters,
|
|
113
|
+
fallbackParameters: fallbackParameters,
|
|
114
|
+
threshold: threshold,
|
|
115
|
+
escapeHTML: escapeHTML,
|
|
116
|
+
transformItems: transformItems
|
|
117
|
+
})), {}, {
|
|
118
|
+
$$widgetType: 'ais.lookingSimilar'
|
|
119
|
+
});
|
|
120
|
+
};
|
|
121
|
+
var _default = lookingSimilar;
|
|
122
|
+
exports.default = _default;
|