UNPKG

@algolia/autocomplete-js

Version:

Fast and fully-featured autocomplete JavaScript library.

1,381 lines (1,341 loc) 210 kB
/*! @algolia/autocomplete-js 1.19.8 | MIT License | © Algolia, Inc. and contributors | https://github.com/algolia/autocomplete */ (function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : typeof define === 'function' && define.amd ? define(['exports'], factory) : (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["@algolia/autocomplete-js"] = {})); })(this, (function (exports) { 'use strict'; function _arrayLikeToArray$a(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; } function _arrayWithHoles$2(r) { if (Array.isArray(r)) return r; } function _arrayWithoutHoles$7(r) { if (Array.isArray(r)) return _arrayLikeToArray$a(r); } function _defineProperty$h(e, r, t) { return (r = _toPropertyKey$h(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } function _iterableToArray$7(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _iterableToArrayLimit$2(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; } } function _nonIterableRest$2() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _nonIterableSpread$7() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function ownKeys$h(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; } function _objectSpread2(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$h(Object(t), !0).forEach(function (r) { _defineProperty$h(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$h(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _objectWithoutProperties$5(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose$5(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; } function _objectWithoutPropertiesLoose$5(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; } function _slicedToArray$2(r, e) { return _arrayWithHoles$2(r) || _iterableToArrayLimit$2(r, e) || _unsupportedIterableToArray$a(r, e) || _nonIterableRest$2(); } function _toConsumableArray$7(r) { return _arrayWithoutHoles$7(r) || _iterableToArray$7(r) || _unsupportedIterableToArray$a(r) || _nonIterableSpread$7(); } function _toPrimitive$h(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); } function _toPropertyKey$h(t) { var i = _toPrimitive$h(t, "string"); return "symbol" == typeof i ? i : i + ""; } function _typeof$i(o) { "@babel/helpers - typeof"; return _typeof$i = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof$i(o); } function _unsupportedIterableToArray$a(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$a(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$a(r, a) : void 0; } } function createRef(initialValue) { return { current: initialValue }; } function debounce(fn, time) { var timerId = undefined; return function () { for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } if (timerId) { clearTimeout(timerId); } timerId = setTimeout(function () { return fn.apply(void 0, args); }, time); }; } function _slicedToArray$1(r, e) { return _arrayWithHoles$1(r) || _iterableToArrayLimit$1(r, e) || _unsupportedIterableToArray$9(r, e) || _nonIterableRest$1(); } function _nonIterableRest$1() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray$9(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$9(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$9(r, a) : void 0; } } function _arrayLikeToArray$9(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; } function _iterableToArrayLimit$1(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; } } function _arrayWithHoles$1(r) { if (Array.isArray(r)) return r; } function _typeof$h(o) { "@babel/helpers - typeof"; return _typeof$h = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof$h(o); } /** * Decycles objects with circular references. * This is used to print cyclic structures in development environment only. */ function decycle(obj) { var seen = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : new Set(); if (!obj || _typeof$h(obj) !== 'object') { return obj; } if (seen.has(obj)) { return '[Circular]'; } var newSeen = seen.add(obj); if (Array.isArray(obj)) { return obj.map(function (x) { return decycle(x, newSeen); }); } return Object.fromEntries(Object.entries(obj).map(function (_ref) { var _ref2 = _slicedToArray$1(_ref, 2), key = _ref2[0], value = _ref2[1]; return [key, decycle(value, newSeen)]; })); } function flatten(values) { return values.reduce(function (a, b) { return a.concat(b); }, []); } var autocompleteId = 0; function generateAutocompleteId() { return "autocomplete-".concat(autocompleteId++); } function getAttributeValueByPath(record, path) { return path.reduce(function (current, key) { return current && current[key]; }, record); } function getItemsCount(state) { if (state.collections.length === 0) { return 0; } return state.collections.reduce(function (sum, collection) { return sum + collection.items.length; }, 0); } /** * Throws an error if the condition is not met in development mode. * This is used to make development a better experience to provide guidance as * to where the error comes from. */ function invariant(condition, message) { if (!condition) { throw new Error("[Autocomplete] ".concat(typeof message === 'function' ? message() : message)); } } function isPrimitive(obj) { return obj !== Object(obj); } function isEqual(first, second) { if (first === second) { return true; } if (isPrimitive(first) || isPrimitive(second) || typeof first === 'function' || typeof second === 'function') { return first === second; } if (Object.keys(first).length !== Object.keys(second).length) { return false; } for (var _i = 0, _Object$keys = Object.keys(first); _i < _Object$keys.length; _i++) { var key = _Object$keys[_i]; if (!(key in second)) { return false; } if (!isEqual(first[key], second[key])) { return false; } } return true; } var noop = function noop() {}; /** * Safely runs code meant for browser environments only. */ function safelyRunOnBrowser(callback) { if (typeof window !== 'undefined') { return callback({ window: window }); } return undefined; } var version = '1.19.8'; var userAgents$1 = [{ segment: 'autocomplete-core', version: version }]; var warnCache = { current: {} }; /** * Logs a warning if the condition is not met. * This is used to log issues in development environment only. */ function warn(condition, message) { if (condition) { return; } var sanitizedMessage = message.trim(); var hasAlreadyPrinted = warnCache.current[sanitizedMessage]; if (!hasAlreadyPrinted) { warnCache.current[sanitizedMessage] = true; // eslint-disable-next-line no-console console.warn("[Autocomplete] ".concat(sanitizedMessage)); } } function createClickedEvent(_ref) { var item = _ref.item, _ref$items = _ref.items, items = _ref$items === void 0 ? [] : _ref$items; return { index: item.__autocomplete_indexName, items: [item], positions: [1 + items.findIndex(function (x) { return x.objectID === item.objectID; })], queryID: item.__autocomplete_queryID, algoliaSource: ['autocomplete'] }; } function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray$8(r, e) || _nonIterableRest(); } 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."); } function _unsupportedIterableToArray$8(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$8(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$8(r, a) : void 0; } } function _arrayLikeToArray$8(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; } 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; } } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } /** * Determines if a given insights `client` supports the optional call to `init` * and the ability to set credentials via extra parameters when sending events. */ function isModernInsightsClient(client) { var _split$map = (client.version || '').split('.').map(Number), _split$map2 = _slicedToArray(_split$map, 2), major = _split$map2[0], minor = _split$map2[1]; /* eslint-disable @typescript-eslint/camelcase */ var v3 = major >= 3; var v2_4 = major === 2 && minor >= 4; var v1_10 = major === 1 && minor >= 10; return v3 || v2_4 || v1_10; /* eslint-enable @typescript-eslint/camelcase */ } var _excluded$8 = ["items"], _excluded2$1 = ["items"]; function _typeof$g(o) { "@babel/helpers - typeof"; return _typeof$g = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof$g(o); } function _toConsumableArray$6(r) { return _arrayWithoutHoles$6(r) || _iterableToArray$6(r) || _unsupportedIterableToArray$7(r) || _nonIterableSpread$6(); } function _nonIterableSpread$6() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray$7(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$7(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$7(r, a) : void 0; } } function _iterableToArray$6(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _arrayWithoutHoles$6(r) { if (Array.isArray(r)) return _arrayLikeToArray$7(r); } function _arrayLikeToArray$7(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; } function _objectWithoutProperties$4(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose$4(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; } function _objectWithoutPropertiesLoose$4(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; } function ownKeys$g(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; } function _objectSpread$g(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$g(Object(t), !0).forEach(function (r) { _defineProperty$g(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$g(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty$g(e, r, t) { return (r = _toPropertyKey$g(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey$g(t) { var i = _toPrimitive$g(t, "string"); return "symbol" == _typeof$g(i) ? i : i + ""; } function _toPrimitive$g(t, r) { if ("object" != _typeof$g(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof$g(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function chunk(item) { var chunkSize = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 20; var chunks = []; for (var i = 0; i < item.objectIDs.length; i += chunkSize) { chunks.push(_objectSpread$g(_objectSpread$g({}, item), {}, { objectIDs: item.objectIDs.slice(i, i + chunkSize) })); } return chunks; } function mapToInsightsParamsApi(params) { return params.map(function (_ref) { var items = _ref.items, param = _objectWithoutProperties$4(_ref, _excluded$8); return _objectSpread$g(_objectSpread$g({}, param), {}, { objectIDs: (items === null || items === void 0 ? void 0 : items.map(function (_ref2) { var objectID = _ref2.objectID; return objectID; })) || param.objectIDs }); }); } function createSearchInsightsApi(searchInsights) { var canSendHeaders = isModernInsightsClient(searchInsights); function sendToInsights(method, payloads, items) { if (canSendHeaders && typeof items !== 'undefined') { var _items$0$__autocomple = items[0].__autocomplete_algoliaCredentials, appId = _items$0$__autocomple.appId, apiKey = _items$0$__autocomple.apiKey; var headers = { 'X-Algolia-Application-Id': appId, 'X-Algolia-API-Key': apiKey }; searchInsights.apply(void 0, [method].concat(_toConsumableArray$6(payloads), [{ headers: headers }])); } else { searchInsights.apply(void 0, [method].concat(_toConsumableArray$6(payloads))); } } return { /** * Initializes Insights with Algolia credentials. */ init: function init(appId, apiKey) { searchInsights('init', { appId: appId, apiKey: apiKey }); }, /** * Sets the authenticated user token to attach to events. * Unsets the authenticated token by passing `undefined`. * * @link https://www.algolia.com/doc/api-reference/api-methods/set-authenticated-user-token/ */ setAuthenticatedUserToken: function setAuthenticatedUserToken(authenticatedUserToken) { searchInsights('setAuthenticatedUserToken', authenticatedUserToken); }, /** * Sets the user token to attach to events. */ setUserToken: function setUserToken(userToken) { searchInsights('setUserToken', userToken); }, /** * Sends click events to capture a query and its clicked items and positions. * * @link https://www.algolia.com/doc/api-reference/api-methods/clicked-object-ids-after-search/ */ clickedObjectIDsAfterSearch: function clickedObjectIDsAfterSearch() { for (var _len = arguments.length, params = new Array(_len), _key = 0; _key < _len; _key++) { params[_key] = arguments[_key]; } if (params.length > 0) { sendToInsights('clickedObjectIDsAfterSearch', mapToInsightsParamsApi(params), params[0].items); } }, /** * Sends click events to capture clicked items. * * @link https://www.algolia.com/doc/api-reference/api-methods/clicked-object-ids/ */ clickedObjectIDs: function clickedObjectIDs() { for (var _len2 = arguments.length, params = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { params[_key2] = arguments[_key2]; } if (params.length > 0) { sendToInsights('clickedObjectIDs', mapToInsightsParamsApi(params), params[0].items); } }, /** * Sends click events to capture the filters a user clicks on. * * @link https://www.algolia.com/doc/api-reference/api-methods/clicked-filters/ */ clickedFilters: function clickedFilters() { for (var _len3 = arguments.length, params = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) { params[_key3] = arguments[_key3]; } if (params.length > 0) { searchInsights.apply(void 0, ['clickedFilters'].concat(params)); } }, /** * Sends conversion events to capture a query and its clicked items. * * @link https://www.algolia.com/doc/api-reference/api-methods/converted-object-ids-after-search/ */ convertedObjectIDsAfterSearch: function convertedObjectIDsAfterSearch() { for (var _len4 = arguments.length, params = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) { params[_key4] = arguments[_key4]; } if (params.length > 0) { sendToInsights('convertedObjectIDsAfterSearch', mapToInsightsParamsApi(params), params[0].items); } }, /** * Sends conversion events to capture clicked items. * * @link https://www.algolia.com/doc/api-reference/api-methods/converted-object-ids/ */ convertedObjectIDs: function convertedObjectIDs() { for (var _len5 = arguments.length, params = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) { params[_key5] = arguments[_key5]; } if (params.length > 0) { sendToInsights('convertedObjectIDs', mapToInsightsParamsApi(params), params[0].items); } }, /** * Sends conversion events to capture the filters a user uses when converting. * * @link https://www.algolia.com/doc/api-reference/api-methods/converted-filters/ */ convertedFilters: function convertedFilters() { for (var _len6 = arguments.length, params = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) { params[_key6] = arguments[_key6]; } if (params.length > 0) { searchInsights.apply(void 0, ['convertedFilters'].concat(params)); } }, /** * Sends view events to capture clicked items. * * @link https://www.algolia.com/doc/api-reference/api-methods/viewed-object-ids/ */ viewedObjectIDs: function viewedObjectIDs() { for (var _len7 = arguments.length, params = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) { params[_key7] = arguments[_key7]; } if (params.length > 0) { params.reduce(function (acc, _ref3) { var items = _ref3.items, param = _objectWithoutProperties$4(_ref3, _excluded2$1); return [].concat(_toConsumableArray$6(acc), _toConsumableArray$6(chunk(_objectSpread$g(_objectSpread$g({}, param), {}, { objectIDs: (items === null || items === void 0 ? void 0 : items.map(function (_ref4) { var objectID = _ref4.objectID; return objectID; })) || param.objectIDs })).map(function (payload) { return { items: items, payload: payload }; }))); }, []).forEach(function (_ref5) { var items = _ref5.items, payload = _ref5.payload; return sendToInsights('viewedObjectIDs', [payload], items); }); } }, /** * Sends view events to capture the filters a user uses when viewing. * * @link https://www.algolia.com/doc/api-reference/api-methods/viewed-filters/ */ viewedFilters: function viewedFilters() { for (var _len8 = arguments.length, params = new Array(_len8), _key8 = 0; _key8 < _len8; _key8++) { params[_key8] = arguments[_key8]; } if (params.length > 0) { searchInsights.apply(void 0, ['viewedFilters'].concat(params)); } } }; } function createViewedEvents(_ref) { var items = _ref.items; var itemsByIndexName = items.reduce(function (acc, current) { var _acc$current$__autoco; acc[current.__autocomplete_indexName] = ((_acc$current$__autoco = acc[current.__autocomplete_indexName]) !== null && _acc$current$__autoco !== void 0 ? _acc$current$__autoco : []).concat(current); return acc; }, {}); return Object.keys(itemsByIndexName).map(function (indexName) { var items = itemsByIndexName[indexName]; return { index: indexName, items: items, algoliaSource: ['autocomplete'] }; }); } function isAlgoliaInsightsHit(hit) { return hit.objectID && hit.__autocomplete_indexName && hit.__autocomplete_queryID; } function _typeof$f(o) { "@babel/helpers - typeof"; return _typeof$f = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof$f(o); } function _toConsumableArray$5(r) { return _arrayWithoutHoles$5(r) || _iterableToArray$5(r) || _unsupportedIterableToArray$6(r) || _nonIterableSpread$5(); } function _nonIterableSpread$5() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray$6(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$6(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$6(r, a) : void 0; } } function _iterableToArray$5(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } function _arrayWithoutHoles$5(r) { if (Array.isArray(r)) return _arrayLikeToArray$6(r); } function _arrayLikeToArray$6(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; } function ownKeys$f(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; } function _objectSpread$f(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$f(Object(t), !0).forEach(function (r) { _defineProperty$f(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$f(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty$f(e, r, t) { return (r = _toPropertyKey$f(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey$f(t) { var i = _toPrimitive$f(t, "string"); return "symbol" == _typeof$f(i) ? i : i + ""; } function _toPrimitive$f(t, r) { if ("object" != _typeof$f(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof$f(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } var VIEW_EVENT_DELAY = 400; var ALGOLIA_INSIGHTS_VERSION = '2.15.0'; var ALGOLIA_INSIGHTS_SRC = "https://cdn.jsdelivr.net/npm/search-insights@".concat(ALGOLIA_INSIGHTS_VERSION, "/dist/search-insights.min.js"); var sendViewedObjectIDs = debounce(function (_ref) { var onItemsChange = _ref.onItemsChange, items = _ref.items, insights = _ref.insights, state = _ref.state; onItemsChange({ insights: insights, insightsEvents: createViewedEvents({ items: items }).map(function (event) { return _objectSpread$f({ eventName: 'Items Viewed' }, event); }), state: state }); }, VIEW_EVENT_DELAY); function createAlgoliaInsightsPlugin(options) { var _getOptions = getOptions(options), providedInsightsClient = _getOptions.insightsClient, insightsInitParams = _getOptions.insightsInitParams, onItemsChange = _getOptions.onItemsChange, onSelectEvent = _getOptions.onSelect, onActiveEvent = _getOptions.onActive, __autocomplete_clickAnalytics = _getOptions.__autocomplete_clickAnalytics; var insightsClient = providedInsightsClient; if (!providedInsightsClient) { safelyRunOnBrowser(function (_ref2) { var window = _ref2.window; var pointer = window.AlgoliaAnalyticsObject || 'aa'; if (typeof pointer === 'string') { insightsClient = window[pointer]; } if (!insightsClient) { window.AlgoliaAnalyticsObject = pointer; if (!window[pointer]) { window[pointer] = function () { if (!window[pointer].queue) { window[pointer].queue = []; } for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } window[pointer].queue.push(args); }; } window[pointer].version = ALGOLIA_INSIGHTS_VERSION; insightsClient = window[pointer]; loadInsights(window); } }); } // We return an empty plugin if `insightsClient` is still undefined at // this stage, which can happen in server environments. if (!insightsClient) { return {}; } if (insightsInitParams) { insightsClient('init', _objectSpread$f({ partial: true }, insightsInitParams)); } var insights = createSearchInsightsApi(insightsClient); var previousItems = createRef([]); var debouncedOnStateChange = debounce(function (_ref3) { var state = _ref3.state; if (!state.isOpen) { return; } var items = state.collections.reduce(function (acc, current) { return [].concat(_toConsumableArray$5(acc), _toConsumableArray$5(current.items)); }, []).filter(isAlgoliaInsightsHit); if (!isEqual(previousItems.current.map(function (x) { return x.objectID; }), items.map(function (x) { return x.objectID; }))) { previousItems.current = items; if (items.length > 0) { sendViewedObjectIDs({ onItemsChange: onItemsChange, items: items, insights: insights, state: state }); } } }, 0); return { name: 'aa.algoliaInsightsPlugin', subscribe: function subscribe(_ref4) { var setContext = _ref4.setContext, onSelect = _ref4.onSelect, onActive = _ref4.onActive; function setInsightsContext(userToken) { setContext({ algoliaInsightsPlugin: { __algoliaSearchParameters: _objectSpread$f(_objectSpread$f({}, __autocomplete_clickAnalytics ? { clickAnalytics: true } : {}), userToken ? { userToken: normalizeUserToken(userToken) } : {}), insights: insights } }); } insightsClient('addAlgoliaAgent', 'insights-plugin'); setInsightsContext(); // Handles user token changes insightsClient('onUserTokenChange', function (userToken) { setInsightsContext(userToken); }); insightsClient('getUserToken', null, function (_error, userToken) { setInsightsContext(userToken); }); onSelect(function (_ref5) { var item = _ref5.item, state = _ref5.state, event = _ref5.event, source = _ref5.source; if (!isAlgoliaInsightsHit(item)) { return; } onSelectEvent({ state: state, event: event, insights: insights, item: item, insightsEvents: [_objectSpread$f({ eventName: 'Item Selected' }, createClickedEvent({ item: item, items: source.getItems().filter(isAlgoliaInsightsHit) }))] }); }); onActive(function (_ref6) { var item = _ref6.item, source = _ref6.source, state = _ref6.state, event = _ref6.event; if (!isAlgoliaInsightsHit(item)) { return; } onActiveEvent({ state: state, event: event, insights: insights, item: item, insightsEvents: [_objectSpread$f({ eventName: 'Item Active' }, createClickedEvent({ item: item, items: source.getItems().filter(isAlgoliaInsightsHit) }))] }); }); }, onStateChange: function onStateChange(_ref7) { var state = _ref7.state; debouncedOnStateChange({ state: state }); }, __autocomplete_pluginOptions: options }; } function getAlgoliaSources() { var _context$algoliaInsig; var algoliaSourceBase = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; var context = arguments.length > 1 ? arguments[1] : undefined; return [].concat(_toConsumableArray$5(algoliaSourceBase), ['autocomplete-internal'], _toConsumableArray$5((_context$algoliaInsig = context.algoliaInsightsPlugin) !== null && _context$algoliaInsig !== void 0 && _context$algoliaInsig.__automaticInsights ? ['autocomplete-automatic'] : [])); } function getOptions(options) { return _objectSpread$f({ onItemsChange: function onItemsChange(_ref8) { var insights = _ref8.insights, insightsEvents = _ref8.insightsEvents, state = _ref8.state; insights.viewedObjectIDs.apply(insights, _toConsumableArray$5(insightsEvents.map(function (event) { return _objectSpread$f(_objectSpread$f({}, event), {}, { algoliaSource: getAlgoliaSources(event.algoliaSource, state.context) }); }))); }, onSelect: function onSelect(_ref9) { var insights = _ref9.insights, insightsEvents = _ref9.insightsEvents, state = _ref9.state; insights.clickedObjectIDsAfterSearch.apply(insights, _toConsumableArray$5(insightsEvents.map(function (event) { return _objectSpread$f(_objectSpread$f({}, event), {}, { algoliaSource: getAlgoliaSources(event.algoliaSource, state.context) }); }))); }, onActive: noop, __autocomplete_clickAnalytics: true }, options); } function loadInsights(environment) { var errorMessage = "[Autocomplete]: Could not load search-insights.js. Please load it manually following https://alg.li/insights-autocomplete"; try { var script = environment.document.createElement('script'); script.async = true; script.src = ALGOLIA_INSIGHTS_SRC; script.onerror = function () { // eslint-disable-next-line no-console console.error(errorMessage); }; document.body.appendChild(script); } catch (cause) { // eslint-disable-next-line no-console console.error(errorMessage); } } /** * While `search-insights` supports both string and number user tokens, * the Search API only accepts strings. This function normalizes the user token. */ function normalizeUserToken(userToken) { return typeof userToken === 'number' ? userToken.toString() : userToken; } function checkOptions(options) { "development" !== 'production' ? warn(!options.debug, 'The `debug` option is meant for development debugging and should not be used in production.') : void 0 ; } function createInternalCancelablePromise(promise, initialState) { var state = initialState; return { then: function then(onfulfilled, onrejected) { return createInternalCancelablePromise(promise.then(createCallback(onfulfilled, state, promise), createCallback(onrejected, state, promise)), state); }, catch: function _catch(onrejected) { return createInternalCancelablePromise(promise.catch(createCallback(onrejected, state, promise)), state); }, finally: function _finally(onfinally) { if (onfinally) { state.onCancelList.push(onfinally); } return createInternalCancelablePromise(promise.finally(createCallback(onfinally && function () { state.onCancelList = []; return onfinally(); }, state, promise)), state); }, cancel: function cancel() { state.isCanceled = true; var callbacks = state.onCancelList; state.onCancelList = []; callbacks.forEach(function (callback) { callback(); }); }, isCanceled: function isCanceled() { return state.isCanceled === true; } }; } function cancelable(promise) { return createInternalCancelablePromise(promise, { isCanceled: false, onCancelList: [] }); } function createCallback(onResult, state, fallback) { if (!onResult) { return fallback; } return function callback(arg) { if (state.isCanceled) { return arg; } return onResult(arg); }; } // Ensures multiple callers sync to the same promise. var _hasWaitPromiseResolved = true; var _waitPromise; function createCancelablePromiseList() { var list = []; return { add: function add(cancelablePromise) { list.push(cancelablePromise); return cancelablePromise.finally(function () { list = list.filter(function (item) { return item !== cancelablePromise; }); }); }, cancelAll: function cancelAll() { list.forEach(function (promise) { return promise.cancel(); }); }, isEmpty: function isEmpty() { return list.length === 0; }, wait: function wait(timeout) { // Reuse promise if already exists. Keeps multiple callers subscribed to the same promise. if (!_hasWaitPromiseResolved) { return _waitPromise; } // Creates a promise which either resolves after all pending requests complete // or the timeout is reached (if provided). Whichever comes first. _hasWaitPromiseResolved = false; _waitPromise = !timeout ? Promise.all(list) : Promise.race([Promise.all(list), new Promise(function (resolve) { return setTimeout(resolve, timeout); })]); return _waitPromise.then(function () { _hasWaitPromiseResolved = true; }); } }; } /** * Creates a runner that executes promises in a concurrent-safe way. * * This is useful to prevent older promises to resolve after a newer promise, * otherwise resulting in stale resolved values. */ function createConcurrentSafePromise() { var basePromiseId = -1; var latestResolvedId = -1; var latestResolvedValue = undefined; return function runConcurrentSafePromise(promise) { basePromiseId++; var currentPromiseId = basePromiseId; return Promise.resolve(promise).then(function (x) { // The promise might take too long to resolve and get outdated. This would // result in resolving stale values. // When this happens, we ignore the promise value and return the one // coming from the latest resolved value. // // +----------------------------------+ // | 100ms | // | run(1) +---> R1 | // | 300ms | // | run(2) +-------------> R2 (SKIP) | // | 200ms | // | run(3) +--------> R3 | // +----------------------------------+ if (latestResolvedValue && currentPromiseId < latestResolvedId) { return latestResolvedValue; } latestResolvedId = currentPromiseId; latestResolvedValue = x; return x; }); }; } /** * Returns the next active item ID from the current state. * * We allow circular keyboard navigation from the base index. * The base index can either be `null` (nothing is highlighted) or `0` * (the first item is highlighted). * The base index is allowed to get assigned `null` only if * `props.defaultActiveItemId` is `null`. This pattern allows to "stop" * by the actual query before navigating to other suggestions as seen on * Google or Amazon. * * @param moveAmount The offset to increment (or decrement) the last index * @param baseIndex The current index to compute the next index from * @param itemCount The number of items * @param defaultActiveItemId The default active index to fallback to */ function getNextActiveItemId(moveAmount, baseIndex, itemCount, defaultActiveItemId) { if (!itemCount) { return null; } if (moveAmount < 0 && (baseIndex === null || defaultActiveItemId !== null && baseIndex === 0)) { return itemCount + moveAmount; } var numericIndex = (baseIndex === null ? -1 : baseIndex) + moveAmount; if (numericIndex <= -1 || numericIndex >= itemCount) { return defaultActiveItemId === null ? null : 0; } return numericIndex; } function ownKeys$e(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; } function _objectSpread$e(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$e(Object(t), !0).forEach(function (r) { _defineProperty$e(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$e(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty$e(e, r, t) { return (r = _toPropertyKey$e(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey$e(t) { var i = _toPrimitive$e(t, "string"); return "symbol" == _typeof$e(i) ? i : i + ""; } function _toPrimitive$e(t, r) { if ("object" != _typeof$e(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof$e(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _typeof$e(o) { "@babel/helpers - typeof"; return _typeof$e = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof$e(o); } function getNormalizedSources(getSources, params) { var seenSourceIds = []; return Promise.resolve(getSources(params)).then(function (sources) { invariant(Array.isArray(sources), function () { return "The `getSources` function must return an array of sources but returned type ".concat(JSON.stringify(_typeof$e(sources)), ":\n\n").concat(JSON.stringify(decycle(sources), null, 2)); }); return Promise.all(sources // We allow `undefined` and `false` sources to allow users to use // `Boolean(query) && source` (=> `false`). // We need to remove these values at this point. .filter(function (maybeSource) { return Boolean(maybeSource); }).map(function (source) { invariant(typeof source.sourceId === 'string', 'A source must provide a `sourceId` string.'); if (seenSourceIds.includes(source.sourceId)) { throw new Error("[Autocomplete] The `sourceId` ".concat(JSON.stringify(source.sourceId), " is not unique.")); } seenSourceIds.push(source.sourceId); var defaultSource = { getItemInputValue: function getItemInputValue(_ref) { var state = _ref.state; return state.query; }, getItemUrl: function getItemUrl() { return undefined; }, onSelect: function onSelect(_ref2) { var setIsOpen = _ref2.setIsOpen; setIsOpen(false); }, onActive: noop, onResolve: noop }; Object.keys(defaultSource).forEach(function (key) { defaultSource[key].__default = true; }); var normalizedSource = _objectSpread$e(_objectSpread$e({}, defaultSource), source); return Promise.resolve(normalizedSource); })); }); } function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray$5(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray$5(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$5(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$5(r, a) : void 0; } } function _arrayLikeToArray$5(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; } /** * If a plugin is configured to await a submit event, this returns a promise * for either the max timeout value found or until it completes. * Otherwise, return undefined. */ var getPluginSubmitPromise = function getPluginSubmitPromise(plugins, pendingRequests) { var waitUntilComplete = false; var timeouts = []; var _iterator = _createForOfIteratorHelper(plugins), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var _plugin$__au