instantsearch.js 4.68.0 → 4.69.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 +9 -1
- package/cjs/lib/utils/addWidgetId.js +13 -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 +82 -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 +403 -10
- package/dist/instantsearch.development.js +1679 -274
- package/dist/instantsearch.development.js.map +1 -1
- package/dist/instantsearch.production.d.ts +403 -10
- package/dist/instantsearch.production.min.d.ts +403 -10
- 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 +9 -1
- package/es/lib/templating/renderTemplate.d.ts +1 -1
- package/es/lib/utils/addWidgetId.d.ts +2 -0
- package/es/lib/utils/addWidgetId.js +7 -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/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 +82 -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
|
@@ -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
|
}
|
|
@@ -459,9 +513,16 @@ var index = function index(widgetParams) {
|
|
|
459
513
|
// schedule a render that will render the results injected on the helper.
|
|
460
514
|
instantSearchInstance.scheduleRender();
|
|
461
515
|
}
|
|
516
|
+
if (hasRecommendWidget) {
|
|
517
|
+
instantSearchInstance._hasRecommendWidget = true;
|
|
518
|
+
}
|
|
519
|
+
if (hasSearchWidget) {
|
|
520
|
+
instantSearchInstance._hasSearchWidget = true;
|
|
521
|
+
}
|
|
462
522
|
},
|
|
463
523
|
render: function render(_ref6) {
|
|
464
|
-
var
|
|
524
|
+
var _derivedHelper2,
|
|
525
|
+
_this4 = this;
|
|
465
526
|
var instantSearchInstance = _ref6.instantSearchInstance;
|
|
466
527
|
// we can't attach a listener to the error event of search, as the error
|
|
467
528
|
// then would no longer be thrown for global handlers.
|
|
@@ -471,7 +532,7 @@ var index = function index(widgetParams) {
|
|
|
471
532
|
|
|
472
533
|
// We only render index widgets if there are no results.
|
|
473
534
|
// This makes sure `render` is never called with `results` being `null`.
|
|
474
|
-
var widgetsToRender = this.getResults() ? localWidgets : localWidgets.filter(_utils.isIndexWidget);
|
|
535
|
+
var widgetsToRender = this.getResults() || (_derivedHelper2 = derivedHelper) !== null && _derivedHelper2 !== void 0 && _derivedHelper2.lastRecommendResults ? localWidgets : localWidgets.filter(_utils.isIndexWidget);
|
|
475
536
|
widgetsToRender = widgetsToRender.filter(function (widget) {
|
|
476
537
|
if (!widget.shouldRender) {
|
|
477
538
|
return true;
|
|
@@ -482,7 +543,7 @@ var index = function index(widgetParams) {
|
|
|
482
543
|
});
|
|
483
544
|
widgetsToRender.forEach(function (widget) {
|
|
484
545
|
if (widget.getRenderState) {
|
|
485
|
-
var renderState = widget.getRenderState(instantSearchInstance.renderState[_this4.getIndexId()] || {}, (0, _utils.createRenderArgs)(instantSearchInstance, _this4));
|
|
546
|
+
var renderState = widget.getRenderState(instantSearchInstance.renderState[_this4.getIndexId()] || {}, (0, _utils.createRenderArgs)(instantSearchInstance, _this4, widget));
|
|
486
547
|
storeRenderState({
|
|
487
548
|
renderState: renderState,
|
|
488
549
|
instantSearchInstance: instantSearchInstance,
|
|
@@ -499,16 +560,16 @@ var index = function index(widgetParams) {
|
|
|
499
560
|
// not have results yet.
|
|
500
561
|
|
|
501
562
|
if (widget.render) {
|
|
502
|
-
widget.render((0, _utils.createRenderArgs)(instantSearchInstance, _this4));
|
|
563
|
+
widget.render((0, _utils.createRenderArgs)(instantSearchInstance, _this4, widget));
|
|
503
564
|
}
|
|
504
565
|
});
|
|
505
566
|
},
|
|
506
567
|
dispose: function dispose() {
|
|
507
568
|
var _this5 = this,
|
|
508
|
-
|
|
509
|
-
|
|
569
|
+
_helper2,
|
|
570
|
+
_derivedHelper3;
|
|
510
571
|
localWidgets.forEach(function (widget) {
|
|
511
|
-
if (widget.dispose) {
|
|
572
|
+
if (widget.dispose && helper) {
|
|
512
573
|
// The dispose function is always called once the instance is started
|
|
513
574
|
// (it's an effect of `removeWidgets`). The index is initialized and
|
|
514
575
|
// the Helper is available. We don't care about the return value of
|
|
@@ -518,15 +579,16 @@ var index = function index(widgetParams) {
|
|
|
518
579
|
widget.dispose({
|
|
519
580
|
helper: helper,
|
|
520
581
|
state: helper.state,
|
|
582
|
+
recommendState: helper.recommendState,
|
|
521
583
|
parent: _this5
|
|
522
584
|
});
|
|
523
585
|
}
|
|
524
586
|
});
|
|
525
587
|
localInstantSearchInstance = null;
|
|
526
588
|
localParent = null;
|
|
527
|
-
(
|
|
589
|
+
(_helper2 = helper) === null || _helper2 === void 0 ? void 0 : _helper2.removeAllListeners();
|
|
528
590
|
helper = null;
|
|
529
|
-
(
|
|
591
|
+
(_derivedHelper3 = derivedHelper) === null || _derivedHelper3 === void 0 ? void 0 : _derivedHelper3.detach();
|
|
530
592
|
derivedHelper = null;
|
|
531
593
|
},
|
|
532
594
|
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;
|
|
@@ -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 _connectRelatedProducts = _interopRequireDefault(require("../../connectors/related-products/connectRelatedProducts"));
|
|
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: 'related-products'
|
|
23
|
+
});
|
|
24
|
+
var RelatedProducts = (0, _instantsearchUiComponents.createRelatedProductsComponent)({
|
|
25
|
+
createElement: _preact.h,
|
|
26
|
+
Fragment: _preact.Fragment
|
|
27
|
+
});
|
|
28
|
+
function createRenderer(_ref) {
|
|
29
|
+
var renderState = _ref.renderState,
|
|
30
|
+
cssClasses = _ref.cssClasses,
|
|
31
|
+
containerNode = _ref.containerNode,
|
|
32
|
+
templates = _ref.templates;
|
|
33
|
+
return function renderer(_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)(RelatedProducts, {
|
|
72
|
+
items: items,
|
|
73
|
+
sendEvent: function sendEvent() {},
|
|
74
|
+
classNames: cssClasses,
|
|
75
|
+
headerComponent: headerComponent,
|
|
76
|
+
itemComponent: itemComponent,
|
|
77
|
+
emptyComponent: emptyComponent,
|
|
78
|
+
status: instantSearchInstance.status
|
|
79
|
+
}), containerNode);
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
var relatedProducts = function relatedProducts(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 = createRenderer({
|
|
101
|
+
containerNode: containerNode,
|
|
102
|
+
cssClasses: cssClasses,
|
|
103
|
+
renderState: {},
|
|
104
|
+
templates: templates
|
|
105
|
+
});
|
|
106
|
+
var makeWidget = (0, _connectRelatedProducts.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.relatedProducts'
|
|
119
|
+
});
|
|
120
|
+
};
|
|
121
|
+
var _default = relatedProducts;
|
|
122
|
+
exports.default = _default;
|
|
@@ -0,0 +1,126 @@
|
|
|
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 _connectTrendingItems = _interopRequireDefault(require("../../connectors/trending-items/connectTrendingItems"));
|
|
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: 'trending-items'
|
|
23
|
+
});
|
|
24
|
+
var TrendingItems = (0, _instantsearchUiComponents.createTrendingItemsComponent)({
|
|
25
|
+
createElement: _preact.h,
|
|
26
|
+
Fragment: _preact.Fragment
|
|
27
|
+
});
|
|
28
|
+
function createRenderer(_ref) {
|
|
29
|
+
var renderState = _ref.renderState,
|
|
30
|
+
cssClasses = _ref.cssClasses,
|
|
31
|
+
containerNode = _ref.containerNode,
|
|
32
|
+
templates = _ref.templates;
|
|
33
|
+
return function renderer(_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)(TrendingItems, {
|
|
72
|
+
items: items,
|
|
73
|
+
sendEvent: function sendEvent() {},
|
|
74
|
+
classNames: cssClasses,
|
|
75
|
+
headerComponent: headerComponent,
|
|
76
|
+
itemComponent: itemComponent,
|
|
77
|
+
emptyComponent: emptyComponent,
|
|
78
|
+
status: instantSearchInstance.status
|
|
79
|
+
}), containerNode);
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
var trendingItems = function trendingItems(widgetParams) {
|
|
83
|
+
var _ref4 = widgetParams || {},
|
|
84
|
+
container = _ref4.container,
|
|
85
|
+
facetName = _ref4.facetName,
|
|
86
|
+
facetValue = _ref4.facetValue,
|
|
87
|
+
limit = _ref4.limit,
|
|
88
|
+
queryParameters = _ref4.queryParameters,
|
|
89
|
+
fallbackParameters = _ref4.fallbackParameters,
|
|
90
|
+
threshold = _ref4.threshold,
|
|
91
|
+
escapeHTML = _ref4.escapeHTML,
|
|
92
|
+
transformItems = _ref4.transformItems,
|
|
93
|
+
_ref4$templates = _ref4.templates,
|
|
94
|
+
templates = _ref4$templates === void 0 ? {} : _ref4$templates,
|
|
95
|
+
_ref4$cssClasses = _ref4.cssClasses,
|
|
96
|
+
cssClasses = _ref4$cssClasses === void 0 ? {} : _ref4$cssClasses;
|
|
97
|
+
if (!container) {
|
|
98
|
+
throw new Error(withUsage('The `container` option is required.'));
|
|
99
|
+
}
|
|
100
|
+
var containerNode = (0, _utils.getContainerNode)(container);
|
|
101
|
+
var specializedRenderer = createRenderer({
|
|
102
|
+
containerNode: containerNode,
|
|
103
|
+
cssClasses: cssClasses,
|
|
104
|
+
renderState: {},
|
|
105
|
+
templates: templates
|
|
106
|
+
});
|
|
107
|
+
var makeWidget = (0, _connectTrendingItems.default)(specializedRenderer, function () {
|
|
108
|
+
return (0, _preact.render)(null, containerNode);
|
|
109
|
+
});
|
|
110
|
+
var facetParameters = facetName && facetValue ? {
|
|
111
|
+
facetName: facetName,
|
|
112
|
+
facetValue: facetValue
|
|
113
|
+
} : {};
|
|
114
|
+
return _objectSpread(_objectSpread({}, makeWidget(_objectSpread(_objectSpread({}, facetParameters), {}, {
|
|
115
|
+
limit: limit,
|
|
116
|
+
queryParameters: queryParameters,
|
|
117
|
+
fallbackParameters: fallbackParameters,
|
|
118
|
+
threshold: threshold,
|
|
119
|
+
escapeHTML: escapeHTML,
|
|
120
|
+
transformItems: transformItems
|
|
121
|
+
}))), {}, {
|
|
122
|
+
$$widgetType: 'ais.trendingItems'
|
|
123
|
+
});
|
|
124
|
+
};
|
|
125
|
+
var _default = trendingItems;
|
|
126
|
+
exports.default = _default;
|