{"version":3,"file":"index.mjs","sources":["../../../../sources/apps/webapp/login/src/lib/constants.js","../../../../node_modules/@babel/runtime/helpers/esm/typeof.js","../../../../node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","../../../../node_modules/@babel/runtime/helpers/esm/toPrimitive.js","../../../../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../../../../node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../../../../node_modules/@clearscore/helpers.cookies/node_modules/cookie/index.js","../../../../node_modules/@clearscore/helpers.resolve-props/src/index.js","../../../../node_modules/@clearscore/helpers.can-use-dom/src/index.js","../../../../node_modules/@clearscore/helpers.envs/src/index.js","../../../../node_modules/@clearscore/helpers.cookies/src/cookies.js","../../../../node_modules/@clearscore/helpers.cookies/src/constants.js","../../../../node_modules/@clearscore/helpers.cookies/src/cookies-publisher.js","../../../../node_modules/@clearscore/helpers.cookies/src/cookies-session.js","../../../../node_modules/@clearscore/helpers.cookies/src/index.js","../../../../sources/apps/webapp/login/src/helpers.ts","../../../../node_modules/@clearscore/constants.session-action-types/dist/esm/index.mjs","../../../../node_modules/@clearscore/helpers.create-action/src/index.js","../../../../node_modules/@clearscore/helpers.create-request-payload/src/index.js","../../../../node_modules/ua-parser-js/src/ua-parser.js","../../../../node_modules/current-device/es/index.js","../../../../node_modules/@clearscore/helpers.device/src/lib/constants.js","../../../../node_modules/@clearscore/helpers.device/src/index.js","../../../../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../../../../node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../../../../node_modules/@fingerprintjs/fingerprintjs/node_modules/tslib/tslib.es6.js","../../../../node_modules/@fingerprintjs/fingerprintjs/dist/fp.esm.js","../../../../node_modules/@clearscore/helpers.cache/src/index.js","../../../../node_modules/@clearscore/helpers.device-fingerprinting/src/fingerprint.js","../../../../node_modules/@clearscore/helpers.segment/src/index.js","../../../../node_modules/@clearscore/redux.session/src/session.actions.js","../../../../node_modules/@clearscore/constants.request-statuses/dist/esm/index.mjs","../../../../node_modules/@clearscore/constants.profile-statuses/dist/esm/index.mjs","../../../../node_modules/@clearscore/constants.role-statuses/dist/esm/index.mjs","../../../../node_modules/@clearscore/constants.profile-action-types/dist/esm/index.mjs","../../../../node_modules/@clearscore/redux.identity/src/identity.types.js","../../../../node_modules/@clearscore/helpers.resolve-request/src/index.js","../../../../node_modules/@clearscore/redux.identity/src/index.js","../../../../node_modules/@clearscore/redux.profile/src/reducers/profile.domain.js","../../../../node_modules/@clearscore/redux.profile/src/reducers/index.js","../../../../node_modules/@clearscore/redux.market/src/utils.js","../../../../node_modules/@clearscore/redux.market/src/types.js","../../../../node_modules/@clearscore/redux.market/src/lib/helpers.js","../../../../node_modules/@clearscore/redux.market/src/reducers/domain.js","../../../../node_modules/@clearscore/redux.market/src/reducers/index.js","../../../../node_modules/@clearscore/redux.market/src/selectors/getFetchStatus.js","../../../../node_modules/@clearscore/redux.market/src/selectors/getPredicate.js","../../../../node_modules/@clearscore/redux.market/src/selectors/getMarkets.js","../../../../node_modules/@clearscore/redux.market/src/selectors/getActiveMarket.js","../../../../node_modules/@clearscore/redux.market/src/selectors/getLocales.js","../../../../node_modules/@clearscore/redux.market/src/selectors/legacy/legacyMap.js","../../../../node_modules/@clearscore/redux.market/src/selectors/legacy/legacy.getLangCode.js","../../../../node_modules/@clearscore/redux.market/src/selectors/getActiveLocale.js","../../../../node_modules/@clearscore/redux.market/src/selectors/getConfig.js","../../../../node_modules/@clearscore/redux.market/src/selectors/getResolution.js","../../../../node_modules/@clearscore/redux.market/src/selectors/legacy.getLanguage.js","../../../../node_modules/@clearscore/redux.market/src/selectors/index.js","../../../../node_modules/@clearscore/redux.market/src/index.js","../../../../node_modules/@clearscore/redux.market/src/actions.js","../../../../node_modules/@clearscore/redux.profile/src/index.js","../../../../node_modules/@clearscore/redux.session/src/reducers/session.domain.js","../../../../node_modules/@clearscore/redux.session/src/reducers/index.js","../../../../node_modules/@clearscore/redux.session/src/selectors/session.getAccountId.js","../../../../node_modules/@clearscore/redux.session/src/selectors/session.getAuthRole.js","../../../../node_modules/@clearscore/redux.session/src/selectors/session.getPredicate.js","../../../../node_modules/@clearscore/redux.session/src/selectors/session.getError.js","../../../../node_modules/@clearscore/redux.session/src/selectors/index.js","../../../../node_modules/@clearscore/redux.session/src/index.js","../../../../node_modules/@clearscore/helpers.has-client-data/src/index.js","../../../../packages/clearscore/libs/webapp-core/add-client-instance/src/client-directory.js","../../../../node_modules/@clearscore/helpers.session/src/index.js","../../../../node_modules/@clearscore/helpers.interpolate-with-market/src/index.js","../../../../packages/clearscore/libs/webapp-core/add-client-instance/src/lib/get-interpolated-url.js","../../../../packages/clearscore/libs/webapp-core/add-client-instance/src/lib/handle-erroneous-response-interceptor.js","../../../../packages/clearscore/libs/webapp-core/add-client-instance/src/clients.js","../../../../node_modules/@clearscore/helpers.monitoring/src/index.js","../../../../packages/clearscore/libs/webapp-core/add-client-instance/src/lib/auth.js","../../../../packages/clearscore/libs/webapp-core/add-client-instance/src/index.js","../../../../node_modules/@clearscore/helpers.branch/src/index.js","../../../../packages/clearscore/libs/webapp-core/logout/src/message/index.js","../../../../packages/clearscore/libs/webapp-core/logout/src/theme/index.js","../../../../packages/clearscore-group/libs/helpers/query-client/src/index.ts","../../../../packages/clearscore/libs/webapp-core/logout/src/index.js","../../../../node_modules/@clearscore/redux.alerts/src/alerts.types.js","../../../../node_modules/@clearscore/redux.alerts/src/reducers/index.js","../../../../node_modules/@clearscore/redux.alerts/src/reducers/alerts.domain.js","../../../../node_modules/@clearscore/redux.alerts/src/index.js","../../../../node_modules/@clearscore/redux.alerts/src/actions/index.js","../../../../node_modules/@clearscore/redux.alerts/src/constants.js","../../../../node_modules/@clearscore/redux.connect/src/index.js","../../../../node_modules/@clearscore/redux.action-bridge-middleware/src/action-bridge-middleware.js","../../../../node_modules/redux-observable/lib/esm/operators.js","../../../../node_modules/redux-observable/lib/esm/ActionsObservable.js","../../../../node_modules/redux-observable/lib/esm/StateObservable.js","../../../../node_modules/redux-observable/lib/esm/combineEpics.js","../../../../node_modules/@clearscore/redux.store/src/index.ts","../../../../node_modules/redux-observable/lib/esm/createEpicMiddleware.js","../../../../node_modules/@clearscore/redux.store/src/assets/development.ts","../../../../node_modules/@clearscore/hooks.use-media/src/index.js","../../../../node_modules/@clearscore/normalize.title-case/src/index.js","../../../../node_modules/@clearscore/helpers.is-internal-url/src/index.js","../../../../packages/clearscore/libs/ui/rainbow/components/text/src/components/text-link/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/text/src/components/text-link/text-link.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/text/src/components/text-strong/text-strong.tsx","../../../../packages/clearscore/libs/ui/rainbow/lib/tokens/dist/index.mjs","../../../../packages/clearscore/libs/ui/rainbow/components/text/src/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/text/src/text.tsx","../../../../packages/clearscore-group/libs/flux-core/common-vertical/src/components/info-panel/index.jsx","../../../../packages/clearscore-group/libs/flux-core/common-vertical/src/components/message/error-message.jsx","../../../../packages/clearscore-group/libs/flux-core/common-vertical/src/lib/lang.js","../../../../packages/clearscore-group/libs/flux-core/common-vertical/src/components/error/vertical-error.jsx","../../../../packages/clearscore-group/libs/flux-core/common-vertical/src/lib/trim-state.js","../../../../packages/clearscore-group/libs/flux-core/common-vertical/src/lib/insert-if-exists.js","../../../../node_modules/@clearscore/redux.routes/src/types.js","../../../../node_modules/@clearscore/helpers.state-normalise/src/index.js","../../../../node_modules/@clearscore/redux.routes/src/reducer/lib/filterRoutesByStatus.js","../../../../node_modules/@clearscore/redux.routes/src/reducer/routes.byId.js","../../../../node_modules/@clearscore/redux.routes/src/reducer/routes.byCategory.js","../../../../node_modules/@clearscore/redux.routes/src/reducer/routes.byTemplate.js","../../../../node_modules/@clearscore/redux.routes/src/reducer/routes.byStage.js","../../../../node_modules/@clearscore/redux.routes/src/reducer/index.js","../../../../node_modules/@clearscore/redux.routes/src/reducer/routes.segmentation.js","../../../../node_modules/@clearscore/helpers.interpolate-values/src/index.js","../../../../node_modules/@clearscore/redux.tracking-middleware/src/index.js","../../../../node_modules/@clearscore/helpers.create-event-context/src/index.js","../../../../node_modules/@clearscore/redux.dashboard/src/index.js","../../../../node_modules/@clearscore/redux.dashboard/src/dashboard.types.js","../../../../packages/clearscore/libs/webapp-core/tracking/src/lib/segmentProps.js","../../../../packages/clearscore/libs/webapp-core/tracking/src/events/first-time-login.js","../../../../packages/clearscore/libs/webapp-core/tracking/src/events/product-apply-click.js","../../../../packages/clearscore/libs/webapp-core/tracking/src/events/score-band-received.js","../../../../packages/clearscore/libs/webapp-core/tracking/src/index.js","../../../../packages/clearscore/libs/webapp-core/tracking/src/config.js","../../../../node_modules/@clearscore/redux.native-bridge-middleware/src/nativeBridgeMiddleware.js","../../../../node_modules/@clearscore/redux.nova-user/src/nova-user.types.js","../../../../node_modules/@clearscore/redux.nova-user/src/index.js","../../../../node_modules/@clearscore/redux.monitoring-middleware/src/index.js","../../../../node_modules/deepmerge/dist/cjs.js","../../../../node_modules/@clearscore/helpers.add-url-variables/src/interpolateValues.js","../../../../node_modules/@clearscore/helpers.add-url-variables/src/index.js","../../../../packages/clearscore/libs/webapp-core/request-middleware/src/index.js","../../../../packages/clearscore/libs/webapp-core/vertical/src/index.js","../../../../packages/clearscore/libs/webapp-core/vertical/src/lib/reducers.js","../../../../packages/clearscore-group/libs/flux-core/common-vertical/src/index.jsx","../../../../packages/clearscore/libs/webapp-core/vertical/src/lib/middleware.js","../../../../packages/clearscore/libs/ui/rainbow/components/container/src/container.tsx","../../../../node_modules/@clearscore/redux.prospect/src/prospect.types.js","../../../../node_modules/@clearscore/redux.prospect/src/reducers/prospect.domain.js","../../../../node_modules/@clearscore/redux.prospect/src/reducers/index.js","../../../../node_modules/@clearscore/redux.prospect/src/index.js","../../../../node_modules/ramda.clone/clone.js","../../../../node_modules/ramda.clone/index.js","../../../../node_modules/lodash.isequal/index.js","../../../../node_modules/@clearscore/redux.create-requests/src/types.js","../../../../node_modules/@clearscore/redux.create-requests/src/request-reducer.js","../../../../node_modules/@clearscore/redux.create-requests/src/reducers.js","../../../../node_modules/@clearscore/redux.create-requests/src/index.js","../../../../sources/apps/webapp/login/src/redux/index.js","../../../../sources/apps/webapp/login/src/redux/actions.js","../../../../sources/apps/webapp/login/src/lib/reducers.js","../../../../node_modules/@clearscore/helpers.uid/src/index.js","../../../../node_modules/@clearscore/helpers.interpolate-with-components/src/index.jsx","../../../../node_modules/@clearscore/epic.alerts/src/lib/interpolate-message-values.js","../../../../sources/apps/webapp/login/src/lib/epics/login-epics.js","../../../../sources/apps/webapp/login/src/lib/alerts-config.js","../../../../sources/apps/webapp/login/src/lib/epics.js","../../../../node_modules/@clearscore/epic.alerts/src/alerts.epic.js","../../../../node_modules/@clearscore/epic.alerts/src/lib/call-config-method.js","../../../../node_modules/@clearscore/redux.session-middleware/src/loginMiddleware.js","../../../../sources/apps/webapp/login/src/lib/middleware.js","../../../../sources/apps/webapp/login/src/lib/appBridgeTypes.js","../../../../node_modules/@babel/runtime/helpers/esm/extends.js","../../../../node_modules/@clearscore/hooks.use-language/src/index.js","../../../../node_modules/@clearscore/hooks.use-market-config-deprecated/src/index.ts","../../../../packages/clearscore/libs/ui/rainbow/icons/clearscore-logo-symbol/clearscore-logo-symbol.svg","../../../../packages/clearscore/libs/ui/rainbow/components/spacer/src/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/spacer/src/spacer.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/loader/src/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/loader/src/loader.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/button/src/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/button/src/button.tsx","../../../../packages/clearscore/libs/ui/shared/contextual-app-download-banner/src/lib/market-config.js","../../../../packages/clearscore/libs/ui/shared/contextual-app-download-banner/src/lib/lang.js","../../../../packages/clearscore/libs/ui/shared/contextual-app-download-banner/src/contextual-app-download-banner.jsx","../../../../node_modules/@clearscore/hooks.use-async-clickout/src/index.js","../../../../node_modules/@clearscore/hooks.use-tracking/src/lib/helpers.js","../../../../node_modules/@clearscore/hooks.use-tracking/src/lib/hooks/use-default-segment-props.js","../../../../node_modules/@clearscore/hooks.use-tracking/src/use-tracking.js","../../../../node_modules/@clearscore/hooks.use-webapp-tracking/src/index.js","../../../../packages/clearscore/libs/ui/webapp/app-download-banner/src/webapp-app-download-banner.jsx","../../../../node_modules/@babel/runtime/helpers/esm/objectDestructuringEmpty.js","../../../../packages/clearscore/libs/ui/webapp/app-download-banner/src/lib/hooks/tracking.js","../../../../sources/apps/webapp/login/src/components/app-download-banner/app-download-banner.tsx","../../../../node_modules/final-form/dist/final-form.es.js","../../../../node_modules/react-final-form/dist/react-final-form.es.js","../../../../packages/clearscore/libs/ui/rainbow/icons/warning-inline/warning-inline.svg","../../../../node_modules/@clearscore/validation.is-number/src/index.js","../../../../packages/clearscore/libs/ui/rainbow/icons/success-inline/success-inline.svg","../../../../packages/clearscore/libs/ui/rainbow/icons/error-inline/error-inline.svg","../../../../packages/clearscore/libs/ui/rainbow/components/criteria/src/criteria.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/text-input/src/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/text-input/src/text-input.tsx","../../../../packages/clearscore-group/libs/ui/shared/form-otp/src/components/multiple-single-digits.jsx","../../../../node_modules/@clearscore/hooks.use-interval/src/index.js","../../../../packages/clearscore-group/libs/ui/shared/form-otp/src/components/resend.jsx","../../../../packages/clearscore-group/libs/ui/shared/form-otp/src/components/submit.jsx","../../../../packages/clearscore-group/libs/ui/shared/form-otp/src/lib/lang.js","../../../../packages/clearscore-group/libs/ui/shared/form-otp/src/index.jsx","../../../../sources/apps/webapp/login/src/components/screen-verify/lib/market-config.ts","../../../../sources/apps/webapp/login/src/components/screen-verify/screen-verify.tsx","../../../../node_modules/@clearscore/validation.is-empty/src/index.js","../../../../node_modules/@clearscore/validation.is-required/src/index.js","../../../../node_modules/@clearscore/validation.is-email/src/index.js","../../../../node_modules/@clearscore/normalize.email/src/index.js","../../../../packages/clearscore/libs/ui/rainbow/icons/show/show.svg","../../../../packages/clearscore/libs/ui/rainbow/icons/show-disabled/show-disabled.svg","../../../../packages/clearscore/libs/ui/rainbow/components/password/src/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/password/src/password.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/checkbox/src/checkbox.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/label/src/label.tsx","../../../../packages/clearscore/libs/ui/rainbow/icons/keyboard-arrow-down/keyboard-arrow-down.svg","../../../../packages/clearscore/libs/ui/rainbow/components/dropdown/src/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/dropdown/src/dropdown.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/form-layout/src/form-layout.tsx","../../../../node_modules/prop-types/lib/ReactPropTypesSecret.js","../../../../node_modules/prop-types/factoryWithThrowingShims.js","../../../../node_modules/prop-types/index.js","../../../../node_modules/@clearscore/helpers.portal/src/portal.jsx","../../../../packages/clearscore/libs/ui/rainbow/icons/status-success/status-success.svg","../../../../packages/clearscore/libs/ui/rainbow/icons/status-info/status-info.svg","../../../../packages/clearscore/libs/ui/rainbow/icons/status-warning/status-warning.svg","../../../../packages/clearscore/libs/ui/rainbow/icons/status-error/status-error.svg","../../../../packages/clearscore/libs/ui/rainbow/icons/cross/cross.svg","../../../../packages/clearscore/libs/ui/rainbow/components/clickable-icon/src/clickable-icon.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/notification/src/constants.ts","../../../../packages/clearscore/libs/ui/rainbow/components/notification/src/notification.tsx","../../../../packages/clearscore/libs/ui/rainbow/components/notification/src/components/notification.controller.tsx","../../../../node_modules/@clearscore/hooks.use-timeout/src/index.js","../../../../sources/apps/webapp/login/src/components/login-form/lib/market-config.ts","../../../../sources/apps/webapp/login/src/components/login-form/component.tsx","../../../../sources/apps/webapp/login/src/components/login-form/container.ts","../../../../node_modules/@clearscore/helpers.form-status/src/index.js","../../../../sources/apps/webapp/login/src/login.jsx","../../../../sources/apps/webapp/login/src/lib/hooks/tracking.js","../../../../sources/apps/webapp/login/src/index.js"],"sourcesContent":["export const COOKIE_ANONYMOUS_ID = 'CS_ANONYMOUS_ID';\n\nexport const RESPONSE_REQUIRES_2FA = '2fa_required';\n\nexport const PAGE_NAMESPACE = 'login';\n","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n}","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nexport default function _toPropertyKey(arg) {\n var key = toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}","import _typeof from \"./typeof.js\";\nexport default function _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}","import toPropertyKey from \"./toPropertyKey.js\";\nexport default function _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}","import defineProperty from \"./defineProperty.js\";\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n return keys;\n}\nexport default function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}","/*!\n * cookie\n * Copyright(c) 2012-2014 Roman Shtylman\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */\n\n'use strict';\n\n/**\n * Module exports.\n * @public\n */\n\nexports.parse = parse;\nexports.serialize = serialize;\n\n/**\n * Module variables.\n * @private\n */\n\nvar decode = decodeURIComponent;\nvar encode = encodeURIComponent;\nvar pairSplitRegExp = /; */;\n\n/**\n * RegExp to match field-content in RFC 7230 sec 3.2\n *\n * field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ]\n * field-vchar = VCHAR / obs-text\n * obs-text = %x80-FF\n */\n\nvar fieldContentRegExp = /^[\\u0009\\u0020-\\u007e\\u0080-\\u00ff]+$/;\n\n/**\n * Parse a cookie header.\n *\n * Parse the given cookie header string into an object\n * The object has the various cookies as keys(names) => values\n *\n * @param {string} str\n * @param {object} [options]\n * @return {object}\n * @public\n */\n\nfunction parse(str, options) {\n if (typeof str !== 'string') {\n throw new TypeError('argument str must be a string');\n }\n\n var obj = {}\n var opt = options || {};\n var pairs = str.split(pairSplitRegExp);\n var dec = opt.decode || decode;\n\n for (var i = 0; i < pairs.length; i++) {\n var pair = pairs[i];\n var eq_idx = pair.indexOf('=');\n\n // skip things that don't look like key=value\n if (eq_idx < 0) {\n continue;\n }\n\n var key = pair.substr(0, eq_idx).trim()\n var val = pair.substr(++eq_idx, pair.length).trim();\n\n // quoted values\n if ('\"' == val[0]) {\n val = val.slice(1, -1);\n }\n\n // only assign once\n if (undefined == obj[key]) {\n obj[key] = tryDecode(val, dec);\n }\n }\n\n return obj;\n}\n\n/**\n * Serialize data into a cookie header.\n *\n * Serialize the a name value pair into a cookie string suitable for\n * http headers. An optional options object specified cookie parameters.\n *\n * serialize('foo', 'bar', { httpOnly: true })\n * => \"foo=bar; httpOnly\"\n *\n * @param {string} name\n * @param {string} val\n * @param {object} [options]\n * @return {string}\n * @public\n */\n\nfunction serialize(name, val, options) {\n var opt = options || {};\n var enc = opt.encode || encode;\n\n if (typeof enc !== 'function') {\n throw new TypeError('option encode is invalid');\n }\n\n if (!fieldContentRegExp.test(name)) {\n throw new TypeError('argument name is invalid');\n }\n\n var value = enc(val);\n\n if (value && !fieldContentRegExp.test(value)) {\n throw new TypeError('argument val is invalid');\n }\n\n var str = name + '=' + value;\n\n if (null != opt.maxAge) {\n var maxAge = opt.maxAge - 0;\n\n if (isNaN(maxAge) || !isFinite(maxAge)) {\n throw new TypeError('option maxAge is invalid')\n }\n\n str += '; Max-Age=' + Math.floor(maxAge);\n }\n\n if (opt.domain) {\n if (!fieldContentRegExp.test(opt.domain)) {\n throw new TypeError('option domain is invalid');\n }\n\n str += '; Domain=' + opt.domain;\n }\n\n if (opt.path) {\n if (!fieldContentRegExp.test(opt.path)) {\n throw new TypeError('option path is invalid');\n }\n\n str += '; Path=' + opt.path;\n }\n\n if (opt.expires) {\n if (typeof opt.expires.toUTCString !== 'function') {\n throw new TypeError('option expires is invalid');\n }\n\n str += '; Expires=' + opt.expires.toUTCString();\n }\n\n if (opt.httpOnly) {\n str += '; HttpOnly';\n }\n\n if (opt.secure) {\n str += '; Secure';\n }\n\n if (opt.sameSite) {\n var sameSite = typeof opt.sameSite === 'string'\n ? opt.sameSite.toLowerCase() : opt.sameSite;\n\n switch (sameSite) {\n case true:\n str += '; SameSite=Strict';\n break;\n case 'lax':\n str += '; SameSite=Lax';\n break;\n case 'strict':\n str += '; SameSite=Strict';\n break;\n case 'none':\n str += '; SameSite=None';\n break;\n default:\n throw new TypeError('option sameSite is invalid');\n }\n }\n\n return str;\n}\n\n/**\n * Try decoding a string using a decoding function.\n *\n * @param {string} str\n * @param {function} decode\n * @private\n */\n\nfunction tryDecode(str, decode) {\n try {\n return decode(str);\n } catch (e) {\n return str;\n }\n}\n","/**\n * Given an single pathref, resolve to the value of the given data object\n * @param {string} pathArr single property path\n * @param {object} obj object of data to resolve\n * @returns {object} object containing resolved data\n */\nexport function resolveProp(pathArr, obj) {\n if (arguments.length === 1) {\n return (objHolder) => resolveProp(pathArr, objHolder);\n }\n if (obj === null || obj === undefined) {\n return undefined;\n }\n let willReturn = obj;\n let counter = 0;\n\n const pathArrValue = typeof pathArr === 'string' ? pathArr.split('.') : pathArr;\n\n while (counter < pathArrValue.length) {\n if (willReturn === null || willReturn === undefined) {\n return undefined;\n }\n willReturn = willReturn[pathArrValue[counter]];\n counter += 1;\n }\n\n return willReturn;\n}\n\n/**\n * Given an object of object property paths and an object, resolves the paths to the values in the object\n * @param {object} paths object of property paths\n * @param {object} data object of data to resolve\n * @returns {object} object containing resolved data\n */\n\nfunction resolveProps(paths, data) {\n return Object.keys(paths).reduce((resolvedData, prop) => {\n const pathRef = paths[prop];\n return {\n ...resolvedData,\n [prop]: resolveProp(pathRef, data),\n };\n }, {});\n}\n\nexport default resolveProps;\n","export default () => !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n","import { resolveProp } from '@clearscore/helpers.resolve-props';\nimport canUseDom from '@clearscore/helpers.can-use-dom';\n\nconst CACHE_NAME = '__cs__';\nconst LOCAL_NAMESPACE = 'local';\nexport const RESET_MARKET_ENVS = {\n local: {},\n};\n\n/**\n * Returns an env after providing a object path\n * @param path\n * @return {*}\n */\n\nfunction getSingleEnv(path) {\n if (!canUseDom()) return ''; // @todo: [PM] get envs on the server\n let envs;\n\n if (window[CACHE_NAME] && window[CACHE_NAME].env) {\n envs = window[CACHE_NAME].env;\n } else {\n envs = window.env;\n }\n\n return resolveProp(`${LOCAL_NAMESPACE}.${path}`, envs) || resolveProp(path, envs);\n}\n\nexport const getEnvs = () => {\n if (!canUseDom()) return '';\n return window[CACHE_NAME].env || window.env;\n};\n\n/**\n * Set envs\n * @param envs - new market envs\n * @return void\n */\n\nexport const setEnvs = (envs = {}) => {\n if (window[CACHE_NAME] && window[CACHE_NAME].env) {\n window[CACHE_NAME].env = Object.assign(window[CACHE_NAME].env, envs);\n } else {\n window.env = Object.assign(window.env, envs);\n }\n};\n\n/**\n * Returns an env after providing a object path or array of multiple object paths\n * @param paths\n * @return {*}\n */\n\nexport default function getEnv(paths) {\n if (Array.isArray(paths)) {\n return paths.map((path) => getSingleEnv(path));\n }\n return getSingleEnv(paths);\n}\n","import cookie from 'cookie';\nimport getEnvs from '@clearscore/helpers.envs';\nimport canUseDom from '@clearscore/helpers.can-use-dom';\n\nconst hasDocumentCookie = () => canUseDom() && 'cookie' in window.document;\n\n// if it looks like JSON, we'll treat it like JSON\nconst isParsingCookie = (value = '') => value[0] === '{' || value[0] === '[' || value[0] === '\"';\nconst readCookie = (value) => {\n if (isParsingCookie(value)) {\n try {\n return JSON.parse(value);\n } catch (e) {\n // at least we tried\n }\n }\n return value;\n};\n\nconst getDefaultOptions = () => ({\n ...(getEnvs('COOKIE_DOMAIN') && { domain: getEnvs('COOKIE_DOMAIN') }),\n path: '/',\n secure: true,\n});\n\n/**\n * set cookie\n * @param {string} cookieName\n * @param {any} payload\n * @param {object} options\n */\nexport const setCookie = (cookieName, payload, options) => {\n const cookieValue = typeof payload === 'object' ? JSON.stringify(payload) : payload;\n\n if (hasDocumentCookie()) {\n document.cookie = cookie.serialize(cookieName, cookieValue, {\n ...getDefaultOptions(),\n ...options,\n });\n }\n};\n\n/**\n * get cookie\n * @param {string} cookieName\n */\nexport const getCookie = (cookieName) => {\n if (hasDocumentCookie()) {\n const cookieValue = cookie.parse(document.cookie ?? '')[cookieName];\n return readCookie(cookieValue);\n }\n return null;\n};\n\n/**\n * get all cookies\n */\nexport const getAllCookies = () => {\n if (hasDocumentCookie()) {\n const allCookies = cookie.parse(document.cookie ?? '');\n\n return Object.entries(allCookies).reduce(\n (acc, [cookieKey, cookieValue]) => ({\n ...acc,\n [cookieKey]: readCookie(cookieValue),\n }),\n {},\n );\n }\n return null;\n};\n\n/**\n * deletes cookie\n * @param {string} cookieName\n */\nexport const removeCookie = (cookieName) => {\n if (hasDocumentCookie()) {\n const options = {\n ...getDefaultOptions(),\n expires: new Date(1970, 1, 1, 0, 0, 1),\n maxAge: 0,\n };\n document.cookie = cookie.serialize(cookieName, '', options);\n }\n};\n","import getEnv from '@clearscore/helpers.envs';\n\nexport const CS_SESSION_COOKIE = getEnv('SESSION_COOKIE') || 'CS_SESSION';\nexport const CS_PERSON_COOKIE = 'CS_PERSON';\nexport const CS_PUBLISHER_ID = 'CS_PUBLISHER_ID';\nexport const VISITED_SITE_COOKIE_NAME = 'CS_VISITED_SITE';\n// Please note this is concatenated with `alertId` to give full cookie key\nexport const CS_ALERT_VIEWED_COOKIE_PREFIX = 'CS_ALERT_VIEWED';\nexport const CS_CURRENT_LANGUAGE = 'CS_CURRENT_LANGUAGE';\n\n// Expiry (in milliseconds)\nexport const EXPIRE_3DAYS = 259200000;\n","import { getCookie, setCookie } from './cookies';\nimport { CS_PUBLISHER_ID, EXPIRE_3DAYS } from './constants';\n\n/**\n * Directly set the publisher cookie to `body` with no validation\n */\nconst setPublisherCookieValue = (body) =>\n setCookie(CS_PUBLISHER_ID, body, {\n expires: new Date(Date.now() + EXPIRE_3DAYS),\n });\n\n/**\n * Sets the CS_PUBLISHER_ID cookie if utm_source + utm_medium is present in search params\n * @param {String} searchParams\n */\nexport const setPublisherCookie = (searchParams = '') => {\n const urlParams = new URLSearchParams(searchParams);\n const publisherId = urlParams.get('utm_source');\n const transactionId = urlParams.get('utm_medium');\n const campaignId = urlParams.get('utm_campaign');\n if (publisherId && transactionId) {\n setPublisherCookieValue({\n publisherId,\n transactionId,\n ...(campaignId && { campaignId }),\n });\n }\n};\n\n/**\n * Returns CS_PUBLISHER_ID cookie or {} if it does not exist\n */\nexport const getPublisherCookie = () => getCookie(CS_PUBLISHER_ID) || {};\n\n/**\n * Returns CS_PUBLISHER_ID cookie (if present) as the original map\n * of `utm_xxx` to value as opposed to the mappings above (`publisherId` etc.)\n */\nexport const getPublisherCookieUTM = () => {\n const { publisherId, transactionId, campaignId, sentToBackend } = getPublisherCookie();\n\n if (!publisherId || !transactionId) {\n return {};\n }\n\n return {\n utm_source: publisherId,\n utm_medium: transactionId,\n ...(campaignId && { utm_campaign: campaignId }),\n ...(sentToBackend && { sentToBackend }),\n };\n};\n\n/**\n * Check if a given publisher cookie has been sent to the backend\n * @param {Object} publisherCookie Publisher cookie as returned from `getPublisherCookie`\n */\nexport const publisherCookieIsSentToBackend = (publisherCookie) => !!publisherCookie.sentToBackend;\n\n/**\n * Mark the publisher cookie as \"sent to the backend\" so we can avoid sending it again\n */\nexport const markPublisherCookieAsSentToBackend = () => {\n const pubCookie = getPublisherCookie();\n\n if (Object.entries(pubCookie).length > 0 && !publisherCookieIsSentToBackend(pubCookie)) {\n setPublisherCookieValue({\n ...pubCookie,\n sentToBackend: true,\n });\n }\n};\n","/* eslint-disable camelcase */\nimport { setCookie, getCookie, removeCookie } from './cookies';\nimport * as constants from './constants';\n\n// needed for the remember-me checkbox on login\n// work around since you can not use JS APIs to calculate if a cookie has 'expires' set\n// We create a session with 'expires', then when changing language, or refreshing a token, we update the cookie.\n// except, 'updating' cookies is impossible, so we need to cache the unreachable properties of the cookie\nconst CS_SESSION_EXPIRES = 'CS_SESSION_EXPIRES';\nconst setExpires = (expiresDate) => {\n window[CS_SESSION_EXPIRES] = expiresDate;\n};\nconst getExpires = () => window[CS_SESSION_EXPIRES];\n\n/**\n * Sets the session cookie\n * @param session.sessionToken\n * @param session.accountId\n * @param session.username\n * @param session.market\n * @todo SESSION - remove old auth flow when LLT/2FA is live\n */\nexport const setSessionCookie = ({ market, access_token, refresh_token, session_id, remember, o_token, locale }) => {\n const expiresDate = new Date(new Date().setFullYear(new Date().getFullYear() + 1));\n setExpires(remember ? expiresDate : undefined);\n setCookie(\n constants.CS_SESSION_COOKIE,\n {\n access_token,\n refresh_token,\n session_id,\n o_token,\n market: market.toLowerCase(),\n ...(locale ? { locale } : {}),\n },\n {\n ...(remember && {\n expires: getExpires(),\n }),\n },\n );\n};\n/* eslint-enable camelcase */\n\n/**\n * Update the session cookie\n */\nexport const updateSessionCookie = (data) => {\n const cookie = getCookie(constants.CS_SESSION_COOKIE);\n setSessionCookie({\n ...cookie,\n ...data,\n remember: !!getExpires(),\n });\n};\n\n/**\n * Get the session cookie\n */\nexport const getSessionCookie = () => getCookie(constants.CS_SESSION_COOKIE);\n\n/**\n * Removes the session cookie\n */\nexport const removeSessionCookie = () => {\n removeCookie(constants.CS_SESSION_COOKIE);\n};\n\nexport default setSessionCookie;\n","import {\n setCookie as setHelper,\n getCookie as getHelper,\n removeCookie as removeHelper,\n getAllCookies as getAllHelper,\n} from './cookies';\nimport {\n setPublisherCookie as setPublisherHelper,\n getPublisherCookie as getPublisherHelper,\n getPublisherCookieUTM as getPublisherUTMHelper,\n publisherCookieIsSentToBackend as publisherIsSentToBackendHelper,\n markPublisherCookieAsSentToBackend as markPublisherAsSentToBackendHelper,\n} from './cookies-publisher';\nimport {\n setPersonCookie as setPersonHelper,\n getPersonCookie as getPersonHelper,\n removePersonCookie as removePersonHelper,\n} from './cs-person';\nimport {\n setVisitedSiteCookie as setVisitedSiteHelper,\n getVisitedSiteCookie as getVisitedSiteHelper,\n removeVisitedSiteCookie as removeVisitedSiteHelper,\n} from './visited-site';\nimport {\n setSessionCookie as setSessionHelper,\n getSessionCookie as getSessionHelper,\n updateSessionCookie as updateSessionHelper,\n removeSessionCookie as removeSessionHelper,\n} from './cookies-session';\nimport {\n getAlertCookie as getAlertHelper,\n setAlertCookie as setAlertHelper,\n hasCookieForAlert as hasCookieForAlertHelper,\n} from './cookies-alerts';\nimport * as consts from './constants';\n\nexport const getAllCookies = getAllHelper;\nexport const setCookie = setHelper;\nexport const getCookie = getHelper;\nexport const removeCookie = removeHelper;\nexport const getPersonCookie = getPersonHelper;\nexport const setPersonCookie = setPersonHelper;\nexport const removePersonCookie = removePersonHelper;\nexport const getVisitedSiteCookie = getVisitedSiteHelper;\nexport const setVisitedSiteCookie = setVisitedSiteHelper;\nexport const removeVisitedSiteCookie = removeVisitedSiteHelper;\nexport const getPublisherCookie = getPublisherHelper;\nexport const setPublisherCookie = setPublisherHelper;\nexport const getPublisherCookieUTM = getPublisherUTMHelper;\nexport const publisherCookieIsSentToBackend = publisherIsSentToBackendHelper;\nexport const markPublisherCookieAsSentToBackend = markPublisherAsSentToBackendHelper;\nexport const setSessionCookie = setSessionHelper;\nexport const getSessionCookie = getSessionHelper;\nexport const updateSessionCookie = updateSessionHelper;\nexport const removeSessionCookie = removeSessionHelper;\nexport const getAlertCookie = getAlertHelper;\nexport const setAlertCookie = setAlertHelper;\nexport const hasCookieForAlert = hasCookieForAlertHelper;\nexport const constants = consts;\n","import { getCookie } from '@clearscore/helpers.cookies';\n\nexport const multilingualFeatureActive = (): boolean => {\n const experimentalFeatures = getCookie('features');\n return !!experimentalFeatures?.multilingual;\n};\n","/** @clearscore/constants.session-action-types v0.3.9: 2023-1-16 14:0 (assemble v5.5.2) **/\nconst LOGIN_OAUTH_SUBMIT = 'CS/LOGIN_OAUTH_SUBMIT';\nconst LOGIN_OAUTH_SUBMIT_ERROR = 'CS/LOGIN_OAUTH_SUBMIT_ERROR';\nconst LOGIN_OAUTH_SUBMIT_SUCCESS = 'CS/LOGIN_OAUTH_SUBMIT_SUCCESS';\nconst LOGIN_OAUTH_AUTHORISE = 'CS/LOGIN_OAUTH_AUTHORISE';\nconst LOGIN_OAUTH_AUTHORISE_ERROR = 'CS/LOGIN_OAUTH_AUTHORISE_ERROR';\nconst LOGIN_OAUTH_AUTHORISE_SUCCESS = 'CS/LOGIN_OAUTH_AUTHORISE_SUCCESS';\nconst LOGIN_OAUTH_REFRESH = 'CS/LOGIN_OAUTH_REFRESH';\nconst LOGIN_OAUTH_REFRESH_ERROR = 'CS/LOGIN_OAUTH_REFRESH_ERROR';\nconst LOGIN_OAUTH_REFRESH_SUCCESS = 'CS/LOGIN_OAUTH_REFRESH_SUCCESS';\nconst SET_SESSION = 'CS/SET_SESSION'; // Native only event, we should never act on this action\n\nconst NATIVE_SET_SESSION = 'CS/NATIVE_SET_SESSION';\nconst TIMEOUT_SUCCESS = 'CS/TIMEOUT_SUCCESS';\nconst LOGOUT_SUBMIT = 'CS/LOGOUT_SUBMIT';\nconst LOGOUT_SUBMIT_ERROR = 'CS/LOGOUT_SUBMIT_ERROR';\nconst LOGOUT_SUBMIT_SUCCESS = 'CS/LOGOUT_SUBMIT_SUCCESS';\nconst CLEAR_SESSION = 'CS/CLEAR_SESSION';\nconst SET_USER_ROLE = 'CS/SET_USER_ROLE';\n\nexport { CLEAR_SESSION, LOGIN_OAUTH_AUTHORISE, LOGIN_OAUTH_AUTHORISE_ERROR, LOGIN_OAUTH_AUTHORISE_SUCCESS, LOGIN_OAUTH_REFRESH, LOGIN_OAUTH_REFRESH_ERROR, LOGIN_OAUTH_REFRESH_SUCCESS, LOGIN_OAUTH_SUBMIT, LOGIN_OAUTH_SUBMIT_ERROR, LOGIN_OAUTH_SUBMIT_SUCCESS, LOGOUT_SUBMIT, LOGOUT_SUBMIT_ERROR, LOGOUT_SUBMIT_SUCCESS, NATIVE_SET_SESSION, SET_SESSION, SET_USER_ROLE, TIMEOUT_SUCCESS };\n//# sourceMappingURL=index.mjs.map\n","/**\n * Create an action object\n * @param {String} type Name of Redux action\n * @param {*} payload action payload\n * @return {{ type: string, payload?: any }} flux action format object\n */\nexport default function createAction(type, payload) {\n return {\n type,\n ...(payload && { payload }),\n };\n}\n","export default function createRequestPayload(\n client,\n url,\n // eslint-disable-next-line default-param-last\n method = 'get',\n data,\n meta,\n headers,\n timeout,\n { params } = {},\n) {\n return {\n request: {\n client,\n url,\n method,\n ...(data && { data }),\n ...(meta && { meta }),\n ...(headers && { headers }),\n ...(timeout && { timeout }),\n ...(params && { params }),\n },\n };\n}\n","/*!@license\n * UAParser.js v0.7.28\n * Lightweight JavaScript-based User-Agent string parser\n * https://github.com/faisalman/ua-parser-js\n *\n * Copyright © 2012-2021 Faisal Salman \n * Licensed under MIT License\n */\n\n(function (window, undefined) {\n\n 'use strict';\n\n //////////////\n // Constants\n /////////////\n\n\n var LIBVERSION = '0.7.28',\n EMPTY = '',\n UNKNOWN = '?',\n FUNC_TYPE = 'function',\n UNDEF_TYPE = 'undefined',\n OBJ_TYPE = 'object',\n STR_TYPE = 'string',\n MAJOR = 'major', // deprecated\n MODEL = 'model',\n NAME = 'name',\n TYPE = 'type',\n VENDOR = 'vendor',\n VERSION = 'version',\n ARCHITECTURE= 'architecture',\n CONSOLE = 'console',\n MOBILE = 'mobile',\n TABLET = 'tablet',\n SMARTTV = 'smarttv',\n WEARABLE = 'wearable',\n EMBEDDED = 'embedded',\n UA_MAX_LENGTH = 255;\n\n\n ///////////\n // Helper\n //////////\n\n\n var util = {\n extend : function (regexes, extensions) {\n var mergedRegexes = {};\n for (var i in regexes) {\n if (extensions[i] && extensions[i].length % 2 === 0) {\n mergedRegexes[i] = extensions[i].concat(regexes[i]);\n } else {\n mergedRegexes[i] = regexes[i];\n }\n }\n return mergedRegexes;\n },\n has : function (str1, str2) {\n return typeof str1 === STR_TYPE ? str2.toLowerCase().indexOf(str1.toLowerCase()) !== -1 : false;\n },\n lowerize : function (str) {\n return str.toLowerCase();\n },\n major : function (version) {\n return typeof(version) === STR_TYPE ? version.replace(/[^\\d\\.]/g,'').split(\".\")[0] : undefined;\n },\n trim : function (str, len) {\n str = str.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '');\n return typeof(len) === UNDEF_TYPE ? str : str.substring(0, UA_MAX_LENGTH);\n }\n };\n\n\n ///////////////\n // Map helper\n //////////////\n\n\n var mapper = {\n\n rgx : function (ua, arrays) {\n\n var i = 0, j, k, p, q, matches, match;\n\n // loop through all regexes maps\n while (i < arrays.length && !matches) {\n\n var regex = arrays[i], // even sequence (0,2,4,..)\n props = arrays[i + 1]; // odd sequence (1,3,5,..)\n j = k = 0;\n\n // try matching uastring with regexes\n while (j < regex.length && !matches) {\n\n matches = regex[j++].exec(ua);\n\n if (!!matches) {\n for (p = 0; p < props.length; p++) {\n match = matches[++k];\n q = props[p];\n // check if given property is actually array\n if (typeof q === OBJ_TYPE && q.length > 0) {\n if (q.length == 2) {\n if (typeof q[1] == FUNC_TYPE) {\n // assign modified match\n this[q[0]] = q[1].call(this, match);\n } else {\n // assign given value, ignore regex match\n this[q[0]] = q[1];\n }\n } else if (q.length == 3) {\n // check whether function or regex\n if (typeof q[1] === FUNC_TYPE && !(q[1].exec && q[1].test)) {\n // call function (usually string mapper)\n this[q[0]] = match ? q[1].call(this, match, q[2]) : undefined;\n } else {\n // sanitize match using given regex\n this[q[0]] = match ? match.replace(q[1], q[2]) : undefined;\n }\n } else if (q.length == 4) {\n this[q[0]] = match ? q[3].call(this, match.replace(q[1], q[2])) : undefined;\n }\n } else {\n this[q] = match ? match : undefined;\n }\n }\n }\n }\n i += 2;\n }\n },\n\n str : function (str, map) {\n\n for (var i in map) {\n // check if array\n if (typeof map[i] === OBJ_TYPE && map[i].length > 0) {\n for (var j = 0; j < map[i].length; j++) {\n if (util.has(map[i][j], str)) {\n return (i === UNKNOWN) ? undefined : i;\n }\n }\n } else if (util.has(map[i], str)) {\n return (i === UNKNOWN) ? undefined : i;\n }\n }\n return str;\n }\n };\n\n\n ///////////////\n // String map\n //////////////\n\n\n var maps = {\n\n browser : {\n // Safari < 3.0\n oldSafari : {\n version : {\n '1.0' : '/8',\n '1.2' : '/1',\n '1.3' : '/3',\n '2.0' : '/412',\n '2.0.2' : '/416',\n '2.0.3' : '/417',\n '2.0.4' : '/419',\n '?' : '/'\n }\n },\n oldEdge : {\n version : {\n '0.1' : '12.',\n '21' : '13.',\n '31' : '14.',\n '39' : '15.',\n '41' : '16.',\n '42' : '17.',\n '44' : '18.'\n }\n }\n },\n\n os : {\n windows : {\n version : {\n 'ME' : '4.90',\n 'NT 3.11' : 'NT3.51',\n 'NT 4.0' : 'NT4.0',\n '2000' : 'NT 5.0',\n 'XP' : ['NT 5.1', 'NT 5.2'],\n 'Vista' : 'NT 6.0',\n '7' : 'NT 6.1',\n '8' : 'NT 6.2',\n '8.1' : 'NT 6.3',\n '10' : ['NT 6.4', 'NT 10.0'],\n 'RT' : 'ARM'\n }\n }\n }\n };\n\n\n //////////////\n // Regex map\n /////////////\n\n\n var regexes = {\n\n browser : [[\n\n /\\b(?:crmo|crios)\\/([\\w\\.]+)/i // Chrome for Android/iOS\n ], [VERSION, [NAME, 'Chrome']], [\n /edg(?:e|ios|a)?\\/([\\w\\.]+)/i // Microsoft Edge\n ], [VERSION, [NAME, 'Edge']], [\n // breaking change (reserved for next major release):\n ///edge\\/([\\w\\.]+)/i // Old Edge (Trident)\n //], [[VERSION, mapper.str, maps.browser.oldEdge.version], [NAME, 'Edge']], [\n\n // Presto based\n /(opera\\smini)\\/([\\w\\.-]+)/i, // Opera Mini\n /(opera\\s[mobiletab]{3,6})\\b.+version\\/([\\w\\.-]+)/i, // Opera Mobi/Tablet\n /(opera)(?:.+version\\/|[\\/\\s]+)([\\w\\.]+)/i, // Opera\n ], [NAME, VERSION], [\n /opios[\\/\\s]+([\\w\\.]+)/i // Opera mini on iphone >= 8.0\n ], [VERSION, [NAME, 'Opera Mini']], [\n /\\sopr\\/([\\w\\.]+)/i // Opera Webkit\n ], [VERSION, [NAME, 'Opera']], [\n\n // Mixed\n /(kindle)\\/([\\w\\.]+)/i, // Kindle\n /(lunascape|maxthon|netfront|jasmine|blazer)[\\/\\s]?([\\w\\.]*)/i, // Lunascape/Maxthon/Netfront/Jasmine/Blazer\n // Trident based\n /(avant\\s|iemobile|slim)(?:browser)?[\\/\\s]?([\\w\\.]*)/i, // Avant/IEMobile/SlimBrowser\n /(ba?idubrowser)[\\/\\s]?([\\w\\.]+)/i, // Baidu Browser\n /(?:ms|\\()(ie)\\s([\\w\\.]+)/i, // Internet Explorer\n\n // Webkit/KHTML based\n /(flock|rockmelt|midori|epiphany|silk|skyfire|ovibrowser|bolt|iron|vivaldi|iridium|phantomjs|bowser|quark|qupzilla|falkon)\\/([\\w\\.-]+)/i,\n // Flock/RockMelt/Midori/Epiphany/Silk/Skyfire/Bolt/Iron/Iridium/PhantomJS/Bowser/QupZilla/Falkon\n /(rekonq|puffin|brave|whale|qqbrowserlite|qq)\\/([\\w\\.]+)/i, // Rekonq/Puffin/Brave/Whale/QQBrowserLite/QQ, aka ShouQ\n /(weibo)__([\\d\\.]+)/i // Weibo\n ], [NAME, VERSION], [\n /(?:[\\s\\/]uc?\\s?browser|(?:juc.+)ucweb)[\\/\\s]?([\\w\\.]+)/i // UCBrowser\n ], [VERSION, [NAME, 'UCBrowser']], [\n /(?:windowswechat)?\\sqbcore\\/([\\w\\.]+)\\b.*(?:windowswechat)?/i // WeChat Desktop for Windows Built-in Browser\n ], [VERSION, [NAME, 'WeChat(Win) Desktop']], [\n /micromessenger\\/([\\w\\.]+)/i // WeChat\n ], [VERSION, [NAME, 'WeChat']], [\n /konqueror\\/([\\w\\.]+)/i // Konqueror\n ], [VERSION, [NAME, 'Konqueror']], [\n /trident.+rv[:\\s]([\\w\\.]{1,9})\\b.+like\\sgecko/i // IE11\n ], [VERSION, [NAME, 'IE']], [\n /yabrowser\\/([\\w\\.]+)/i // Yandex\n ], [VERSION, [NAME, 'Yandex']], [\n /(avast|avg)\\/([\\w\\.]+)/i // Avast/AVG Secure Browser\n ], [[NAME, /(.+)/, '$1 Secure Browser'], VERSION], [\n /focus\\/([\\w\\.]+)/i // Firefox Focus\n ], [VERSION, [NAME, 'Firefox Focus']], [\n /opt\\/([\\w\\.]+)/i // Opera Touch\n ], [VERSION, [NAME, 'Opera Touch']], [\n /coc_coc_browser\\/([\\w\\.]+)/i // Coc Coc Browser\n ], [VERSION, [NAME, 'Coc Coc']], [\n /dolfin\\/([\\w\\.]+)/i // Dolphin\n ], [VERSION, [NAME, 'Dolphin']], [\n /coast\\/([\\w\\.]+)/i // Opera Coast\n ], [VERSION, [NAME, 'Opera Coast']],\n [/xiaomi\\/miuibrowser\\/([\\w\\.]+)/i // MIUI Browser\n ], [VERSION, [NAME, 'MIUI Browser']], [\n /fxios\\/([\\w\\.-]+)/i // Firefox for iOS\n ], [VERSION, [NAME, 'Firefox']], [\n /(qihu|qhbrowser|qihoobrowser|360browser)/i // 360\n ], [[NAME, '360 Browser']], [\n /(oculus|samsung|sailfish)browser\\/([\\w\\.]+)/i\n ], [[NAME, /(.+)/, '$1 Browser'], VERSION], [ // Oculus/Samsung/Sailfish Browser\n /(comodo_dragon)\\/([\\w\\.]+)/i // Comodo Dragon\n ], [[NAME, /_/g, ' '], VERSION], [\n /\\s(electron)\\/([\\w\\.]+)\\ssafari/i, // Electron-based App\n /(tesla)(?:\\sqtcarbrowser|\\/(20[12]\\d\\.[\\w\\.-]+))/i, // Tesla\n /m?(qqbrowser|baiduboxapp|2345Explorer)[\\/\\s]?([\\w\\.]+)/i // QQBrowser/Baidu App/2345 Browser\n ], [NAME, VERSION], [\n /(MetaSr)[\\/\\s]?([\\w\\.]+)/i, // SouGouBrowser\n /(LBBROWSER)/i // LieBao Browser\n ], [NAME], [\n\n // WebView\n /;fbav\\/([\\w\\.]+);/i // Facebook App for iOS & Android with version\n ], [VERSION, [NAME, 'Facebook']], [\n /FBAN\\/FBIOS|FB_IAB\\/FB4A/i // Facebook App for iOS & Android without version\n ], [[NAME, 'Facebook']], [\n /safari\\s(line)\\/([\\w\\.]+)/i, // Line App for iOS\n /\\b(line)\\/([\\w\\.]+)\\/iab/i, // Line App for Android\n /(chromium|instagram)[\\/\\s]([\\w\\.-]+)/i // Chromium/Instagram\n ], [NAME, VERSION], [\n /\\bgsa\\/([\\w\\.]+)\\s.*safari\\//i // Google Search Appliance on iOS\n ], [VERSION, [NAME, 'GSA']], [\n\n /headlesschrome(?:\\/([\\w\\.]+)|\\s)/i // Chrome Headless\n ], [VERSION, [NAME, 'Chrome Headless']], [\n\n /\\swv\\).+(chrome)\\/([\\w\\.]+)/i // Chrome WebView\n ], [[NAME, 'Chrome WebView'], VERSION], [\n\n /droid.+\\sversion\\/([\\w\\.]+)\\b.+(?:mobile\\ssafari|safari)/i // Android Browser\n ], [VERSION, [NAME, 'Android Browser']], [\n\n /(chrome|omniweb|arora|[tizenoka]{5}\\s?browser)\\/v?([\\w\\.]+)/i // Chrome/OmniWeb/Arora/Tizen/Nokia\n ], [NAME, VERSION], [\n\n /version\\/([\\w\\.]+)\\s.*mobile\\/\\w+\\s(safari)/i // Mobile Safari\n ], [VERSION, [NAME, 'Mobile Safari']], [\n /version\\/([\\w\\.]+)\\s.*(mobile\\s?safari|safari)/i // Safari & Safari Mobile\n ], [VERSION, NAME], [\n /webkit.+?(mobile\\s?safari|safari)(\\/[\\w\\.]+)/i // Safari < 3.0\n ], [NAME, [VERSION, mapper.str, maps.browser.oldSafari.version]], [\n\n /(webkit|khtml)\\/([\\w\\.]+)/i\n ], [NAME, VERSION], [\n\n // Gecko based\n /(navigator|netscape)\\/([\\w\\.-]+)/i // Netscape\n ], [[NAME, 'Netscape'], VERSION], [\n /ile\\svr;\\srv:([\\w\\.]+)\\).+firefox/i // Firefox Reality\n ], [VERSION, [NAME, 'Firefox Reality']], [\n /ekiohf.+(flow)\\/([\\w\\.]+)/i, // Flow\n /(swiftfox)/i, // Swiftfox\n /(icedragon|iceweasel|camino|chimera|fennec|maemo\\sbrowser|minimo|conkeror)[\\/\\s]?([\\w\\.\\+]+)/i,\n // IceDragon/Iceweasel/Camino/Chimera/Fennec/Maemo/Minimo/Conkeror\n /(firefox|seamonkey|k-meleon|icecat|iceape|firebird|phoenix|palemoon|basilisk|waterfox)\\/([\\w\\.-]+)$/i,\n // Firefox/SeaMonkey/K-Meleon/IceCat/IceApe/Firebird/Phoenix\n /(firefox)\\/([\\w\\.]+)\\s[\\w\\s\\-]+\\/[\\w\\.]+$/i, // Other Firefox-based\n /(mozilla)\\/([\\w\\.]+)\\s.+rv\\:.+gecko\\/\\d+/i, // Mozilla\n\n // Other\n /(polaris|lynx|dillo|icab|doris|amaya|w3m|netsurf|sleipnir)[\\/\\s]?([\\w\\.]+)/i,\n // Polaris/Lynx/Dillo/iCab/Doris/Amaya/w3m/NetSurf/Sleipnir\n /(links)\\s\\(([\\w\\.]+)/i, // Links\n /(gobrowser)\\/?([\\w\\.]*)/i, // GoBrowser\n /(ice\\s?browser)\\/v?([\\w\\._]+)/i, // ICE Browser\n /(mosaic)[\\/\\s]([\\w\\.]+)/i // Mosaic\n ], [NAME, VERSION]\n ],\n\n cpu : [[\n\n /(?:(amd|x(?:(?:86|64)[_-])?|wow|win)64)[;\\)]/i // AMD64 (x64)\n ], [[ARCHITECTURE, 'amd64']], [\n\n /(ia32(?=;))/i // IA32 (quicktime)\n ], [[ARCHITECTURE, util.lowerize]], [\n\n /((?:i[346]|x)86)[;\\)]/i // IA32 (x86)\n ], [[ARCHITECTURE, 'ia32']], [\n\n /\\b(aarch64|armv?8e?l?)\\b/i // ARM64\n ], [[ARCHITECTURE, 'arm64']], [\n\n /\\b(arm(?:v[67])?ht?n?[fl]p?)\\b/i // ARMHF\n ], [[ARCHITECTURE, 'armhf']], [\n\n // PocketPC mistakenly identified as PowerPC\n /windows\\s(ce|mobile);\\sppc;/i\n ], [[ARCHITECTURE, 'arm']], [\n\n /((?:ppc|powerpc)(?:64)?)(?:\\smac|;|\\))/i // PowerPC\n ], [[ARCHITECTURE, /ower/, '', util.lowerize]], [\n\n /(sun4\\w)[;\\)]/i // SPARC\n ], [[ARCHITECTURE, 'sparc']], [\n\n /((?:avr32|ia64(?=;))|68k(?=\\))|\\barm(?:64|(?=v(?:[1-7]|[5-7]1)l?|;|eabi))|(?=atmel\\s)avr|(?:irix|mips|sparc)(?:64)?\\b|pa-risc)/i\n // IA64, 68K, ARM/64, AVR/32, IRIX/64, MIPS/64, SPARC/64, PA-RISC\n ], [[ARCHITECTURE, util.lowerize]]\n ],\n\n device : [[\n\n //////////////////////////\n // MOBILES & TABLETS\n // Ordered by popularity\n /////////////////////////\n\n // Samsung\n /\\b(sch-i[89]0\\d|shw-m380s|sm-[pt]\\w{2,4}|gt-[pn]\\d{2,4}|sgh-t8[56]9|nexus\\s10)/i\n ], [MODEL, [VENDOR, 'Samsung'], [TYPE, TABLET]], [\n /\\b((?:s[cgp]h|gt|sm)-\\w+|galaxy\\snexus)/i,\n /\\ssamsung[\\s-]([\\w-]+)/i,\n /sec-(sgh\\w+)/i\n ], [MODEL, [VENDOR, 'Samsung'], [TYPE, MOBILE]], [\n\n // Apple\n /\\((ip(?:hone|od)[\\s\\w]*);/i // iPod/iPhone\n ], [MODEL, [VENDOR, 'Apple'], [TYPE, MOBILE]], [\n /\\((ipad);[\\w\\s\\),;-]+apple/i, // iPad\n /applecoremedia\\/[\\w\\.]+\\s\\((ipad)/i,\n /\\b(ipad)\\d\\d?,\\d\\d?[;\\]].+ios/i\n ], [MODEL, [VENDOR, 'Apple'], [TYPE, TABLET]], [\n\n // Huawei\n /\\b((?:agr|ags[23]|bah2?|sht?)-a?[lw]\\d{2})/i,\n ], [MODEL, [VENDOR, 'Huawei'], [TYPE, TABLET]], [\n /d\\/huawei([\\w\\s-]+)[;\\)]/i,\n /\\b(nexus\\s6p|vog-[at]?l\\d\\d|ane-[at]?l[x\\d]\\d|eml-a?l\\d\\da?|lya-[at]?l\\d[\\dc]|clt-a?l\\d\\di?|ele-l\\d\\d)/i,\n /\\b(\\w{2,4}-[atu][ln][01259][019])[;\\)\\s]/i\n ], [MODEL, [VENDOR, 'Huawei'], [TYPE, MOBILE]], [\n\n // Xiaomi\n /\\b(poco[\\s\\w]+)(?:\\sbuild|\\))/i, // Xiaomi POCO\n /\\b;\\s(\\w+)\\sbuild\\/hm\\1/i, // Xiaomi Hongmi 'numeric' models\n /\\b(hm[\\s\\-_]?note?[\\s_]?(?:\\d\\w)?)\\sbuild/i, // Xiaomi Hongmi\n /\\b(redmi[\\s\\-_]?(?:note|k)?[\\w\\s_]+)(?:\\sbuild|\\))/i, // Xiaomi Redmi\n /\\b(mi[\\s\\-_]?(?:a\\d|one|one[\\s_]plus|note lte)?[\\s_]?(?:\\d?\\w?)[\\s_]?(?:plus)?)\\sbuild/i // Xiaomi Mi\n ], [[MODEL, /_/g, ' '], [VENDOR, 'Xiaomi'], [TYPE, MOBILE]], [\n /\\b(mi[\\s\\-_]?(?:pad)(?:[\\w\\s_]+))(?:\\sbuild|\\))/i // Mi Pad tablets\n ],[[MODEL, /_/g, ' '], [VENDOR, 'Xiaomi'], [TYPE, TABLET]], [\n\n // OPPO\n /;\\s(\\w+)\\sbuild.+\\soppo/i,\n /\\s(cph[12]\\d{3}|p(?:af|c[al]|d\\w|e[ar])[mt]\\d0|x9007)\\b/i\n ], [MODEL, [VENDOR, 'OPPO'], [TYPE, MOBILE]], [\n\n // Vivo\n /\\svivo\\s(\\w+)(?:\\sbuild|\\))/i,\n /\\s(v[12]\\d{3}\\w?[at])(?:\\sbuild|;)/i\n ], [MODEL, [VENDOR, 'Vivo'], [TYPE, MOBILE]], [\n\n // Realme\n /\\s(rmx[12]\\d{3})(?:\\sbuild|;)/i\n ], [MODEL, [VENDOR, 'Realme'], [TYPE, MOBILE]], [\n\n // Motorola\n /\\s(milestone|droid(?:[2-4x]|\\s(?:bionic|x2|pro|razr))?:?(\\s4g)?)\\b[\\w\\s]+build\\//i,\n /\\smot(?:orola)?[\\s-](\\w*)/i,\n /((?:moto[\\s\\w\\(\\)]+|xt\\d{3,4}|nexus\\s6)(?=\\sbuild|\\)))/i\n ], [MODEL, [VENDOR, 'Motorola'], [TYPE, MOBILE]], [\n /\\s(mz60\\d|xoom[\\s2]{0,2})\\sbuild\\//i\n ], [MODEL, [VENDOR, 'Motorola'], [TYPE, TABLET]], [\n\n // LG\n /((?=lg)?[vl]k\\-?\\d{3})\\sbuild|\\s3\\.[\\s\\w;-]{10}lg?-([06cv9]{3,4})/i\n ], [MODEL, [VENDOR, 'LG'], [TYPE, TABLET]], [\n /(lm-?f100[nv]?|nexus\\s[45])/i,\n /lg[e;\\s\\/-]+((?!browser|netcast)\\w+)/i,\n /\\blg(\\-?[\\d\\w]+)\\sbuild/i\n ], [MODEL, [VENDOR, 'LG'], [TYPE, MOBILE]], [\n\n // Lenovo\n /(ideatab[\\w\\-\\s]+)/i,\n /lenovo\\s?(s(?:5000|6000)(?:[\\w-]+)|tab(?:[\\s\\w]+)|yt[\\d\\w-]{6}|tb[\\d\\w-]{6})/i // Lenovo tablets\n ], [MODEL, [VENDOR, 'Lenovo'], [TYPE, TABLET]], [\n\n // Nokia\n /(?:maemo|nokia).*(n900|lumia\\s\\d+)/i,\n /nokia[\\s_-]?([\\w\\.-]*)/i\n ], [[MODEL, /_/g, ' '], [VENDOR, 'Nokia'], [TYPE, MOBILE]], [\n\n // Google\n /droid.+;\\s(pixel\\sc)[\\s)]/i // Google Pixel C\n ], [MODEL, [VENDOR, 'Google'], [TYPE, TABLET]], [\n /droid.+;\\s(pixel[\\s\\daxl]{0,6})(?:\\sbuild|\\))/i // Google Pixel\n ], [MODEL, [VENDOR, 'Google'], [TYPE, MOBILE]], [\n\n // Sony\n /droid.+\\s([c-g]\\d{4}|so[-l]\\w+|xq-a\\w[4-7][12])(?=\\sbuild\\/|\\).+chrome\\/(?![1-6]{0,1}\\d\\.))/i\n ], [MODEL, [VENDOR, 'Sony'], [TYPE, MOBILE]], [\n /sony\\stablet\\s[ps]\\sbuild\\//i,\n /(?:sony)?sgp\\w+(?:\\sbuild\\/|\\))/i\n ], [[MODEL, 'Xperia Tablet'], [VENDOR, 'Sony'], [TYPE, TABLET]], [\n\n // OnePlus\n /\\s(kb2005|in20[12]5|be20[12][59])\\b/i,\n /\\ba000(1)\\sbuild/i, // OnePlus\n /\\boneplus\\s(a\\d{4})[\\s)]/i\n ], [MODEL, [VENDOR, 'OnePlus'], [TYPE, MOBILE]], [\n\n // Amazon\n /(alexa)webm/i,\n /(kf[a-z]{2}wi)(\\sbuild\\/|\\))/i, // Kindle Fire without Silk\n /(kf[a-z]+)(\\sbuild\\/|\\)).+silk\\//i // Kindle Fire HD\n ], [MODEL, [VENDOR, 'Amazon'], [TYPE, TABLET]], [\n /(sd|kf)[0349hijorstuw]+(\\sbuild\\/|\\)).+silk\\//i // Fire Phone\n ], [[MODEL, 'Fire Phone'], [VENDOR, 'Amazon'], [TYPE, MOBILE]], [\n\n // BlackBerry\n /\\((playbook);[\\w\\s\\),;-]+(rim)/i // BlackBerry PlayBook\n ], [MODEL, VENDOR, [TYPE, TABLET]], [\n /((?:bb[a-f]|st[hv])100-\\d)/i,\n /\\(bb10;\\s(\\w+)/i // BlackBerry 10\n ], [MODEL, [VENDOR, 'BlackBerry'], [TYPE, MOBILE]], [\n\n // Asus\n /(?:\\b|asus_)(transfo[prime\\s]{4,10}\\s\\w+|eeepc|slider\\s\\w+|nexus\\s7|padfone|p00[cj])/i\n ], [MODEL, [VENDOR, 'ASUS'], [TYPE, TABLET]], [\n /\\s(z[es]6[027][01][km][ls]|zenfone\\s\\d\\w?)\\b/i\n ], [MODEL, [VENDOR, 'ASUS'], [TYPE, MOBILE]], [\n\n // HTC\n /(nexus\\s9)/i // HTC Nexus 9\n ], [MODEL, [VENDOR, 'HTC'], [TYPE, TABLET]], [\n /(htc)[;_\\s-]{1,2}([\\w\\s]+(?=\\)|\\sbuild)|\\w+)/i, // HTC\n\n // ZTE\n /(zte)-(\\w*)/i,\n /(alcatel|geeksphone|nexian|panasonic|(?=;\\s)sony)[_\\s-]?([\\w-]*)/i // Alcatel/GeeksPhone/Nexian/Panasonic/Sony\n ], [VENDOR, [MODEL, /_/g, ' '], [TYPE, MOBILE]], [\n\n // Acer\n /droid[x\\d\\.\\s;]+\\s([ab][1-7]\\-?[0178a]\\d\\d?)/i\n ], [MODEL, [VENDOR, 'Acer'], [TYPE, TABLET]], [\n\n // Meizu\n /droid.+;\\s(m[1-5]\\snote)\\sbuild/i,\n /\\bmz-([\\w-]{2,})/i\n ], [MODEL, [VENDOR, 'Meizu'], [TYPE, MOBILE]], [\n\n // MIXED\n /(blackberry|benq|palm(?=\\-)|sonyericsson|acer|asus|dell|meizu|motorola|polytron)[\\s_-]?([\\w-]*)/i,\n // BlackBerry/BenQ/Palm/Sony-Ericsson/Acer/Asus/Dell/Meizu/Motorola/Polytron\n /(hp)\\s([\\w\\s]+\\w)/i, // HP iPAQ\n /(asus)-?(\\w+)/i, // Asus\n /(microsoft);\\s(lumia[\\s\\w]+)/i, // Microsoft Lumia\n /(lenovo)[_\\s-]?([\\w-]+)/i, // Lenovo\n /linux;.+(jolla);/i, // Jolla\n /droid.+;\\s(oppo)\\s?([\\w\\s]+)\\sbuild/i // OPPO\n ], [VENDOR, MODEL, [TYPE, MOBILE]], [\n\n /(archos)\\s(gamepad2?)/i, // Archos\n /(hp).+(touchpad(?!.+tablet)|tablet)/i, // HP TouchPad\n /(kindle)\\/([\\w\\.]+)/i, // Kindle\n /\\s(nook)[\\w\\s]+build\\/(\\w+)/i, // Nook\n /(dell)\\s(strea[kpr\\s\\d]*[\\dko])/i, // Dell Streak\n /[;\\/]\\s?(le[\\s\\-]+pan)[\\s\\-]+(\\w{1,9})\\sbuild/i, // Le Pan Tablets\n /[;\\/]\\s?(trinity)[\\-\\s]*(t\\d{3})\\sbuild/i, // Trinity Tablets\n /\\b(gigaset)[\\s\\-]+(q\\w{1,9})\\sbuild/i, // Gigaset Tablets\n /\\b(vodafone)\\s([\\w\\s]+)(?:\\)|\\sbuild)/i // Vodafone\n ], [VENDOR, MODEL, [TYPE, TABLET]], [\n\n /\\s(surface\\sduo)\\s/i // Surface Duo\n ], [MODEL, [VENDOR, 'Microsoft'], [TYPE, TABLET]], [\n /droid\\s[\\d\\.]+;\\s(fp\\du?)\\sbuild/i\n ], [MODEL, [VENDOR, 'Fairphone'], [TYPE, MOBILE]], [\n /\\s(u304aa)\\sbuild/i // AT&T\n ], [MODEL, [VENDOR, 'AT&T'], [TYPE, MOBILE]], [\n /sie-(\\w*)/i // Siemens\n ], [MODEL, [VENDOR, 'Siemens'], [TYPE, MOBILE]], [\n /[;\\/]\\s?(rct\\w+)\\sbuild/i // RCA Tablets\n ], [MODEL, [VENDOR, 'RCA'], [TYPE, TABLET]], [\n /[;\\/\\s](venue[\\d\\s]{2,7})\\sbuild/i // Dell Venue Tablets\n ], [MODEL, [VENDOR, 'Dell'], [TYPE, TABLET]], [\n /[;\\/]\\s?(q(?:mv|ta)\\w+)\\sbuild/i // Verizon Tablet\n ], [MODEL, [VENDOR, 'Verizon'], [TYPE, TABLET]], [\n /[;\\/]\\s(?:barnes[&\\s]+noble\\s|bn[rt])([\\w\\s\\+]*)\\sbuild/i // Barnes & Noble Tablet\n ], [MODEL, [VENDOR, 'Barnes & Noble'], [TYPE, TABLET]], [\n /[;\\/]\\s(tm\\d{3}\\w+)\\sbuild/i\n ], [MODEL, [VENDOR, 'NuVision'], [TYPE, TABLET]], [\n /;\\s(k88)\\sbuild/i // ZTE K Series Tablet\n ], [MODEL, [VENDOR, 'ZTE'], [TYPE, TABLET]], [\n /;\\s(nx\\d{3}j)\\sbuild/i // ZTE Nubia\n ], [MODEL, [VENDOR, 'ZTE'], [TYPE, MOBILE]], [\n /[;\\/]\\s?(gen\\d{3})\\sbuild.*49h/i // Swiss GEN Mobile\n ], [MODEL, [VENDOR, 'Swiss'], [TYPE, MOBILE]], [\n /[;\\/]\\s?(zur\\d{3})\\sbuild/i // Swiss ZUR Tablet\n ], [MODEL, [VENDOR, 'Swiss'], [TYPE, TABLET]], [\n /[;\\/]\\s?((zeki)?tb.*\\b)\\sbuild/i // Zeki Tablets\n ], [MODEL, [VENDOR, 'Zeki'], [TYPE, TABLET]], [\n /[;\\/]\\s([yr]\\d{2})\\sbuild/i,\n /[;\\/]\\s(dragon[\\-\\s]+touch\\s|dt)(\\w{5})\\sbuild/i // Dragon Touch Tablet\n ], [[VENDOR, 'Dragon Touch'], MODEL, [TYPE, TABLET]], [\n /[;\\/]\\s?(ns-?\\w{0,9})\\sbuild/i // Insignia Tablets\n ], [MODEL, [VENDOR, 'Insignia'], [TYPE, TABLET]], [\n /[;\\/]\\s?((nxa|Next)-?\\w{0,9})\\sbuild/i // NextBook Tablets\n ], [MODEL, [VENDOR, 'NextBook'], [TYPE, TABLET]], [\n /[;\\/]\\s?(xtreme\\_)?(v(1[045]|2[015]|[3469]0|7[05]))\\sbuild/i\n ], [[VENDOR, 'Voice'], MODEL, [TYPE, MOBILE]], [ // Voice Xtreme Phones\n /[;\\/]\\s?(lvtel\\-)?(v1[12])\\sbuild/i // LvTel Phones\n ], [[VENDOR, 'LvTel'], MODEL, [TYPE, MOBILE]], [\n /;\\s(ph-1)\\s/i\n ], [MODEL, [VENDOR, 'Essential'], [TYPE, MOBILE]], [ // Essential PH-1\n /[;\\/]\\s?(v(100md|700na|7011|917g).*\\b)\\sbuild/i // Envizen Tablets\n ], [MODEL, [VENDOR, 'Envizen'], [TYPE, TABLET]], [\n /[;\\/]\\s?(trio[\\s\\w\\-\\.]+)\\sbuild/i // MachSpeed Tablets\n ], [MODEL, [VENDOR, 'MachSpeed'], [TYPE, TABLET]], [\n /[;\\/]\\s?tu_(1491)\\sbuild/i // Rotor Tablets\n ], [MODEL, [VENDOR, 'Rotor'], [TYPE, TABLET]], [\n /(shield[\\w\\s]+)\\sbuild/i // Nvidia Shield Tablets\n ], [MODEL, [VENDOR, 'Nvidia'], [TYPE, TABLET]], [\n /(sprint)\\s(\\w+)/i // Sprint Phones\n ], [VENDOR, MODEL, [TYPE, MOBILE]], [\n /(kin\\.[onetw]{3})/i // Microsoft Kin\n ], [[MODEL, /\\./g, ' '], [VENDOR, 'Microsoft'], [TYPE, MOBILE]], [\n /droid\\s[\\d\\.]+;\\s(cc6666?|et5[16]|mc[239][23]x?|vc8[03]x?)\\)/i // Zebra\n ], [MODEL, [VENDOR, 'Zebra'], [TYPE, TABLET]], [\n /droid\\s[\\d\\.]+;\\s(ec30|ps20|tc[2-8]\\d[kx])\\)/i\n ], [MODEL, [VENDOR, 'Zebra'], [TYPE, MOBILE]], [\n\n ///////////////////\n // CONSOLES\n ///////////////////\n\n /\\s(ouya)\\s/i, // Ouya\n /(nintendo)\\s([wids3utch]+)/i // Nintendo\n ], [VENDOR, MODEL, [TYPE, CONSOLE]], [\n /droid.+;\\s(shield)\\sbuild/i // Nvidia\n ], [MODEL, [VENDOR, 'Nvidia'], [TYPE, CONSOLE]], [\n /(playstation\\s[345portablevi]+)/i // Playstation\n ], [MODEL, [VENDOR, 'Sony'], [TYPE, CONSOLE]], [\n /[\\s\\(;](xbox(?:\\sone)?(?!;\\sxbox))[\\s\\);]/i // Microsoft Xbox\n ], [MODEL, [VENDOR, 'Microsoft'], [TYPE, CONSOLE]], [\n\n ///////////////////\n // SMARTTVS\n ///////////////////\n\n /smart-tv.+(samsung)/i // Samsung\n ], [VENDOR, [TYPE, SMARTTV]], [\n /hbbtv.+maple;(\\d+)/i\n ], [[MODEL, /^/, 'SmartTV'], [VENDOR, 'Samsung'], [TYPE, SMARTTV]], [\n /(?:linux;\\snetcast.+smarttv|lg\\snetcast\\.tv-201\\d)/i, // LG SmartTV\n ], [[VENDOR, 'LG'], [TYPE, SMARTTV]], [\n /(apple)\\s?tv/i // Apple TV\n ], [VENDOR, [MODEL, 'Apple TV'], [TYPE, SMARTTV]], [\n /crkey/i // Google Chromecast\n ], [[MODEL, 'Chromecast'], [VENDOR, 'Google'], [TYPE, SMARTTV]], [\n /droid.+aft([\\w])(\\sbuild\\/|\\))/i // Fire TV\n ], [MODEL, [VENDOR, 'Amazon'], [TYPE, SMARTTV]], [\n /\\(dtv[\\);].+(aquos)/i // Sharp\n ], [MODEL, [VENDOR, 'Sharp'], [TYPE, SMARTTV]], [\n /hbbtv\\/\\d+\\.\\d+\\.\\d+\\s+\\([\\w\\s]*;\\s*(\\w[^;]*);([^;]*)/i // HbbTV devices\n ], [[VENDOR, util.trim], [MODEL, util.trim], [TYPE, SMARTTV]], [\n /[\\s\\/\\(](android\\s|smart[-\\s]?|opera\\s)tv[;\\)\\s]/i // SmartTV from Unidentified Vendors\n ], [[TYPE, SMARTTV]], [\n\n ///////////////////\n // WEARABLES\n ///////////////////\n\n /((pebble))app\\/[\\d\\.]+\\s/i // Pebble\n ], [VENDOR, MODEL, [TYPE, WEARABLE]], [\n /droid.+;\\s(glass)\\s\\d/i // Google Glass\n ], [MODEL, [VENDOR, 'Google'], [TYPE, WEARABLE]], [\n /droid\\s[\\d\\.]+;\\s(wt63?0{2,3})\\)/i\n ], [MODEL, [VENDOR, 'Zebra'], [TYPE, WEARABLE]], [\n\n ///////////////////\n // EMBEDDED\n ///////////////////\n\n /(tesla)(?:\\sqtcarbrowser|\\/20[12]\\d\\.[\\w\\.-]+)/i // Tesla\n ], [VENDOR, [TYPE, EMBEDDED]], [\n\n ////////////////////\n // MIXED (GENERIC)\n ///////////////////\n\n /droid .+?; ([^;]+?)(?: build|\\) applewebkit).+? mobile safari/i // Android Phones from Unidentified Vendors\n ], [MODEL, [TYPE, MOBILE]], [\n /droid .+?;\\s([^;]+?)(?: build|\\) applewebkit).+?(?! mobile) safari/i // Android Tablets from Unidentified Vendors\n ], [MODEL, [TYPE, TABLET]], [\n /\\s(tablet|tab)[;\\/]/i, // Unidentifiable Tablet\n /\\s(mobile)(?:[;\\/]|\\ssafari)/i // Unidentifiable Mobile\n ], [[TYPE, util.lowerize]], [\n /(android[\\w\\.\\s\\-]{0,9});.+build/i // Generic Android Device\n ], [MODEL, [VENDOR, 'Generic']], [\n /(phone)/i\n ], [[TYPE, MOBILE]]\n ],\n\n engine : [[\n\n /windows.+\\sedge\\/([\\w\\.]+)/i // EdgeHTML\n ], [VERSION, [NAME, 'EdgeHTML']], [\n\n /webkit\\/537\\.36.+chrome\\/(?!27)([\\w\\.]+)/i // Blink\n ], [VERSION, [NAME, 'Blink']], [\n\n /(presto)\\/([\\w\\.]+)/i, // Presto\n /(webkit|trident|netfront|netsurf|amaya|lynx|w3m|goanna)\\/([\\w\\.]+)/i, // WebKit/Trident/NetFront/NetSurf/Amaya/Lynx/w3m/Goanna\n /ekioh(flow)\\/([\\w\\.]+)/i, // Flow\n /(khtml|tasman|links)[\\/\\s]\\(?([\\w\\.]+)/i, // KHTML/Tasman/Links\n /(icab)[\\/\\s]([23]\\.[\\d\\.]+)/i // iCab\n ], [NAME, VERSION], [\n\n /rv\\:([\\w\\.]{1,9})\\b.+(gecko)/i // Gecko\n ], [VERSION, NAME]\n ],\n\n os : [[\n\n // Windows\n /microsoft\\s(windows)\\s(vista|xp)/i // Windows (iTunes)\n ], [NAME, VERSION], [\n /(windows)\\snt\\s6\\.2;\\s(arm)/i, // Windows RT\n /(windows\\sphone(?:\\sos)*)[\\s\\/]?([\\d\\.\\s\\w]*)/i, // Windows Phone\n /(windows\\smobile|windows)[\\s\\/]?([ntce\\d\\.\\s]+\\w)(?!.+xbox)/i\n ], [NAME, [VERSION, mapper.str, maps.os.windows.version]], [\n /(win(?=3|9|n)|win\\s9x\\s)([nt\\d\\.]+)/i\n ], [[NAME, 'Windows'], [VERSION, mapper.str, maps.os.windows.version]], [\n\n // iOS/macOS\n /ip[honead]{2,4}\\b(?:.*os\\s([\\w]+)\\slike\\smac|;\\sopera)/i, // iOS\n /cfnetwork\\/.+darwin/i\n ], [[VERSION, /_/g, '.'], [NAME, 'iOS']], [\n /(mac\\sos\\sx)\\s?([\\w\\s\\.]*)/i,\n /(macintosh|mac(?=_powerpc)\\s)(?!.+haiku)/i // Mac OS\n ], [[NAME, 'Mac OS'], [VERSION, /_/g, '.']], [\n\n // Mobile OSes // Android/WebOS/Palm/QNX/Bada/RIM/MeeGo/Contiki/Sailfish OS\n /(android|webos|palm\\sos|qnx|bada|rim\\stablet\\sos|meego|sailfish|contiki)[\\/\\s-]?([\\w\\.]*)/i,\n /(blackberry)\\w*\\/([\\w\\.]*)/i, // Blackberry\n /(tizen|kaios)[\\/\\s]([\\w\\.]+)/i, // Tizen/KaiOS\n /\\((series40);/i // Series 40\n ], [NAME, VERSION], [\n /\\(bb(10);/i // BlackBerry 10\n ], [VERSION, [NAME, 'BlackBerry']], [\n /(?:symbian\\s?os|symbos|s60(?=;)|series60)[\\/\\s-]?([\\w\\.]*)/i // Symbian\n ], [VERSION, [NAME, 'Symbian']], [\n /mozilla.+\\(mobile;.+gecko.+firefox/i // Firefox OS\n ], [[NAME, 'Firefox OS']], [\n /web0s;.+rt(tv)/i,\n /\\b(?:hp)?wos(?:browser)?\\/([\\w\\.]+)/i // WebOS\n ], [VERSION, [NAME, 'webOS']], [\n\n // Google Chromecast\n /crkey\\/([\\d\\.]+)/i // Google Chromecast\n ], [VERSION, [NAME, 'Chromecast']], [\n /(cros)\\s[\\w]+\\s([\\w\\.]+\\w)/i // Chromium OS\n ], [[NAME, 'Chromium OS'], VERSION],[\n\n // Console\n /(nintendo|playstation)\\s([wids345portablevuch]+)/i, // Nintendo/Playstation\n /(xbox);\\s+xbox\\s([^\\);]+)/i, // Microsoft Xbox (360, One, X, S, Series X, Series S)\n\n // GNU/Linux based\n /(mint)[\\/\\s\\(\\)]?(\\w*)/i, // Mint\n /(mageia|vectorlinux)[;\\s]/i, // Mageia/VectorLinux\n /(joli|[kxln]?ubuntu|debian|suse|opensuse|gentoo|arch(?=\\slinux)|slackware|fedora|mandriva|centos|pclinuxos|redhat|zenwalk|linpus|raspbian)(?:\\sgnu\\/linux)?(?:\\slinux)?[\\/\\s-]?(?!chrom|package)([\\w\\.-]*)/i,\n // Joli/Ubuntu/Debian/SUSE/Gentoo/Arch/Slackware\n // Fedora/Mandriva/CentOS/PCLinuxOS/RedHat/Zenwalk/Linpus\n /(hurd|linux)\\s?([\\w\\.]*)/i, // Hurd/Linux\n /(gnu)\\s?([\\w\\.]*)/i, // GNU\n\n // BSD based\n /\\s([frentopc-]{0,4}bsd|dragonfly)\\s?(?!amd|[ix346]{1,2}86)([\\w\\.]*)/i, // FreeBSD/NetBSD/OpenBSD/PC-BSD/DragonFly\n /(haiku)\\s(\\w+)/i // Haiku\n ], [NAME, VERSION], [\n\n // Other\n /(sunos)\\s?([\\w\\.\\d]*)/i // Solaris\n ], [[NAME, 'Solaris'], VERSION], [\n /((?:open)?solaris)[\\/\\s-]?([\\w\\.]*)/i, // Solaris\n /(aix)\\s((\\d)(?=\\.|\\)|\\s)[\\w\\.])*/i, // AIX\n /(plan\\s9|minix|beos|os\\/2|amigaos|morphos|risc\\sos|openvms|fuchsia)/i, // Plan9/Minix/BeOS/OS2/AmigaOS/MorphOS/RISCOS/OpenVMS/Fuchsia\n /(unix)\\s?([\\w\\.]*)/i // UNIX\n ], [NAME, VERSION]\n ]\n };\n\n\n /////////////////\n // Constructor\n ////////////////\n var UAParser = function (ua, extensions) {\n\n if (typeof ua === 'object') {\n extensions = ua;\n ua = undefined;\n }\n\n if (!(this instanceof UAParser)) {\n return new UAParser(ua, extensions).getResult();\n }\n\n var _ua = ua || ((typeof window !== 'undefined' && window.navigator && window.navigator.userAgent) ? window.navigator.userAgent : EMPTY);\n var _rgxmap = extensions ? util.extend(regexes, extensions) : regexes;\n\n this.getBrowser = function () {\n var _browser = { name: undefined, version: undefined };\n mapper.rgx.call(_browser, _ua, _rgxmap.browser);\n _browser.major = util.major(_browser.version); // deprecated\n return _browser;\n };\n this.getCPU = function () {\n var _cpu = { architecture: undefined };\n mapper.rgx.call(_cpu, _ua, _rgxmap.cpu);\n return _cpu;\n };\n this.getDevice = function () {\n var _device = { vendor: undefined, model: undefined, type: undefined };\n mapper.rgx.call(_device, _ua, _rgxmap.device);\n return _device;\n };\n this.getEngine = function () {\n var _engine = { name: undefined, version: undefined };\n mapper.rgx.call(_engine, _ua, _rgxmap.engine);\n return _engine;\n };\n this.getOS = function () {\n var _os = { name: undefined, version: undefined };\n mapper.rgx.call(_os, _ua, _rgxmap.os);\n return _os;\n };\n this.getResult = function () {\n return {\n ua : this.getUA(),\n browser : this.getBrowser(),\n engine : this.getEngine(),\n os : this.getOS(),\n device : this.getDevice(),\n cpu : this.getCPU()\n };\n };\n this.getUA = function () {\n return _ua;\n };\n this.setUA = function (ua) {\n _ua = (typeof ua === STR_TYPE && ua.length > UA_MAX_LENGTH) ? util.trim(ua, UA_MAX_LENGTH) : ua;\n return this;\n };\n this.setUA(_ua);\n return this;\n };\n\n UAParser.VERSION = LIBVERSION;\n UAParser.BROWSER = {\n NAME : NAME,\n MAJOR : MAJOR, // deprecated\n VERSION : VERSION\n };\n UAParser.CPU = {\n ARCHITECTURE : ARCHITECTURE\n };\n UAParser.DEVICE = {\n MODEL : MODEL,\n VENDOR : VENDOR,\n TYPE : TYPE,\n CONSOLE : CONSOLE,\n MOBILE : MOBILE,\n SMARTTV : SMARTTV,\n TABLET : TABLET,\n WEARABLE: WEARABLE,\n EMBEDDED: EMBEDDED\n };\n UAParser.ENGINE = {\n NAME : NAME,\n VERSION : VERSION\n };\n UAParser.OS = {\n NAME : NAME,\n VERSION : VERSION\n };\n\n ///////////\n // Export\n //////////\n\n\n // check js environment\n if (typeof(exports) !== UNDEF_TYPE) {\n // nodejs env\n if (typeof module !== UNDEF_TYPE && module.exports) {\n exports = module.exports = UAParser;\n }\n exports.UAParser = UAParser;\n } else {\n // requirejs env (optional)\n if (typeof(define) === 'function' && define.amd) {\n define(function () {\n return UAParser;\n });\n } else if (typeof window !== 'undefined') {\n // browser env\n window.UAParser = UAParser;\n }\n }\n\n // jQuery/Zepto specific (optional)\n // Note:\n // In AMD env the global scope should be kept clean, but jQuery is an exception.\n // jQuery always exports to global scope, unless jQuery.noConflict(true) is used,\n // and we should catch that.\n var $ = typeof window !== 'undefined' && (window.jQuery || window.Zepto);\n if ($ && !$.ua) {\n var parser = new UAParser();\n $.ua = parser.getResult();\n $.ua.get = function () {\n return parser.getUA();\n };\n $.ua.set = function (uastring) {\n parser.setUA(uastring);\n var result = parser.getResult();\n for (var prop in result) {\n $.ua[prop] = result[prop];\n }\n };\n }\n\n})(typeof window === 'object' ? window : this);\n","var _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\n// Save the previous value of the device variable.\nvar previousDevice = window.device;\n\nvar device = {};\n\nvar changeOrientationList = [];\n\n// Add device as a global object.\nwindow.device = device;\n\n// The element.\nvar documentElement = window.document.documentElement;\n\n// The client user agent string.\n// Lowercase, so we can use the more efficient indexOf(), instead of Regex\nvar userAgent = window.navigator.userAgent.toLowerCase();\n\n// Detectable television devices.\nvar television = ['googletv', 'viera', 'smarttv', 'internet.tv', 'netcast', 'nettv', 'appletv', 'boxee', 'kylo', 'roku', 'dlnadoc', 'pov_tv', 'hbbtv', 'ce-html'];\n\n// Main functions\n// --------------\n\ndevice.macos = function () {\n return find('mac');\n};\n\ndevice.ios = function () {\n return device.iphone() || device.ipod() || device.ipad();\n};\n\ndevice.iphone = function () {\n return !device.windows() && find('iphone');\n};\n\ndevice.ipod = function () {\n return find('ipod');\n};\n\ndevice.ipad = function () {\n var iPadOS13Up = navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1;\n return find('ipad') || iPadOS13Up;\n};\n\ndevice.android = function () {\n return !device.windows() && find('android');\n};\n\ndevice.androidPhone = function () {\n return device.android() && find('mobile');\n};\n\ndevice.androidTablet = function () {\n return device.android() && !find('mobile');\n};\n\ndevice.blackberry = function () {\n return find('blackberry') || find('bb10');\n};\n\ndevice.blackberryPhone = function () {\n return device.blackberry() && !find('tablet');\n};\n\ndevice.blackberryTablet = function () {\n return device.blackberry() && find('tablet');\n};\n\ndevice.windows = function () {\n return find('windows');\n};\n\ndevice.windowsPhone = function () {\n return device.windows() && find('phone');\n};\n\ndevice.windowsTablet = function () {\n return device.windows() && find('touch') && !device.windowsPhone();\n};\n\ndevice.fxos = function () {\n return (find('(mobile') || find('(tablet')) && find(' rv:');\n};\n\ndevice.fxosPhone = function () {\n return device.fxos() && find('mobile');\n};\n\ndevice.fxosTablet = function () {\n return device.fxos() && find('tablet');\n};\n\ndevice.meego = function () {\n return find('meego');\n};\n\ndevice.cordova = function () {\n return window.cordova && location.protocol === 'file:';\n};\n\ndevice.nodeWebkit = function () {\n return _typeof(window.process) === 'object';\n};\n\ndevice.mobile = function () {\n return device.androidPhone() || device.iphone() || device.ipod() || device.windowsPhone() || device.blackberryPhone() || device.fxosPhone() || device.meego();\n};\n\ndevice.tablet = function () {\n return device.ipad() || device.androidTablet() || device.blackberryTablet() || device.windowsTablet() || device.fxosTablet();\n};\n\ndevice.desktop = function () {\n return !device.tablet() && !device.mobile();\n};\n\ndevice.television = function () {\n var i = 0;\n while (i < television.length) {\n if (find(television[i])) {\n return true;\n }\n i++;\n }\n return false;\n};\n\ndevice.portrait = function () {\n if (screen.orientation && Object.prototype.hasOwnProperty.call(window, 'onorientationchange')) {\n return includes(screen.orientation.type, 'portrait');\n }\n if (device.ios() && Object.prototype.hasOwnProperty.call(window, 'orientation')) {\n return Math.abs(window.orientation) !== 90;\n }\n return window.innerHeight / window.innerWidth > 1;\n};\n\ndevice.landscape = function () {\n if (screen.orientation && Object.prototype.hasOwnProperty.call(window, 'onorientationchange')) {\n return includes(screen.orientation.type, 'landscape');\n }\n if (device.ios() && Object.prototype.hasOwnProperty.call(window, 'orientation')) {\n return Math.abs(window.orientation) === 90;\n }\n return window.innerHeight / window.innerWidth < 1;\n};\n\n// Public Utility Functions\n// ------------------------\n\n// Run device.js in noConflict mode,\n// returning the device variable to its previous owner.\ndevice.noConflict = function () {\n window.device = previousDevice;\n return this;\n};\n\n// Private Utility Functions\n// -------------------------\n\n// Check if element exists\nfunction includes(haystack, needle) {\n return haystack.indexOf(needle) !== -1;\n}\n\n// Simple UA string search\nfunction find(needle) {\n return includes(userAgent, needle);\n}\n\n// Check if documentElement already has a given class.\nfunction hasClass(className) {\n return documentElement.className.match(new RegExp(className, 'i'));\n}\n\n// Add one or more CSS classes to the element.\nfunction addClass(className) {\n var currentClassNames = null;\n if (!hasClass(className)) {\n currentClassNames = documentElement.className.replace(/^\\s+|\\s+$/g, '');\n documentElement.className = currentClassNames + ' ' + className;\n }\n}\n\n// Remove single CSS class from the element.\nfunction removeClass(className) {\n if (hasClass(className)) {\n documentElement.className = documentElement.className.replace(' ' + className, '');\n }\n}\n\n// HTML Element Handling\n// ---------------------\n\n// Insert the appropriate CSS class based on the _user_agent.\n\nif (device.ios()) {\n if (device.ipad()) {\n addClass('ios ipad tablet');\n } else if (device.iphone()) {\n addClass('ios iphone mobile');\n } else if (device.ipod()) {\n addClass('ios ipod mobile');\n }\n} else if (device.macos()) {\n addClass('macos desktop');\n} else if (device.android()) {\n if (device.androidTablet()) {\n addClass('android tablet');\n } else {\n addClass('android mobile');\n }\n} else if (device.blackberry()) {\n if (device.blackberryTablet()) {\n addClass('blackberry tablet');\n } else {\n addClass('blackberry mobile');\n }\n} else if (device.windows()) {\n if (device.windowsTablet()) {\n addClass('windows tablet');\n } else if (device.windowsPhone()) {\n addClass('windows mobile');\n } else {\n addClass('windows desktop');\n }\n} else if (device.fxos()) {\n if (device.fxosTablet()) {\n addClass('fxos tablet');\n } else {\n addClass('fxos mobile');\n }\n} else if (device.meego()) {\n addClass('meego mobile');\n} else if (device.nodeWebkit()) {\n addClass('node-webkit');\n} else if (device.television()) {\n addClass('television');\n} else if (device.desktop()) {\n addClass('desktop');\n}\n\nif (device.cordova()) {\n addClass('cordova');\n}\n\n// Orientation Handling\n// --------------------\n\n// Handle device orientation changes.\nfunction handleOrientation() {\n if (device.landscape()) {\n removeClass('portrait');\n addClass('landscape');\n walkOnChangeOrientationList('landscape');\n } else {\n removeClass('landscape');\n addClass('portrait');\n walkOnChangeOrientationList('portrait');\n }\n setOrientationCache();\n}\n\nfunction walkOnChangeOrientationList(newOrientation) {\n for (var index = 0; index < changeOrientationList.length; index++) {\n changeOrientationList[index](newOrientation);\n }\n}\n\ndevice.onChangeOrientation = function (cb) {\n if (typeof cb == 'function') {\n changeOrientationList.push(cb);\n }\n};\n\n// Detect whether device supports orientationchange event,\n// otherwise fall back to the resize event.\nvar orientationEvent = 'resize';\nif (Object.prototype.hasOwnProperty.call(window, 'onorientationchange')) {\n orientationEvent = 'orientationchange';\n}\n\n// Listen for changes in orientation.\nif (window.addEventListener) {\n window.addEventListener(orientationEvent, handleOrientation, false);\n} else if (window.attachEvent) {\n window.attachEvent(orientationEvent, handleOrientation);\n} else {\n window[orientationEvent] = handleOrientation;\n}\n\nhandleOrientation();\n\n// Public functions to get the current value of type, os, or orientation\n// ---------------------------------------------------------------------\n\nfunction findMatch(arr) {\n for (var i = 0; i < arr.length; i++) {\n if (device[arr[i]]()) {\n return arr[i];\n }\n }\n return 'unknown';\n}\n\ndevice.type = findMatch(['mobile', 'tablet', 'desktop']);\ndevice.os = findMatch(['ios', 'iphone', 'ipad', 'ipod', 'android', 'blackberry', 'macos', 'windows', 'fxos', 'meego', 'television']);\n\nfunction setOrientationCache() {\n device.orientation = findMatch(['portrait', 'landscape']);\n}\n\nsetOrientationCache();\n\nexport default device;","export const IOS_WEBVIEW = 'native_ios';\nexport const ANDROID_WEBVIEW = 'native_android';\n\nexport const IOS_MOBILE = 'ios';\nexport const ANDROID_MOBILE = 'android';\nexport const IOS_TABLET = 'tablet_ios';\nexport const ANDROID_TABLET = 'tablet_android';\n","import canUseDom from '@clearscore/helpers.can-use-dom';\nimport getEnv from '@clearscore/helpers.envs';\nimport UAParser from 'ua-parser-js';\nimport currentDevice from 'current-device';\n\nimport { IOS_WEBVIEW, ANDROID_WEBVIEW, IOS_MOBILE, IOS_TABLET, ANDROID_MOBILE, ANDROID_TABLET } from './lib/constants';\n\nconst browserParsed = new UAParser().getResult();\nconst SERVER = 'server';\nconst NATIVE = 'native';\nconst MOBILE = 'mobile';\nconst WEBVIEW = 'WEBVIEW';\n\nfunction getDevice() {\n if (!canUseDom()) {\n return SERVER;\n }\n\n const deviceLib = currentDevice.noConflict();\n const device = deviceLib.default || deviceLib;\n\n const isWebview = getEnv(WEBVIEW);\n const type = isWebview ? NATIVE : device.type;\n\n if (type === MOBILE) {\n return device.os;\n }\n return `${type}_${device.os}`;\n}\n\nexport const isIOSWebview = () => getDevice() === IOS_WEBVIEW;\nexport const isAndroidWebview = () => getDevice() === ANDROID_WEBVIEW;\n\nexport const isIOSBrowser = () => [IOS_MOBILE, IOS_TABLET].includes(getDevice());\nexport const isAndroidBrowser = () => [ANDROID_MOBILE, ANDROID_TABLET].includes(getDevice());\n\nexport const isDesktop = () => getDevice().includes('desktop');\n\nexport const getBrowser = () => {\n const parser = new UAParser();\n const { browser } = parser.getResult();\n if (!browser.version) {\n // put within conditional so we don't have to update mocks in a tonne of vertical tests\n const ua = parser.getUA();\n if (ua.indexOf('Pingdom.com_bot') > -1) {\n const versionString = ua.replace('Pingdom.com_bot_version_', '').replace('_(http://www.pingdom.com/)', '');\n const [major, minor = 0] = versionString.split('.');\n const version = `${major}.${minor}`;\n return { name: 'pingdom', version };\n }\n return { name: 'unknown', version: 'unknown' };\n }\n\n const [major, minor = 0] = browser.version?.split('.') || ['unknown'];\n const version = `${major}.${minor}`;\n return {\n name: browser.name,\n version,\n };\n};\n\ngetDevice.DEVICE_NAME = `${browserParsed.os.name} ${browserParsed.browser.name}`;\n\nexport * as deviceConstants from './lib/constants';\n\nexport default getDevice;\n","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}","import objectWithoutPropertiesLoose from \"./objectWithoutPropertiesLoose.js\";\nexport default function _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.push(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.push(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","/**\n * FingerprintJS v3.0.6 - Copyright (c) FingerprintJS, Inc, 2021 (https://fingerprintjs.com)\n * Licensed under the MIT (http://www.opensource.org/licenses/mit-license.php) license.\n *\n * This software contains code from open-source projects:\n * MurmurHash3 by Karan Lyons (https://github.com/karanlyons/murmurHash3.js)\n */\n\nimport { __assign, __awaiter, __generator } from 'tslib';\n\n/*\n * Taken from https://github.com/karanlyons/murmurHash3.js/blob/a33d0723127e2e5415056c455f8aed2451ace208/murmurHash3.js\n */\n//\n// Given two 64bit ints (as an array of two 32bit ints) returns the two\n// added together as a 64bit int (as an array of two 32bit ints).\n//\nfunction x64Add(m, n) {\n m = [m[0] >>> 16, m[0] & 0xffff, m[1] >>> 16, m[1] & 0xffff];\n n = [n[0] >>> 16, n[0] & 0xffff, n[1] >>> 16, n[1] & 0xffff];\n var o = [0, 0, 0, 0];\n o[3] += m[3] + n[3];\n o[2] += o[3] >>> 16;\n o[3] &= 0xffff;\n o[2] += m[2] + n[2];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n o[1] += m[1] + n[1];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n o[0] += m[0] + n[0];\n o[0] &= 0xffff;\n return [(o[0] << 16) | o[1], (o[2] << 16) | o[3]];\n}\n//\n// Given two 64bit ints (as an array of two 32bit ints) returns the two\n// multiplied together as a 64bit int (as an array of two 32bit ints).\n//\nfunction x64Multiply(m, n) {\n m = [m[0] >>> 16, m[0] & 0xffff, m[1] >>> 16, m[1] & 0xffff];\n n = [n[0] >>> 16, n[0] & 0xffff, n[1] >>> 16, n[1] & 0xffff];\n var o = [0, 0, 0, 0];\n o[3] += m[3] * n[3];\n o[2] += o[3] >>> 16;\n o[3] &= 0xffff;\n o[2] += m[2] * n[3];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n o[2] += m[3] * n[2];\n o[1] += o[2] >>> 16;\n o[2] &= 0xffff;\n o[1] += m[1] * n[3];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n o[1] += m[2] * n[2];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n o[1] += m[3] * n[1];\n o[0] += o[1] >>> 16;\n o[1] &= 0xffff;\n o[0] += m[0] * n[3] + m[1] * n[2] + m[2] * n[1] + m[3] * n[0];\n o[0] &= 0xffff;\n return [(o[0] << 16) | o[1], (o[2] << 16) | o[3]];\n}\n//\n// Given a 64bit int (as an array of two 32bit ints) and an int\n// representing a number of bit positions, returns the 64bit int (as an\n// array of two 32bit ints) rotated left by that number of positions.\n//\nfunction x64Rotl(m, n) {\n n %= 64;\n if (n === 32) {\n return [m[1], m[0]];\n }\n else if (n < 32) {\n return [(m[0] << n) | (m[1] >>> (32 - n)), (m[1] << n) | (m[0] >>> (32 - n))];\n }\n else {\n n -= 32;\n return [(m[1] << n) | (m[0] >>> (32 - n)), (m[0] << n) | (m[1] >>> (32 - n))];\n }\n}\n//\n// Given a 64bit int (as an array of two 32bit ints) and an int\n// representing a number of bit positions, returns the 64bit int (as an\n// array of two 32bit ints) shifted left by that number of positions.\n//\nfunction x64LeftShift(m, n) {\n n %= 64;\n if (n === 0) {\n return m;\n }\n else if (n < 32) {\n return [(m[0] << n) | (m[1] >>> (32 - n)), m[1] << n];\n }\n else {\n return [m[1] << (n - 32), 0];\n }\n}\n//\n// Given two 64bit ints (as an array of two 32bit ints) returns the two\n// xored together as a 64bit int (as an array of two 32bit ints).\n//\nfunction x64Xor(m, n) {\n return [m[0] ^ n[0], m[1] ^ n[1]];\n}\n//\n// Given a block, returns murmurHash3's final x64 mix of that block.\n// (`[0, h[0] >>> 1]` is a 33 bit unsigned right shift. This is the\n// only place where we need to right shift 64bit ints.)\n//\nfunction x64Fmix(h) {\n h = x64Xor(h, [0, h[0] >>> 1]);\n h = x64Multiply(h, [0xff51afd7, 0xed558ccd]);\n h = x64Xor(h, [0, h[0] >>> 1]);\n h = x64Multiply(h, [0xc4ceb9fe, 0x1a85ec53]);\n h = x64Xor(h, [0, h[0] >>> 1]);\n return h;\n}\n//\n// Given a string and an optional seed as an int, returns a 128 bit\n// hash using the x64 flavor of MurmurHash3, as an unsigned hex.\n//\nfunction x64hash128(key, seed) {\n key = key || '';\n seed = seed || 0;\n var remainder = key.length % 16;\n var bytes = key.length - remainder;\n var h1 = [0, seed];\n var h2 = [0, seed];\n var k1 = [0, 0];\n var k2 = [0, 0];\n var c1 = [0x87c37b91, 0x114253d5];\n var c2 = [0x4cf5ad43, 0x2745937f];\n var i;\n for (i = 0; i < bytes; i = i + 16) {\n k1 = [\n (key.charCodeAt(i + 4) & 0xff) |\n ((key.charCodeAt(i + 5) & 0xff) << 8) |\n ((key.charCodeAt(i + 6) & 0xff) << 16) |\n ((key.charCodeAt(i + 7) & 0xff) << 24),\n (key.charCodeAt(i) & 0xff) |\n ((key.charCodeAt(i + 1) & 0xff) << 8) |\n ((key.charCodeAt(i + 2) & 0xff) << 16) |\n ((key.charCodeAt(i + 3) & 0xff) << 24),\n ];\n k2 = [\n (key.charCodeAt(i + 12) & 0xff) |\n ((key.charCodeAt(i + 13) & 0xff) << 8) |\n ((key.charCodeAt(i + 14) & 0xff) << 16) |\n ((key.charCodeAt(i + 15) & 0xff) << 24),\n (key.charCodeAt(i + 8) & 0xff) |\n ((key.charCodeAt(i + 9) & 0xff) << 8) |\n ((key.charCodeAt(i + 10) & 0xff) << 16) |\n ((key.charCodeAt(i + 11) & 0xff) << 24),\n ];\n k1 = x64Multiply(k1, c1);\n k1 = x64Rotl(k1, 31);\n k1 = x64Multiply(k1, c2);\n h1 = x64Xor(h1, k1);\n h1 = x64Rotl(h1, 27);\n h1 = x64Add(h1, h2);\n h1 = x64Add(x64Multiply(h1, [0, 5]), [0, 0x52dce729]);\n k2 = x64Multiply(k2, c2);\n k2 = x64Rotl(k2, 33);\n k2 = x64Multiply(k2, c1);\n h2 = x64Xor(h2, k2);\n h2 = x64Rotl(h2, 31);\n h2 = x64Add(h2, h1);\n h2 = x64Add(x64Multiply(h2, [0, 5]), [0, 0x38495ab5]);\n }\n k1 = [0, 0];\n k2 = [0, 0];\n switch (remainder) {\n case 15:\n k2 = x64Xor(k2, x64LeftShift([0, key.charCodeAt(i + 14)], 48));\n // fallthrough\n case 14:\n k2 = x64Xor(k2, x64LeftShift([0, key.charCodeAt(i + 13)], 40));\n // fallthrough\n case 13:\n k2 = x64Xor(k2, x64LeftShift([0, key.charCodeAt(i + 12)], 32));\n // fallthrough\n case 12:\n k2 = x64Xor(k2, x64LeftShift([0, key.charCodeAt(i + 11)], 24));\n // fallthrough\n case 11:\n k2 = x64Xor(k2, x64LeftShift([0, key.charCodeAt(i + 10)], 16));\n // fallthrough\n case 10:\n k2 = x64Xor(k2, x64LeftShift([0, key.charCodeAt(i + 9)], 8));\n // fallthrough\n case 9:\n k2 = x64Xor(k2, [0, key.charCodeAt(i + 8)]);\n k2 = x64Multiply(k2, c2);\n k2 = x64Rotl(k2, 33);\n k2 = x64Multiply(k2, c1);\n h2 = x64Xor(h2, k2);\n // fallthrough\n case 8:\n k1 = x64Xor(k1, x64LeftShift([0, key.charCodeAt(i + 7)], 56));\n // fallthrough\n case 7:\n k1 = x64Xor(k1, x64LeftShift([0, key.charCodeAt(i + 6)], 48));\n // fallthrough\n case 6:\n k1 = x64Xor(k1, x64LeftShift([0, key.charCodeAt(i + 5)], 40));\n // fallthrough\n case 5:\n k1 = x64Xor(k1, x64LeftShift([0, key.charCodeAt(i + 4)], 32));\n // fallthrough\n case 4:\n k1 = x64Xor(k1, x64LeftShift([0, key.charCodeAt(i + 3)], 24));\n // fallthrough\n case 3:\n k1 = x64Xor(k1, x64LeftShift([0, key.charCodeAt(i + 2)], 16));\n // fallthrough\n case 2:\n k1 = x64Xor(k1, x64LeftShift([0, key.charCodeAt(i + 1)], 8));\n // fallthrough\n case 1:\n k1 = x64Xor(k1, [0, key.charCodeAt(i)]);\n k1 = x64Multiply(k1, c1);\n k1 = x64Rotl(k1, 31);\n k1 = x64Multiply(k1, c2);\n h1 = x64Xor(h1, k1);\n // fallthrough\n }\n h1 = x64Xor(h1, [0, key.length]);\n h2 = x64Xor(h2, [0, key.length]);\n h1 = x64Add(h1, h2);\n h2 = x64Add(h2, h1);\n h1 = x64Fmix(h1);\n h2 = x64Fmix(h2);\n h1 = x64Add(h1, h2);\n h2 = x64Add(h2, h1);\n return (('00000000' + (h1[0] >>> 0).toString(16)).slice(-8) +\n ('00000000' + (h1[1] >>> 0).toString(16)).slice(-8) +\n ('00000000' + (h2[0] >>> 0).toString(16)).slice(-8) +\n ('00000000' + (h2[1] >>> 0).toString(16)).slice(-8));\n}\n\nvar version = \"3.0.6\";\n\nfunction requestIdleCallbackIfAvailable(fallbackTimeout, deadlineTimeout) {\n if (deadlineTimeout === void 0) { deadlineTimeout = Infinity; }\n return new Promise(function (resolve) {\n var requestIdleCallback = window.requestIdleCallback;\n if (requestIdleCallback) {\n requestIdleCallback(function () { return resolve(); }, { timeout: deadlineTimeout });\n }\n else {\n setTimeout(resolve, Math.min(fallbackTimeout, deadlineTimeout));\n }\n });\n}\n\n/**\n * Converts an error object to a plain object that can be used with `JSON.stringify`.\n * If you just run `JSON.stringify(error)`, you'll get `'{}'`.\n */\nfunction errorToObject(error) {\n var _a;\n return __assign({ name: error.name, message: error.message, stack: (_a = error.stack) === null || _a === void 0 ? void 0 : _a.split('\\n') }, error);\n}\n\n/*\n * This file contains functions to work with pure data only (no browser features, DOM, side effects, etc).\n */\n/**\n * Does the same as Array.prototype.includes but has better typing\n */\nfunction includes(haystack, needle) {\n for (var i = 0, l = haystack.length; i < l; ++i) {\n if (haystack[i] === needle) {\n return true;\n }\n }\n return false;\n}\n/**\n * Like `!includes()` but with proper typing\n */\nfunction excludes(haystack, needle) {\n return !includes(haystack, needle);\n}\n/**\n * Be careful, NaN can return\n */\nfunction toInt(value) {\n return parseInt(value);\n}\n/**\n * Be careful, NaN can return\n */\nfunction toFloat(value) {\n return parseFloat(value);\n}\nfunction replaceNaN(value, replacement) {\n return typeof value === 'number' && isNaN(value) ? replacement : value;\n}\nfunction countTruthy(values) {\n return values.reduce(function (sum, value) { return sum + (value ? 1 : 0); }, 0);\n}\n\n/*\n * Functions to help with features that vary through browsers\n */\n/**\n * Checks whether the browser is based on Trident (the Internet Explorer engine) without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nfunction isTrident() {\n var w = window;\n var n = navigator;\n // The properties are checked to be in IE 10, IE 11 and not to be in other browsers in October 2020\n return (countTruthy([\n 'MSCSSMatrix' in w,\n 'msSetImmediate' in w,\n 'msIndexedDB' in w,\n 'msMaxTouchPoints' in n,\n 'msPointerEnabled' in n,\n ]) >= 4);\n}\n/**\n * Checks whether the browser is based on EdgeHTML (the pre-Chromium Edge engine) without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nfunction isEdgeHTML() {\n // Based on research in October 2020\n var w = window;\n var n = navigator;\n return (countTruthy(['msWriteProfilerMark' in w, 'MSStream' in w, 'msLaunchUri' in n, 'msSaveBlob' in n]) >= 3 &&\n !isTrident());\n}\n/**\n * Checks whether the browser is based on Chromium without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nfunction isChromium() {\n // Based on research in October 2020. Tested to detect Chromium 42-86.\n var w = window;\n var n = navigator;\n return (countTruthy([\n 'webkitPersistentStorage' in n,\n 'webkitTemporaryStorage' in n,\n n.vendor.indexOf('Google') === 0,\n 'webkitResolveLocalFileSystemURL' in w,\n 'BatteryManager' in w,\n 'webkitMediaStream' in w,\n 'webkitSpeechGrammar' in w,\n ]) >= 5);\n}\n/**\n * Checks whether the browser is based on mobile or desktop Safari without using user-agent.\n * All iOS browsers use WebKit (the Safari engine).\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nfunction isWebKit() {\n // Based on research in September 2020\n var w = window;\n var n = navigator;\n return (countTruthy([\n 'ApplePayError' in w,\n 'CSSPrimitiveValue' in w,\n 'Counter' in w,\n n.vendor.indexOf('Apple') === 0,\n 'getStorageUpdates' in n,\n 'WebKitMediaKeys' in w,\n ]) >= 4);\n}\n/**\n * Checks whether the WebKit browser is a desktop Safari.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nfunction isDesktopSafari() {\n var w = window;\n return (countTruthy([\n 'safari' in w,\n !('DeviceMotionEvent' in w),\n !('ongestureend' in w),\n !('standalone' in navigator),\n ]) >= 3);\n}\n/**\n * Checks whether the browser is based on Gecko (Firefox engine) without using user-agent.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nfunction isGecko() {\n var _a, _b;\n var w = window;\n // Based on research in September 2020\n return (countTruthy([\n 'buildID' in navigator,\n 'MozAppearance' in ((_b = (_a = document.documentElement) === null || _a === void 0 ? void 0 : _a.style) !== null && _b !== void 0 ? _b : {}),\n 'MediaRecorderErrorEvent' in w,\n 'mozInnerScreenX' in w,\n 'CSSMozDocumentRule' in w,\n 'CanvasCaptureMediaStream' in w,\n ]) >= 4);\n}\n/**\n * Checks whether the browser is based on Chromium version ≥86 without using user-agent.\n * It doesn't check that the browser is based on Chromium, there is a separate function for this.\n */\nfunction isChromium86OrNewer() {\n // Checked in Chrome 85 vs Chrome 86 both on desktop and Android\n var w = window;\n return (countTruthy([\n !('MediaSettingsRange' in w),\n 'RTCEncodedAudioFrame' in w,\n '' + w.Intl === '[object Intl]',\n '' + w.Reflect === '[object Reflect]',\n ]) >= 3);\n}\n/**\n * Checks whether the browser is based on WebKit version ≥606 (Safari ≥12) without using user-agent.\n * It doesn't check that the browser is based on WebKit, there is a separate function for this.\n *\n * @link https://en.wikipedia.org/wiki/Safari_version_history#Release_history Safari-WebKit versions map\n */\nfunction isWebKit606OrNewer() {\n // Checked in Safari 9–14\n var w = window;\n return (countTruthy([\n 'DOMRectList' in w,\n 'RTCPeerConnectionIceEvent' in w,\n 'SVGGeometryElement' in w,\n 'ontransitioncancel' in w,\n ]) >= 3);\n}\n\n// Inspired by and based on https://github.com/cozylife/audio-fingerprint\nfunction getAudioFingerprint() {\n return __awaiter(this, void 0, void 0, function () {\n var w, AudioContext, context, oscillator, compressor, buffer, error_1;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n w = window;\n AudioContext = w.OfflineAudioContext || w.webkitOfflineAudioContext;\n if (!AudioContext) {\n return [2 /*return*/, -2 /* NotSupported */];\n }\n // In some browsers, audio context always stays suspended unless the context is started in response to a user action\n // (e.g. a click or a tap). It prevents audio fingerprint from being taken at an arbitrary moment of time.\n // Such browsers are old and unpopular, so the audio fingerprinting is just skipped in them.\n // See a similar case explanation at https://stackoverflow.com/questions/46363048/onaudioprocess-not-called-on-ios11#46534088\n if (doesCurrentBrowserSuspendAudioContext()) {\n return [2 /*return*/, -1 /* KnownToSuspend */];\n }\n context = new AudioContext(1, 44100, 44100);\n oscillator = context.createOscillator();\n oscillator.type = 'triangle';\n setAudioParam(context, oscillator.frequency, 10000);\n compressor = context.createDynamicsCompressor();\n setAudioParam(context, compressor.threshold, -50);\n setAudioParam(context, compressor.knee, 40);\n setAudioParam(context, compressor.ratio, 12);\n setAudioParam(context, compressor.reduction, -20);\n setAudioParam(context, compressor.attack, 0);\n setAudioParam(context, compressor.release, 0.25);\n oscillator.connect(compressor);\n compressor.connect(context.destination);\n oscillator.start(0);\n _a.label = 1;\n case 1:\n _a.trys.push([1, 3, 4, 5]);\n return [4 /*yield*/, renderAudio(context)];\n case 2:\n buffer = _a.sent();\n return [3 /*break*/, 5];\n case 3:\n error_1 = _a.sent();\n if (error_1.name === \"timeout\" /* Timeout */ || error_1.name === \"suspended\" /* Suspended */) {\n return [2 /*return*/, -3 /* Timeout */];\n }\n throw error_1;\n case 4:\n oscillator.disconnect();\n compressor.disconnect();\n return [7 /*endfinally*/];\n case 5: return [2 /*return*/, getHash(buffer.getChannelData(0))];\n }\n });\n });\n}\n/**\n * Checks if the current browser is known to always suspend audio context\n */\nfunction doesCurrentBrowserSuspendAudioContext() {\n return isWebKit() && !isDesktopSafari() && !isWebKit606OrNewer();\n}\nfunction setAudioParam(context, param, value) {\n var isAudioParam = function (value) {\n return value && typeof value.setValueAtTime === 'function';\n };\n if (isAudioParam(param)) {\n param.setValueAtTime(value, context.currentTime);\n }\n}\nfunction renderAudio(context) {\n var resumeTriesMaxCount = 3;\n var resumeRetryDelay = 500;\n var runningTimeout = 1000;\n return new Promise(function (resolve, reject) {\n context.oncomplete = function (event) { return resolve(event.renderedBuffer); };\n var resumeTriesLeft = resumeTriesMaxCount;\n var tryResume = function () {\n context.startRendering();\n switch (context.state) {\n case 'running':\n setTimeout(function () { return reject(makeInnerError(\"timeout\" /* Timeout */)); }, runningTimeout);\n break;\n // Sometimes the audio context doesn't start after calling `startRendering` (in addition to the cases where\n // audio context doesn't start at all). A known case is starting an audio context when the browser tab is in\n // background on iPhone. Retries usually help in this case.\n case 'suspended':\n // The audio context can reject starting until the tab is in foreground. Long fingerprint duration\n // in background isn't a problem, therefore the retry attempts don't count in background. It can lead to\n // a situation when a fingerprint takes very long time and finishes successfully. FYI, the audio context\n // can be suspended when `document.hidden === false` and start running after a retry.\n if (!document.hidden) {\n resumeTriesLeft--;\n }\n if (resumeTriesLeft > 0) {\n setTimeout(tryResume, resumeRetryDelay);\n }\n else {\n reject(makeInnerError(\"suspended\" /* Suspended */));\n }\n break;\n }\n };\n tryResume();\n });\n}\nfunction getHash(signal) {\n var hash = 0;\n for (var i = 4500; i < 5000; ++i) {\n hash += Math.abs(signal[i]);\n }\n return hash;\n}\nfunction makeInnerError(name) {\n var error = new Error(name);\n error.name = name;\n return error;\n}\n\n// We use m or w because these two characters take up the maximum width.\n// And we use a LLi so that the same matching fonts can get separated.\nvar testString = 'mmMwWLliI0O&1';\n// We test using 48px font size, we may use any size. I guess larger the better.\nvar testSize = '48px';\n// A font will be compared against all the three default fonts.\n// And if it doesn't match all 3 then that font is not available.\nvar baseFonts = ['monospace', 'sans-serif', 'serif'];\nvar fontList = [\n // This is android-specific font from \"Roboto\" family\n 'sans-serif-thin',\n 'ARNO PRO',\n 'Agency FB',\n 'Arabic Typesetting',\n 'Arial Unicode MS',\n 'AvantGarde Bk BT',\n 'BankGothic Md BT',\n 'Batang',\n 'Bitstream Vera Sans Mono',\n 'Calibri',\n 'Century',\n 'Century Gothic',\n 'Clarendon',\n 'EUROSTILE',\n 'Franklin Gothic',\n 'Futura Bk BT',\n 'Futura Md BT',\n 'GOTHAM',\n 'Gill Sans',\n 'HELV',\n 'Haettenschweiler',\n 'Helvetica Neue',\n 'Humanst521 BT',\n 'Leelawadee',\n 'Letter Gothic',\n 'Levenim MT',\n 'Lucida Bright',\n 'Lucida Sans',\n 'Menlo',\n 'MS Mincho',\n 'MS Outlook',\n 'MS Reference Specialty',\n 'MS UI Gothic',\n 'MT Extra',\n 'MYRIAD PRO',\n 'Marlett',\n 'Meiryo UI',\n 'Microsoft Uighur',\n 'Minion Pro',\n 'Monotype Corsiva',\n 'PMingLiU',\n 'Pristina',\n 'SCRIPTINA',\n 'Segoe UI Light',\n 'Serifa',\n 'SimHei',\n 'Small Fonts',\n 'Staccato222 BT',\n 'TRAJAN PRO',\n 'Univers CE 55 Medium',\n 'Vrinda',\n 'ZWAdobeF',\n];\nvar fontSpanStyle = {\n // CSS font reset to reset external styles\n fontStyle: 'normal',\n fontWeight: 'normal',\n letterSpacing: 'normal',\n lineBreak: 'auto',\n lineHeight: 'normal',\n textTransform: 'none',\n textAlign: 'left',\n textDecoration: 'none',\n textShadow: 'none',\n whiteSpace: 'normal',\n wordBreak: 'normal',\n wordSpacing: 'normal',\n // We need this css as in some weird browser this span elements shows up for a microSec which creates\n // a bad user experience\n position: 'absolute',\n left: '-9999px',\n fontSize: testSize,\n};\n// kudos to http://www.lalit.org/lab/javascript-css-font-detect/\nfunction getFonts() {\n var d = document;\n var holder = d.body;\n // div to load spans for the base fonts\n var baseFontsDiv = d.createElement('div');\n // div to load spans for the fonts to detect\n var fontsDiv = d.createElement('div');\n var defaultWidth = {};\n var defaultHeight = {};\n // creates a span where the fonts will be loaded\n var createSpan = function () {\n var span = d.createElement('span');\n span.textContent = testString;\n for (var _i = 0, _a = Object.keys(fontSpanStyle); _i < _a.length; _i++) {\n var prop = _a[_i];\n span.style[prop] = fontSpanStyle[prop];\n }\n return span;\n };\n // creates a span and load the font to detect and a base font for fallback\n var createSpanWithFonts = function (fontToDetect, baseFont) {\n var s = createSpan();\n s.style.fontFamily = \"'\" + fontToDetect + \"',\" + baseFont;\n return s;\n };\n // creates spans for the base fonts and adds them to baseFontsDiv\n var initializeBaseFontsSpans = function () {\n return baseFonts.map(function (baseFont) {\n var s = createSpan();\n s.style.fontFamily = baseFont;\n baseFontsDiv.appendChild(s);\n return s;\n });\n };\n // creates spans for the fonts to detect and adds them to fontsDiv\n var initializeFontsSpans = function () {\n // Stores {fontName : [spans for that font]}\n var spans = {};\n var _loop_1 = function (font) {\n spans[font] = baseFonts.map(function (baseFont) {\n var s = createSpanWithFonts(font, baseFont);\n fontsDiv.appendChild(s);\n return s;\n });\n };\n for (var _i = 0, fontList_1 = fontList; _i < fontList_1.length; _i++) {\n var font = fontList_1[_i];\n _loop_1(font);\n }\n return spans;\n };\n // checks if a font is available\n var isFontAvailable = function (fontSpans) {\n return baseFonts.some(function (baseFont, baseFontIndex) {\n return fontSpans[baseFontIndex].offsetWidth !== defaultWidth[baseFont] ||\n fontSpans[baseFontIndex].offsetHeight !== defaultHeight[baseFont];\n });\n };\n // create spans for base fonts\n var baseFontsSpans = initializeBaseFontsSpans();\n // add the spans to the DOM\n holder.appendChild(baseFontsDiv);\n // get the default width for the three base fonts\n for (var index = 0, length_1 = baseFonts.length; index < length_1; index++) {\n defaultWidth[baseFonts[index]] = baseFontsSpans[index].offsetWidth; // width for the default font\n defaultHeight[baseFonts[index]] = baseFontsSpans[index].offsetHeight; // height for the default font\n }\n // create spans for fonts to detect\n var fontsSpans = initializeFontsSpans();\n // add all the spans to the DOM\n holder.appendChild(fontsDiv);\n // check available fonts\n var available = [];\n for (var i = 0, l = fontList.length; i < l; i++) {\n if (isFontAvailable(fontsSpans[fontList[i]])) {\n available.push(fontList[i]);\n }\n }\n // remove spans from DOM\n holder.removeChild(fontsDiv);\n holder.removeChild(baseFontsDiv);\n return available;\n}\n\nfunction getPlugins() {\n if (isTrident()) {\n return [];\n }\n if (!navigator.plugins) {\n return undefined;\n }\n var plugins = [];\n // Safari 10 doesn't support iterating navigator.plugins with for...of\n for (var i = 0; i < navigator.plugins.length; ++i) {\n var plugin = navigator.plugins[i];\n if (!plugin) {\n continue;\n }\n var mimeTypes = [];\n for (var j = 0; j < plugin.length; ++j) {\n var mimeType = plugin[j];\n mimeTypes.push({\n type: mimeType.type,\n suffixes: mimeType.suffixes,\n });\n }\n plugins.push({\n name: plugin.name,\n description: plugin.description,\n mimeTypes: mimeTypes,\n });\n }\n return plugins;\n}\n\nfunction makeCanvasContext() {\n var canvas = document.createElement('canvas');\n canvas.width = 240;\n canvas.height = 140;\n canvas.style.display = 'inline';\n return [canvas, canvas.getContext('2d')];\n}\nfunction isSupported(canvas, context) {\n // TODO: look into: https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob\n return !!(context && canvas.toDataURL);\n}\nfunction save(canvas) {\n // TODO: look into: https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toBlob\n return canvas.toDataURL();\n}\n// https://www.browserleaks.com/canvas#how-does-it-work\nfunction getCanvasFingerprint() {\n var _a = makeCanvasContext(), canvas = _a[0], context = _a[1];\n if (!isSupported(canvas, context)) {\n return { winding: false, data: '' };\n }\n // detect browser support of canvas winding\n // http://blogs.adobe.com/webplatform/2013/01/30/winding-rules-in-canvas/\n // https://github.com/Modernizr/Modernizr/blob/master/feature-detects/canvas/winding.js\n context.rect(0, 0, 10, 10);\n context.rect(2, 2, 6, 6);\n var winding = !context.isPointInPath(5, 5, 'evenodd');\n context.textBaseline = 'alphabetic';\n context.fillStyle = '#f60';\n context.fillRect(125, 1, 62, 20);\n context.fillStyle = '#069';\n // https://github.com/Valve/fingerprintjs2/issues/66\n // this can affect FP generation when applying different CSS on different websites\n context.font = '11pt no-real-font-123';\n // the choice of emojis has a gigantic impact on rendering performance (especially in FF)\n // some newer emojis cause it to slow down 50-200 times\n // context.fillText(\"Cw爨m fjordbank \\ud83d\\ude03 gly\", 2, 15)\n var printedText = 'Cwm fjordbank \\ud83d\\ude03 gly';\n context.fillText(printedText, 2, 15);\n context.fillStyle = 'rgba(102, 204, 0, 0.2)';\n context.font = '18pt Arial';\n context.fillText(printedText, 4, 45);\n // canvas blending\n // http://blogs.adobe.com/webplatform/2013/01/28/blending-features-in-canvas/\n // http://jsfiddle.net/NDYV8/16/\n context.globalCompositeOperation = 'multiply';\n context.fillStyle = 'rgb(255,0,255)';\n context.beginPath();\n context.arc(50, 50, 50, 0, Math.PI * 2, true);\n context.closePath();\n context.fill();\n context.fillStyle = 'rgb(0,255,255)';\n context.beginPath();\n context.arc(100, 50, 50, 0, Math.PI * 2, true);\n context.closePath();\n context.fill();\n context.fillStyle = 'rgb(255,255,0)';\n context.beginPath();\n context.arc(75, 100, 50, 0, Math.PI * 2, true);\n context.closePath();\n context.fill();\n context.fillStyle = 'rgb(255,0,255)';\n // canvas winding\n // http://blogs.adobe.com/webplatform/2013/01/30/winding-rules-in-canvas/\n // http://jsfiddle.net/NDYV8/19/\n context.arc(75, 75, 75, 0, Math.PI * 2, true);\n context.arc(75, 75, 25, 0, Math.PI * 2, true);\n context.fill('evenodd');\n return {\n winding: winding,\n data: save(canvas),\n };\n}\n\n/**\n * This is a crude and primitive touch screen detection. It's not possible to currently reliably detect the availability\n * of a touch screen with a JS, without actually subscribing to a touch event.\n *\n * @see http://www.stucox.com/blog/you-cant-detect-a-touchscreen/\n * @see https://github.com/Modernizr/Modernizr/issues/548\n */\nfunction getTouchSupport() {\n var n = navigator;\n var maxTouchPoints = 0;\n var touchEvent;\n if (n.maxTouchPoints !== undefined) {\n maxTouchPoints = toInt(n.maxTouchPoints);\n }\n else if (n.msMaxTouchPoints !== undefined) {\n maxTouchPoints = n.msMaxTouchPoints;\n }\n try {\n document.createEvent('TouchEvent');\n touchEvent = true;\n }\n catch (_) {\n touchEvent = false;\n }\n var touchStart = 'ontouchstart' in window;\n return {\n maxTouchPoints: maxTouchPoints,\n touchEvent: touchEvent,\n touchStart: touchStart,\n };\n}\n\nfunction getOsCpu() {\n return navigator.oscpu;\n}\n\nfunction getLanguages() {\n var n = navigator;\n var result = [];\n var language = n.language || n.userLanguage || n.browserLanguage || n.systemLanguage;\n if (language !== undefined) {\n result.push([language]);\n }\n if (Array.isArray(n.languages)) {\n // Starting from Chromium 86, there is only a single value in `navigator.language` in Incognito mode:\n // the value of `navigator.language`. Therefore the value is ignored in this browser.\n if (!(isChromium() && isChromium86OrNewer())) {\n result.push(n.languages);\n }\n }\n else if (typeof n.languages === 'string') {\n var languages = n.languages;\n if (languages) {\n result.push(languages.split(','));\n }\n }\n return result;\n}\n\nfunction getColorDepth() {\n return window.screen.colorDepth;\n}\n\nfunction getDeviceMemory() {\n // `navigator.deviceMemory` is a string containing a number in some unidentified cases\n return replaceNaN(toFloat(navigator.deviceMemory), undefined);\n}\n\nfunction getScreenResolution() {\n var s = screen;\n // Some browsers return screen resolution as strings, e.g. \"1200\", instead of a number, e.g. 1200.\n // I suspect it's done by certain plugins that randomize browser properties to prevent fingerprinting.\n var dimensions = [toInt(s.width), toInt(s.height)];\n dimensions.sort().reverse();\n return dimensions;\n}\n\nfunction getAvailableScreenResolution() {\n var s = screen;\n if (s.availWidth && s.availHeight) {\n // Some browsers return screen resolution as strings, e.g. \"1200\", instead of a number, e.g. 1200.\n // I suspect it's done by certain plugins that randomize browser properties to prevent fingerprinting.\n var dimensions = [toInt(s.availWidth), toInt(s.availHeight)];\n dimensions.sort().reverse();\n return dimensions;\n }\n return undefined;\n}\n\nfunction getHardwareConcurrency() {\n try {\n // sometimes hardware concurrency is a string\n var concurrency = toInt(navigator.hardwareConcurrency);\n return isNaN(concurrency) ? 1 : concurrency;\n }\n catch (e) {\n return 1;\n }\n}\n\nfunction getTimezoneOffset() {\n var currentYear = new Date().getFullYear();\n // The timezone offset may change over time due to daylight saving time (DST) shifts.\n // The non-DST timezone offset is used as the result timezone offset.\n // Since the DST season differs in the northern and the southern hemispheres,\n // both January and July timezones offsets are considered.\n return Math.max(\n // `getTimezoneOffset` returns a number as a string in some unidentified cases\n toFloat(new Date(currentYear, 0, 1).getTimezoneOffset()), toFloat(new Date(currentYear, 6, 1).getTimezoneOffset()));\n}\n\nfunction getTimezone() {\n var _a;\n var DateTimeFormat = (_a = window.Intl) === null || _a === void 0 ? void 0 : _a.DateTimeFormat;\n if (DateTimeFormat) {\n return new DateTimeFormat().resolvedOptions().timeZone;\n }\n return undefined;\n}\n\nfunction getSessionStorage() {\n try {\n return !!window.sessionStorage;\n }\n catch (error) {\n /* SecurityError when referencing it means it exists */\n return true;\n }\n}\n\n// https://bugzilla.mozilla.org/show_bug.cgi?id=781447\nfunction getLocalStorage() {\n try {\n return !!window.localStorage;\n }\n catch (e) {\n /* SecurityError when referencing it means it exists */\n return true;\n }\n}\n\nfunction getIndexedDB() {\n // IE and Edge don't allow accessing indexedDB in private mode, therefore IE and Edge will have different\n // visitor identifier in normal and private modes.\n if (isTrident() || isEdgeHTML()) {\n return undefined;\n }\n try {\n return !!window.indexedDB;\n }\n catch (e) {\n /* SecurityError when referencing it means it exists */\n return true;\n }\n}\n\nfunction getOpenDatabase() {\n return !!window.openDatabase;\n}\n\nfunction getCpuClass() {\n return navigator.cpuClass;\n}\n\n/**\n * It should be improved to handle mock value on iOS:\n * https://github.com/fingerprintjs/fingerprintjs/issues/514#issuecomment-727782842\n */\nfunction getPlatform() {\n return navigator.platform;\n}\n\nfunction getPluginsSupport() {\n return navigator.plugins !== undefined;\n}\n\nfunction getProductSub() {\n return navigator.productSub; // It's undefined in IE\n}\n\nfunction getEmptyEvalLength() {\n return eval.toString().length;\n}\n\nfunction getErrorFF() {\n try {\n throw 'a';\n }\n catch (e) {\n try {\n e.toSource();\n return true;\n }\n catch (e2) {\n return false;\n }\n }\n}\n\nfunction getVendor() {\n return navigator.vendor;\n}\n\nfunction getChrome() {\n return window.chrome !== undefined;\n}\n\n/**\n * navigator.cookieEnabled cannot detect custom or nuanced cookie blocking configurations. For example, when blocking\n * cookies via the Advanced Privacy Settings in IE9, it always returns true. And there have been issues in the past with\n * site-specific exceptions. Don't rely on it.\n *\n * @see https://github.com/Modernizr/Modernizr/blob/master/feature-detects/cookies.js Taken from here\n */\nfunction areCookiesEnabled() {\n var d = document;\n // Taken from here: https://github.com/Modernizr/Modernizr/blob/master/feature-detects/cookies.js\n // navigator.cookieEnabled cannot detect custom or nuanced cookie blocking configurations. For example, when blocking\n // cookies via the Advanced Privacy Settings in IE9, it always returns true. And there have been issues in the past\n // with site-specific exceptions. Don't rely on it.\n // try..catch because some in situations `document.cookie` is exposed but throws a\n // SecurityError if you try to access it; e.g. documents created from data URIs\n // or in sandboxed iframes (depending on flags/context)\n try {\n // Create cookie\n d.cookie = 'cookietest=1; SameSite=Strict;';\n var result = d.cookie.indexOf('cookietest=') !== -1;\n // Delete cookie\n d.cookie = 'cookietest=1; SameSite=Strict; expires=Thu, 01-Jan-1970 00:00:01 GMT';\n return result;\n }\n catch (e) {\n return false;\n }\n}\n\n/**\n * The list of entropy sources used to make visitor identifiers.\n *\n * This value isn't restricted by Semantic Versioning, i.e. it may be changed without bumping minor or major version of\n * this package.\n */\nvar sources = {\n // Expected errors and default values must be handled inside the functions. Unexpected errors must be thrown.\n osCpu: getOsCpu,\n languages: getLanguages,\n colorDepth: getColorDepth,\n deviceMemory: getDeviceMemory,\n screenResolution: getScreenResolution,\n availableScreenResolution: getAvailableScreenResolution,\n hardwareConcurrency: getHardwareConcurrency,\n timezoneOffset: getTimezoneOffset,\n timezone: getTimezone,\n sessionStorage: getSessionStorage,\n localStorage: getLocalStorage,\n indexedDB: getIndexedDB,\n openDatabase: getOpenDatabase,\n cpuClass: getCpuClass,\n platform: getPlatform,\n plugins: getPlugins,\n canvas: getCanvasFingerprint,\n // adBlock: isAdblockUsed, // https://github.com/fingerprintjs/fingerprintjs/issues/405\n touchSupport: getTouchSupport,\n fonts: getFonts,\n audio: getAudioFingerprint,\n pluginsSupport: getPluginsSupport,\n productSub: getProductSub,\n emptyEvalLength: getEmptyEvalLength,\n errorFF: getErrorFF,\n vendor: getVendor,\n chrome: getChrome,\n cookiesEnabled: areCookiesEnabled,\n};\n/**\n * Gets a components list from the given list of entropy sources.\n *\n * Warning for package users:\n * This function is out of Semantic Versioning, i.e. can change unexpectedly. Usage is at your own risk.\n */\nfunction getComponents(sources, sourceOptions, excludeSources) {\n return __awaiter(this, void 0, void 0, function () {\n var timestamp, components, _i, _a, sourceKey, result, error_1, nextTimestamp;\n var _b;\n return __generator(this, function (_c) {\n switch (_c.label) {\n case 0:\n timestamp = Date.now();\n components = {};\n _i = 0, _a = Object.keys(sources);\n _c.label = 1;\n case 1:\n if (!(_i < _a.length)) return [3 /*break*/, 7];\n sourceKey = _a[_i];\n if (!excludes(excludeSources, sourceKey)) {\n return [3 /*break*/, 6];\n }\n result = void 0;\n _c.label = 2;\n case 2:\n _c.trys.push([2, 4, , 5]);\n _b = {};\n return [4 /*yield*/, sources[sourceKey](sourceOptions)];\n case 3:\n result = (_b.value = _c.sent(), _b);\n return [3 /*break*/, 5];\n case 4:\n error_1 = _c.sent();\n result = error_1 && typeof error_1 === 'object' && 'message' in error_1 ? { error: error_1 } : { error: { message: error_1 } };\n return [3 /*break*/, 5];\n case 5:\n nextTimestamp = Date.now();\n components[sourceKey] = __assign(__assign({}, result), { duration: nextTimestamp - timestamp }); // TypeScript has beaten me here\n timestamp = nextTimestamp;\n _c.label = 6;\n case 6:\n _i++;\n return [3 /*break*/, 1];\n case 7: return [2 /*return*/, components];\n }\n });\n });\n}\n/**\n * Collects entropy components from the built-in sources to make the visitor identifier.\n */\nfunction getBuiltinComponents() {\n return getComponents(sources, undefined, []);\n}\n\nfunction componentsToCanonicalString(components) {\n var result = '';\n for (var _i = 0, _a = Object.keys(components); _i < _a.length; _i++) {\n var componentKey = _a[_i];\n var component = components[componentKey];\n var value = component.error ? 'error' : JSON.stringify(component.value);\n result += \"\" + (result ? '|' : '') + componentKey.replace(/([:|\\\\])/g, '\\\\$1') + \":\" + value;\n }\n return result;\n}\nfunction componentsToDebugString(components) {\n return JSON.stringify(components, function (_key, value) {\n if (value instanceof Error) {\n return errorToObject(value);\n }\n return value;\n }, 2);\n}\nfunction hashComponents(components) {\n return x64hash128(componentsToCanonicalString(components));\n}\n/**\n * Makes a GetResult implementation that calculates the visitor id hash on demand.\n * Designed for optimisation.\n */\nfunction makeLazyGetResult(components) {\n var visitorIdCache;\n // A plain class isn't used because its getters and setters aren't enumerable.\n return {\n components: components,\n get visitorId() {\n if (visitorIdCache === undefined) {\n visitorIdCache = hashComponents(this.components);\n }\n return visitorIdCache;\n },\n set visitorId(visitorId) {\n visitorIdCache = visitorId;\n },\n };\n}\n/**\n * The class isn't exported from the index file to not expose the constructor.\n * The hiding gives more freedom for future non-breaking updates.\n */\nvar OpenAgent = /** @class */ (function () {\n function OpenAgent() {\n }\n /**\n * @inheritDoc\n */\n OpenAgent.prototype.get = function (options) {\n if (options === void 0) { options = {}; }\n return __awaiter(this, void 0, void 0, function () {\n var components, result;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, getBuiltinComponents()];\n case 1:\n components = _a.sent();\n result = makeLazyGetResult(components);\n if (options.debug) {\n // console.log is ok here because it's under a debug clause\n // eslint-disable-next-line no-console\n console.log(\"Copy the text below to get the debug data:\\n\\n```\\nversion: \" + version + \"\\nuserAgent: \" + navigator.userAgent + \"\\ngetOptions: \" + JSON.stringify(options, undefined, 2) + \"\\nvisitorId: \" + result.visitorId + \"\\ncomponents: \" + componentsToDebugString(components) + \"\\n```\");\n }\n return [2 /*return*/, result];\n }\n });\n });\n };\n return OpenAgent;\n}());\n/**\n * Builds an instance of Agent and waits a delay required for a proper operation.\n */\nfunction load(_a) {\n var _b = (_a === void 0 ? {} : _a).delayFallback, delayFallback = _b === void 0 ? 50 : _b;\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_c) {\n switch (_c.label) {\n case 0: \n // A delay is required to ensure consistent entropy components.\n // See https://github.com/fingerprintjs/fingerprintjs/issues/254\n // and https://github.com/fingerprintjs/fingerprintjs/issues/307\n // and https://github.com/fingerprintjs/fingerprintjs/commit/945633e7c5f67ae38eb0fea37349712f0e669b18\n // A proper deadline is unknown. Let it be twice the fallback timeout so that both cases have the same average time.\n return [4 /*yield*/, requestIdleCallbackIfAvailable(delayFallback, delayFallback * 2)];\n case 1:\n // A delay is required to ensure consistent entropy components.\n // See https://github.com/fingerprintjs/fingerprintjs/issues/254\n // and https://github.com/fingerprintjs/fingerprintjs/issues/307\n // and https://github.com/fingerprintjs/fingerprintjs/commit/945633e7c5f67ae38eb0fea37349712f0e669b18\n // A proper deadline is unknown. Let it be twice the fallback timeout so that both cases have the same average time.\n _c.sent();\n return [2 /*return*/, new OpenAgent()];\n }\n });\n });\n}\n\n// The default export is a syntax sugar (`import * as FP from '...' → import FP from '...'`).\n// It should contain all the public exported values.\nvar index = { load: load, hashComponents: hashComponents, componentsToDebugString: componentsToDebugString };\n// The exports below are for private usage. They may change unexpectedly. Use them at your own risk.\n/** Not documented, out of Semantic Versioning, usage is at your own risk */\nvar murmurX64Hash128 = x64hash128;\n\nexport default index;\nexport { componentsToDebugString, getComponents, hashComponents, isChromium, isDesktopSafari, isEdgeHTML, isGecko, isTrident, isWebKit, load, murmurX64Hash128 };\n","import canUseDom from '@clearscore/helpers.can-use-dom';\n\nconst CACHE_NAME = '__cs__';\nconst objGlobal = canUseDom() ? window : {};\n\nobjGlobal[CACHE_NAME] = objGlobal[CACHE_NAME] || {};\nobjGlobal[CACHE_NAME].verticals = objGlobal[CACHE_NAME].verticals || {};\nobjGlobal[CACHE_NAME].envs = objGlobal[CACHE_NAME].envs || {};\n\nexport const cache = objGlobal[CACHE_NAME];\n\nexport function loadRoutes() {\n return cache.routes || [];\n}\n\nexport function hasComponent(name) {\n const vertical = cache.verticals[name];\n return !!vertical;\n}\n\nexport function loadComponent(name) {\n const vertical = cache.verticals[name];\n return vertical ? vertical.Component : undefined;\n}\n\nexport function getEntry(key) {\n if (cache && cache[key]) {\n return cache[key];\n }\n return null;\n}\n\nexport function setEntry(key, value) {\n cache[key] = value;\n return getEntry(key);\n}\n","import FingerprintJS from '@fingerprintjs/fingerprintjs';\nimport { cache } from '@clearscore/helpers.cache';\nimport device from '@clearscore/helpers.device';\n\n// eslint-disable-next-line import/no-mutable-exports\nconst fingerprint = {\n component: [],\n hash: 'server',\n calculate: function fingerprintPromise() {\n return FingerprintJS.load()\n .then((fp) => fp.get())\n .then((components) => components.visitorId);\n },\n};\n\n(async () => {\n const fp = await FingerprintJS.load();\n const results = await fp.get();\n\n const {\n colorDepth,\n screenResolution,\n availableScreenResolution,\n plugins,\n fonts,\n canvas,\n audio,\n touchSupport,\n ...components\n } = results.components;\n\n const extendedComponents = {\n ...components,\n osAndBrowser: { value: device.DEVICE_NAME },\n };\n\n const visitorId = FingerprintJS.hashComponents(extendedComponents);\n\n fingerprint.hash = visitorId;\n fingerprint.components = extendedComponents;\n cache.device = {\n hash: fingerprint.hash,\n components: fingerprint.components,\n };\n})();\n\nexport default fingerprint;\n","import canUseDom from '@clearscore/helpers.can-use-dom';\n\n/**\n * Make sure segment exists adn has that function\n * @param {String} fcnName - Function name\n * @return {boolean} does the fucntion exist\n */\nexport function hasSegmentFunction(fcnName) {\n return canUseDom() ? window.analytics && typeof window.analytics[fcnName] === 'function' : false;\n}\n\n/**\n * Get the user anonymousID\n * @return {String} the user anonymousId\n */\nexport function getAnonymousId() {\n return hasSegmentFunction('user') ? window.analytics.user().anonymousId() : '';\n}\n\n/**\n * Reset the user is including anonymousID\n * @return {void}\n */\nexport function resetUser() {\n if (hasSegmentFunction('reset')) {\n window.analytics.reset();\n }\n}\n\n/**\n * Export the segment library by default\n */\nexport default canUseDom() ? window.analytics : false;\n","import createAction from '@clearscore/helpers.create-action';\nimport createRequestPayload from '@clearscore/helpers.create-request-payload';\nimport getEnv from '@clearscore/helpers.envs';\nimport getDevice from '@clearscore/helpers.device';\nimport fingerprint from '@clearscore/helpers.device-fingerprinting';\nimport {\n getPublisherCookieUTM,\n publisherCookieIsSentToBackend,\n markPublisherCookieAsSentToBackend,\n} from '@clearscore/helpers.cookies';\nimport { getAnonymousId } from '@clearscore/helpers.segment';\nimport {\n SET_SESSION,\n LOGIN_OAUTH_AUTHORISE,\n LOGIN_OAUTH_SUBMIT,\n TIMEOUT_SUCCESS,\n LOGOUT_SUBMIT,\n CLEAR_SESSION,\n SET_USER_ROLE,\n LOGIN_OAUTH_REFRESH,\n NATIVE_SET_SESSION,\n} from '@clearscore/constants.session-action-types';\n\n/**\n * Get the extra payload to add to requests containing the\n * user's UTM data (if any, and not sent already), and\n * mark cookie as \"sent\" if found so we don't send again\n */\nconst getMarketingIntentPayload = () => {\n const utmParams = getPublisherCookieUTM();\n\n if (Object.entries(utmParams).length > 0 && !publisherCookieIsSentToBackend(utmParams)) {\n markPublisherCookieAsSentToBackend(utmParams);\n\n return {\n utm_parameters: utmParams,\n };\n }\n\n return {};\n};\n\n/*\n * Send action for global login\n *\n * @param {Object} data - object containing required properties\n * @param {String} data.email - users uuid\n * @param {String} data.password - users password\n * @todo: remove conditional when oAuth is out\n */\nexport const login = (data, meta) =>\n createAction(\n LOGIN_OAUTH_SUBMIT,\n createRequestPayload(\n 'international',\n '/login-service/v3/authorise',\n 'post',\n {\n ...(getEnv('SSO_AGENT_ID') && { agent_id: navigator?.userAgent }),\n response_type: 'code', // its always code\n client_type: 'internal', // its always internal\n client_id: getEnv('OAUTH_CLIENT_ID'),\n device_id: fingerprint.hash,\n device_type: getDevice(), // Desktop\n device_name: getDevice.DEVICE_NAME, // Browser Name\n refresh_token_ttl: getEnv('OAUTH_REFRESH_TLL'), // default life of refresh token\n ...data,\n },\n meta,\n ),\n );\n\n/*\n * Auth code for a refresh_token and session_token\n *\n * @param {Object} data - object containing required properties\n * @param {String} data.email - users uuid\n * @param {String} data.password - users password\n */\nexport const authorise = (data, meta) =>\n createAction(\n LOGIN_OAUTH_AUTHORISE,\n createRequestPayload(\n 'international',\n '/login-service/v3/token',\n 'post',\n {\n grant_type: 'authorization_code',\n client_type: 'internal',\n client_id: getEnv('OAUTH_CLIENT_ID'),\n device_id: fingerprint.hash,\n session_id: getAnonymousId(),\n ...getMarketingIntentPayload(),\n ...data,\n },\n meta,\n ),\n );\n\n/*\n * Refresh oauth tokens\n *\n * @param {Object} data - object containing required properties\n */\nexport const refreshToken = (data, meta) =>\n createAction(\n LOGIN_OAUTH_REFRESH,\n createRequestPayload(\n 'international',\n '/login-service/v3/token',\n 'post',\n {\n grant_type: 'refresh_token',\n client_type: 'internal',\n client_id: getEnv('OAUTH_CLIENT_ID'),\n device_id: fingerprint.hash,\n session_id: getAnonymousId(),\n ...getMarketingIntentPayload(),\n ...data,\n },\n meta,\n ),\n );\n\n/*\n * Manually set the session data\n *\n * @param {string} data.accountId - users uuid\n * @param {string} data.sessionToken - unique session token\n */\nexport const setSession = (data) =>\n createAction(SET_SESSION, { accountId: '', sessionToken: data.accessToken || data.access_token || '', ...data });\n\n/*\n * Manually set the native session, we should never listen to this action\n *\n * @param {string} data.accountId - users uuid\n * @param {string} data.sessionToken - unique session token\n */\nexport const setNativeSession = (data) =>\n createAction(NATIVE_SET_SESSION, {\n accountId: '',\n sessionToken: data.accessToken || data.access_token || '',\n ...data,\n });\n\nexport const timeout = () => createAction(TIMEOUT_SUCCESS);\nexport const clearSession = () => createAction(CLEAR_SESSION);\n\nexport const logout = () => createAction(LOGOUT_SUBMIT);\n\nexport const setUserRole = ({ role }) => createAction(SET_USER_ROLE, { role });\n","/** @clearscore/constants.request-statuses v2.2.9: 2023-1-16 14:0 (assemble v5.5.2) **/\nconst INITIAL = 'initial';\nconst SUCCESS = 'success';\nconst ERROR = 'error';\nconst PENDING = 'pending';\n\nexport { ERROR, INITIAL, PENDING, SUCCESS };\n//# sourceMappingURL=index.mjs.map\n","/** @clearscore/constants.profile-statuses v3.2.9: 2023-1-16 14:0 (assemble v5.5.2) **/\nconst PROFILE_STATUSES = {\n NONE: 'NONE',\n BAV: 'BAV',\n CREATE_ACCOUNT: 'CREATE_ACCOUNT',\n CARD_REQD: 'CARD_REQD',\n CHALLENGE: 'CHALLENGE',\n CHOICE_KBA_BAV: 'CHOICE_KBA_BAV',\n CREATE_ACCOUNT_FAIL: 'CREATE_ACCOUNT_FAIL',\n DOC_PENDING: 'DOC_PENDING',\n DOC_REJECTED: 'DOC_REJECTED',\n DOC_SECURITY: 'DOC_SECURITY',\n DOC_VERIFY: 'DOC_VERIFY',\n ERROR: 'ERROR',\n FAIL: 'FAIL',\n ID_CHECK: 'ID_CHECK',\n INCORRECT_PHONE_NUMBER: 'INCORRECT_PHONE_NUMBER',\n INCORRECT_EMAIL_ADDRESS: 'INCORRECT_EMAIL_ADDRESS',\n KBA: 'KBA',\n KBA_BLOCKED: 'KBA_BLOCKED',\n MISSING_ADDRESS: 'MISSING_ADDRESS',\n NO_FILE: 'NO_FILE',\n OTP: 'OTP',\n OTP_EMAIL: 'OTP_EMAIL',\n OTP_MASKED: 'OTP_MASKED',\n OTP_MASKED_EMAIL: 'OTP_MASKED_EMAIL',\n OTP_PHONE_OR_EMAIL: 'OTP_PHONE_OR_EMAIL',\n PASS: 'PASS',\n REVIEW_DVS: 'REVIEW_DVS',\n TEMP_NO_FILE: 'TEMP_NO_FILE',\n TEMP_PARTIAL_MATCH: 'TEMP_PARTIAL_MATCH',\n THIN_FILE: 'THIN_FILE',\n UNVERIFIED: 'UNVERIFIED',\n WAIT_72_HOURS: 'WAIT_72_HOURS',\n PASSED_DVS: 'PASSED_DVS'\n};\nconst PROFILE_FAILURE_REASONS = {\n FAIL1: 'FAIL1',\n FAIL2: 'FAIL2',\n FAIL3: 'FAIL3',\n FAIL4: 'FAIL4',\n FAIL5: 'FAIL5',\n BAV_REQUIRED: 'BAV_REQUIRED',\n DOC_FILED_BAV: 'DOC_FILED_BAV',\n DOC_REQUIRED: 'DOC_REQUIRED',\n DOC_RESUBMIT: 'DOC_RESUBMIT',\n DOC_SUBMITTED: 'DOC_SUBMITTED',\n DOC_CIFAS: 'DOC_CIFAS',\n PARTIAL_MATCH_FAIL: 'PARTIAL_MATCH_FAIL',\n FRAUD_RISK: 'FRAUD_RISK',\n BAN: 'BAN',\n DVS_NO_MATCH: 'DVS_NO_MATCH',\n OTP_FAILED: 'OTP_FAILED'\n};\nconst ACCOUNT_STATUSES = {\n BLOCKED: 'BLOCKED',\n ACTIVE: 'ACTIVE',\n INACTIVE: 'INACTIVE',\n PASS: 'PASS',\n TEMP_LOCKED: 'TEMP_LOCKED',\n LOCKED: 'LOCKED',\n DUP_LOCKED: 'DUP_LOCKED',\n SEC_LOCKED: 'SEC_LOCKED'\n};\nconst RESUBMIT_STATUS = {\n idvStatus: PROFILE_STATUSES.THIN_FILE,\n idvReason: 'DOC_RESUBMIT'\n};\nconst DOCUMENTS_UPLOAD_STATUSES = [PROFILE_STATUSES.DOC_VERIFY, PROFILE_STATUSES.DOC_PENDING];\nconst OPT_STATUSES = [PROFILE_STATUSES.ID_CHECK, PROFILE_STATUSES.OTP, PROFILE_STATUSES.OTP_MASKED, PROFILE_STATUSES.INCORRECT_PHONE_NUMBER];\nconst GB_PASS_STATUSES = [PROFILE_STATUSES.PASS, PROFILE_STATUSES.NO_FILE];\nconst GB_REGISTRATION_STATUSES = [PROFILE_STATUSES.CREATE_ACCOUNT, PROFILE_STATUSES.CREATE_ACCOUNT_FAIL, PROFILE_STATUSES.FAIL, PROFILE_STATUSES.MISSING_ADDRESS, PROFILE_STATUSES.ID_CHECK, PROFILE_STATUSES.UNVERIFIED, PROFILE_STATUSES.KBA, PROFILE_STATUSES.DOC_VERIFY, PROFILE_STATUSES.DOC_PENDING, PROFILE_STATUSES.THIN_FILE, PROFILE_STATUSES.CHOICE_KBA_BAV, PROFILE_STATUSES.TEMP_NO_FILE, PROFILE_STATUSES.TEMP_PARTIAL_MATCH, PROFILE_STATUSES.BAV, PROFILE_STATUSES.DOC_REJECTED, PROFILE_STATUSES.DOC_SECURITY, PROFILE_STATUSES.WAIT_72_HOURS];\nconst EMPLOYMENT_STATUSES = {\n SALARIED: 'SALARIED',\n SELF_EMPLOYED_BUSINESS: 'SELF_EMPLOYED_BUSINESS',\n SELF_EMPLOYED_PROFESSIONAL: 'SELF_EMPLOYED_PROFESSIONAL',\n STUDENT: 'STUDENT',\n RETIRED: 'RETIRED',\n UNEMPLOYED: 'UNEMPLOYED',\n FT_EMPLOYED: 'FT_EMPLOYED',\n PT_EMPLOYED: 'PT_EMPLOYED',\n WORK_AT_HOME: 'WORK_AT_HOME',\n SELF_EMPLOYED: 'SELF_EMPLOYED'\n};\nconst RESIDENTIAL_STATUSES = {\n HOMEOWNER: 'HOMEOWNER',\n PRIVATE_TENANT: 'PRIVATE_TENANT',\n COUNCIL_TENANT: 'COUNCIL_TENANT',\n WITH_PARENTS: 'WITH_PARENTS',\n RDP_TENANT: 'RDP_TENANT'\n};\n\nexport { ACCOUNT_STATUSES, DOCUMENTS_UPLOAD_STATUSES, EMPLOYMENT_STATUSES, GB_PASS_STATUSES, GB_REGISTRATION_STATUSES, OPT_STATUSES, PROFILE_FAILURE_REASONS, PROFILE_STATUSES, RESIDENTIAL_STATUSES, RESUBMIT_STATUS };\n//# sourceMappingURL=index.mjs.map\n","/** @clearscore/constants.role-statuses v2.2.9: 2023-1-16 14:0 (assemble v5.5.2) **/\nconst UNAUTHORISED = 'unauthorised';\nconst AUTHORISED = 'authorised';\nconst PROSPECT = 'prospect';\nconst PENDING = 'pending';\n\nexport { AUTHORISED, PENDING, PROSPECT, UNAUTHORISED };\n//# sourceMappingURL=index.mjs.map\n","/** @clearscore/constants.profile-action-types v0.6.9: 2023-1-16 14:0 (assemble v5.5.2) **/\nconst PROFILE_FETCH = 'CS/PROFILE_FETCH';\nconst PROFILE_FETCH_SUCCESS = `CS/PROFILE_FETCH_SUCCESS`;\nconst PROFILE_FETCH_ERROR = `CS/PROFILE_FETCH_ERROR`;\nconst PROFILE_SAVE = 'CS/PROFILE_SAVE';\nconst PROFILE_SAVE_SUCCESS = `CS/PROFILE_SAVE_SUCCESS`;\nconst PROFILE_SAVE_ERROR = `CS/PROFILE_SAVE_ERROR`;\nconst PROFILE_REMOVE = 'CS/PROFILE_REMOVE';\nconst PROFILE_REMOVE_SUCCESS = `CS/PROFILE_REMOVE_SUCCESS`;\nconst PROFILE_REMOVE_ERROR = `CS/PROFILE_REMOVE_ERROR`;\nconst PROFILE_ERASE = 'CS/PROFILE_ERASE';\nconst PROFILE_ERASE_SUCCESS = `CS/PROFILE_ERASE_SUCCESS`;\nconst PROFILE_ERASE_ERROR = `CS/PROFILE_ERASE_ERROR`;\nconst PROFILE_FETCH_REPORT_ADDRESSES = 'CS/PROFILE_FETCH_REPORT_ADDRESSES';\nconst PROFILE_FETCH_REPORT_ADDRESSES_SUCCESS = `CS/PROFILE_FETCH_REPORT_ADDRESSES_SUCCESS`;\nconst PROFILE_FETCH_REPORT_ADDRESSES_ERROR = `CS/PROFILE_FETCH_REPORT_ADDRESSES_ERROR`;\nconst PROFILE_SAVE_CURRENT_ADDRESS = 'CS/PROFILE_SAVE_CURRENT_ADDRESS';\nconst PROFILE_SAVE_CURRENT_ADDRESS_SUCCESS = `CS/PROFILE_SAVE_CURRENT_ADDRESS_SUCCESS`;\nconst PROFILE_SAVE_CURRENT_ADDRESS_ERROR = `CS/PROFILE_SAVE_CURRENT_ADDRESS_ERROR`;\nconst PROFILE_SEND_USER_DATA = 'CS/PROFILE_SEND_USER_DATA';\nconst PROFILE_SEND_USER_DATA_SUCCESS = `CS/PROFILE_SEND_USER_DATA_SUCCESS`;\nconst PROFILE_SEND_USER_DATA_ERROR = `CS/PROFILE_SEND_USER_DATA_ERROR`;\nconst PROFILE_SEND_USER_DATA_UNVERIFIED_EMAIL = 'CS/PROFILE_SEND_USER_DATA_UNVERIFIED_EMAIL';\nconst PROFILE_RESEND_EMAIL_VERIFICATION = 'CS/PROFILE_RESEND_EMAIL_VERIFICATION';\nconst PROFILE_RESEND_EMAIL_VERIFICATION_SUCCESS = `CS/PROFILE_RESEND_EMAIL_VERIFICATION_SUCCESS`;\nconst PROFILE_RESEND_EMAIL_VERIFICATION_ERROR = `CS/PROFILE_RESEND_EMAIL_VERIFICATION_ERROR`;\nconst PROFILE_MKTG_PREF_FETCH = 'CS/PROFILE_MKTG_PREF_FETCH';\nconst PROFILE_MKTG_PREF_FETCH_SUCCESS = `CS/PROFILE_MKTG_PREF_FETCH_SUCCESS`;\nconst PROFILE_MKTG_PREF_FETCH_ERROR = `CS/PROFILE_MKTG_PREF_FETCH_ERROR`;\nconst PROFILE_MKTG_PREF_SAVE = 'CS/PROFILE_MKTG_PREF_SAVE';\nconst PROFILE_MKTG_PREF_SAVE_SUCCESS = `CS/PROFILE_MKTG_PREF_SAVE_SUCCESS`;\nconst PROFILE_MKTG_PREF_SAVE_ERROR = `CS/PROFILE_MKTG_PREF_SAVE_ERROR`;\nconst PROFILE_SAVE_TERMS = 'CS/PROFILE_SAVE_TERMS';\nconst PROFILE_SAVE_TERMS_SUCCESS = `CS/PROFILE_SAVE_TERMS_SUCCESS`;\nconst PROFILE_SAVE_TERMS_ERROR = `CS/PROFILE_SAVE_TERMS_ERROR`;\n\nexport { PROFILE_ERASE, PROFILE_ERASE_ERROR, PROFILE_ERASE_SUCCESS, PROFILE_FETCH, PROFILE_FETCH_ERROR, PROFILE_FETCH_REPORT_ADDRESSES, PROFILE_FETCH_REPORT_ADDRESSES_ERROR, PROFILE_FETCH_REPORT_ADDRESSES_SUCCESS, PROFILE_FETCH_SUCCESS, PROFILE_MKTG_PREF_FETCH, PROFILE_MKTG_PREF_FETCH_ERROR, PROFILE_MKTG_PREF_FETCH_SUCCESS, PROFILE_MKTG_PREF_SAVE, PROFILE_MKTG_PREF_SAVE_ERROR, PROFILE_MKTG_PREF_SAVE_SUCCESS, PROFILE_REMOVE, PROFILE_REMOVE_ERROR, PROFILE_REMOVE_SUCCESS, PROFILE_RESEND_EMAIL_VERIFICATION, PROFILE_RESEND_EMAIL_VERIFICATION_ERROR, PROFILE_RESEND_EMAIL_VERIFICATION_SUCCESS, PROFILE_SAVE, PROFILE_SAVE_CURRENT_ADDRESS, PROFILE_SAVE_CURRENT_ADDRESS_ERROR, PROFILE_SAVE_CURRENT_ADDRESS_SUCCESS, PROFILE_SAVE_ERROR, PROFILE_SAVE_SUCCESS, PROFILE_SAVE_TERMS, PROFILE_SAVE_TERMS_ERROR, PROFILE_SAVE_TERMS_SUCCESS, PROFILE_SEND_USER_DATA, PROFILE_SEND_USER_DATA_ERROR, PROFILE_SEND_USER_DATA_SUCCESS, PROFILE_SEND_USER_DATA_UNVERIFIED_EMAIL };\n//# sourceMappingURL=index.mjs.map\n","export const IDENTITY_IDENTIFY = 'CS/IDENTITY_IDENTIFY';\nexport const IDENTITY_IDENTIFY_SUCCESS = `${IDENTITY_IDENTIFY}_SUCCESS`;\nexport const IDENTITY_IDENTIFY_ERROR = `${IDENTITY_IDENTIFY}_ERROR`;\nexport const IDENTITY_REIDENTIFY = 'CS/IDENTITY_REIDENTIFY';\nexport const IDENTITY_REIDENTIFY_SUCCESS = `${IDENTITY_REIDENTIFY}_SUCCESS`;\nexport const IDENTITY_REIDENTIFY_ERROR = `${IDENTITY_REIDENTIFY}_ERROR`;\nexport const IDENTITY_RESTART = 'CS/IDENTITY_RESTART';\nexport const IDENTITY_RESTART_SUCCESS = `${IDENTITY_RESTART}_SUCCESS`;\nexport const IDENTITY_RESTART_ERROR = `${IDENTITY_RESTART}_ERROR`;\nexport const IDENTITY_GENERATE_TOKEN = 'CS/IDENTITY_GENERATE_TOKEN';\nexport const IDENTITY_GENERATE_TOKEN_SUCCESS = `${IDENTITY_GENERATE_TOKEN}_SUCCESS`;\nexport const IDENTITY_GENERATE_TOKEN_ERROR = `${IDENTITY_GENERATE_TOKEN}_ERROR`;\nexport const IDENTITY_VERIFY_OTP_TOKEN = 'CS/IDENTITY_VERIFY_OTP_TOKEN';\nexport const IDENTITY_VERIFY_OTP_TOKEN_SUCCESS = `${IDENTITY_VERIFY_OTP_TOKEN}_SUCCESS`;\nexport const IDENTITY_VERIFY_OTP_TOKEN_ERROR = `${IDENTITY_VERIFY_OTP_TOKEN}_ERROR`;\nexport const IDENTITY_CHOOSE = 'CS/IDENTITY_CHOOSE';\nexport const IDENTITY_CHOOSE_SUCCESS = `${IDENTITY_CHOOSE}_SUCCESS`;\nexport const IDENTITY_CHOOSE_ERROR = `${IDENTITY_CHOOSE}_ERROR`;\nexport const IDENTITY_FIRST_TIME_VISIT = 'CS/IDENTITY_FIRST_TIME_VISIT';\nexport const IDENTITY_FIRST_TIME_REGISTRATION = 'CS/IDENTITY_FIRST_TIME_REGISTRATION';\n\nexport const IDENTITY_FETCH_KBA = 'CS/IDENTITY_FETCH_KBA';\nexport const IDENTITY_FETCH_KBA_SUCCESS = `${IDENTITY_FETCH_KBA}_SUCCESS`;\nexport const IDENTITY_FETCH_KBA_ERROR = `${IDENTITY_FETCH_KBA}_ERROR`;\nexport const IDENTITY_VERIFY_KBA = 'CS/IDENTITY_VERIFY_KBA';\nexport const IDENTITY_VERIFY_KBA_SUCCESS = `${IDENTITY_VERIFY_KBA}_SUCCESS`;\nexport const IDENTITY_VERIFY_KBA_ERROR = `${IDENTITY_VERIFY_KBA}_ERROR`;\n\nexport const IDENTITY_VERIFY_BAV = 'CS/IDENTITY_VERIFY_BAV';\nexport const IDENTITY_VERIFY_BAV_SUCCESS = `${IDENTITY_VERIFY_BAV}_SUCCESS`;\nexport const IDENTITY_VERIFY_BAV_ERROR = `${IDENTITY_VERIFY_BAV}_ERROR`;\nexport const IDENTITY_SKIP_BAV = 'CS/IDENTITY_SKIP_BAV';\nexport const IDENTITY_SKIP_BAV_SUCCESS = `${IDENTITY_SKIP_BAV}_SUCCESS`;\nexport const IDENTITY_SKIP_BAV_ERROR = `${IDENTITY_SKIP_BAV}_ERROR`;\n\nexport const IDENTITY_MARKETING_USER = 'CS/IDENTITY_MARKETING_USER';\nexport const IDENTITY_SKIP_OTP = 'CS/IDENTITY_SKIP_OTP';\nexport const IDENTITY_SKIP_OTP_SUCCESS = `${IDENTITY_SKIP_OTP}_SUCCESS`;\nexport const IDENTITY_SKIP_OTP_ERROR = `${IDENTITY_SKIP_OTP}_ERROR`;\n\nexport const IDENTITY_SKIP_REIDENTIFY = 'CS/IDENTITY_SKIP_REIDENTIFY';\nexport const IDENTITY_SKIP_REIDENTIFY_SUCCESS = `${IDENTITY_SKIP_REIDENTIFY}_SUCCESS`;\nexport const IDENTITY_SKIP_REIDENTIFY_ERROR = `${IDENTITY_SKIP_REIDENTIFY}_ERROR`;\n\nexport const IDENTITY_EMPTY = 'CS/IDENTITY_EMPTY';\n","import { resolveProp } from '@clearscore/helpers.resolve-props';\nimport * as requestStatuses from '@clearscore/constants.request-statuses';\n\nexport const getRequestStatus = (status, statusCode) => ({\n isInitial: status === requestStatuses.INITIAL,\n isPending: status === requestStatuses.PENDING,\n isComplete: status === requestStatuses.SUCCESS,\n hasFailed: status === requestStatuses.ERROR,\n statusCode,\n});\n\nconst calculateIsCompleteMultiple = (statusList) => {\n if (statusList.every((status) => status === requestStatuses.SUCCESS)) return true;\n if (statusList.every((status) => status === requestStatuses.ERROR)) return false;\n\n return statusList\n .map((status) => status === requestStatuses.SUCCESS || status === requestStatuses.ERROR)\n .every(Boolean);\n};\n\nexport const getRequestStatusMultiple = (statusList = [], statusCodes = []) => {\n const hasStatuses = statusList.length;\n\n return {\n isInitial: hasStatuses ? statusList.every((status) => status === requestStatuses.INITIAL) : true,\n isPending: statusList.some((status) => status === requestStatuses.PENDING),\n isComplete: hasStatuses ? calculateIsCompleteMultiple(statusList) : false,\n hasFailed: hasStatuses ? statusList.every((status) => status === requestStatuses.ERROR) : false,\n hasFailures: statusList.some((status) => status === requestStatuses.ERROR),\n statusCodes,\n };\n};\n\nexport default (state, prop) => {\n const props = prop.split('.');\n const hasValidRootReducer = props.length === 1 ? state : state[props[0]];\n if (hasValidRootReducer) {\n return resolveProp(prop, state) || requestStatuses.INITIAL;\n }\n console.error(`Cannot resolve root state for prop: ${prop}`); // eslint-disable-line no-console\n return requestStatuses.ERROR;\n};\n","import * as actionsImport from './identity.actions';\nimport * as reducersImport from './identity.reducers';\nimport * as selectorsImport from './selectors/index';\nimport * as typesImport from './identity.types';\n\nexport const actions = actionsImport;\nexport const reducers = reducersImport;\nexport const selectors = selectorsImport;\nexport const types = typesImport;\n","import * as requestStatuses from '@clearscore/constants.request-statuses';\nimport { types as identityTypes } from '@clearscore/redux.identity';\nimport {\n PROFILE_FETCH,\n PROFILE_FETCH_SUCCESS,\n PROFILE_FETCH_ERROR,\n PROFILE_SAVE,\n PROFILE_SAVE_SUCCESS,\n PROFILE_SAVE_ERROR,\n PROFILE_REMOVE,\n PROFILE_REMOVE_SUCCESS,\n PROFILE_REMOVE_ERROR,\n PROFILE_ERASE,\n PROFILE_ERASE_ERROR,\n PROFILE_ERASE_SUCCESS,\n PROFILE_FETCH_REPORT_ADDRESSES,\n PROFILE_FETCH_REPORT_ADDRESSES_SUCCESS,\n PROFILE_FETCH_REPORT_ADDRESSES_ERROR,\n PROFILE_SAVE_CURRENT_ADDRESS,\n PROFILE_SAVE_CURRENT_ADDRESS_SUCCESS,\n PROFILE_SAVE_CURRENT_ADDRESS_ERROR,\n PROFILE_SEND_USER_DATA,\n PROFILE_SEND_USER_DATA_SUCCESS,\n PROFILE_SEND_USER_DATA_ERROR,\n PROFILE_RESEND_EMAIL_VERIFICATION,\n PROFILE_RESEND_EMAIL_VERIFICATION_SUCCESS,\n PROFILE_RESEND_EMAIL_VERIFICATION_ERROR,\n PROFILE_MKTG_PREF_FETCH,\n PROFILE_MKTG_PREF_FETCH_SUCCESS,\n PROFILE_MKTG_PREF_FETCH_ERROR,\n PROFILE_MKTG_PREF_SAVE,\n PROFILE_MKTG_PREF_SAVE_SUCCESS,\n PROFILE_MKTG_PREF_SAVE_ERROR,\n PROFILE_SAVE_TERMS,\n PROFILE_SAVE_TERMS_SUCCESS,\n PROFILE_SAVE_TERMS_ERROR,\n} from '@clearscore/constants.profile-action-types';\n\nconst initialState = {\n fetchStatus: requestStatuses.INITIAL,\n saveCurrentAddressStatus: requestStatuses.INITIAL,\n reportAddressesFetchStatus: requestStatuses.INITIAL,\n sendUserDataStatus: requestStatuses.INITIAL,\n resendEmailStatus: requestStatuses.INITIAL,\n mktgFetchStatus: requestStatuses.INITIAL,\n mktgSaveStatus: requestStatuses.INITIAL,\n};\n\nconst transformPhoneNumber = (requestData) => ({\n ...requestData,\n ...{\n phoneNumber: requestData.phoneNumber.number,\n phoneCountryCode: requestData.phoneNumber.countryCode,\n phoneType: requestData.phoneNumber.type,\n },\n});\n\nconst transformSaveSuccessRequestData = (requestData) =>\n requestData.phoneNumber && typeof requestData.phoneNumber !== 'string'\n ? transformPhoneNumber(requestData)\n : requestData;\n\nexport default (state = initialState, action = {}) => {\n const { type, payload, requestData } = action;\n\n // N.B phoneNumber property in profile-service GET and PATCH methods isn't consistent\n // 1. .save() action is creating requestData passed from phone-form.container that's matching PATCH method\n // 2. phoneNumber data needs to be transformed back to its original shape provided by profile-service GET method\n const saveSuccessRequestData = requestData && transformSaveSuccessRequestData(requestData);\n\n switch (type) {\n case PROFILE_FETCH:\n return {\n ...state,\n fetchStatus: requestStatuses.PENDING,\n };\n case PROFILE_FETCH_SUCCESS:\n return {\n ...state,\n data: {\n ...payload,\n },\n fetchStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_FETCH_ERROR:\n return {\n ...state,\n fetchStatus: requestStatuses.ERROR,\n };\n case PROFILE_SAVE: {\n const { modified, ...stateWithoutModified } = state;\n return {\n ...stateWithoutModified,\n saveStatus: requestStatuses.PENDING,\n };\n }\n case PROFILE_SAVE_SUCCESS:\n return {\n ...state,\n data: {\n ...state.data,\n ...saveSuccessRequestData,\n },\n modified: payload.modified,\n saveStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_SAVE_ERROR:\n return {\n ...state,\n saveStatus: requestStatuses.ERROR,\n };\n case PROFILE_ERASE:\n case PROFILE_REMOVE:\n return {\n ...state,\n removeStatus: requestStatuses.PENDING,\n };\n case PROFILE_ERASE_SUCCESS:\n case PROFILE_REMOVE_SUCCESS:\n return {\n ...state,\n data: {\n ...state.data,\n ...requestData,\n },\n removeStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_ERASE_ERROR:\n case PROFILE_REMOVE_ERROR:\n return {\n ...state,\n removeStatus: requestStatuses.ERROR,\n };\n case PROFILE_FETCH_REPORT_ADDRESSES:\n return {\n ...state,\n reportAddressesFetchStatus: requestStatuses.PENDING,\n };\n case PROFILE_FETCH_REPORT_ADDRESSES_SUCCESS:\n return {\n ...state,\n reportAddresses: [...Object.values(payload || {})],\n reportAddressesFetchStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_FETCH_REPORT_ADDRESSES_ERROR:\n return {\n ...state,\n reportAddressesFetchStatus: requestStatuses.ERROR,\n };\n case PROFILE_SAVE_CURRENT_ADDRESS:\n return {\n ...state,\n saveCurrentAddressStatus: requestStatuses.PENDING,\n };\n case PROFILE_SAVE_CURRENT_ADDRESS_SUCCESS:\n return {\n ...state,\n data: {\n ...state.data,\n ...requestData,\n },\n saveCurrentAddressStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_SAVE_CURRENT_ADDRESS_ERROR:\n return {\n ...state,\n saveCurrentAddressStatus: requestStatuses.ERROR,\n };\n case PROFILE_SEND_USER_DATA:\n return {\n ...state,\n sendUserDataStatus: requestStatuses.PENDING,\n };\n case PROFILE_SEND_USER_DATA_SUCCESS:\n return {\n ...state,\n sendUserDataStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_SEND_USER_DATA_ERROR:\n return {\n ...state,\n sendUserDataStatus: requestStatuses.ERROR,\n };\n case PROFILE_RESEND_EMAIL_VERIFICATION:\n return {\n ...state,\n resendEmailStatus: requestStatuses.PENDING,\n };\n case PROFILE_RESEND_EMAIL_VERIFICATION_SUCCESS:\n return {\n ...state,\n resendEmailStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_RESEND_EMAIL_VERIFICATION_ERROR:\n return {\n ...state,\n resendEmailStatus: requestStatuses.ERROR,\n };\n case PROFILE_MKTG_PREF_FETCH:\n return {\n ...state,\n mktgFetchStatus: requestStatuses.PENDING,\n };\n case PROFILE_MKTG_PREF_FETCH_SUCCESS:\n return {\n ...state,\n mktg: {\n ...state.mktg,\n ...payload,\n },\n mktgFetchStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_MKTG_PREF_FETCH_ERROR:\n return {\n ...state,\n mktgFetchStatus: requestStatuses.ERROR,\n };\n case PROFILE_MKTG_PREF_SAVE:\n return {\n ...state,\n mktgSaveStatus: requestStatuses.PENDING,\n };\n case PROFILE_MKTG_PREF_SAVE_SUCCESS:\n return {\n ...state,\n mktg: {\n ...state.mktg,\n ...requestData,\n },\n mktgSaveStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_MKTG_PREF_SAVE_ERROR:\n return {\n ...state,\n mktgSaveStatus: requestStatuses.ERROR,\n };\n case identityTypes.IDENTITY_IDENTIFY_SUCCESS:\n case identityTypes.IDENTITY_VERIFY_KBA_SUCCESS:\n return {\n ...state,\n data: {\n ...state.data,\n accountIDVStatus: payload.accountIDVStatus,\n },\n };\n case PROFILE_SAVE_TERMS: {\n const { modified, ...stateWithoutModified } = state;\n return {\n ...stateWithoutModified,\n termsSaveStatus: requestStatuses.PENDING,\n };\n }\n case PROFILE_SAVE_TERMS_SUCCESS:\n return {\n ...state,\n data: {\n ...state.data,\n ...saveSuccessRequestData,\n },\n modified: payload.modified,\n termsSaveStatus: requestStatuses.SUCCESS,\n };\n case PROFILE_SAVE_TERMS_ERROR:\n return {\n ...state,\n termsSaveStatus: requestStatuses.ERROR,\n };\n default:\n return state;\n }\n};\n","/* eslint-disable import/prefer-default-export */\nimport profileDomain from './profile.domain';\n\nexport const domain = profileDomain;\n","/* eslint-disable import/prefer-default-export */\nimport getEnv from '@clearscore/helpers.envs';\n\n/**\n * Get the app version from querystring if running in webview\n * context (to be passed eventually to segmenter)\n */\nexport const getWebviewAppVersion = () => {\n if (!getEnv('WEBVIEW')) return null;\n\n return new URLSearchParams(window.location?.search).get('appVersion');\n};\n","const MARKET = 'CS/MARKET';\n\nexport const MARKET_SET_MARKETS = `${MARKET}_SET_MARKETS`;\nexport const MARKET_SET_LOCALES = `${MARKET}_SET_LOCALES`;\nexport const MARKET_SET_ENVS = `${MARKET}_SET_ENVS`;\n\nexport const MARKET_SET_ACTIVE_MARKET = `${MARKET}_SET_ACTIVE_MARKET`;\nexport const MARKET_SET_ACTIVE_LOCALE = `${MARKET}_SET_ACTIVE_LOCALE`;\n\nexport const MARKET_FETCH_CONFIG = `${MARKET}_FETCH_CONFIG`;\nexport const MARKET_FETCH_CONFIG_PENDING = `${MARKET}_FETCH_CONFIG_PENDING`;\nexport const MARKET_FETCH_CONFIG_SUCCESS = `${MARKET_FETCH_CONFIG}_SUCCESS`;\nexport const MARKET_FETCH_CONFIG_ERROR = `${MARKET_FETCH_CONFIG}_ERROR`;\n\nexport const MARKET_FETCH_STATIC_CONFIG = `${MARKET}_FETCH_STATIC_CONFIG`;\nexport const MARKET_FETCH_STATIC_CONFIG_SUCCESS = `${MARKET_FETCH_STATIC_CONFIG}_SUCCESS`;\nexport const MARKET_FETCH_STATIC_CONFIG_ERROR = `${MARKET_FETCH_STATIC_CONFIG}_ERROR`;\n","import { GLOBAL, EN_GB } from '@clearscore/config.i18n';\nimport { getSessionCookie } from '@clearscore/helpers.cookies';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nconst getCurrentMarketDetails = () => {\n const sessionToken = getSessionCookie();\n const marketSessionToken = resolveProp('market', sessionToken);\n const localeSessionToken = resolveProp('locale', sessionToken);\n\n return {\n marketSessionToken,\n localeSessionToken,\n };\n};\n\nexport const getActiveMarket = () => {\n const { marketSessionToken } = getCurrentMarketDetails();\n return marketSessionToken || GLOBAL;\n};\n\nexport const getActiveLocale = () => {\n const { marketSessionToken, localeSessionToken } = getCurrentMarketDetails();\n\n if (localeSessionToken) return localeSessionToken;\n if (marketSessionToken) return `en-${marketSessionToken}`;\n return EN_GB;\n};\n","import { MARKETS, LOCALES } from '@clearscore/config.i18n';\nimport * as requestStatuses from '@clearscore/constants.request-statuses';\n\nimport { getActiveLocale, getActiveMarket } from '../lib/helpers';\nimport {\n MARKET_SET_LOCALES,\n MARKET_SET_MARKETS,\n MARKET_SET_ACTIVE_LOCALE,\n MARKET_SET_ACTIVE_MARKET,\n MARKET_FETCH_CONFIG,\n MARKET_FETCH_CONFIG_PENDING,\n MARKET_FETCH_CONFIG_ERROR,\n MARKET_FETCH_CONFIG_SUCCESS,\n MARKET_FETCH_STATIC_CONFIG,\n MARKET_FETCH_STATIC_CONFIG_SUCCESS,\n} from '../types';\n\nconst initialState = () => ({\n checkStatus: requestStatuses.INITIAL,\n fetchStatus: requestStatuses.INITIAL,\n activeMarket: getActiveMarket(),\n activeLocale: getActiveLocale(),\n markets: MARKETS,\n locales: LOCALES,\n});\n\nconst domain = (state = initialState(), action = {}) => {\n const { type, payload } = action;\n\n switch (type) {\n case MARKET_FETCH_CONFIG:\n case MARKET_FETCH_CONFIG_PENDING: // allow core to be aware of pending updates, without re-fetching the config\n case MARKET_FETCH_STATIC_CONFIG:\n return {\n ...state,\n fetchStatus: requestStatuses.PENDING,\n };\n case MARKET_FETCH_CONFIG_SUCCESS:\n case MARKET_FETCH_STATIC_CONFIG_SUCCESS:\n return {\n ...state,\n fetchStatus: requestStatuses.SUCCESS,\n };\n case MARKET_FETCH_CONFIG_ERROR:\n return {\n ...state,\n fetchStatus: requestStatuses.ERROR,\n };\n case MARKET_SET_ACTIVE_MARKET: {\n return {\n ...state,\n activeMarket: (payload && payload.market) || initialState().activeMarket,\n activeLocale: (payload && `en-${payload.market}`) || initialState().activeLocale,\n };\n }\n case MARKET_SET_ACTIVE_LOCALE:\n return {\n ...state,\n activeLocale: payload || initialState().activeLocale,\n };\n case MARKET_SET_LOCALES:\n return {\n ...state,\n locales: payload || initialState().locales,\n };\n case MARKET_SET_MARKETS:\n return {\n ...state,\n markets: payload || initialState().markets,\n };\n default:\n return state;\n }\n};\n\nexport default domain;\n","/* eslint-disable import/prefer-default-export */\nimport marketDomain from './domain';\n\nexport const domain = marketDomain;\n","import { createSelector } from 'reselect';\nimport resolveRequest, { getRequestStatus } from '@clearscore/helpers.resolve-request';\n\nconst resolveFetchStatus = (state) => resolveRequest(state, 'market.fetchStatus');\n\nexport default createSelector(resolveFetchStatus, (fetchStatus) => getRequestStatus(fetchStatus));\n","import { createSelector } from 'reselect';\nimport resolveRequest, { getRequestStatus } from '@clearscore/helpers.resolve-request';\n\nimport getFetchStatus from './getFetchStatus';\n\nconst getCheckStatus = (state) => resolveRequest(state, 'market.checkStatus');\n\nexport default createSelector(getCheckStatus, getFetchStatus, (checkStatus, fetchStatus) => ({\n check: getRequestStatus(checkStatus),\n fetch: fetchStatus,\n}));\n","import { createSelector } from 'reselect';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nconst marketsSelector = (state) => resolveProp('market.markets', state);\n\nexport default createSelector(marketsSelector, (markets) => markets);\n","import { createSelector } from 'reselect';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nconst activeMarketSelector = (state) => resolveProp('market.activeMarket', state);\n\nexport default createSelector(activeMarketSelector, (activeMarket) => activeMarket);\n","import { createSelector } from 'reselect';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nconst localesSelector = (state) => resolveProp('market.locales', state);\n\nexport default createSelector(localesSelector, (locales = []) => locales);\n","const legacyMap = {\n uk: 'en-gb',\n za: 'en-za',\n};\n\nexport default legacyMap;\n","import { createSelector } from 'reselect';\n\nimport legacyMap from './legacyMap';\n\nconst localeSelector = (state = {}) => state.locale;\nconst getActiveLanguage = (locale = {}) => ((locale && locale.languages) || []).find((copy) => copy.active === true);\n\nexport default createSelector(localeSelector, (locale) => {\n const activeLanguage = getActiveLanguage(locale) || {};\n const activeLocale = activeLanguage.languageCode || activeLanguage.code;\n return legacyMap[activeLocale] || activeLocale || 'en-gb';\n});\n","import { createSelector } from 'reselect';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nimport getLegacyLanguageCode from './legacy/legacy.getLangCode';\nimport localesSelector from './getLocales';\n\nconst activeLocaleSelector = (state) => resolveProp('market.activeLocale', state);\n\nexport default createSelector(\n activeLocaleSelector,\n localesSelector,\n getLegacyLanguageCode,\n (locale = '', locales = [], legacyLocale = '') =>\n locales.find((item) => item === locale) || legacyLocale || 'en-gb',\n);\n","import { createSelector } from 'reselect';\n\nimport getActiveMarket from './getActiveMarket.js';\n\nexport default createSelector(\n getActiveMarket,\n (activeMarket) => (marketConfig) => marketConfig[activeMarket] || marketConfig.gb || {},\n);\n","import { createSelector } from 'reselect';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nconst getResolution = (state) => resolveProp('market.resolution', state) || 'ip';\n\nexport default createSelector(getResolution, (resolution) => resolution);\n","import { createSelector } from 'reselect';\n\nimport getActiveLocale from './getActiveLocale';\n\nexport default createSelector(getActiveLocale, (locale) => (copy) => copy[locale] || copy['en-gb'] || copy.uk);\n","import marketGetPredicate from './getPredicate';\nimport marketGetFetchStatus from './getFetchStatus';\nimport marketGetMarkets from './getMarkets';\nimport marketGetActiveMarket from './getActiveMarket';\nimport marketGetLocales from './getLocales';\nimport marketGetActiveLocale from './getActiveLocale';\nimport marketGetConfig from './getConfig';\nimport marketGetResolution from './getResolution';\nimport marketLegacyGetLanguage from './legacy.getLanguage';\n\nexport const getPredicate = marketGetPredicate;\nexport const getFetchStatus = marketGetFetchStatus;\nexport const getConfig = marketGetConfig;\nexport const getMarkets = marketGetMarkets;\nexport const getActiveMarket = marketGetActiveMarket;\nexport const getLocales = marketGetLocales;\nexport const getActiveLocale = marketGetActiveLocale;\nexport const getResolution = marketGetResolution;\nexport const getLegacyLanguage = marketLegacyGetLanguage;\n","import { GB, ZA, GLOBAL, MARKETS, EN_GB, EN_ZA, LOCALES } from '@clearscore/config.i18n';\n\nimport {\n setActiveLocale,\n setActiveMarket,\n setMarketsEnvs,\n setLocales,\n setMarkets,\n fetchMarketConfig,\n setFetchPending,\n fetchStaticMarketConfig,\n} from './actions';\nimport {\n MARKET_SET_ACTIVE_LOCALE,\n MARKET_SET_ACTIVE_MARKET,\n MARKET_SET_LOCALES,\n MARKET_SET_MARKETS,\n MARKET_SET_ENVS,\n MARKET_FETCH_CONFIG,\n MARKET_FETCH_CONFIG_PENDING,\n MARKET_FETCH_CONFIG_ERROR,\n MARKET_FETCH_CONFIG_SUCCESS,\n MARKET_FETCH_STATIC_CONFIG,\n MARKET_FETCH_STATIC_CONFIG_ERROR,\n MARKET_FETCH_STATIC_CONFIG_SUCCESS,\n} from './types';\nimport { domain } from './reducers';\nimport {\n getPredicate,\n getFetchStatus,\n getConfig,\n getActiveLocale,\n getActiveMarket,\n getLocales,\n getMarkets,\n getResolution,\n getLegacyLanguage,\n} from './selectors/index';\n\nexport * as helpers from './lib/helpers';\n\nexport const actions = {\n setActiveLocale,\n setActiveMarket,\n setMarkets,\n setLocales,\n setMarketsEnvs,\n fetchMarketConfig,\n setFetchPending,\n fetchStaticMarketConfig,\n};\nexport const types = {\n MARKET_SET_ACTIVE_LOCALE,\n MARKET_SET_ACTIVE_MARKET,\n MARKET_SET_MARKETS,\n MARKET_SET_LOCALES,\n MARKET_SET_ENVS,\n MARKET_FETCH_CONFIG,\n MARKET_FETCH_CONFIG_PENDING,\n MARKET_FETCH_CONFIG_ERROR,\n MARKET_FETCH_CONFIG_SUCCESS,\n MARKET_FETCH_STATIC_CONFIG,\n MARKET_FETCH_STATIC_CONFIG_ERROR,\n MARKET_FETCH_STATIC_CONFIG_SUCCESS,\n};\n/* export for backward compatibility, however these should be imported directly from @clearscore/config.i18n */\nexport const constants = { GB, ZA, GLOBAL, MARKETS, EN_GB, EN_ZA, LOCALES };\nexport const reducers = { domain };\nexport const selectors = {\n getFetchStatus,\n getPredicate,\n getConfig,\n getLocales,\n getMarkets,\n getActiveMarket,\n getActiveLocale,\n getResolution,\n getLegacyLanguage,\n};\n","import createAction from '@clearscore/helpers.create-action';\nimport createRequestPayload from '@clearscore/helpers.create-request-payload';\nimport getEnv from '@clearscore/helpers.envs';\n\nimport { getWebviewAppVersion } from './utils';\nimport {\n MARKET_SET_LOCALES,\n MARKET_SET_ACTIVE_LOCALE,\n MARKET_SET_MARKETS,\n MARKET_SET_ACTIVE_MARKET,\n MARKET_SET_ENVS,\n MARKET_FETCH_CONFIG,\n MARKET_FETCH_CONFIG_PENDING,\n MARKET_FETCH_STATIC_CONFIG,\n} from './types';\n\nexport const setMarkets = (markets) => ({ type: MARKET_SET_MARKETS, payload: markets });\n\nexport const setLocales = (locales) => ({ type: MARKET_SET_LOCALES, payload: locales });\n\nexport const setMarketsEnvs = (envs) => ({ type: MARKET_SET_ENVS, payload: envs });\n\nexport const setActiveMarket = (market) => createAction(MARKET_SET_ACTIVE_MARKET, { market });\n\nexport const setFetchPending = () => ({ type: MARKET_FETCH_CONFIG_PENDING });\nexport const fetchMarketConfig = (market) => {\n const meta = {\n market,\n };\n const timeout = getEnv('MARKET_REQUEST_TIMEOUT') || 1000;\n const appVersion = getWebviewAppVersion();\n\n const headers = {\n 'x-app-id': getEnv('APP'),\n 'x-market-id': market,\n ...(appVersion && { 'x-cs-app-version': appVersion }),\n };\n\n return createAction(\n MARKET_FETCH_CONFIG,\n createRequestPayload('international', '/render-engine-local/v1/config', 'get', null, meta, headers, timeout),\n );\n};\n\nexport const fetchStaticMarketConfig = (market) =>\n createAction(MARKET_FETCH_STATIC_CONFIG, {\n ...createRequestPayload(\n 'renderEngine',\n `${market}.json?version=${getEnv(`${market.toUpperCase()}_VERSION`) || '1'}`,\n ),\n market,\n });\n\nexport const setActiveLocale = (activeLocale) => createAction(MARKET_SET_ACTIVE_LOCALE, activeLocale);\n","import * as profileTypes from '@clearscore/constants.profile-action-types';\n\nimport * as actionsImport from './actions';\nimport * as constantsImport from './constants';\nimport * as reducersImport from './reducers';\nimport * as selectorsImport from './selectors';\n\nexport const actions = actionsImport;\nexport const constants = constantsImport;\nexport const reducers = reducersImport;\nexport const selectors = selectorsImport;\nexport const types = profileTypes;\n","import * as requestStatuses from '@clearscore/constants.request-statuses';\nimport { getSessionCookie } from '@clearscore/helpers.cookies';\nimport { PROFILE_STATUSES, ACCOUNT_STATUSES } from '@clearscore/constants.profile-statuses';\nimport * as roles from '@clearscore/constants.role-statuses';\nimport { types as profileTypes } from '@clearscore/redux.profile';\nimport * as types from '@clearscore/constants.session-action-types';\n\n/**\n * List of all statuses for userRole AUTHORISED\n */\nexport const AUTHED_IDV_STATUSES = [PROFILE_STATUSES.PASS, PROFILE_STATUSES.THIN_FILE, PROFILE_STATUSES.NO_FILE];\n\nconst getProfileFetchSuccessRole = (payload) => {\n const { accountIDVStatus, failureReason, userStatus } = payload || {};\n\n if (AUTHED_IDV_STATUSES.includes(accountIDVStatus) && !failureReason && userStatus === ACCOUNT_STATUSES.ACTIVE) {\n return roles.AUTHORISED;\n }\n\n return roles.PROSPECT;\n};\n\nconst sessionToken = getSessionCookie();\n\n// @todo: This conditional is added to allow old consumers (native apps, etc) to continue working\n// once native stop being hybrid this code can be removed.\nif (sessionToken) {\n sessionToken.accountId = sessionToken.username;\n delete sessionToken.username;\n}\n\nconst role = sessionToken ? roles.PENDING : roles.UNAUTHORISED;\n\nconst initialState = sessionToken ? { role, meta: {}, error: null } : {};\n\nexport default (state = initialState, action = {}) => {\n const { type, payload } = action;\n switch (type) {\n case types.SET_USER_ROLE:\n return {\n ...state,\n role: payload.role,\n };\n case profileTypes.PROFILE_FETCH:\n return {\n ...state,\n role: roles.PENDING,\n };\n case profileTypes.PROFILE_FETCH_SUCCESS:\n return {\n ...state,\n role: getProfileFetchSuccessRole(payload),\n };\n case types.LOGIN_OAUTH_SUBMIT_ERROR:\n case types.LOGIN_OAUTH_AUTHORISE_ERROR:\n return {\n ...state,\n meta: {},\n error: payload ? payload.data : null,\n status: requestStatuses.ERROR,\n role: roles.UNAUTHORISED,\n };\n case types.CLEAR_SESSION:\n case types.TIMEOUT_SUCCESS:\n case types.LOGOUT_SUBMIT:\n return {\n meta: {},\n error: null,\n status: requestStatuses.INITIAL,\n };\n default:\n return state;\n }\n};\n","/* eslint-disable import/prefer-default-export */\nimport sessionDomain from './session.domain';\n\nexport const domain = sessionDomain;\n","import { createSelector } from 'reselect';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nconst getAccountId = (state) => resolveProp('session.auth.accountId', state);\n\nexport default createSelector(getAccountId, (accountId) => accountId);\n","import { createSelector } from 'reselect';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\nimport * as roles from '@clearscore/constants.role-statuses';\n\nconst authRole = (state) => resolveProp('session.role', state) || roles.UNAUTHORISED;\n\nexport default createSelector(authRole, (role) => role);\n","import { createSelector } from 'reselect';\nimport resolveRequest, { getRequestStatus } from '@clearscore/helpers.resolve-request';\n\nconst getSessionStatus = (state) => resolveRequest(state, 'session.status');\n\nexport default createSelector(getSessionStatus, (sessionStatus) => ({\n fetch: getRequestStatus(sessionStatus),\n}));\n","import { createSelector } from 'reselect';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nconst getError = (state) => resolveProp('session.error', state);\n\nexport default createSelector(getError, (error) => error);\n","import sessiongetAccountId from './session.getAccountId';\nimport sessionGetAuthRole from './session.getAuthRole';\nimport sessionGetPredicate from './session.getPredicate';\nimport sessionGetError from './session.getError';\n\nexport const getAccountId = sessiongetAccountId;\nexport const getAuthRole = sessionGetAuthRole;\nexport const getPredicate = sessionGetPredicate;\nexport const getError = sessionGetError;\n","import * as sessionTypes from '@clearscore/constants.session-action-types';\n\nimport * as actionsImport from './session.actions';\nimport * as reducersImport from './reducers';\nimport * as selectorsImport from './selectors';\n\nexport const actions = actionsImport;\nexport const reducers = reducersImport;\nexport const selectors = selectorsImport;\nexport const types = sessionTypes;\n","/**\n * Check if action has correct client data structure in payload\n * @param {object} action redux action\n * @returns {boolean} if action structure is correct\n */\nfunction hasClientData(action) {\n return !!(action.payload && action.payload.request && action.payload.request.client);\n}\n\nexport default hasClientData;\n","import getEnv from '@clearscore/helpers.envs';\n\nexport default {\n media: {\n baseURL: getEnv('MEDIA_API_DOMAIN'),\n responseType: 'json',\n },\n banking: {\n baseURL: getEnv('OB_API_DOMAIN'),\n responseType: 'json',\n },\n bankingTl: {\n baseURL: getEnv('OB_TL_API_DOMAIN'),\n responseType: 'json',\n },\n uploadS3Policy: {\n headers: { 'Content-Type': 'multipart/form-data' },\n responseType: 'json',\n },\n staticDescriptors: {\n baseURL: getEnv('STATIC_JSON_URL'),\n responseType: 'json',\n },\n international: {\n baseURL: getEnv('INTERNATIONAL_API_DOMAIN'),\n responseType: 'json',\n },\n internationalBlob: {\n baseURL: getEnv('INTERNATIONAL_API_DOMAIN'),\n responseType: 'blob',\n },\n internationalText: {\n baseURL: getEnv('INTERNATIONAL_API_DOMAIN'),\n responseType: 'text',\n },\n flux: {\n baseURL: getEnv('FLUX_API_DOMAIN'),\n responseType: 'json',\n },\n gbService: {\n baseURL: getEnv('GB_SERVICE_DOMAIN'),\n responseType: 'json',\n },\n connect: {\n baseURL: getEnv('CONNECT_API_DOMAIN'),\n responseType: 'json',\n },\n connectUpload: {\n headers: {\n 'Content-Disposition': 'attachment',\n },\n },\n products: {\n baseURL: getEnv('PRODUCTS_API_DOMAIN'),\n responseType: 'json',\n },\n renderEngine: {\n baseURL: getEnv('RENDER_ENGINE_API_DOMAIN'),\n responseType: 'json',\n },\n};\n","/* eslint-disable camelcase */\nimport { getSessionCookie } from '@clearscore/helpers.cookies';\n\nexport const getSessionToken = () => {\n const { access_token, sessionToken } = getSessionCookie() || {};\n return access_token || sessionToken;\n};\n\nexport const getRefreshToken = () => {\n const { refresh_token } = getSessionCookie() || {};\n return refresh_token;\n};\n\nexport const getStructuredData = () => {\n const { access_token, sessionToken, refresh_token } = getSessionCookie() || {};\n return { authToken: access_token || sessionToken, refreshToken: refresh_token };\n};\n","import { selectors as marketSelectors } from '@clearscore/redux.market';\n\nconst interpolateWithMarket = ({ state, url = '', market = null }) =>\n url.replace(/@market@/gi, market || marketSelectors.getActiveMarket(state) || 'global');\n\nexport default interpolateWithMarket;\n","import interpolateWithMarket from '@clearscore/helpers.interpolate-with-market';\n\nconst getInterpolatedUrl = (client, state, requestMeta) => {\n const isFunction = (config) => typeof config === 'function';\n const baseURL = isFunction(client.baseURL) ? client.baseURL(state) : client.baseURL;\n\n return baseURL\n ? interpolateWithMarket({\n state,\n url: baseURL,\n market: requestMeta ? requestMeta.market : null,\n })\n : null;\n};\n\nexport default getInterpolatedUrl;\n","import axios from 'axios';\nimport {\n getPublisherCookieUTM,\n publisherCookieIsSentToBackend,\n markPublisherCookieAsSentToBackend,\n updateSessionCookie,\n} from '@clearscore/helpers.cookies';\nimport getEnv from '@clearscore/helpers.envs';\nimport fingerprint from '@clearscore/helpers.device-fingerprinting';\nimport { getStructuredData } from '@clearscore/helpers.session';\nimport { getAnonymousId } from '@clearscore/helpers.segment';\nimport { actions as sessionActions } from '@clearscore/redux.session';\nimport logout from '@clearscore/lib.webapp-core.logout';\n\nimport clientDirectory from '../client-directory';\nimport getInterpolatedUrl from './get-interpolated-url';\n\nconst TIMEOUT_STATUS_CODES = [401, 403];\nlet isRefreshing = false;\nlet requestQueue = [];\n\nconst parseJwt = (token) =>\n JSON.parse(\n decodeURIComponent(\n window\n .atob(token.split('.')[1].replace(/-/g, '+').replace(/_/g, '/'))\n .split('')\n .map((c) => `%${`00${c.charCodeAt(0).toString(16)}`.slice(-2)}`)\n .join(''),\n ),\n );\n\n/**\n * Get the extra payload to add to requests containing the\n * user's UTM data (if any, and not sent already), and\n * mark cookie as \"sent\" if found so we don't send again\n */\nconst getMarketingIntentPayload = () => {\n const utmParams = getPublisherCookieUTM();\n\n if (Object.entries(utmParams).length > 0 && !publisherCookieIsSentToBackend(utmParams)) {\n markPublisherCookieAsSentToBackend(utmParams);\n\n return {\n utm_parameters: utmParams,\n };\n }\n\n return {};\n};\n\nexport const clearRequestState = () => {\n requestQueue = [];\n isRefreshing = false;\n};\n\nconst getAuthToken = async (isLogout, store, requestMeta) => {\n try {\n const { authToken, refreshToken } = getStructuredData();\n const baseURL = getInterpolatedUrl(clientDirectory.international, store.getState(), requestMeta);\n\n return await axios.post(`${baseURL}/login-service/v3/token`, {\n grant_type: 'refresh_token',\n refresh_token: refreshToken,\n client_type: 'internal',\n client_id: getEnv('OAUTH_CLIENT_ID'),\n device_id: parseJwt(authToken)['device-id'] || fingerprint.hash,\n session_id: getAnonymousId(),\n ...getMarketingIntentPayload(),\n });\n } catch (error) {\n clearRequestState();\n store.dispatch(sessionActions.logout());\n return Promise.reject(error);\n }\n};\n\nconst addToRequestQueue = (cb) => {\n requestQueue.push(cb);\n};\n\nconst onRefreshed = (token) => {\n requestQueue.map((cb) => cb(token));\n clearRequestState();\n};\n\nexport default async (error, store, client, requestMeta, isLogout) => {\n if (error.response?.status === 503) {\n store.dispatch({ type: 'CS/MAINTENANCE_MODE_ENABLED' });\n return Promise.reject(error);\n }\n if (TIMEOUT_STATUS_CODES.includes(error.response?.status)) {\n const originalRequest = error.config;\n\n if (originalRequest._retry) {\n if (!isLogout) await logout(store.getState(), store, requestMeta);\n clearRequestState();\n return Promise.reject(error);\n }\n\n originalRequest._retry = true;\n\n const retryRequest = new Promise((resolve) =>\n addToRequestQueue((token) => {\n originalRequest.headers.Authorization = `Bearer ${token}`;\n resolve(client(originalRequest));\n }),\n );\n\n if (!isRefreshing) {\n isRefreshing = true;\n try {\n const { data: authData } = await getAuthToken(isLogout, store, requestMeta);\n isRefreshing = false;\n updateSessionCookie({\n access_token: authData.access_token,\n refresh_token: authData.refresh_token,\n });\n store.dispatch(\n sessionActions.setNativeSession({\n access_token: authData.access_token,\n refresh_token: authData.refresh_token,\n refreshToken: authData.refresh_token,\n }),\n );\n onRefreshed(authData.access_token);\n } catch (e) {\n return Promise.reject(error);\n }\n }\n return retryRequest;\n }\n\n return Promise.reject(error);\n};\n","import axios from 'axios';\nimport canUseDom from '@clearscore/helpers.can-use-dom';\nimport { getEntry, setEntry } from '@clearscore/helpers.cache';\n\nimport clientDirectory from './client-directory';\nimport handleErroneousResponseInterceptor from './lib/handle-erroneous-response-interceptor';\nimport getInterpolatedUrl from './lib/get-interpolated-url';\n\nconst CACHE_KEY = 'http_clients';\n\nconst buildClients = (store, requestMeta) =>\n Object.keys(clientDirectory).reduce((prev, clientName) => {\n const client = axios.create(clientDirectory[clientName]);\n client.interceptors.response.use(\n (response) => response,\n async (error) => handleErroneousResponseInterceptor(error, store, client, requestMeta),\n );\n return { ...prev, [clientName]: client };\n }, {});\n\nconst UNKNOWN_CLIENT_ERROR = (client) =>\n `ERROR [add-client-instance]: Unknown client '${client}'.\n Please check allowed clients in @clearscore/lib.webapp-core.add-client-instance`;\n\nexport default (clientKey, store, requestMeta) => {\n const state = store.getState();\n if (canUseDom() && !getEntry(CACHE_KEY)) {\n setEntry(CACHE_KEY, buildClients(store, requestMeta));\n }\n const client = clientDirectory[clientKey];\n const clientConfiguration = getEntry(CACHE_KEY)?.[clientKey];\n if (!client || !clientConfiguration) throw Error(UNKNOWN_CLIENT_ERROR(clientKey));\n\n clientConfiguration.defaults.baseURL = getInterpolatedUrl(client, state, requestMeta);\n return clientConfiguration;\n};\n","import canUseDom from '@clearscore/helpers.can-use-dom';\n\nconst CACHE_NAME = '__cs__';\nconst MONITORING_NAME = 'monitoring';\n/**\n * helper to check if monitoring is available\n */\nfunction hasMonitoring() {\n return canUseDom && window[CACHE_NAME] && window[CACHE_NAME][MONITORING_NAME];\n}\n\nfunction pageview(location) {\n if (hasMonitoring()) window[CACHE_NAME][MONITORING_NAME].pageview(location);\n}\n\nfunction identity(uuid) {\n if (hasMonitoring()) window[CACHE_NAME][MONITORING_NAME].identity(uuid);\n}\n\nfunction tag(name, value) {\n if (hasMonitoring()) window[CACHE_NAME][MONITORING_NAME].tag(name, value);\n}\n\nfunction property(name, value) {\n if (hasMonitoring()) window[CACHE_NAME][MONITORING_NAME].property(name, value);\n}\n\nfunction addBreadcrumb(data) {\n if (hasMonitoring()) window[CACHE_NAME][MONITORING_NAME].addBreadcrumb(data);\n}\n\nfunction error(err) {\n if (hasMonitoring()) window[CACHE_NAME][MONITORING_NAME].error(err);\n}\n\nfunction log(msg) {\n if (hasMonitoring()) window[CACHE_NAME][MONITORING_NAME].log(msg);\n}\n\nfunction withScope(func) {\n if (hasMonitoring()) window[CACHE_NAME][MONITORING_NAME].withScope(func);\n}\n\nexport default {\n hasMonitoring,\n identity,\n tag,\n property,\n addBreadcrumb,\n error,\n log,\n withScope,\n pageview,\n};\n","import getDevice from '@clearscore/helpers.device';\nimport getEnv from '@clearscore/helpers.envs';\nimport { getSessionToken } from '@clearscore/helpers.session';\nimport monitoring from '@clearscore/helpers.monitoring';\n\nconst UNKNOWN_CLIENT_ERROR = (client) =>\n `ERROR [add-auth-headers]: Unknown client '${client}'.\n Please check allowed clients in @clearscore/lib.webapp-core.add-client-instance`;\n\n/**\n * add device header to api calls\n * @param store\n * @return {{\"X-CS-Device\"}}\n * @private\n */\nfunction addDeviceHeader() {\n return {\n 'X-CS-Device': getDevice(),\n };\n}\n\n/**\n * Get auth and device\n * @param {object} store redux store\n * @returns {object} headers based on session and device\n */\nfunction getFluxHeaders() {\n const sessionToken = getSessionToken();\n return {\n ...(sessionToken && { Authorization: `Bearer ${sessionToken}` }), // Must be conditional to avoid breaking nova\n ...addDeviceHeader(),\n };\n}\n\n/**\n * Get auth headers required for Banking API request (needs auth)\n * @param {object} store redux store\n * @returns {object} auth headers\n */\nfunction getBankingAuth() {\n return {\n Authorization: `Bearer ${getSessionToken()}`,\n };\n}\n\n/**\n * Get auth headers required for Caesium API requests using bearer token\n * @param {object} store redux store\n * @returns {object} auth headers\n */\nfunction getCaesiumBearerAuth() {\n const deviceHeader = addDeviceHeader();\n if (!deviceHeader['X-CS-Device']) monitoring.log('No device attached in the header');\n return {\n Authorization: `Bearer ${getSessionToken()}`,\n ...addDeviceHeader(),\n };\n}\n\nfunction getRenderEngineApiKey() {\n return {\n 'x-api-key': getEnv('RENDER_ENGINE_API_KEY'),\n };\n}\n\n/**\n * Get auth headers required for Caesium API request\n * @param {string} client api client to match auth headers for\n * @param {object} store redux store\n * @returns {object} auth headers\n */\nfunction getAuth(client) {\n switch (client) {\n case 'banking':\n case 'bankingTl':\n return getBankingAuth();\n case 'gbService':\n case 'international':\n case 'internationalBlob':\n case 'internationalText':\n return getCaesiumBearerAuth();\n case 'flux':\n return getFluxHeaders();\n case 'staticDescriptors':\n case 'media':\n case 'connectUpload':\n case 'uploadS3Policy':\n case 'connect':\n case 'products':\n return {};\n case 'renderEngine':\n return getRenderEngineApiKey();\n default:\n throw Error(UNKNOWN_CLIENT_ERROR(client));\n }\n}\n\nexport default getAuth;\n","import hasClientData from '@clearscore/helpers.has-client-data';\n\nimport clients from './clients';\nimport clientDirectory from './client-directory';\nimport handleErroneousResponseInterceptor from './lib/handle-erroneous-response-interceptor';\nimport getAuth from './lib/auth';\n\n/**\n * Add client instance to payload meta object\n * @param {object} store redux store\n * @param {object} action redux action\n * @returns {boolean} if action structure is correct\n */\nfunction addClient(store, action) {\n const {\n payload: {\n request: { client, meta: requestMeta },\n },\n } = action;\n\n const meta = {\n ...action.payload.meta,\n client: clients(client, store, requestMeta),\n };\n const headers = {\n ...action.payload.request.headers,\n ...getAuth(client, store),\n };\n\n return {\n ...action,\n payload: {\n ...action.payload,\n meta,\n request: {\n ...action.payload.request,\n headers,\n },\n },\n };\n}\n\n/**\n * If the action payload has a client object, add the correct client instance.\n * If no client matches, fallback to the default client\n * @param {object} store redux store\n * @param {object} action redux action\n * @returns {object} action redux action\n */\n\nfunction addClientInstance(store, action) {\n return hasClientData(action) ? addClient(store, action) : action;\n}\n\nexport const allClients = clients;\nexport { getAuth, clientDirectory, handleErroneousResponseInterceptor };\nexport default addClientInstance;\n","import { GB } from '@clearscore/config.i18n';\nimport monitoring from '@clearscore/helpers.monitoring';\n\nconst segmentAnonymousId = () => window.analytics?.user?.().anonymousId?.();\n\n/** To align with native and internal marketing team terminology */\nconst convertMarket = (market) => (market === GB ? 'uk' : market);\n\nconst branch = {\n handleError(err) {\n if (!err) return;\n\n if (monitoring.hasMonitoring()) {\n // Default error messages are provided as strings from branch SDK\n const errObject = typeof err === 'string' ? new Error(`[helpers.branch] ${err}`) : err;\n\n monitoring.error(errObject);\n }\n },\n\n ensureBranch() {\n if (!window.branch?.logEvent) {\n this.handleError('Tried to log event to branch without branch SDK installed');\n return false;\n }\n\n return true;\n },\n\n defaultProperties() {\n return {\n $segment_anonymous_id: segmentAnonymousId(),\n };\n },\n\n logEvent(name, { properties = {}, market = 'global' } = {}) {\n if (!this.ensureBranch()) return;\n\n const fullProperties = { ...properties, ...this.defaultProperties() };\n\n try {\n window.branch.logEvent(\n // Event name - eg. \"LOGIN\"\n name,\n // \"Event and custom data\" - segment anon ID + per-event properties (if any)\n fullProperties,\n // \"Content items\" - currently not used\n [],\n // \"Customer event alias\" - should be set to \"cs_site\" value\n convertMarket(market),\n // Error handler\n (err) => {\n this.handleError(err);\n },\n );\n } catch (err) {\n this.handleError(err.message);\n }\n },\n\n setIdentity(userId) {\n if (!this.ensureBranch()) return;\n\n try {\n window.branch.setIdentity(userId, (err) => {\n this.handleError(err);\n });\n } catch (err) {\n this.handleError(err.message);\n }\n },\n\n logout() {\n if (!this.ensureBranch()) return;\n\n try {\n window.branch.logout((err) => {\n this.handleError(err);\n });\n } catch (err) {\n this.handleError(err.message);\n }\n },\n\n addListener(event, listener) {\n if (!this.ensureBranch()) return;\n\n try {\n window.branch.addListener(event, listener);\n } catch (err) {\n this.handleError(err.message);\n }\n },\n\n removeListener(listener) {\n if (!this.ensureBranch()) return;\n\n try {\n window.branch.removeListener(listener);\n } catch (err) {\n this.handleError(err.message);\n }\n },\n};\n\nexport default branch;\n","const KEY_LOGOUT_MESSAGE = 'CS_LOGOUT_MESSAGE';\n\nexport const setLogoutMessage = (message) => window.localStorage?.setItem(KEY_LOGOUT_MESSAGE, message);\n\nexport const clearLogoutMessage = () => window.localStorage?.removeItem(KEY_LOGOUT_MESSAGE);\n\nexport const getLogoutMessage = ({ clear = false } = {}) => {\n const message = window.localStorage?.getItem(KEY_LOGOUT_MESSAGE);\n\n if (clear) clearLogoutMessage();\n\n return message;\n};\n","const KEY_LOGOUT_THEME = 'CS_LOGOUT_THEME';\n\nexport const setLogoutTheme = (theme) => window.localStorage?.setItem(KEY_LOGOUT_THEME, theme);\n\nexport const clearLogoutTheme = () => window.localStorage?.removeItem(KEY_LOGOUT_THEME);\n\nexport const getLogoutTheme = ({ clear = false } = {}) => {\n const theme = window.localStorage?.getItem(KEY_LOGOUT_THEME);\n\n if (clear) clearLogoutTheme();\n\n return theme;\n};\n","import type { QueryClient } from 'react-query';\nimport getEnv, { setEnvs } from '@clearscore/helpers.envs';\n\nexport const setQueryClient = (queryClient: QueryClient): void => setEnvs({ queryClient });\nexport const getQueryClient = (): QueryClient => getEnv('queryClient');\n","import axios from 'axios';\nimport { actions as sessionActions } from '@clearscore/redux.session';\nimport {\n clientDirectory,\n getAuth,\n handleErroneousResponseInterceptor,\n} from '@clearscore/lib.webapp-core.add-client-instance';\nimport interpolateWithMarket from '@clearscore/helpers.interpolate-with-market';\nimport monitoring from '@clearscore/helpers.monitoring';\nimport branch from '@clearscore/helpers.branch';\nimport { getQueryClient } from '@clearscore-group/lib.helpers.query-client';\n\nconst BEARER_FORMAT = new RegExp(/((Bearer)\\s[\\w-]*\\.[\\w-]*\\.[\\w-]*$)/);\n\nconst getInterpolatedUrl = (baseURL, state, requestMeta) => {\n const isFunction = (config) => typeof config === 'function';\n\n const url = isFunction(baseURL) ? baseURL(state) : baseURL;\n\n return baseURL\n ? interpolateWithMarket({\n state,\n url,\n market: requestMeta ? requestMeta.market : null,\n })\n : null;\n};\n\nconst branchLogout = () => {\n try {\n branch.logout();\n } catch (e) {\n monitoring.log(`Error logging out from branch ${e.message}`);\n }\n};\n\nconst clearUserSession = async (store, instance, headers) => {\n branchLogout();\n if (BEARER_FORMAT.test(headers.Authorization)) {\n try {\n await instance.post('/login-service/v3/logout', {}, { headers });\n } catch (e) {\n monitoring.log('Error when trying to logout via the login-service');\n }\n }\n const queryClient = getQueryClient();\n if (queryClient) {\n queryClient.clear();\n }\n\n if (store) return store.dispatch(sessionActions.logout());\n return sessionActions.logout();\n};\n\nexport default async (state, store, requestMeta, isDeleteAccount = false) => {\n if (isDeleteAccount) {\n branchLogout();\n if (store) return store.dispatch(sessionActions.logout());\n return sessionActions.logout();\n }\n const headers = getAuth('international');\n const config = {\n ...clientDirectory.international,\n baseURL: getInterpolatedUrl(clientDirectory.international.baseURL, state, requestMeta),\n };\n const instance = axios.create(config);\n instance.interceptors.response.use(\n (response) => response,\n async (error) => handleErroneousResponseInterceptor(error, store, instance, requestMeta, true),\n );\n\n return clearUserSession(store, instance, headers);\n};\n\nexport * from './message';\nexport * from './theme';\n","export const ALERTS_SHOW_ALERT = 'CS/ALERTS_SHOW_ALERT';\nexport const ALERTS_HIDE_ALERT = 'CS/ALERTS_HIDE_ALERT';\nexport const ALERTS_PARTIAL_HIDE_ALERT = 'CS/ALERTS_PARTIAL_HIDE_ALERT';\n","import alertsDomain from './alerts.domain';\n/* eslint-disable import/prefer-default-export */\nexport const domain = alertsDomain;\n","import { LOCATION_CHANGE } from 'connected-react-router';\n\nimport { ALERTS_SHOW_ALERT, ALERTS_HIDE_ALERT, ALERTS_PARTIAL_HIDE_ALERT } from '../alerts.types';\n\nexport const initialState = {\n isAlertOpen: false,\n isDismissible: true,\n isNewTab: false,\n};\n\nexport default (state = initialState, action = {}) => {\n const { type, payload } = action;\n const { isDismissible, isNewTab } = state;\n\n switch (type) {\n case ALERTS_SHOW_ALERT:\n return {\n isDismissible,\n isNewTab,\n ...payload,\n isAlertOpen: true,\n };\n\n case ALERTS_PARTIAL_HIDE_ALERT: // useful for delays/transitions\n return {\n ...state,\n ...initialState,\n };\n\n case ALERTS_HIDE_ALERT:\n return initialState;\n\n case LOCATION_CHANGE:\n if (!state.sticky) {\n return initialState;\n }\n return state;\n default:\n return state;\n }\n};\n","import * as actionsImport from './actions/index';\nimport * as typesImport from './alerts.types';\nimport * as reducersImport from './reducers/index';\nimport * as selectorsImport from './selectors/index';\nimport * as constantsImport from './constants';\n\nexport const actions = actionsImport;\nexport const types = typesImport;\nexport const reducers = reducersImport;\nexport const selectors = selectorsImport;\nexport const constants = constantsImport;\n","import createAction from '@clearscore/helpers.create-action';\n\nimport { ALERTS_SHOW_ALERT, ALERTS_HIDE_ALERT, ALERTS_PARTIAL_HIDE_ALERT } from '../alerts.types';\n\nexport const showAlert = (payload) => createAction(ALERTS_SHOW_ALERT, payload);\n\nexport const delayedDismissAlert = () => createAction(ALERTS_PARTIAL_HIDE_ALERT);\n\nexport const dismissAlert = () => createAction(ALERTS_HIDE_ALERT);\n","export const WARNING = 'warning';\nexport const ERROR = 'error';\nexport const SUCCESS = 'success';\nexport const ALERT_INFO = 'alert_info';\n","import { connect } from 'react-redux';\nimport { withRouter as _withRouter } from 'react-router-dom';\n\nconst withRouter = (useRouter) => (Component) => useRouter ? _withRouter(Component) : Component;\n\nexport default (mapState, mapDispatch, { mergeProps, useRouter, options } = {}) =>\n (Component) =>\n withRouter(useRouter)(connect(mapState, mapDispatch, mergeProps, options)(Component));\n","import * as sessionTypes from '@clearscore/constants.session-action-types';\n\n/** Type for the bridge */\nconst ROUTER_TYPE = ['@@router'];\nconst DEFAULT_TYPES = [sessionTypes.LOGIN_OAUTH_REFRESH_SUCCESS];\n\n/**\n * Conditional to check if action should be pushed\n * Currently pushing all router and session stuff\n * @todo: if there is anymore we should come up with a better pattern\n * @param {object} action redux action\n * @param {Array} appBridgeTypes array of type to bridge\n * @returns {boolean} if action structure is correct\n */\nfunction _shouldBridge(action, appBridgeTypes) {\n if (!action) throw Error('action-bridge-types: undefined action');\n if (!action.type) throw Error('action-bridge-types: undefined action.type');\n const types = [...DEFAULT_TYPES, ...appBridgeTypes];\n return action.type.includes(ROUTER_TYPE) || types.includes(action.type);\n}\n\n/**\n * Propagate all actions to core store if available\n * @returns {Function} middleware\n */\nconst _actionBridge = (store, next, action, coreDispatch) => {\n if (coreDispatch) coreDispatch(action);\n next(action);\n};\n\n/**\n * If action has correct signature, perform API request.\n * Dispatch success or error actions\n * @param {object} coreDispatch redux store\n * @param {array} appBridgeTypes array of type to bridge\n * @returns {Function} middleware\n */\nconst actionBridgeMiddleware =\n (coreDispatch, appBridgeTypes = []) =>\n (store) =>\n (next) =>\n (action) =>\n _shouldBridge(action, appBridgeTypes) ? _actionBridge(store, next, action, coreDispatch) : next(action);\n\nexport default actionBridgeMiddleware;\n","import { filter } from 'rxjs/operators';\n\nvar keyHasType = function keyHasType(type, key) {\n return type === key || typeof key === 'function' && type === key.toString();\n};\n\nexport var ofType = function ofType() {\n for (var _len = arguments.length, keys = Array(_len), _key = 0; _key < _len; _key++) {\n keys[_key] = arguments[_key];\n }\n\n return function (source) {\n return source.pipe(filter(function (_ref) {\n var type = _ref.type;\n\n var len = keys.length;\n if (len === 1) {\n return keyHasType(type, keys[0]);\n } else {\n for (var i = 0; i < len; i++) {\n if (keyHasType(type, keys[i])) {\n return true;\n }\n }\n }\n return false;\n }));\n };\n};","var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nimport { Observable, of as _of, from as _from } from 'rxjs';\nimport { ofType as _ofType } from './operators';\n\nexport var ActionsObservable = function (_Observable) {\n _inherits(ActionsObservable, _Observable);\n\n _createClass(ActionsObservable, null, [{\n key: 'of',\n value: function of() {\n return new this(_of.apply(undefined, arguments));\n }\n }, {\n key: 'from',\n value: function from(actions, scheduler) {\n return new this(_from(actions, scheduler));\n }\n }]);\n\n function ActionsObservable(actionsSubject) {\n _classCallCheck(this, ActionsObservable);\n\n var _this = _possibleConstructorReturn(this, (ActionsObservable.__proto__ || Object.getPrototypeOf(ActionsObservable)).call(this));\n\n _this.source = actionsSubject;\n return _this;\n }\n\n _createClass(ActionsObservable, [{\n key: 'lift',\n value: function lift(operator) {\n var observable = new ActionsObservable(this);\n observable.operator = operator;\n return observable;\n }\n }, {\n key: 'ofType',\n value: function ofType() {\n return _ofType.apply(undefined, arguments)(this);\n }\n }]);\n\n return ActionsObservable;\n}(Observable);","function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nimport { Observable, Subject } from 'rxjs';\n\nexport var StateObservable = function (_Observable) {\n _inherits(StateObservable, _Observable);\n\n function StateObservable(stateSubject, initialState) {\n _classCallCheck(this, StateObservable);\n\n var _this = _possibleConstructorReturn(this, (StateObservable.__proto__ || Object.getPrototypeOf(StateObservable)).call(this, function (subscriber) {\n var subscription = _this.__notifier.subscribe(subscriber);\n if (subscription && !subscription.closed) {\n subscriber.next(_this.value);\n }\n return subscription;\n }));\n\n _this.value = initialState;\n _this.__notifier = new Subject();\n _this.__subscription = stateSubject.subscribe(function (value) {\n // We only want to update state$ if it has actually changed since\n // redux requires reducers use immutability patterns.\n // This is basically what distinctUntilChanged() does but it's so simple\n // we don't need to pull that code in\n if (value !== _this.value) {\n _this.value = value;\n _this.__notifier.next(value);\n }\n });\n return _this;\n }\n\n return StateObservable;\n}(Observable);","function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nimport { merge } from 'rxjs';\n\n/**\n Merges all epics into a single one.\n */\nexport var combineEpics = function combineEpics() {\n for (var _len = arguments.length, epics = Array(_len), _key = 0; _key < _len; _key++) {\n epics[_key] = arguments[_key];\n }\n\n var merger = function merger() {\n for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n return merge.apply(undefined, _toConsumableArray(epics.map(function (epic) {\n var output$ = epic.apply(undefined, args);\n if (!output$) {\n throw new TypeError('combineEpics: one of the provided Epics \"' + (epic.name || '') + '\" does not return a stream. Double check you\\'re not missing a return statement!');\n }\n return output$;\n })));\n };\n\n // Technically the `name` property on Function's are supposed to be read-only.\n // While some JS runtimes allow it anyway (so this is useful in debugging)\n // some actually throw an exception when you attempt to do so.\n try {\n Object.defineProperty(merger, 'name', {\n value: 'combineEpics(' + epics.map(function (epic) {\n return epic.name || '';\n }).join(', ') + ')'\n });\n } catch (e) {}\n\n return merger;\n};","import type { Dispatch, Middleware, Reducer, Store } from 'redux';\nimport { combineReducers, createStore } from 'redux';\nimport { connectRouter, routerMiddleware, ConnectedRouter } from 'connected-react-router';\nimport createActionBridgeMiddleware from '@clearscore/redux.action-bridge-middleware';\nimport type { Epic } from 'redux-observable';\nimport { combineEpics, createEpicMiddleware } from 'redux-observable';\nimport type { MemoryHistory, History } from 'history';\nimport { createMemoryHistory, createBrowserHistory } from 'history';\n// import { createBrowserHistory } from 'history'; // <-- this does not work in verticals with v4.9.0\n// import createBrowserHistory from 'history/createBrowserHistory';\nimport * as sessionTypes from '@clearscore/constants.session-action-types';\nimport { reducers as marketReducers } from '@clearscore/redux.market';\nimport canUseDom from '@clearscore/helpers.can-use-dom';\nimport { Provider as ReduxProvider } from 'react-redux';\n\n// TODO: with our current setup they get included anyways\n// only that these tools never get initialized. Once modules are ready\n// we can conditionally handle this in a better way, like `import()` [TC]\nimport composeWithTools from './assets/development';\n\nexport const Provider = ReduxProvider;\nexport const Router = ConnectedRouter;\nexport const browserHistory = (basename = ''): History | MemoryHistory =>\n canUseDom() ? createBrowserHistory({ basename }) : createMemoryHistory({ initialEntries: [basename || '/'] });\n\ntype NestedReducer = Record;\n\nconst isCombined = (reducers?: S | Record): reducers is S => typeof reducers === 'function';\n\nexport const combineNestedReducers = (reducers: NestedReducer): Reducer => {\n const nestedReducers = Object.keys(reducers).reduce(\n (prev, reducer) => ({\n ...prev,\n [reducer]: typeof reducers[reducer] === 'function' ? reducers[reducer] : combineReducers(reducers[reducer]),\n }),\n {},\n );\n return combineReducers(nestedReducers);\n};\n\ninterface ComposeMiddleWaresOptions {\n pageMiddleWare: Middleware[];\n actionBridgeMiddleWare?: Middleware;\n epicMiddleWare?: Middleware;\n routerMiddleWare?: Middleware;\n}\n\nexport const composeMiddleWares = ({\n pageMiddleWare = [],\n actionBridgeMiddleWare,\n epicMiddleWare,\n routerMiddleWare,\n}: ComposeMiddleWaresOptions): Middleware[] =>\n [actionBridgeMiddleWare, epicMiddleWare, routerMiddleWare, ...pageMiddleWare].filter(\n (maybeMiddleware: Middleware | undefined): maybeMiddleware is Middleware => Boolean(maybeMiddleware),\n );\n\n// Can't use `?` as optional argument, since `reducers` is not in last position so it has\n// to be explicitly typed as `undefined`\nconst createRootReducer = (reducers: Reducer | NestedReducer | undefined, baseReducers: NestedReducer): Reducer => {\n const combinedReducers = isCombined(reducers)\n ? reducers\n : combineNestedReducers({ ...baseReducers, ...reducers });\n\n return (state, action) => {\n if ([sessionTypes.LOGOUT_SUBMIT, sessionTypes.TIMEOUT_SUCCESS].includes(action.type)) {\n return combinedReducers(undefined, action);\n }\n return combinedReducers(state, action);\n };\n};\n\ninterface ConfigStoreOptions {\n initialState?: Record;\n reducers?: Reducer | NestedReducer;\n name?: string;\n appBridgeTypes?: string[];\n coreDispatch?: Dispatch;\n pageMiddleWare?: Middleware[];\n pageEpics?: Record;\n history?: History;\n}\n\n/**\n * Returns store\n * @param initialState\n * @param reducers\n * @param name\n * @param appBridgeTypes\n * @param coreDispatch\n * @param pageMiddleWare\n * @param pageEpics\n * @param history\n * @return Object\n * */\nexport default function configureStore({\n initialState = {},\n reducers,\n name,\n appBridgeTypes = [],\n coreDispatch,\n pageMiddleWare = [],\n pageEpics,\n history = browserHistory(),\n}: ConfigStoreOptions = {}): Store {\n const epicMiddleWare = pageEpics && createEpicMiddleware();\n const actionBridgeMiddleWare = coreDispatch && createActionBridgeMiddleware(coreDispatch, appBridgeTypes);\n\n const middleWares = composeMiddleWares({\n pageMiddleWare,\n actionBridgeMiddleWare,\n epicMiddleWare,\n routerMiddleWare: routerMiddleware(history),\n });\n\n const rootReducer = createRootReducer(reducers, {\n router: connectRouter(history),\n market: marketReducers.domain,\n });\n\n const enhancer = composeWithTools({ name, middleWares });\n const store = createStore(rootReducer, initialState, enhancer);\n\n if (pageEpics) {\n epicMiddleWare?.run(isCombined(pageEpics) ? pageEpics : combineEpics(...Object.values(pageEpics)));\n }\n\n return store;\n}\n","import { Subject, from, queueScheduler } from 'rxjs';\nimport { map, mergeMap, observeOn, subscribeOn } from 'rxjs/operators';\nimport { ActionsObservable } from './ActionsObservable';\nimport { StateObservable } from './StateObservable';\nimport { warn } from './utils/console';\n\nexport function createEpicMiddleware() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n // This isn't great. RxJS doesn't publicly export the constructor for\n // QueueScheduler nor QueueAction, so we reach in. We need to do this because\n // we don't want our internal queuing mechanism to be on the same queue as any\n // other RxJS code outside of redux-observable internals.\n var QueueScheduler = queueScheduler.constructor;\n var uniqueQueueScheduler = new QueueScheduler(queueScheduler.SchedulerAction);\n\n if (process.env.NODE_ENV !== 'production' && typeof options === 'function') {\n throw new TypeError('Providing your root Epic to `createEpicMiddleware(rootEpic)` is no longer supported, instead use `epicMiddleware.run(rootEpic)`\\n\\nLearn more: https://redux-observable.js.org/MIGRATION.html#setting-up-the-middleware');\n }\n\n var epic$ = new Subject();\n var store = void 0;\n\n var epicMiddleware = function epicMiddleware(_store) {\n if (process.env.NODE_ENV !== 'production' && store) {\n // https://github.com/redux-observable/redux-observable/issues/389\n warn('this middleware is already associated with a store. createEpicMiddleware should be called for every store.\\n\\nLearn more: https://goo.gl/2GQ7Da');\n }\n store = _store;\n var actionSubject$ = new Subject().pipe(observeOn(uniqueQueueScheduler));\n var stateSubject$ = new Subject().pipe(observeOn(uniqueQueueScheduler));\n var action$ = new ActionsObservable(actionSubject$);\n var state$ = new StateObservable(stateSubject$, store.getState());\n\n var result$ = epic$.pipe(map(function (epic) {\n var output$ = 'dependencies' in options ? epic(action$, state$, options.dependencies) : epic(action$, state$);\n\n if (!output$) {\n throw new TypeError('Your root Epic \"' + (epic.name || '') + '\" does not return a stream. Double check you\\'re not missing a return statement!');\n }\n\n return output$;\n }), mergeMap(function (output$) {\n return from(output$).pipe(subscribeOn(uniqueQueueScheduler), observeOn(uniqueQueueScheduler));\n }));\n\n result$.subscribe(store.dispatch);\n\n return function (next) {\n return function (action) {\n // Downstream middleware gets the action first,\n // which includes their reducers, so state is\n // updated before epics receive the action\n var result = next(action);\n\n // It's important to update the state$ before we emit\n // the action because otherwise it would be stale\n stateSubject$.next(store.getState());\n actionSubject$.next(action);\n\n return result;\n };\n };\n };\n\n epicMiddleware.run = function (rootEpic) {\n if (process.env.NODE_ENV !== 'production' && !store) {\n warn('epicMiddleware.run(rootEpic) called before the middleware has been setup by redux. Provide the epicMiddleware instance to createStore() first.');\n }\n epic$.next(rootEpic);\n };\n\n return epicMiddleware;\n}","/* eslint-disable prefer-spread */\n/* eslint-disable prefer-template */\n// must be ie11 compatible\nimport * as logger from 'redux-logger';\nimport type * as Redux from 'redux';\nimport canUseDom from '@clearscore/helpers.can-use-dom';\nimport { compose, applyMiddleware } from 'redux';\n\nconst regex = /@@redux-form\\/(BLUR|FOCUS|CHANGE)/g;\n\nfunction logging(name?: string): Redux.Middleware {\n // redux-logger has issue for this https://github.com/LogRocket/redux-logger/issues/233\n // rollup and webpack seem to understand it's build in different way, so need to check,\n // which one is fine\n // @ts-expect-error ts-middleware-issue\n const createLogger: typeof logger.createLogger = logger.__moduleExports\n ? // @ts-expect-error ts-middleware-issue\n logger.__moduleExports.createLogger\n : logger.createLogger;\n return createLogger({\n collapsed: function collapsed(getState, action, logEntry) {\n return !logEntry?.error;\n },\n titleFormatter: function titleFormatter(action, time, took) {\n return '[' + name + '] ' + action.type + ' (' + took.toFixed(2) + 'ms)';\n },\n predicate: function predicate(getState, action) {\n return !action.type.match(regex);\n },\n });\n}\n\ndeclare global {\n interface Window {\n __REDUX_DEVTOOLS_EXTENSION_COMPOSE__?: typeof compose;\n }\n}\n\nconst composeWithDevTools =\n canUseDom() && window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__\n ? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__\n : // eslint-disable-next-line @typescript-eslint/explicit-function-return-type\n function () {\n if (arguments.length === 0) return undefined;\n // eslint-disable-next-line prefer-rest-params\n if (typeof arguments[0] === 'object') return compose;\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n return compose.apply(null, arguments); // eslint-disable-line prefer-rest-params, @typescript-eslint/ban-ts-comment, max-len\n };\n\nfunction composeWithTools(options: {\n middleWares: Redux.Middleware[];\n name?: string;\n}): Redux.StoreEnhancer<{ dispatch: unknown }, unknown> {\n if (process.env.DEBUG) {\n options.middleWares.unshift(logging(options.name));\n // @ts-expect-error ts-middleware-issue\n return composeWithDevTools({ name: options.name })(applyMiddleware.apply(null, options.middleWares));\n }\n return compose(applyMiddleware.apply(null, options.middleWares));\n}\n\nexport default composeWithTools;\n","/* eslint-disable react-hooks/exhaustive-deps */\nimport { useEffect, useState } from 'react';\nimport canUseDom from '@clearscore/helpers.can-use-dom';\n\nfunction getValue(mediaQueryLists, values) {\n const index = mediaQueryLists.findIndex((mql) => mql.matches);\n if (Array.isArray(values)) {\n return typeof values[index] === 'undefined' ? values[0] : values[index];\n }\n return values;\n}\n\nfunction useMedia(queries, values) {\n const isBrowser = canUseDom();\n // fall back to first query if rendering on the server as window is unavailable\n const mediaQueryLists = isBrowser ? queries.map((q) => window.matchMedia(q)) : [true];\n const [value, setValue] = useState(getValue(mediaQueryLists, values));\n\n function setState() {\n setValue(getValue(mediaQueryLists, values));\n }\n\n useEffect(() => {\n if (canUseDom()) {\n mediaQueryLists.forEach((mql) => mql.addListener(setState));\n }\n\n setState();\n return () => {\n if (canUseDom()) {\n mediaQueryLists.forEach((mql) => mql.removeListener(setState));\n }\n };\n }, [queries, values, isBrowser]);\n\n return value;\n}\n\nexport default useMedia;\n","export default (string) => {\n if (string && string.split) {\n return string\n .split(/_|-| /)\n .map((part) => part[0].toUpperCase() + part.substr(1).toLowerCase())\n .join('');\n }\n\n return string;\n};\n","const removeSubDomain = (url = '') => (url.split('.').length > 2 ? url.split('.').slice(1).join('.') : url);\nconst matchSubDomain = (url = '', subdomains = []) => subdomains.includes(url.split('//')[1]?.split('.')[0]);\n\n// apps which should keep focus when going to other apps, ie. `app` and `beta` on all envs.\nconst APPS = ['app', 'app-ci', 'app-stg', 'beta', 'beta-ci', 'beta-stg'];\n\nconst sameOrigin = (pathname) => {\n const { hostname } = window.location;\n const comingFromApp = matchSubDomain(`//${hostname}`, APPS);\n const goingToApp = matchSubDomain(pathname, APPS);\n const appToApp = (comingFromApp && goingToApp) || !comingFromApp;\n return removeSubDomain(pathname).includes(removeSubDomain(hostname)) && appToApp;\n};\n\n// always ensure www links start with // (i.e. learn articles)\n// if its a link on same domain, then remove http(s) so RR doesn't prefix with `/`\nconst normalisePath = (pathname) => {\n const url = pathname.startsWith('www.') ? `//${pathname}` : pathname;\n return sameOrigin(pathname) ? url.replace(/https?:/, '') : url;\n};\n\nexport default (href) => {\n const url = normalisePath(href);\n const hasFullUrl = /^(https?:\\/\\/|\\/\\/)/.test(url); // starts with 'http(s)?:' or '//'\n const isRelative = /^(\\.\\.?\\/|\\/(?!\\/)|\\?)/.test(url); // starts with './', '../', single '/', or '?'\n const isAppLink = hasFullUrl\n ? url.split('//')[1].split('/')[0].indexOf(':') > 0\n : url.split('/')[0].indexOf(':') > 0; // e.g. tel:1902 or mail:pete@clearscore.com\n const isSameOrigin = !isAppLink && sameOrigin(url);\n const isRelativeWithoutSlash = !hasFullUrl && !isAppLink; // i.e. href=\"results/details\"\n return url && (isSameOrigin || isRelative || isRelativeWithoutSlash);\n};\n","/* eslint-disable import/prefer-default-export */\nexport const themes = {\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n INHERIT: 'INHERIT',\n} as const;\n","import type { ReactNode, ReactElement, MouseEventHandler } from 'react';\nimport React from 'react';\nimport cx from 'classnames';\nimport { Link as RouterLink } from 'react-router-dom';\nimport toTitleCase from '@clearscore/normalize.title-case';\nimport isInternalUrl from '@clearscore/helpers.is-internal-url';\n\nimport { themes } from './constants';\nimport styles from './text-link.module.css';\n\nexport interface ToProps {\n pathname?: string;\n search?: string;\n hash?: string;\n state?: object;\n}\n\ntype PathPropsTo = ToProps | string | ((location: ToProps) => ToProps);\n\ninterface PathnameProps {\n href?: string;\n to?: PathPropsTo;\n}\n\ninterface TextLinkExports {\n themes: typeof themes;\n}\n\nexport interface TextLinkProps {\n children: ReactNode;\n theme?: typeof themes[keyof typeof themes];\n href?: string;\n title?: string;\n ariaLabel?: string;\n isNewTab?: boolean;\n isSimpleLink?: boolean;\n to?: PathPropsTo;\n onClick?: MouseEventHandler;\n}\n\ntype TextLink = (props: TextLinkProps) => ReactElement;\n\nconst removeSubDomain = (url: string | undefined = ''): string =>\n url.split('.').length > 2 ? url.split('.').slice(1).join('.') : url;\nconst getSubDomain = (url: string): string | undefined =>\n url.split('//').length > 1 ? url.split('.').shift() : undefined;\n\nconst sameOrigin = (pathname: string): boolean => {\n const { hostname } = window.location;\n return removeSubDomain(pathname).includes(removeSubDomain(hostname));\n};\n\nconst sameSubDomain = (pathname: string): boolean => {\n const { origin } = window.location;\n const linkSubdomain = getSubDomain(pathname);\n\n if (!linkSubdomain) return true;\n\n const originSubDomain = getSubDomain(origin);\n const pathnameSubDomain = getSubDomain(pathname);\n\n if (!originSubDomain || !pathnameSubDomain) return false;\n\n return originSubDomain.includes(pathnameSubDomain);\n};\n\n// always ensure www links start with // (i.e. learn articles)\n// if its a link on same domain, then remove http(s) so RR doesn't prefix with `/`\nconst normalisePath = (pathname: string): string => {\n const url = pathname.startsWith('www.') ? `//${pathname}` : pathname;\n return sameOrigin(pathname) ? url.replace(/https?:/, '') : url;\n};\n\nconst getPathname = ({ href, to }: PathnameProps): string => {\n if (typeof to === 'string') return to;\n if (typeof to === 'function') return getPathname({ to: to(window.location) });\n if (typeof to?.pathname === 'string') return to.pathname;\n if (typeof href === 'string') return href;\n return '';\n};\n\n// note: href is now deprecated please do not use\nconst TextLink: TextLink & TextLinkExports = ({\n children,\n theme = themes.LIGHT,\n href,\n title,\n isNewTab = false,\n onClick,\n isSimpleLink = false,\n to,\n ariaLabel,\n}) => {\n const link = normalisePath(getPathname({ href, to }));\n const internalLink = isInternalUrl(link);\n const newTabProps = { rel: 'noopener noreferrer', target: '_blank' };\n const reactRouterSafe = !link.startsWith('#') && sameSubDomain(link); // react-router doesn't like '#' or different sub-domains links\n const linkProps = {\n className: cx(styles.component, styles[`isTheme${toTitleCase(theme)}`], {\n [styles.isSimpleLink]: isSimpleLink,\n }),\n onClick,\n title,\n 'aria-label': ariaLabel,\n };\n\n switch (true) {\n case internalLink && reactRouterSafe:\n return (\n \n {children}\n \n );\n case !link:\n return (\n \n );\n case internalLink:\n return (\n \n {children}\n \n );\n default:\n return (\n \n {children}\n \n );\n }\n};\n\nTextLink.themes = themes;\n\nexport default TextLink;\n","import type { ReactNode, ReactElement } from 'react';\nimport React from 'react';\n\nimport styles from './text-strong.module.css';\n\nexport interface ITextStrongProps {\n children: ReactNode;\n}\n\ntype TextStrong = (props: ITextStrongProps) => ReactElement;\n\nconst TextStrong: TextStrong = ({ children }) => {children};\n\nexport default TextStrong;\n","var borderRadius = {\n \"rnb-border-radius-circle\": \"50%\",\n \"rnb-border-radius-small\": \"0.25rem\",\n \"rnb-border-radius-medium\": \"0.5rem\",\n \"rnb-border-radius-large\": \"1rem\",\n \"rnb-border-radius-big\": \"1.25rem\"\n};\nvar borderWidth = {\n \"rnb-border-width-thin\": \"1px\",\n \"rnb-border-width-thin-offset\": \"-1px\",\n \"rnb-border-width-default\": \"2px\",\n \"rnb-border-width-thick\": \"4px\"\n};\nconst black = \"#000\";\nconst blackRgb = \"0, 0, 0\";\nconst white = \"#fff\";\nconst whiteRgb = \"255, 255, 255\";\nconst midnight = \"#263648\";\nconst midnightRgb = \"38, 54, 72\";\nconst chill = \"#0f81a3\";\nconst chillRgb = \"15, 129, 163\";\nconst rose = \"#bd2f2f\";\nconst roseRgb = \"189, 47, 47\";\nconst lavender = \"#d27df3\";\nconst lavenderRgb = \"210, 125, 243\";\nconst sand = \"#f69f4d\";\nconst sandRgb = \"246, 159, 77\";\nconst dandelion = \"#e9c627\";\nconst dandelionRgb = \"233, 198, 39\";\nconst moss = \"#add230\";\nconst mossRgb = \"173, 210, 48\";\nconst sea = \"#2cdb7b\";\nconst seaRgb = \"44, 219, 123\";\nconst reef = \"#2bcfc8\";\nconst reefRgb = \"43, 207, 200\";\nconst salvia = \"#9E86E7\";\nconst salviaRgb = \"158, 134, 231\";\nconst sky = \"#49C1E3\";\nconst skyRgb = \"73, 193, 227\";\nconst core = {\n \"rnb-colour-transparent\": \"transparent\",\n \"rnb-colour-black-tint-4\": \"#f5f5f5\",\n \"rnb-colour-black-tint-4-rgb\": \"245, 245, 245\",\n \"rnb-colour-black-alpha-4\": `rgba(${blackRgb}, 0.04)`,\n \"rnb-colour-black-alpha-8\": `rgba(${blackRgb}, 0.08)`,\n \"rnb-colour-black-alpha-16\": `rgba(${blackRgb}, 0.16)`,\n \"rnb-colour-black-alpha-32\": `rgba(${blackRgb}, 0.32)`,\n \"rnb-colour-black-alpha-64\": `rgba(${blackRgb}, 0.64)`,\n \"rnb-colour-black\": black,\n \"rnb-colour-black-rgb\": blackRgb,\n \"rnb-colour-white-alpha-4\": `rgba(${whiteRgb}, 0.04)`,\n \"rnb-colour-white-alpha-8\": `rgba(${whiteRgb}, 0.08)`,\n \"rnb-colour-white-alpha-16\": `rgba(${whiteRgb}, 0.16)`,\n \"rnb-colour-white-alpha-32\": `rgba(${whiteRgb}, 0.32)`,\n \"rnb-colour-white-alpha-48\": `rgba(${whiteRgb}, 0.48)`,\n \"rnb-colour-white-alpha-64\": `rgba(${whiteRgb}, 0.64)`,\n \"rnb-colour-white-alpha-80\": `rgba(${whiteRgb}, 0.80)`,\n \"rnb-colour-white\": white,\n \"rnb-colour-white-rgb\": whiteRgb,\n \"rnb-colour-midnight-tint-4\": \"#f7f7f8\",\n \"rnb-colour-midnight-tint-4-rgb\": \"247, 247, 248\",\n \"rnb-colour-midnight-tint-8\": \"#eeeff1\",\n \"rnb-colour-midnight-tint-8-rgb\": \"238, 239, 241\",\n \"rnb-colour-midnight-tint-16\": \"#dcdfe2\",\n \"rnb-colour-midnight-tint-16-rgb\": \"220, 223, 226\",\n \"rnb-colour-midnight-tint-32\": \"#b9bec4\",\n \"rnb-colour-midnight-tint-32-rgb\": \"185, 190, 196\",\n \"rnb-colour-midnight-tint-48\": \"#979fa8\",\n \"rnb-colour-midnight-tint-48-rgb\": \"151, 159, 168\",\n \"rnb-colour-midnight-tint-64\": \"#747f8a\",\n \"rnb-colour-midnight-tint-64-rgb\": \"116, 127, 138\",\n \"rnb-colour-midnight-tint-80\": \"#515E6D\",\n \"rnb-colour-midnight-tint-80-rgb\": \"81, 94, 109\",\n \"rnb-colour-midnight-alpha-96\": `rgba(${midnightRgb}, 0.96)`,\n \"rnb-colour-midnight\": midnight,\n \"rnb-colour-midnight-rgb\": midnightRgb,\n \"rnb-colour-midnight-shade-64\": \"#18232e\",\n \"rnb-colour-midnight-shade-64-rgb\": \"24, 35, 46\",\n \"rnb-colour-midnight-shade-48\": \"#121a23\",\n \"rnb-colour-midnight-shade-48-rgb\": \"18, 26, 35\",\n \"rnb-colour-midnight-shade-32\": \"#0c1117\",\n \"rnb-colour-midnight-shade-32-rgb\": \"12, 17, 23\",\n \"rnb-colour-chill-tint-4\": \"#f6fafc\",\n \"rnb-colour-chill-tint-4-rgb\": \"246, 250, 252\",\n \"rnb-colour-chill-tint-8\": \"#ecf5f8\",\n \"rnb-colour-chill-tint-8-rgb\": \"236, 245, 248\",\n \"rnb-colour-chill-tint-16\": \"#d8ebf0\",\n \"rnb-colour-chill-tint-16-rgb\": \"216, 235, 240\",\n \"rnb-colour-chill-tint-32\": \"#b2d6e1\",\n \"rnb-colour-chill-tint-32-rgb\": \"178, 214, 225\",\n \"rnb-colour-chill-tint-64\": \"#66aec5\",\n \"rnb-colour-chill-tint-64-rgb\": \"102, 174, 197\",\n \"rnb-colour-chill\": chill,\n \"rnb-colour-chill-rgb\": chillRgb,\n \"rnb-colour-chill-shade-64\": \"#0a5269\",\n \"rnb-colour-chill-shade-64-rgb\": \"10, 82, 105\",\n \"rnb-colour-chill-shade-48\": \"#073e4e\",\n \"rnb-colour-chill-shade-48-rgb\": \"7, 62, 78\",\n \"rnb-colour-chill-shade-32\": \"#052934\",\n \"rnb-colour-chill-shade-32-rgb\": \"5, 41, 52\",\n \"rnb-colour-rose-tint-8\": \"#faefef\",\n \"rnb-colour-rose-tint-8-rgb\": \"250, 239, 239\",\n \"rnb-colour-rose-tint-16\": \"#f4dede\",\n \"rnb-colour-rose-tint-16-rgb\": \"244, 222, 222\",\n \"rnb-colour-rose-tint-32\": \"#e9bcbc\",\n \"rnb-colour-rose-tint-32-rgb\": \"233, 188, 188\",\n \"rnb-colour-rose-tint-64\": \"#d57a7a\",\n \"rnb-colour-rose-tint-64-rgb\": \"213, 122, 122\",\n \"rnb-colour-rose\": rose,\n \"rnb-colour-rose-rgb\": roseRgb,\n \"rnb-colour-rose-shade-64\": \"#791e1e\",\n \"rnb-colour-rose-shade-64-rgb\": \"121, 30, 30\",\n \"rnb-colour-rose-shade-48\": \"#5b1717\",\n \"rnb-colour-rose-shade-48-rgb\": \"91, 23, 23\",\n \"rnb-colour-rose-shade-32\": \"#3c0f0f\",\n \"rnb-colour-rose-shade-32-rgb\": \"60, 15, 15\",\n \"rnb-colour-lavender-tint-16\": \"#f8eafd\",\n \"rnb-colour-lavender-tint-16-rgb\": \"248, 234, 253\",\n \"rnb-colour-lavender-tint-32\": \"#f0d5fb\",\n \"rnb-colour-lavender-tint-32-rgb\": \"240, 213, 251\",\n \"rnb-colour-lavender-tint-64\": \"#e2acf7\",\n \"rnb-colour-lavender-tint-64-rgb\": \"226, 172, 247\",\n \"rnb-colour-lavender\": lavender,\n \"rnb-colour-lavender-rgb\": lavenderRgb,\n \"rnb-colour-lavender-shade-64\": \"#86509b\",\n \"rnb-colour-lavender-shade-64-rgb\": \"134, 80, 155\",\n \"rnb-colour-lavender-shade-48\": \"#653c75\",\n \"rnb-colour-lavender-shade-48-rgb\": \"101, 60, 117\",\n \"rnb-colour-lavender-shade-32\": \"#43284e\",\n \"rnb-colour-lavender-shade-32-rgb\": \"67, 40, 78\",\n \"rnb-colour-sand-tint-8\": \"#fff8f1\",\n \"rnb-colour-sand-tint-8-rgb\": \"255, 248, 241\",\n \"rnb-colour-sand-tint-16\": \"#fdefe2\",\n \"rnb-colour-sand-tint-16-rgb\": \"253, 239, 226\",\n \"rnb-colour-sand-tint-32\": \"#fce0c6\",\n \"rnb-colour-sand-tint-32-rgb\": \"252, 224, 198\",\n \"rnb-colour-sand-tint-64\": \"#f9c28d\",\n \"rnb-colour-sand-tint-64-rgb\": \"249, 194, 141\",\n \"rnb-colour-sand\": sand,\n \"rnb-colour-sand-rgb\": sandRgb,\n \"rnb-colour-sand-shade-64\": \"#9d6631\",\n \"rnb-colour-sand-shade-64-rgb\": \"157, 102, 49\",\n \"rnb-colour-sand-shade-48\": \"#764c25\",\n \"rnb-colour-sand-shade-48-rgb\": \"118, 76, 37\",\n \"rnb-colour-sand-shade-32\": \"#4f3319\",\n \"rnb-colour-sand-shade-32-rgb\": \"79, 51, 25\",\n \"rnb-colour-dandelion-tint-16\": \"#fbf6dc\",\n \"rnb-colour-dandelion-tint-16-rgb\": \"251, 246, 220\",\n \"rnb-colour-dandelion-tint-32\": \"#f8ecb9\",\n \"rnb-colour-dandelion-tint-32-rgb\": \"248, 236, 185\",\n \"rnb-colour-dandelion-tint-64\": \"#f1db75\",\n \"rnb-colour-dandelion-tint-64-rgb\": \"41, 219, 117\",\n \"rnb-colour-dandelion\": dandelion,\n \"rnb-colour-dandelion-rgb\": dandelionRgb,\n \"rnb-colour-dandelion-shade-64\": \"#957f19\",\n \"rnb-colour-dandelion-shade-64-rgb\": \"149, 127, 25\",\n \"rnb-colour-dandelion-shade-48\": \"#705f13\",\n \"rnb-colour-dandelion-shade-48-rgb\": \"112, 95, 19\",\n \"rnb-colour-dandelion-shade-32\": \"#4b3f0c\",\n \"rnb-colour-dandelion-shade-32-rgb\": \"75, 63, 12\",\n \"rnb-colour-moss-tint-16\": \"#f2f8de\",\n \"rnb-colour-moss-tint-16-rgb\": \"242, 248, 222\",\n \"rnb-colour-moss-tint-32\": \"#e4f0bc\",\n \"rnb-colour-moss-tint-32-rgb\": \"228, 240, 188\",\n \"rnb-colour-moss-tint-64\": \"#cbe27b\",\n \"rnb-colour-moss-tint-64-rgb\": \"203, 226, 123\",\n \"rnb-colour-moss\": moss,\n \"rnb-colour-moss-rgb\": mossRgb,\n \"rnb-colour-moss-shade-64\": \"#6f861f\",\n \"rnb-colour-moss-shade-64-rgb\": \"111, 134, 3\",\n \"rnb-colour-moss-shade-48\": \"#536517\",\n \"rnb-colour-moss-shade-48-rgb\": \"83, 101, 23\",\n \"rnb-colour-moss-shade-32\": \"#37430f\",\n \"rnb-colour-moss-shade-32-rgb\": \"55, 67, 15\",\n \"rnb-colour-sea-tint-8\": \"#effdf5\",\n \"rnb-colour-sea-tint-8-rgb\": \"#239, 253, 245\",\n \"rnb-colour-sea-tint-16\": \"#ddf9ea\",\n \"rnb-colour-sea-tint-16-rgb\": \"221, 249, 234\",\n \"rnb-colour-sea-tint-32\": \"#bbf3d4\",\n \"rnb-colour-sea-tint-32-rgb\": \"187, 243, 212\",\n \"rnb-colour-sea-tint-64\": \"#78e8ab\",\n \"rnb-colour-sea-tint-64-rgb\": \"120, 232, 171\",\n \"rnb-colour-sea\": sea,\n \"rnb-colour-sea-rgb\": seaRgb,\n \"rnb-colour-sea-shade-64\": \"#1c8c4f\",\n \"rnb-colour-sea-shade-64-rgb\": \"28, 140, 79\",\n \"rnb-colour-sea-shade-48\": \"#15693b\",\n \"rnb-colour-sea-shade-48-rgb\": \"21, 105, 59\",\n \"rnb-colour-sea-shade-32\": \"#0e4627\",\n \"rnb-colour-sea-shade-32-rgb\": \"14, 70, 39\",\n \"rnb-colour-reef-tint-8\": \"#effcfb\",\n \"rnb-colour-reef-tint-8-rgb\": \"239, 252, 25\",\n \"rnb-colour-reef-tint-16\": \"#ddf8f7\",\n \"rnb-colour-reef-tint-16-rgb\": \"221, 248, 247\",\n \"rnb-colour-reef-tint-32\": \"#bbf0ee\",\n \"rnb-colour-reef-tint-32-rgb\": \"187, 240, 238\",\n \"rnb-colour-reef-tint-64\": \"#78e1dc\",\n \"rnb-colour-reef-tint-64-rgb\": \"120, 225, 220\",\n \"rnb-colour-reef\": reef,\n \"rnb-colour-reef-rgb\": reefRgb,\n \"rnb-colour-reef-shade-64\": \"#1c8580\",\n \"rnb-colour-reef-shade-64-rgb\": \"28, 133, 128\",\n \"rnb-colour-reef-shade-48\": \"#156460\",\n \"rnb-colour-reef-shade-48-rgb\": \"21, 100, 96\",\n \"rnb-colour-reef-shade-32\": \"#0e4341\",\n \"rnb-colour-reef-shade-32-rgb\": \"14, 67, 65\",\n \"rnb-colour-salvia\": salvia,\n \"rnb-colour-salvia-rgb\": salviaRgb,\n \"rnb-colour-salvia-shade-32\": \"#332B4A\",\n \"rnb-colour-salvia-shade-32-rgb\": \"51, 43, 74\",\n \"rnb-colour-salvia-shade-48\": \"#4C406F\",\n \"rnb-colour-salvia-shade-48-rgb\": \"76, 64, 111\",\n \"rnb-colour-salvia-shade-64\": \"#655694\",\n \"rnb-colour-salvia-shade-64-rgb\": \"101, 86, 148\",\n \"rnb-colour-salvia-tint-8\": \"#F7F5FD\",\n \"rnb-colour-salvia-tint-8-rgb\": \"247, 245, 253\",\n \"rnb-colour-salvia-tint-16\": \"#EFECFB\",\n \"rnb-colour-salvia-tint-16-rgb\": \"239, 236, 251\",\n \"rnb-colour-salvia-tint-32\": \"#E0D8F7\",\n \"rnb-colour-salvia-tint-32-rgb\": \"224, 216, 247\",\n \"rnb-colour-salvia-tint-64\": \"#C1B2F0\",\n \"rnb-colour-salvia-tint-64-rgb\": \"193, 178, 240\",\n \"rnb-colour-sky\": sky,\n \"rnb-colour-sky-rgb\": skyRgb,\n \"rnb-colour-sky-shade-32\": \"#173E49\",\n \"rnb-colour-sky-shade-32-rgb\": \"23, 62, 73\",\n \"rnb-colour-sky-shade-48\": \"#235D6D\",\n \"rnb-colour-sky-shade-48-rgb\": \"35, 93, 109\",\n \"rnb-colour-sky-shade-64\": \"#2F7C91\",\n \"rnb-colour-sky-shade-64-rgb\": \"47, 124, 145\",\n \"rnb-colour-sky-tint-8\": \"#F0FAFD\",\n \"rnb-colour-sky-tint-8-rgb\": \"240, 250, 253\",\n \"rnb-colour-sky-tint-16\": \"#E2F5FB\",\n \"rnb-colour-sky-tint-16-rgb\": \"225, 245, 251\",\n \"rnb-colour-sky-tint-32\": \"#C5EBF6\",\n \"rnb-colour-sky-tint-32-rgb\": \"197, 235, 246\",\n \"rnb-colour-sky-tint-64\": \"#8AD8ED\",\n \"rnb-colour-sky-tint-64-rgb\": \"138, 216, 237\",\n \"rnb-colour-grad-shade-a\": \"#1A2430\",\n \"rnb-colour-grad-shade-a-rgb\": \"26, 36, 48, 1\",\n \"rnb-colour-grad-shade-tint\": \"#3E3837\",\n \"rnb-colour-grad-shade-tint-rgb\": \"62, 56, 55, 1\",\n \"rnb-colour-grad-shade-b\": \"#C46466\",\n \"rnb-colour-grad-shade-b-rgb\": \"196, 100, 102, 1\"\n};\nconst defaults = {\n \"rnb-colour-band-theta\": core[\"rnb-colour-sand-tint-64\"],\n \"rnb-colour-band-alpha\": core[\"rnb-colour-sand-tint-64\"],\n \"rnb-colour-band-beta\": core[\"rnb-colour-dandelion-tint-64\"],\n \"rnb-colour-band-gamma\": core[\"rnb-colour-moss-tint-64\"],\n \"rnb-colour-band-delta\": core[\"rnb-colour-sea-tint-64\"],\n \"rnb-colour-band-epsilon\": core[\"rnb-colour-chill-tint-32\"],\n \"rnb-colour-primary-light\": core[\"rnb-colour-midnight\"],\n \"rnb-colour-primary-inverted-light\": core[\"rnb-colour-white\"],\n \"rnb-colour-primary-light-rgb\": core[\"rnb-colour-midnight-rgb\"],\n \"rnb-colour-secondary-light\": core[\"rnb-colour-midnight-tint-64\"],\n \"rnb-colour-secondary-light-rgb\": core[\"rnb-colour-midnight-tint-64-rgb\"],\n \"rnb-colour-tertiary-light\": core[\"rnb-colour-midnight-tint-48\"],\n \"rnb-colour-tertiary-light-rgb\": core[\"rnb-colour-midnight-tint-48-rgb\"],\n \"rnb-colour-positive-light\": core[\"rnb-colour-sea-shade-64\"],\n \"rnb-colour-positive-light-rgb\": core[\"rnb-colour-sea-shade-64-rgb\"],\n \"rnb-colour-negative-light\": core[\"rnb-colour-rose\"],\n \"rnb-colour-negative-light-rgb\": core[\"rnb-colour-rose-rgb\"],\n \"rnb-colour-attention-light\": core[\"rnb-colour-sand\"],\n \"rnb-colour-attention-light-rgb\": core[\"rnb-colour-sand-rgb\"],\n \"rnb-colour-disabled-light\": core[\"rnb-colour-midnight-tint-16\"],\n \"rnb-colour-disabled-light-rgb\": core[\"rnb-colour-midnight-tint-16-rgb\"],\n \"rnb-colour-action-light\": core[\"rnb-colour-chill\"],\n \"rnb-colour-action-light-rgb\": core[\"rnb-colour-chill-rgb\"],\n \"rnb-colour-action-hover-light\": core[\"rnb-colour-chill-shade-64\"],\n \"rnb-colour-overlay-light\": core[\"rnb-colour-midnight-alpha-96\"],\n \"rnb-colour-background-light\": core[\"rnb-colour-midnight-tint-4\"],\n \"rnb-colour-card-light\": core[\"rnb-colour-white\"],\n \"rnb-colour-cell-light\": core[\"rnb-colour-white\"],\n \"rnb-colour-section-light\": core[\"rnb-colour-white\"],\n \"rnb-colour-header-light\": core[\"rnb-colour-white\"],\n \"rnb-colour-footer-light\": core[\"rnb-colour-midnight-shade-64\"],\n \"rnb-colour-primary-dark\": core[\"rnb-colour-white\"],\n \"rnb-colour-primary-inverted-dark\": core[\"rnb-colour-midnight\"],\n \"rnb-colour-secondary-dark\": core[\"rnb-colour-white-alpha-64\"],\n \"rnb-colour-tertiary-dark\": core[\"rnb-colour-white-alpha-48\"],\n \"rnb-colour-positive-dark\": core[\"rnb-colour-sea\"],\n \"rnb-colour-negative-dark\": core[\"rnb-colour-rose-tint-64\"],\n \"rnb-colour-attention-dark\": core[\"rnb-colour-sand\"],\n \"rnb-colour-disabled-dark\": core[\"rnb-colour-white-alpha-16\"],\n \"rnb-colour-action-dark\": core[\"rnb-colour-white\"],\n \"rnb-colour-action-hover-dark\": core[\"rnb-colour-white-alpha-64\"],\n \"rnb-colour-overlay-dark\": core[\"rnb-colour-black-alpha-64\"],\n \"rnb-colour-background-dark\": core[\"rnb-colour-midnight-shade-32\"],\n \"rnb-colour-card-dark\": core[\"rnb-colour-midnight-shade-64\"],\n \"rnb-colour-cell-dark\": core[\"rnb-colour-white-alpha-4\"],\n \"rnb-colour-section-dark\": core[\"rnb-colour-white-alpha-4\"],\n \"rnb-colour-header-dark\": core[\"rnb-colour-white-alpha-4\"],\n \"rnb-colour-footer-dark\": core[\"rnb-colour-white-alpha-4\"]\n};\nvar colour = { ...core, ...defaults };\nvar fontFamily = {\n \"rnb-font-family-cs-clarity\": \"CSClarity, Helvetica Neue, Helvetica, Arial, sans-serif\"\n};\nvar fontSize = {\n \"rnb-font-size-micro\": \"0.625rem\",\n \"rnb-font-size-tiny\": \"0.75rem\",\n \"rnb-font-size-mini\": \"0.875rem\",\n \"rnb-font-size-small\": \"1rem\",\n \"rnb-font-size-medium\": \"1.25rem\",\n \"rnb-font-size-large\": \"1.5rem\",\n \"rnb-font-size-big\": \"2rem\",\n \"rnb-font-size-huge\": \"2.5rem\",\n \"rnb-font-size-massive\": \"2.75rem\",\n \"rnb-font-size-jumbo\": \"4rem\",\n \"rnb-font-size-gargantuan\": \"6rem\",\n \"rnb-font-size-ridiculous\": \"8rem\"\n};\nvar fontWeight = {\n \"rnb-font-weight-thin\": 100,\n \"rnb-font-weight-light\": 200,\n \"rnb-font-weight-book\": 300,\n \"rnb-font-weight-regular\": 400,\n \"rnb-font-weight-medium\": 500,\n \"rnb-font-weight-bold\": 700,\n \"rnb-font-weight-black\": 900\n};\nvar lineHeight = {\n \"rnb-line-height-reset\": \"1\",\n \"rnb-line-height-text\": \"1.5\",\n \"rnb-line-height-heading\": \"1.2\"\n};\nconst small = 375;\nconst phablet = 512;\nconst medium = 768;\nconst large = 1024;\nconst huge = 1408;\nvar mediaQuery = {\n \"rnb-mq-small\": `(min-width: ${small}px)`,\n \"rnb-mq-phablet\": `(min-width: ${phablet}px)`,\n \"rnb-mq-medium\": `(min-width: ${medium}px)`,\n \"rnb-mq-lt-medium\": `(max-width: ${medium - 1}px)`,\n \"rnb-mq-large\": `(min-width: ${large}px)`,\n \"rnb-mq-huge\": `(min-width: ${huge}px)`\n};\nvar shadow = {\n \"rnb-shadow-sea\": `0 0 0 ${colour[\"rnb-colour-transparent\"]}`,\n \"rnb-shadow-earth\": `0 0.125rem 0.25rem ${colour[\"rnb-colour-black-alpha-16\"]}`,\n \"rnb-shadow-hill\": `0 0.25rem 0.5rem ${colour[\"rnb-colour-black-alpha-16\"]}`,\n \"rnb-shadow-mountain\": `0 0.5rem 0.75rem ${colour[\"rnb-colour-black-alpha-16\"]}`,\n \"rnb-shadow-hill-light\": `0 0 0.75rem ${colour[\"rnb-colour-black-alpha-4\"]}, 0 0.4rem 0.75rem ${colour[\"rnb-colour-black-alpha-8\"]}`,\n \"rnb-shadow-earth-top\": `0 -0.125rem 0.25rem ${colour[\"rnb-colour-black-alpha-16\"]}`,\n \"rnb-shadow-hill-top\": `0 -0.25rem 0.5rem ${colour[\"rnb-colour-black-alpha-16\"]}`,\n \"rnb-shadow-mountain-top\": `0 -0.5rem 0.75rem ${colour[\"rnb-colour-black-alpha-16\"]}`\n};\nconst spacing = {\n \"rnb-spacing-none\": \"0rem\",\n \"rnb-spacing-micro\": \"0.25rem\",\n \"rnb-spacing-tiny\": \"0.5rem\",\n \"rnb-spacing-small\": \"0.75rem\",\n \"rnb-spacing-medium\": \"1rem\",\n \"rnb-spacing-large\": \"1.5rem\",\n \"rnb-spacing-big\": \"2rem\",\n \"rnb-spacing-huge\": \"3rem\",\n \"rnb-spacing-super\": \"4rem\",\n \"rnb-spacing-jumbo\": \"8rem\"\n};\nvar spacing$1 = {\n ...spacing,\n \"rnb-spacing-inset-squash-micro\": `${spacing[\"rnb-spacing-micro\"]} ${spacing[\"rnb-spacing-tiny\"]}`,\n \"rnb-spacing-inset-squash-tiny\": `${spacing[\"rnb-spacing-tiny\"]} ${spacing[\"rnb-spacing-small\"]}`,\n \"rnb-spacing-inset-squash-small\": `${spacing[\"rnb-spacing-small\"]} ${spacing[\"rnb-spacing-medium\"]}`,\n \"rnb-spacing-inset-squash-medium\": `${spacing[\"rnb-spacing-medium\"]} ${spacing[\"rnb-spacing-large\"]}`,\n \"rnb-spacing-inset-squeeze-micro\": `${spacing[\"rnb-spacing-tiny\"]} ${spacing[\"rnb-spacing-micro\"]}`,\n \"rnb-spacing-inset-squeeze-tiny\": `${spacing[\"rnb-spacing-small\"]} ${spacing[\"rnb-spacing-tiny\"]}`,\n \"rnb-spacing-inset-squeeze-medium\": `${spacing[\"rnb-spacing-large\"]} ${spacing[\"rnb-spacing-medium\"]}`\n};\nvar timing = {\n \"rnb-timing-fast\": \"250ms\",\n \"rnb-timing-normal\": \"500ms\",\n \"rnb-timing-slow\": \"1000ms\",\n \"rnb-timing-easing-in\": \"cubic-bezier(0.4, 0, 1, 1)\"\n};\nvar zIndex = {\n \"rnb-zindex-dive\": -200,\n \"rnb-zindex-default\": 1,\n \"rnb-zindex-levitate\": 2,\n \"rnb-zindex-rise\": 200,\n \"rnb-zindex-sky\": 400,\n \"rnb-zindex-top\": 600\n};\nvar gradient = {\n \"rnb-gradient-exclusive\": `linear-gradient(-180deg, ${colour[\"rnb-colour-midnight\"]}, ${colour[\"rnb-colour-midnight-shade-64\"]})`\n};\nexport { borderRadius, borderWidth, colour, fontFamily, fontSize, fontWeight, gradient, lineHeight, mediaQuery, shadow, spacing$1 as spacing, timing, zIndex };\n","import { mediaQuery } from '@clearscore/rainbow.tokens';\n\nexport const types = {\n MICRO: 'MICRO',\n TINY: 'TINY',\n MINI: 'MINI',\n SMALL: 'SMALL',\n MEDIUM: 'MEDIUM',\n LARGE: 'LARGE',\n BIG: 'BIG',\n HUGE: 'HUGE',\n MASSIVE: 'MASSIVE',\n JUMBO: 'JUMBO',\n GARGANTUAN: 'GARGANTUAN',\n RIDICULOUS: 'RIDICULOUS',\n} as const;\n\nexport const weights = {\n THIN: 'THIN',\n LIGHT: 'LIGHT',\n BOOK: 'BOOK',\n REGULAR: 'REGULAR',\n MEDIUM: 'MEDIUM',\n BOLD: 'BOLD',\n BLACK: 'BLACK',\n} as const;\n\nexport const spacings = {\n TIGHT: 'TIGHT',\n WIDE: 'WIDE',\n EXPLODED: 'EXPLODED',\n} as const;\n\nexport const tags = {\n DIV: 'div',\n H1: 'h1',\n H2: 'h2',\n H3: 'h3',\n H4: 'h4',\n H5: 'h5',\n H6: 'h6',\n P: 'p',\n SPAN: 'span',\n LABEL: 'label',\n LEGEND: 'legend',\n} as const;\n\nexport const presets = {\n J1: {\n type: [types.GARGANTUAN, types.RIDICULOUS],\n weight: weights.THIN,\n breakpoints: [null, mediaQuery['rnb-mq-medium']],\n },\n J2: {\n type: [types.JUMBO, types.GARGANTUAN],\n weight: weights.THIN,\n breakpoints: [null, mediaQuery['rnb-mq-medium']],\n },\n J3: {\n type: [types.MASSIVE, types.JUMBO],\n weight: weights.THIN,\n breakpoints: [null, mediaQuery['rnb-mq-medium']],\n },\n J4: {\n type: [types.BIG, types.MASSIVE],\n breakpoints: [null, mediaQuery['rnb-mq-medium']],\n },\n\n H1: {\n type: [types.BIG, types.HUGE],\n tag: tags.H1,\n breakpoints: [null, mediaQuery['rnb-mq-medium']],\n },\n H2: {\n type: [types.MEDIUM, types.LARGE],\n tag: tags.H2,\n weight: weights.BOLD,\n breakpoints: [null, mediaQuery['rnb-mq-medium']],\n },\n H3: {\n type: types.SMALL,\n weight: weights.BOLD,\n tag: tags.H3,\n },\n H4: {\n type: types.MINI,\n weight: weights.BOLD,\n tag: tags.H4,\n },\n H5: {\n type: types.MINI,\n spacing: spacings.WIDE,\n tag: tags.H5,\n isUppercase: true,\n },\n H6: {\n type: types.TINY,\n weight: weights.BOLD,\n spacing: spacings.WIDE,\n tag: tags.H6,\n isUppercase: true,\n },\n\n BODY1: {\n type: types.SMALL,\n tag: tags.P,\n },\n BODY2: {\n type: types.MINI,\n tag: tags.P,\n },\n BODY3: {\n type: types.MINI,\n weight: weights.BOLD,\n tag: tags.P,\n },\n BODY4: {\n type: types.TINY,\n tag: tags.P,\n },\n BODY5: {\n type: types.TINY,\n weight: weights.BOLD,\n tag: tags.P,\n },\n BODY6: {\n type: types.MICRO,\n spacing: spacings.WIDE,\n tag: tags.P,\n },\n\n BUTTON1: {\n type: types.MINI,\n weight: weights.BOLD,\n spacing: spacings.WIDE,\n },\n BUTTON2: {\n type: types.TINY,\n weight: weights.BOLD,\n spacing: spacings.WIDE,\n },\n\n CAPTION: {\n type: types.TINY,\n spacing: spacings.WIDE,\n },\n\n OVERLINE: {\n type: types.TINY,\n spacing: spacings.EXPLODED,\n isUppercase: true,\n },\n LINK: {\n type: types.MINI,\n weight: weights.BOLD,\n },\n} as const;\n","import type { ReactElement, ReactNode, HTMLAttributes, LabelHTMLAttributes } from 'react';\nimport React from 'react';\nimport cx from 'classnames';\nimport useMedia from '@clearscore/hooks.use-media';\nimport toTitleCase from '@clearscore/normalize.title-case';\nimport type { mediaQuery } from '@clearscore/rainbow.tokens';\n\nimport type { TextLinkProps } from './components/text-link';\nimport TextLink from './components/text-link';\nimport TextStrong from './components/text-strong';\nimport { types, weights, spacings, tags, presets } from './constants';\nimport styles from './text.module.css';\n\ntype ValueOf = T[keyof T];\n\ninterface ITextProps\n extends HTMLAttributes<\n HTMLHeadingElement | HTMLParagraphElement | HTMLDivElement | HTMLSpanElement | HTMLLegendElement\n >,\n Pick, 'htmlFor'>,\n Omit {\n children: ReactNode;\n type?: readonly ValueOf[] | ValueOf;\n weight?: ValueOf;\n spacing?: ValueOf;\n tag?: ValueOf;\n breakpoints?: readonly (ValueOf | null)[];\n isItalic?: boolean;\n isUppercase?: boolean;\n isLink?: boolean;\n isSimpleLink?: boolean;\n dataId?: string;\n}\n\ninterface DisplayNameExport {\n displayName?: string;\n}\n\ntype Text = (props: ITextProps) => ReactElement;\n\nexport interface TextExports {\n types: typeof types;\n weights: typeof weights;\n spacings: typeof spacings;\n tags: typeof tags;\n presets: typeof presets;\n Link: typeof TextLink;\n Strong: typeof TextStrong;\n Link1: Text & DisplayNameExport;\n J1: Text & DisplayNameExport;\n J2: Text & DisplayNameExport;\n J3: Text & DisplayNameExport;\n J4: Text & DisplayNameExport;\n H1: Text & DisplayNameExport;\n H2: Text & DisplayNameExport;\n H3: Text & DisplayNameExport;\n H4: Text & DisplayNameExport;\n H5: Text & DisplayNameExport;\n H6: Text & DisplayNameExport;\n Body1: Text & DisplayNameExport;\n Body2: Text & DisplayNameExport;\n Body3: Text & DisplayNameExport;\n Body4: Text & DisplayNameExport;\n Body5: Text & DisplayNameExport;\n Body6: Text & DisplayNameExport;\n Button1: Text & DisplayNameExport;\n Button2: Text & DisplayNameExport;\n Caption: Text & DisplayNameExport;\n Overline: Text & DisplayNameExport;\n}\n\nconst Text: Text & TextExports = ({\n children,\n type,\n weight = weights.REGULAR,\n spacing = spacings.TIGHT,\n tag = tags.DIV,\n breakpoints = [],\n isItalic = false,\n isUppercase = false,\n isLink = false,\n isSimpleLink = false,\n dataId,\n ...wrapProps\n}) => {\n const typeValue = useMedia(breakpoints, type);\n const typeClass = styles[`isType${toTitleCase(typeValue)}`];\n const weightClass = styles[`isWeight${toTitleCase(weight)}`];\n const spacingClass = styles[`isSpacing${toTitleCase(spacing)}`];\n const isWrapped = isLink || wrapProps.href || wrapProps.to;\n const Tag = tag as React.ElementType;\n\n return (\n \n {isWrapped ? (\n \n {children}\n \n ) : (\n children\n )}\n \n );\n};\n\nText.types = types;\nText.weights = weights;\nText.spacings = spacings;\nText.tags = tags;\nText.presets = presets;\n\nText.Link = TextLink;\nText.Strong = TextStrong;\n\nText.Link1 = ({ tag, ...props }): ReactElement => ;\nText.Link1.displayName = 'Link1';\nText.J1 = ({ tag, ...props }): ReactElement => ;\nText.J1.displayName = 'J1';\nText.J2 = ({ tag, ...props }): ReactElement => ;\nText.J2.displayName = 'J2';\nText.J3 = ({ tag, ...props }): ReactElement => ;\nText.J3.displayName = 'J3';\nText.J4 = ({ tag, ...props }): ReactElement => ;\nText.J4.displayName = 'J4';\nText.H1 = ({ tag, ...props }): ReactElement => ;\nText.H1.displayName = 'H1';\nText.H2 = ({ tag, ...props }): ReactElement => ;\nText.H2.displayName = 'H2';\nText.H3 = ({ tag, ...props }): ReactElement => ;\nText.H3.displayName = 'H3';\nText.H4 = ({ tag, ...props }): ReactElement => ;\nText.H4.displayName = 'H4';\nText.H5 = ({ tag, ...props }): ReactElement => ;\nText.H5.displayName = 'H5';\nText.H6 = ({ tag, ...props }): ReactElement => ;\nText.H6.displayName = 'H6';\nText.Body1 = ({ tag, ...props }): ReactElement => ;\nText.Body1.displayName = 'Body1';\nText.Body2 = ({ tag, ...props }): ReactElement => ;\nText.Body2.displayName = 'Body2';\nText.Body3 = ({ tag, ...props }): ReactElement => ;\nText.Body3.displayName = 'Body3';\nText.Body4 = ({ tag, ...props }): ReactElement => ;\nText.Body4.displayName = 'Body4';\nText.Body5 = ({ tag, ...props }): ReactElement => ;\nText.Body5.displayName = 'Body5';\nText.Body6 = ({ tag, ...props }): ReactElement => ;\nText.Body6.displayName = 'Body6';\nText.Button1 = ({ tag, ...props }): ReactElement => ;\nText.Button1.displayName = 'Button1';\nText.Button2 = ({ tag, ...props }): ReactElement => ;\nText.Button2.displayName = 'Button2';\nText.Caption = ({ tag, ...props }): ReactElement => ;\nText.Caption.displayName = 'Caption';\nText.Overline = ({ tag, ...props }): ReactElement => ;\nText.Overline.displayName = 'Overline';\n\nexport default Text;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport cx from 'classnames';\nimport Text from '@clearscore/rainbow.text';\n\n// eslint-disable-next-line postcss-modules/no-unused-class\nimport styles from './index.module.css';\n\nfunction InfoPanel({ language, type }) {\n const { heading, content } = language;\n\n return (\n
\n {heading}\n
\n {content}\n
\n
\n );\n}\n\nInfoPanel.propTypes = {\n type: PropTypes.oneOf(['success', 'warning', 'error', 'standard']),\n language: PropTypes.object,\n};\n\nInfoPanel.defaultProps = {\n type: 'success',\n language: {},\n};\n\nexport default InfoPanel;\n","import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport InfoPanel from '../info-panel';\nimport styles from '../error/index.module.css';\n\nconst ErrorMessage = (props) => (\n
\n \n
\n);\n\nErrorMessage.propTypes = {\n language: PropTypes.object.isRequired,\n};\n\nexport default ErrorMessage;\n","import { EN_GB, EN_AU, EN_ZA } from '@clearscore/config.i18n';\n\nexport default {\n [EN_GB]: {\n heading: 'Oops! Something went wrong...',\n content: 'We are sorry but it seems we have had a problem trying to load this page.',\n },\n [EN_ZA]: {\n heading: 'Oops! Something went wrong...',\n content: 'We are sorry but it seems we have had a problem trying to load this page.',\n },\n [EN_AU]: {\n heading: 'Oops! Something went wrong...',\n content: 'We are sorry but it seems we have had a problem trying to load this page.',\n },\n};\n","import React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport monitoring from '@clearscore/helpers.monitoring';\n\nimport ErrorMessage from '../message';\nimport lang from '../../lib/lang';\n\nclass VerticalError extends Component {\n state = { hasError: false };\n\n componentDidCatch(error, errorInfo) {\n this.setState({ hasError: true });\n if (monitoring.hasMonitoring()) {\n monitoring.withScope((scope) => {\n scope.setExtras(errorInfo);\n Sentry.captureException(error);\n });\n }\n }\n\n render() {\n const language = lang[this.props.locale];\n if (this.state.hasError) return ;\n return this.props.children;\n }\n}\n\nVerticalError.propTypes = {\n children: PropTypes.node.isRequired,\n locale: PropTypes.string,\n};\n\nVerticalError.defaultProps = {\n locale: 'en-gb',\n};\n\nexport default VerticalError;\n","/**\n * State filter helper, reduces down state to match only filter keys\n * @param filter\n * @param object\n * @return {{}}\n */\nfunction reduceState(filter = {}, object = {}) {\n return Object.keys(filter).reduce((state, key) => {\n if (!object[key]) return state;\n return {\n ...state,\n [key]: object[key],\n };\n }, {});\n}\n\n/**\n * Reduce initial state to match reducer\n * @param reducer\n * @param state\n * @return {{entities: {}}}\n */\nexport default function initialStateFilter(reducer, state = {}) {\n const initialState = reduceState(reducer, state);\n if (reducer.entities) initialState.entities = reduceState(reducer.entities, state.entities);\n return initialState;\n}\n","export default function insertIfExists(elements) {\n return elements ? [...elements] : [];\n}\n","const ROUTES = 'CS/ROUTES';\n/* eslint-disable import/prefer-default-export */\nexport const ROUTES_REINITIALISE = `${ROUTES}_REINITIALISE`;\n","import { resolveProp } from '@clearscore/helpers.resolve-props';\n\n/**\n * Returns an object of routes by id\n * @param collection Array\n * @param id String (id or id.key etc)\n */\nconst objectById = (collection, id = 'id') =>\n collection.reduce((state, item) => {\n const key = resolveProp(id, item);\n return {\n ...state,\n [key]: item,\n };\n }, {});\n\n/**\n * Returns a simplified object with an array of ids\n * @param collection\n * @param id\n * @param name\n */\n// eslint-disable-next-line default-param-last\nexport const lookupById = (collection, id = 'id', name) =>\n collection.reduce((state, item) => {\n const reduceState = { ...state };\n if (item[id]) {\n if (Array.isArray(item[id])) {\n item[id].forEach((idvName) => {\n if (!state[idvName]) {\n reduceState[idvName] = {\n id: idvName,\n [name]: [item.id],\n };\n } else {\n reduceState[idvName][name].push(item.id);\n }\n });\n } else if (!state[item[id]]) {\n reduceState[item[id]] = {\n id: item[id],\n [name]: [item.id],\n };\n } else {\n reduceState[item[id]][name].push(item.id);\n }\n }\n return reduceState;\n }, {});\n\nexport default objectById;\n","export default (routes, accountIDVStatus) => {\n const routeHasVisibility = ({ visibility }) =>\n (Array.isArray(visibility) && visibility.includes(accountIDVStatus)) || !visibility || !accountIDVStatus;\n\n return routes.filter((route) => routeHasVisibility(route));\n};\n","import { loadRoutes } from '@clearscore/helpers.cache';\nimport objectById from '@clearscore/helpers.state-normalise';\nimport * as requestStatuses from '@clearscore/constants.request-statuses';\nimport * as sessionTypes from '@clearscore/constants.session-action-types';\n\nimport { ROUTES_REINITIALISE } from '../types';\nimport filterRoutesByStatus from './lib/filterRoutesByStatus';\n\n/**\n * Normalise routes by id\n * @param routes\n * @return {{byId, allIds: Array}}\n */\nfunction normaliseById(routes) {\n const byId = objectById(routes);\n const allIds = Object.keys(byId);\n\n return {\n status: requestStatuses.INITIAL,\n byId,\n allIds,\n };\n}\n\n/**\n * Route initial state\n * @returns {array}\n */\nconst initialState = normaliseById(loadRoutes());\n\n/**\n * Routes Reducer\n * @param state\n * @param action\n */\nexport default function routesReducer(state = initialState, action = {}) {\n switch (action.type) {\n case sessionTypes.TIMEOUT_SUCCESS:\n case sessionTypes.LOGOUT_SUBMIT:\n case ROUTES_REINITIALISE:\n if (action && action.payload && action.payload.routes) {\n const { routes, accountIDVStatus } = action.payload;\n return {\n ...normaliseById([...loadRoutes(), ...filterRoutesByStatus(routes, accountIDVStatus)]),\n status: requestStatuses.SUCCESS,\n };\n }\n return {\n ...state,\n status: requestStatuses.SUCCESS,\n };\n default:\n return state;\n }\n}\n","import { loadRoutes } from '@clearscore/helpers.cache';\nimport { lookupById } from '@clearscore/helpers.state-normalise';\nimport * as requestStatuses from '@clearscore/constants.request-statuses';\nimport * as sessionTypes from '@clearscore/constants.session-action-types';\n\nimport { ROUTES_REINITIALISE } from '../types';\nimport filterRoutesByStatus from './lib/filterRoutesByStatus';\n\n/**\n * Normalise routes by categories\n * @param routes\n * @return {{byId, allIds: Array}}\n */\nfunction normaliseCategories(routes) {\n const byId = lookupById(routes, 'category', 'routes');\n const allIds = Object.keys(byId);\n\n return {\n status: requestStatuses.SUCCESS,\n byId,\n allIds,\n };\n}\n\n/**\n * Route initial state\n * @returns {array}\n */\nconst initialState = normaliseCategories(loadRoutes());\n\n/**\n * Routes Reducer\n * @param state\n * @param action\n */\nexport default function routesReducer(state = initialState, action = {}) {\n switch (action.type) {\n case sessionTypes.TIMEOUT_SUCCESS:\n case sessionTypes.LOGOUT_SUBMIT:\n case ROUTES_REINITIALISE: {\n const { routes, accountIDVStatus } = action.payload || {};\n\n if (routes) {\n return {\n ...normaliseCategories([...loadRoutes(), ...filterRoutesByStatus(routes, accountIDVStatus)]),\n status: requestStatuses.SUCCESS,\n };\n }\n\n return {\n ...state,\n status: requestStatuses.SUCCESS,\n };\n }\n\n default:\n return state;\n }\n}\n","import { loadRoutes } from '@clearscore/helpers.cache';\nimport { lookupById } from '@clearscore/helpers.state-normalise';\nimport * as requestStatuses from '@clearscore/constants.request-statuses';\nimport * as sessionTypes from '@clearscore/constants.session-action-types';\n\nimport { ROUTES_REINITIALISE } from '../types';\nimport filterRoutesByStatus from './lib/filterRoutesByStatus';\n\n/**\n * Normalise routes by templates\n * @param routes\n * @return {{byId, allIds: Array}}\n */\nfunction normaliseTemplates(routes) {\n const byId = lookupById(routes, 'template', 'routes');\n const allIds = Object.keys(byId);\n\n return {\n status: requestStatuses.SUCCESS,\n byId,\n allIds,\n };\n}\n\n/**\n * Route initial state\n * @returns {array}\n */\nconst initialState = normaliseTemplates(loadRoutes());\n\n/**\n * Routes Reducer\n * @param state\n * @param action\n */\nexport default function routesReducer(state = initialState, action = {}) {\n switch (action.type) {\n case sessionTypes.TIMEOUT_SUCCESS:\n case sessionTypes.LOGOUT_SUBMIT:\n case ROUTES_REINITIALISE:\n if (action && action.payload && action.payload.routes) {\n const { routes, accountIDVStatus } = action.payload;\n\n return {\n ...normaliseTemplates([...loadRoutes(), ...filterRoutesByStatus(routes, accountIDVStatus)]),\n status: requestStatuses.SUCCESS,\n };\n }\n return {\n ...state,\n status: requestStatuses.SUCCESS,\n };\n default:\n return state;\n }\n}\n","import { loadRoutes } from '@clearscore/helpers.cache';\nimport { lookupById } from '@clearscore/helpers.state-normalise';\nimport * as requestStatuses from '@clearscore/constants.request-statuses';\nimport * as sessionTypes from '@clearscore/constants.session-action-types';\n\nimport { ROUTES_REINITIALISE } from '../types';\nimport filterRoutesByStatus from './lib/filterRoutesByStatus';\n\n/**\n * Normalise routes by status\n * @param routes\n * @return {{byId, allIds: Array}}\n */\nfunction normaliseStatus(routes) {\n const byId = lookupById(routes, 'idvStatus', 'routes');\n const allIds = Object.keys(byId);\n\n return {\n status: requestStatuses.INITIAL,\n byId,\n allIds,\n };\n}\n\n/**\n * Route initial state\n * @returns {array}\n */\nconst initialState = normaliseStatus(loadRoutes());\n\n/**\n * Routes Reducer\n * @param state\n * @param action\n */\nexport default function routesReducer(state = initialState, action = {}) {\n switch (action.type) {\n case sessionTypes.TIMEOUT_SUCCESS:\n case sessionTypes.LOGOUT_SUBMIT:\n case ROUTES_REINITIALISE:\n if (action && action.payload && action.payload.routes) {\n const { routes, accountIDVStatus } = action.payload;\n\n return {\n ...normaliseStatus([...loadRoutes(), ...filterRoutesByStatus(routes, accountIDVStatus)]),\n status: requestStatuses.SUCCESS,\n };\n }\n return {\n ...state,\n status: requestStatuses.SUCCESS,\n };\n default:\n return state;\n }\n}\n","import domainImport from './routes.domain';\nimport byId from './routes.byId';\nimport byCategory from './routes.byCategory';\nimport byTemplate from './routes.byTemplate';\nimport byStage from './routes.byStage';\nimport segments from './routes.segmentation';\n\nexport const domain = domainImport;\nexport const entities = {\n routes: byId,\n routeCategories: byCategory,\n routeTemplate: byTemplate,\n routeStages: byStage,\n routeSegments: segments,\n};\n","import * as requestStatuses from '@clearscore/constants.request-statuses';\nimport * as sessionTypes from '@clearscore/constants.session-action-types';\n\nimport { ROUTES_REINITIALISE } from '../types';\n\n/**\n * Route segmentation Reducer\n * @param state\n * @param action\n */\nexport default function routesSegmentation(state = {}, action = {}) {\n switch (action.type) {\n case sessionTypes.TIMEOUT_SUCCESS:\n case sessionTypes.LOGOUT_SUBMIT:\n case ROUTES_REINITIALISE:\n if (action?.payload?.segmentation) {\n const { segmentation } = action.payload;\n\n return {\n segmentation,\n status: requestStatuses.SUCCESS,\n };\n }\n return {\n segmentation: { groups: [] },\n status: requestStatuses.SUCCESS,\n };\n default:\n return state;\n }\n}\n","import { resolveProp } from '@clearscore/helpers.resolve-props';\n\nexport const ERR_CONTEXT_NOT_OBJECT = 'Parameter `context` provided was not an object';\nexport const ERR_VALUES_NOT_OBJECT = 'Parameter `values` provided was not an object';\n\nconst DELIMETER_MAP = [\n { delimeter: '@', isOptionalRegex: /\\?@/g },\n { delimeter: '#', isOptionalRegex: /\\?#/g, usesDictionary: true },\n];\n\n/**\n * Predicate to evaluate if given item is an object\n * @param {object} item to check\n * @returns {boolean} if item is object\n */\nfunction _isObject(item) {\n return typeof item === 'object' && item !== null;\n}\n\nconst _getProp = (value, delimeter) =>\n value.substring(value.indexOf(delimeter)).replace(new RegExp(delimeter, 'g'), '');\n\nfunction _resolver(context, value, dictionary) {\n if (typeof value !== 'string') return value;\n const { delimeter, isOptionalRegex, usesDictionary } = DELIMETER_MAP.find((entry) =>\n value.includes(entry.delimeter),\n ) || {\n delimeter: null,\n isOptionalRegex: null,\n usesDictionary: false,\n };\n if (!delimeter) return value;\n const prop = _getProp(value, delimeter);\n const resolvedProp = usesDictionary ? resolveProp(prop, dictionary) : resolveProp(prop, context);\n if (!resolvedProp) {\n return isOptionalRegex.test(value) ? null : value;\n }\n\n return dictionary && dictionary[resolvedProp] ? dictionary[resolvedProp] : resolvedProp;\n}\n\n/**\n * Look through given values object and attempt to resolve any values beginning with @ from given context\n * @param {Object} context state to resolve values from\n * @param {Object} values object of kv pairs to attempt to resolve\n * @param {Object} dictionary optional lookup for renaming values\n * @returns {Object} values object copy with any possible values interpolated\n */\nconst interpolateValues = (context, values, dictionary) => {\n if (!_isObject(context)) {\n throw new Error(ERR_CONTEXT_NOT_OBJECT);\n }\n\n if (!_isObject(values)) {\n throw new Error(ERR_VALUES_NOT_OBJECT);\n }\n\n return Object.keys(values).reduce((accum, propName) => {\n const value = values[propName];\n\n return {\n ...accum,\n [propName]: _resolver(context, value, dictionary) || accum[propName],\n };\n }, {});\n};\n\nexport default interpolateValues;\n","import createEventContext from '@clearscore/helpers.create-event-context';\nimport interpolateValues from '@clearscore/helpers.interpolate-values';\nimport { getAllCookies } from '@clearscore/helpers.cookies';\nimport { getEnvs } from '@clearscore/helpers.envs';\nimport getDevice from '@clearscore/helpers.device';\n\nconst timeout = 150;\nconst isInPage = ({ payload }) => payload && payload.trackInPage && payload.trackInPage.url;\nconst gotoUrl = ({ newTab, url }) => {\n if (newTab === false) {\n window.location.assign(url);\n } else {\n window.open(url, '_blank');\n }\n};\n\nconst toSnakeCase = (props) =>\n Object.keys(props).reduce(\n (prev, key) => ({\n ...prev,\n [key]: String(props[key]).replace(/ /g, '_').toLowerCase(),\n }),\n {},\n );\n\nconst format = (type, props = {}) => {\n switch (type) {\n case 'snake-case':\n return toSnakeCase(props);\n default:\n return props;\n }\n};\n\nconst getTrackingValues = (trackingObject, { payload }, state) => {\n const { tracking, context, e } = payload.trackInPage;\n const eDictionary = createEventContext({ e, context });\n const { props, formatValues } = trackingObject || { props: tracking } || {};\n const returnedProps =\n typeof props === 'function'\n ? props({ state, device: getDevice(), cookies: getAllCookies(), envs: getEnvs(), context: eDictionary })\n : props;\n const trackingProps = props ? interpolateValues(state, returnedProps, eDictionary) : {};\n return { props, tracking: format(formatValues, trackingProps) };\n};\n\n/**\n * Handle the tracking in-page\n * @param {object} store redux store\n * @param {object} action redux action\n * @param {object} config tracking object container trackingKeys and event values\n * @returns {void}\n */\nfunction handleInPageTracking(store, action, config) {\n const { url, newTab } = action.payload.trackInPage;\n const { providers } = config[action.type] || { providers: {} };\n const state = store.getState();\n const { tracking } = getTrackingValues(providers.segment, action, state);\n\n window.analytics.track(tracking.e, tracking);\n setTimeout(() => gotoUrl({ url, newTab }), timeout);\n}\n\n/**\n * If action has correct signature, perform redirect\n * Dispatch success or error actions\n * @param {object} config tracking object\n * @returns {Function} middleware\n */\nconst redirectMiddleware = (config) => (store) => (next) => (action) => {\n switch (true) {\n case !!isInPage(action):\n return handleInPageTracking(store, action, config);\n default:\n return next(action);\n }\n};\n\nexport default redirectMiddleware;\n","export default ({ e = {}, context }) => ({\n context: {\n label: e.currentTarget && e.currentTarget.textContent,\n location: window.location.href,\n referrer: document.referrer || 'Direct',\n ...context,\n },\n});\n","import * as actionsImport from './dashboard.actions';\nimport * as constantsImport from './dashboard.constants';\nimport * as reducersImport from './reducers';\nimport * as selectorsImport from './selectors';\nimport * as typesImport from './dashboard.types';\n\nexport const actions = actionsImport;\nexport const constants = constantsImport;\nexport const reducers = reducersImport;\nexport const selectors = selectorsImport;\nexport const types = typesImport;\n","export const DASHBOARD_FETCH = 'CS/DASHBOARD_FETCH';\nexport const DASHBOARD_FETCH_SUCCESS = 'CS/DASHBOARD_FETCH_SUCCESS';\nexport const DASHBOARD_FETCH_ERROR = 'CS/DASHBOARD_FETCH_ERROR';\n\nexport const DASHBOARD_SERVICE_FETCH_ERROR = 'CS/DASHBOARD_SERVICE_FETCH_ERROR';\nexport const DASHBOARD_SERVICE_REPORT_NOT_FOUND_ERROR = 'CS/DASHBOARD_SERVICE_REPORT_NOT_FOUND_ERROR';\n","import getDevice from '@clearscore/helpers.device';\n\nconst device = getDevice();\n\nexport default {\n cs_site: '@market.activeMarket',\n score_band: '?@dashboard.data.creditReportInfo.scoreBand',\n device,\n};\n","import segmentProps from '../lib/segmentProps';\n\nexport default {\n providers: {\n segment: {\n type: 'track',\n name: 'fe_first_time_login',\n props: {\n ...segmentProps,\n },\n },\n },\n};\n","import segmentProps from '../lib/segmentProps';\n\nexport default {\n providers: {\n segment: {\n type: 'track',\n name: 'fe_product_apply_clicked',\n props: {\n ...segmentProps,\n category: '#context.category',\n label: '#context.label',\n scoreBand: '?#context.scoreBand',\n isNewUser: '?#context.isNewUser',\n hero_rating: '?#context.productHeroRating',\n },\n },\n },\n};\n","import segmentProps from '../lib/segmentProps';\n\nexport default {\n providers: {\n segment: {\n type: 'track',\n name: 'fe_credit_score_band_requested',\n props: {\n ...segmentProps,\n },\n },\n },\n};\n","import setupTrackingEpic from '@clearscore/epic.tracking';\nimport setupTrackingMiddleWare from '@clearscore/redux.tracking-middleware';\n\nimport config from './config';\n\nexport const trackingEpic = setupTrackingEpic(config);\nexport const trackingMiddleware = setupTrackingMiddleWare(config);\n","import { types as identityTypes } from '@clearscore/redux.identity';\nimport { types as productsTypes } from '@clearscore/redux.products';\nimport { types as dashboardTypes } from '@clearscore/redux.dashboard';\n\nimport { FIRST_TIME_LOGIN, PRODUCT_APPLY_CLICK, SCORE_BAND_RECEIVED } from './events';\n\nexport default {\n [identityTypes.IDENTITY_FIRST_TIME_REGISTRATION]: [FIRST_TIME_LOGIN],\n [productsTypes.PRODUCTS_APPLY_CLICK]: [PRODUCT_APPLY_CLICK],\n [dashboardTypes.DASHBOARD_FETCH_SUCCESS]: [SCORE_BAND_RECEIVED],\n};\n","import getEnv from '@clearscore/helpers.envs';\n\nconst NATIVE_BRIDGE = 'nativeBridge';\nconst NATIVE_BRIDGE_FUNCTION = 'stream';\n\n/**\n * Checks to see if the device supports safari messageHandlers\n */\nfunction _hasIosBridge() {\n const useIosBridge = getEnv('ENABLE_IOS_MESSAGE_HANDLER');\n return !!(\n useIosBridge &&\n window &&\n window.webkit &&\n window.webkit.messageHandlers &&\n window.webkit.messageHandlers.callback &&\n window.webkit.messageHandlers.callback &&\n typeof window.webkit.messageHandlers.callback.postMessage === 'function'\n );\n}\n\n/**\n * Checks to see if the native bridge is present\n * @return Boolean\n * @private\n */\nfunction _hasNativeBridge() {\n return !!(\n window &&\n window[NATIVE_BRIDGE] &&\n window[NATIVE_BRIDGE][NATIVE_BRIDGE_FUNCTION] &&\n typeof window[NATIVE_BRIDGE][NATIVE_BRIDGE_FUNCTION] === 'function'\n );\n}\n\n/**\n * Check for any data bridge\n * @param {*} next\n * @param {*} action\n */\nfunction _hasBridge() {\n return _hasIosBridge() || _hasNativeBridge();\n}\n\n/**\n * Send the action to the native bridge and continue\n * @param {function} next next middleware func\n * @param {object} action redux action\n * @returns {void}\n */\nfunction _sendAction(next, action) {\n const message = JSON.stringify(action);\n if (_hasIosBridge()) {\n window.webkit.messageHandlers.callback.postMessage(message);\n } else {\n window[NATIVE_BRIDGE][NATIVE_BRIDGE_FUNCTION](message);\n }\n next(action);\n}\n\n/**\n * If native bridge is available then send the action to the native bridge\n * @returns {Function} middleware\n */\nconst nativeBridgeMiddleware = () => () => (next) => (action) =>\n _hasBridge() ? _sendAction(next, action) : next(action);\n\nexport default nativeBridgeMiddleware;\n","export const NOVA_USER_FETCH = 'CS/NOVA_USER_FETCH';\nexport const NOVA_USER_FETCH_SUCCESS = `${NOVA_USER_FETCH}_SUCCESS`;\nexport const NOVA_USER_FETCH_ERROR = `${NOVA_USER_FETCH}_ERROR`;\n\nexport const NOVA_USER_SAVE = 'CS/NOVA_USER_SAVE';\nexport const NOVA_USER_SAVE_SUCCESS = `${NOVA_USER_SAVE}_SUCCESS`;\nexport const NOVA_USER_SAVE_ERROR = `${NOVA_USER_SAVE}_ERROR`;\n\nexport const NOVA_USER_RESET = 'CS/NOVA_USER_RESET';\n","import * as actionsImport from './nova-user.actions';\nimport * as reducersImport from './reducers';\nimport * as selectorsImport from './selectors';\nimport * as typesImport from './nova-user.types';\n\nexport const actions = actionsImport;\nexport const reducers = reducersImport;\nexport const selectors = selectorsImport;\nexport const types = typesImport;\n","import monitoring from '@clearscore/helpers.monitoring';\nimport { types as profileTypes } from '@clearscore/redux.profile';\nimport { types as marketTypes } from '@clearscore/redux.market';\nimport { types as novaUserActionTypes } from '@clearscore/redux.nova-user';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\n/**\n * Send the action.type to monitoring as an info\n * @param {function} next next middleware func\n * @param {object} action redux action\n * @returns {void}\n */\nfunction _sendAction(zone, next, action) {\n const { payload, type, requestMeta } = action;\n switch (type) {\n case marketTypes.MARKET_SET_ACTIVE_MARKET:\n monitoring.tag('market', resolveProp('market', payload));\n break;\n case profileTypes.PROFILE_FETCH_SUCCESS:\n monitoring.identity(resolveProp('uuid', payload));\n monitoring.tag('idv_status', resolveProp('accountIDVStatus', payload));\n break;\n case marketTypes.MARKET_FETCH_CONFIG_SUCCESS:\n break;\n case marketTypes.MARKET_FETCH_CONFIG_ERROR:\n monitoring.tag('market_fetch_config_error', resolveProp('market', requestMeta));\n break;\n case novaUserActionTypes.NOVA_USER_FETCH_SUCCESS:\n monitoring.identity(resolveProp('email', payload));\n monitoring.tag('user_roles', resolveProp('roles', payload));\n break;\n default:\n break;\n }\n\n if (action && action.type) {\n monitoring.addBreadcrumb({\n category: 'actions',\n message: `${zone}: [${action.type}]`,\n level: 'info',\n });\n }\n\n next(action);\n}\n\n/**\n * Pass all actions to the monitoring\n * @returns {Function} middleware\n */\nconst monitoringMiddleware = (zone) => () => (next) => (action) => _sendAction(zone, next, action);\n\nexport default monitoringMiddleware;\n","'use strict';\n\nvar isMergeableObject = function isMergeableObject(value) {\n\treturn isNonNullObject(value)\n\t\t&& !isSpecial(value)\n};\n\nfunction isNonNullObject(value) {\n\treturn !!value && typeof value === 'object'\n}\n\nfunction isSpecial(value) {\n\tvar stringValue = Object.prototype.toString.call(value);\n\n\treturn stringValue === '[object RegExp]'\n\t\t|| stringValue === '[object Date]'\n\t\t|| isReactElement(value)\n}\n\n// see https://github.com/facebook/react/blob/b5ac963fb791d1298e7f396236383bc955f916c1/src/isomorphic/classic/element/ReactElement.js#L21-L25\nvar canUseSymbol = typeof Symbol === 'function' && Symbol.for;\nvar REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for('react.element') : 0xeac7;\n\nfunction isReactElement(value) {\n\treturn value.$$typeof === REACT_ELEMENT_TYPE\n}\n\nfunction emptyTarget(val) {\n\treturn Array.isArray(val) ? [] : {}\n}\n\nfunction cloneUnlessOtherwiseSpecified(value, options) {\n\treturn (options.clone !== false && options.isMergeableObject(value))\n\t\t? deepmerge(emptyTarget(value), value, options)\n\t\t: value\n}\n\nfunction defaultArrayMerge(target, source, options) {\n\treturn target.concat(source).map(function(element) {\n\t\treturn cloneUnlessOtherwiseSpecified(element, options)\n\t})\n}\n\nfunction getMergeFunction(key, options) {\n\tif (!options.customMerge) {\n\t\treturn deepmerge\n\t}\n\tvar customMerge = options.customMerge(key);\n\treturn typeof customMerge === 'function' ? customMerge : deepmerge\n}\n\nfunction getEnumerableOwnPropertySymbols(target) {\n\treturn Object.getOwnPropertySymbols\n\t\t? Object.getOwnPropertySymbols(target).filter(function(symbol) {\n\t\t\treturn target.propertyIsEnumerable(symbol)\n\t\t})\n\t\t: []\n}\n\nfunction getKeys(target) {\n\treturn Object.keys(target).concat(getEnumerableOwnPropertySymbols(target))\n}\n\nfunction propertyIsOnObject(object, property) {\n\ttry {\n\t\treturn property in object\n\t} catch(_) {\n\t\treturn false\n\t}\n}\n\n// Protects from prototype poisoning and unexpected merging up the prototype chain.\nfunction propertyIsUnsafe(target, key) {\n\treturn propertyIsOnObject(target, key) // Properties are safe to merge if they don't exist in the target yet,\n\t\t&& !(Object.hasOwnProperty.call(target, key) // unsafe if they exist up the prototype chain,\n\t\t\t&& Object.propertyIsEnumerable.call(target, key)) // and also unsafe if they're nonenumerable.\n}\n\nfunction mergeObject(target, source, options) {\n\tvar destination = {};\n\tif (options.isMergeableObject(target)) {\n\t\tgetKeys(target).forEach(function(key) {\n\t\t\tdestination[key] = cloneUnlessOtherwiseSpecified(target[key], options);\n\t\t});\n\t}\n\tgetKeys(source).forEach(function(key) {\n\t\tif (propertyIsUnsafe(target, key)) {\n\t\t\treturn\n\t\t}\n\n\t\tif (propertyIsOnObject(target, key) && options.isMergeableObject(source[key])) {\n\t\t\tdestination[key] = getMergeFunction(key, options)(target[key], source[key], options);\n\t\t} else {\n\t\t\tdestination[key] = cloneUnlessOtherwiseSpecified(source[key], options);\n\t\t}\n\t});\n\treturn destination\n}\n\nfunction deepmerge(target, source, options) {\n\toptions = options || {};\n\toptions.arrayMerge = options.arrayMerge || defaultArrayMerge;\n\toptions.isMergeableObject = options.isMergeableObject || isMergeableObject;\n\t// cloneUnlessOtherwiseSpecified is added to `options` so that custom arrayMerge()\n\t// implementations can use it. The caller may not replace it.\n\toptions.cloneUnlessOtherwiseSpecified = cloneUnlessOtherwiseSpecified;\n\n\tvar sourceIsArray = Array.isArray(source);\n\tvar targetIsArray = Array.isArray(target);\n\tvar sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;\n\n\tif (!sourceAndTargetTypesMatch) {\n\t\treturn cloneUnlessOtherwiseSpecified(source, options)\n\t} else if (sourceIsArray) {\n\t\treturn options.arrayMerge(target, source, options)\n\t} else {\n\t\treturn mergeObject(target, source, options)\n\t}\n}\n\ndeepmerge.all = function deepmergeAll(array, options) {\n\tif (!Array.isArray(array)) {\n\t\tthrow new Error('first argument should be an array')\n\t}\n\n\treturn array.reduce(function(prev, next) {\n\t\treturn deepmerge(prev, next, options)\n\t}, {})\n};\n\nvar deepmerge_1 = deepmerge;\n\nmodule.exports = deepmerge_1;\n","/* eslint-disable no-useless-escape */\n\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\n/**\n * Predicate to evaluate if given value is a string beginning with @\n * @param {string} val to check\n * @returns {boolean} if item is object\n */\nconst _shouldLookupProperty = (val) => typeof val === 'string' && val.startsWith('@');\n\n/**\n * Look through given url string and attempt to resolve any values beginning with @ from given context\n * @param {Object} context state to resolve values from\n * @param {string} urlString url string\n * @returns {string} URL with values interpolated\n */\nconst interpolateValues = (context, urlString = '') => {\n let interpolatedUrlString = urlString;\n\n function _resolveProp(prefixedPath) {\n const isOptionalProp = prefixedPath.startsWith('?@');\n const prefixLength = isOptionalProp ? 2 : 1;\n const resolvedProp = resolveProp(prefixedPath.substring(prefixLength), context);\n if (!resolvedProp) {\n return isOptionalProp ? null : prefixedPath;\n }\n\n return resolvedProp;\n }\n\n const matches = interpolatedUrlString.match(/(@.[^\\/]*)/);\n\n if (matches && matches.length) {\n matches.forEach((match) => {\n const resolvedProp = _shouldLookupProperty(match) ? _resolveProp(match) : match;\n interpolatedUrlString = resolvedProp\n ? interpolatedUrlString.replace(match, resolvedProp)\n : interpolatedUrlString;\n });\n }\n\n return interpolatedUrlString;\n};\n\nexport default interpolateValues;\n","import hasClientData from '@clearscore/helpers.has-client-data';\n\nimport interpolateValues from './interpolateValues';\n\n/**\n * check for url property and replace common variables\n * @param {object} action redux action\n * @param {object} store redux store\n * @returns {object} action redux action\n */\nfunction _addVariables(action, store) {\n const {\n payload: { request },\n } = action;\n const state = store.getState();\n\n if (request.url) {\n request.url = interpolateValues(state, request.url);\n }\n\n return action;\n}\n\n/**\n * If the action payload has a client object, check and replace common variables.\n * @param {object} action redux action\n * @param {object} store redux store\n * @returns {function} function that takes an action and returns an action\n */\nconst addUrlVariables = (store) => (action) => hasClientData(action) ? _addVariables(action, store) : action;\n\nexport default addUrlVariables;\n","/* eslint-disable camelcase */\nimport { defer } from 'rxjs';\nimport deepmerge from 'deepmerge';\nimport addClientInstance from '@clearscore/lib.webapp-core.add-client-instance';\nimport addUrlVariables from '@clearscore/helpers.add-url-variables';\n\nfunction createRequestAction(store, action) {\n const addVars = addUrlVariables(store);\n\n return addVars(addClientInstance(store, action));\n}\n\nfunction fromRequestAction({ payload: { request = {}, meta } }, extendRequest) {\n if (extendRequest) return defer(() => meta.client(deepmerge(request, extendRequest)));\n return defer(() => meta.client(request));\n}\n\n/**\n * Check if action has correct structure in payload required for middleware\n * @param {object} action redux action\n * @returns {boolean} if action structure is correct\n */\nfunction hasData(action) {\n return action?.payload?.request?.headers && action?.payload?.request?.url && action?.payload?.meta;\n}\n\n/**\n * Perform API request\n * @param {object} store redux store\n * @param {function} next next middleware func\n * @param {object} action redux action\n * @returns {void}\n */\nfunction handleRequest(store, next, requestAction) {\n // dispatch original action type to reducer before attempting request\n next(requestAction);\n\n const {\n payload: { request = {} },\n } = requestAction;\n\n const dispatchSuccess = (response, requestData) =>\n store.dispatch({\n type: `${requestAction.type}_SUCCESS`,\n payload: response.data,\n requestData: requestData.data,\n requestMeta: requestData.meta,\n statusCode: response.status,\n });\n\n // eslint-disable-next-line arrow-body-style\n const dispatchError = (res = {}, requestData) => {\n // console.log(res, requestData)\n return store.dispatch({\n type: `${requestAction.type}_ERROR`,\n payload: res.response ? res.response : res,\n requestMeta: requestData.meta,\n statusCode: res.response?.status,\n });\n };\n\n const oAuthRequest$ = fromRequestAction(requestAction);\n\n oAuthRequest$.subscribe(\n (response) => dispatchSuccess(response, request),\n (response) => dispatchError(response, request),\n );\n}\n\n/**\n * If action has correct signature, perform API request.\n * Dispatch success or error actions\n * @param {object} store redux store\n * @returns {Function} middleware\n */\nconst requestMiddleware = (store) => (next) => (action) => {\n // add request data from helpers\n const requestAction = createRequestAction(store, action);\n return hasData(requestAction) ? handleRequest(store, next, requestAction) : next(requestAction);\n};\n\nexport default requestMiddleware;\n","import withVerticalFactory from '@clearscore-group/lib.flux-core.common-vertical';\n\nimport verticalReducers from './lib/reducers';\nimport verticalMiddleware from './lib/middleware';\n\nexport const reducers = verticalReducers;\nexport const middleware = verticalMiddleware;\nexport default withVerticalFactory(middleware, reducers);\n","import { reducers as session } from '@clearscore/redux.session';\nimport { reducers as routes } from '@clearscore/redux.routes';\nimport { reducers as profile } from '@clearscore/redux.profile';\nimport { reducers as market } from '@clearscore/redux.market';\n\nexport default function combine({ entities, ...reducers }) {\n return {\n entities: {\n ...routes.entities,\n ...entities,\n },\n market: market.domain,\n session: session.domain,\n profile: profile.domain,\n ...reducers,\n };\n}\n","/* eslint-disable react/prop-types */\nimport React, { useState, useEffect } from 'react';\nimport configureStore, { Provider, browserHistory } from '@clearscore/redux.store';\nimport { resolveProp } from '@clearscore/helpers.resolve-props';\n\nimport VerticalError from './components/error';\nimport trimState from './lib/trim-state';\nimport insertIfExists from './lib/insert-if-exists';\n\nconst createVerticalStoreFactory =\n ({ name, reducer = {}, middleware = [], epics = null, appBridgeTypes = [], verticalMiddleware, reducers }) =>\n ({ dispatch, initialState, coreAppBridgeTypes, history }) => {\n const allReducers = reducers(reducer);\n return configureStore({\n initialState: trimState(allReducers, initialState),\n reducers: allReducers,\n name,\n coreDispatch: dispatch,\n pageMiddleWare: [...insertIfExists(verticalMiddleware(name)), ...insertIfExists(middleware)],\n pageEpics: epics,\n appBridgeTypes: [...insertIfExists(coreAppBridgeTypes), ...insertIfExists(appBridgeTypes)],\n history,\n });\n };\n\n// TODO: remove vertical level appBridgeTypes when ALL apps have migrated to use @scaffolding/core-app\nconst withVerticalFactory =\n (verticalMiddleware, reducers) =>\n (Component, { name, reducer = {}, middleware = [], epics = null, appBridgeTypes = [] }) => {\n const createVerticalStore = createVerticalStoreFactory({\n name,\n reducer,\n middleware,\n epics,\n appBridgeTypes,\n verticalMiddleware,\n reducers,\n });\n\n const WithVerticalStateful = (props) => {\n const { children, routeConfig: { id, routeProps = {} } = {}, ...restProps } = props;\n const [store, setStore] = useState();\n const [history, setHistory] = useState();\n\n useEffect(() => {\n const { dispatch, coreAppBridgeTypes, initialState, history: _history = browserHistory() } = props;\n const _store = createVerticalStore({ dispatch, initialState, coreAppBridgeTypes, history: _history });\n\n setStore(_store);\n setHistory(_history);\n }, [id]); // eslint-disable-line react-hooks/exhaustive-deps\n\n if (!store) return null;\n\n return (\n \n \n {typeof children === 'function' ? children({ store, history }) : children || null}\n \n \n );\n };\n\n return ({ initialState = {}, dispatch, ...props }) => (\n \n \n \n );\n };\n\nexport default withVerticalFactory;\n","import { trackingMiddleware } from '@clearscore/lib.webapp-core.tracking';\nimport nativeBridgeMiddleware from '@clearscore/redux.native-bridge-middleware';\nimport monitoringMiddleware from '@clearscore/redux.monitoring-middleware';\nimport requestMiddleWare from '@clearscore/lib.webapp-core.request-middleware';\n\nexport default function verticalMiddleware(verticalName) {\n return [requestMiddleWare, monitoringMiddleware(verticalName), nativeBridgeMiddleware(), trackingMiddleware];\n}\n","import type { ReactElement, ReactNode } from 'react';\nimport React from 'react';\nimport cx from 'classnames';\nimport toTitleCase from '@clearscore/normalize.title-case';\n\nimport styles from './container.module.css';\n\nconst Theme = {\n TRANSPARENT: 'TRANSPARENT',\n WHITE: 'WHITE',\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n} as const;\n\nconst Size = {\n TINY: 'TINY',\n SMALL: 'SMALL',\n MEDIUM: 'MEDIUM',\n MEDIUM_LARGE: 'MEDIUM_LARGE',\n LARGE: 'LARGE',\n HUGE: 'HUGE',\n MAX: 'MAX',\n} as const;\n\nconst Spacing = {\n NONE: 'NONE',\n MICRO: 'MICRO',\n TINY: 'TINY',\n SMALL: 'SMALL',\n MEDIUM: 'MEDIUM',\n LARGE: 'LARGE',\n BIG: 'BIG',\n HUGE: 'HUGE',\n SUPER: 'SUPER',\n JUMBO: 'JUMBO',\n} as const;\n\ninterface IContainerProps {\n size?: typeof Size[keyof typeof Size];\n theme?: typeof Theme[keyof typeof Theme];\n top?: typeof Spacing[keyof typeof Spacing];\n bottom?: typeof Spacing[keyof typeof Spacing];\n dataId?: string;\n children: ReactNode;\n isFullHeight?: boolean;\n excludeGutter?: boolean;\n isTranslucent?: boolean;\n}\n\nexport interface ContainerExport {\n (props: IContainerProps): ReactElement;\n Spacing: typeof Spacing;\n Theme: typeof Theme;\n Size: typeof Size;\n}\n\nconst Container: ContainerExport = ({\n size = Size.MAX,\n theme = Theme.TRANSPARENT,\n top = Spacing.NONE,\n bottom = Spacing.NONE,\n isFullHeight = false,\n excludeGutter = false,\n dataId,\n children,\n isTranslucent = false,\n}) => {\n const containerClass = cx(styles.container, styles[`isTheme${toTitleCase(theme)}`], {\n [styles.isFullHeight]: isFullHeight,\n [styles.isTranslucent]: isTranslucent,\n });\n const contentContainerClass = cx(\n styles.contentContainer,\n styles[`isSize${toTitleCase(size)}`],\n styles[`isTopSpacing${toTitleCase(top)}`],\n styles[`isBottomSpacing${toTitleCase(bottom)}`],\n {\n [styles.excludeGutter]: excludeGutter,\n },\n );\n return (\n
\n
\n {children}\n
\n
\n );\n};\n\nContainer.Spacing = Spacing;\nContainer.Theme = Theme;\nContainer.Size = Size;\n\nexport default Container;\n","const PROSPECT = 'CS/PROSPECT';\n\nexport const PROSPECT_GET = `${PROSPECT}_GET`;\nexport const PROSPECT_GET_SUCCESS = `${PROSPECT}_GET_SUCCESS`;\nexport const PROSPECT_GET_ERROR = `${PROSPECT}_GET_ERROR`;\n\nexport const PROSPECT_REGISTER = `${PROSPECT}_REGISTER`;\n\nexport const PROSPECT_CREATE = `${PROSPECT}_CREATE`;\nexport const PROSPECT_CREATE_SUCCESS = `${PROSPECT}_CREATE_SUCCESS`;\nexport const PROSPECT_CREATE_ERROR = `${PROSPECT}_CREATE_ERROR`;\n\nexport const PROSPECT_CLEAR = `${PROSPECT}_CLEAR`;\n","import * as requestStatuses from '@clearscore/constants.request-statuses';\nimport { PROFILE_FETCH_SUCCESS } from '@clearscore/constants.profile-action-types';\n\nimport {\n PROSPECT_GET,\n PROSPECT_GET_SUCCESS,\n PROSPECT_GET_ERROR,\n PROSPECT_REGISTER,\n PROSPECT_CREATE,\n PROSPECT_CREATE_SUCCESS,\n PROSPECT_CREATE_ERROR,\n PROSPECT_CLEAR,\n} from '../prospect.types';\n\nconst initialState = {\n status: requestStatuses.INITIAL,\n};\n\nconst domain = (state = initialState, action = {}) => {\n const { type, payload } = action;\n\n switch (type) {\n case PROSPECT_REGISTER:\n return {\n ...state,\n ...payload,\n };\n case PROSPECT_GET:\n case PROSPECT_CREATE:\n return {\n ...state,\n status: requestStatuses.PENDING,\n };\n case PROSPECT_GET_SUCCESS:\n case PROSPECT_CREATE_SUCCESS:\n return {\n ...state,\n ...payload,\n status: requestStatuses.SUCCESS,\n };\n case PROSPECT_GET_ERROR:\n case PROSPECT_CREATE_ERROR:\n return {\n ...state,\n status: requestStatuses.ERROR,\n };\n case PROSPECT_CLEAR:\n case PROFILE_FETCH_SUCCESS:\n return initialState;\n default:\n return state;\n }\n};\n\nexport default domain;\n","/* eslint-disable import/prefer-default-export */\nimport prospectDomain from './prospect.domain';\n\nexport const domain = prospectDomain;\n","import * as actionsImport from './prospect.actions';\nimport * as typesImport from './prospect.types';\nimport * as reducersImport from './reducers';\nimport * as selectorsImport from './selectors/index';\n\nexport const actions = actionsImport;\nexport const reducers = reducersImport;\nexport const selectors = selectorsImport;\nexport const types = typesImport;\n","// Ramda v0.26.1\n// https://github.com/ramda/ramda\n// (c) 2013-2019 Scott Sauyet, Michael Hurley, and David Chambers\n// Ramda may be freely distributed under the MIT license.\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n typeof define === 'function' && define.amd ? define(['exports'], factory) :\n (factory((global.R = {})));\n}(this, (function (exports) { 'use strict';\n\n function _cloneRegExp(pattern) {\n return new RegExp(pattern.source, (pattern.global ? 'g' : '') +\n (pattern.ignoreCase ? 'i' : '') +\n (pattern.multiline ? 'm' : '') +\n (pattern.sticky ? 'y' : '') +\n (pattern.unicode ? 'u' : ''));\n }\n\n function _isPlaceholder(a) {\n return a != null &&\n typeof a === 'object' &&\n a['@@functional/placeholder'] === true;\n }\n\n /**\n * Optimized internal one-arity curry function.\n *\n * @private\n * @category Function\n * @param {Function} fn The function to curry.\n * @return {Function} The curried function.\n */\n function _curry1(fn) {\n return function f1(a) {\n if (arguments.length === 0 || _isPlaceholder(a)) {\n return f1;\n } else {\n return fn.apply(this, arguments);\n }\n };\n }\n\n /**\n * Gives a single-word string description of the (native) type of a value,\n * returning such answers as 'Object', 'Number', 'Array', or 'Null'. Does not\n * attempt to distinguish user Object types any further, reporting them all as\n * 'Object'.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Type\n * @sig (* -> {*}) -> String\n * @param {*} val The value to test\n * @return {String}\n * @example\n *\n * R.type({}); //=> \"Object\"\n * R.type(1); //=> \"Number\"\n * R.type(false); //=> \"Boolean\"\n * R.type('s'); //=> \"String\"\n * R.type(null); //=> \"Null\"\n * R.type([]); //=> \"Array\"\n * R.type(/[A-z]/); //=> \"RegExp\"\n * R.type(() => {}); //=> \"Function\"\n * R.type(undefined); //=> \"Undefined\"\n */\n var type = _curry1(function type(val) {\n return val === null\n ? 'Null'\n : val === undefined\n ? 'Undefined'\n : Object.prototype.toString.call(val).slice(8, -1);\n });\n\n /**\n * Copies an object.\n *\n * @private\n * @param {*} value The value to be copied\n * @param {Array} refFrom Array containing the source references\n * @param {Array} refTo Array containing the copied source references\n * @param {Boolean} deep Whether or not to perform deep cloning.\n * @return {*} The copied value.\n */\n function _clone(value, refFrom, refTo, deep) {\n var copy = function copy(copiedValue) {\n var len = refFrom.length;\n var idx = 0;\n while (idx < len) {\n if (value === refFrom[idx]) {\n return refTo[idx];\n }\n idx += 1;\n }\n refFrom[idx + 1] = value;\n refTo[idx + 1] = copiedValue;\n for (var key in value) {\n copiedValue[key] = deep ?\n _clone(value[key], refFrom, refTo, true) : value[key];\n }\n return copiedValue;\n };\n switch (type(value)) {\n case 'Object': return copy({});\n case 'Array': return copy([]);\n case 'Date': return new Date(value.valueOf());\n case 'RegExp': return _cloneRegExp(value);\n default: return value;\n }\n }\n\n /**\n * Creates a deep copy of the value which may contain (nested) `Array`s and\n * `Object`s, `Number`s, `String`s, `Boolean`s and `Date`s. `Function`s are\n * assigned by reference rather than copied\n *\n * Dispatches to a `clone` method if present.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig {*} -> {*}\n * @param {*} value The object or array to clone\n * @return {*} A deeply cloned copy of `val`\n * @example\n *\n * const objects = [{}, {}, {}];\n * const objectsClone = R.clone(objects);\n * objects === objectsClone; //=> false\n * objects[0] === objectsClone[0]; //=> false\n */\n var clone = _curry1(function clone(value) {\n return value != null && typeof value.clone === 'function' ?\n value.clone() :\n _clone(value, [], [], true);\n });\n\n exports.clone = clone;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n})));\n","'use strict';\n\nmodule.exports = require('./clone').clone;\n","/**\n * Lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright JS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\n/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\n/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n Map = getNative(root, 'Map'),\n Promise = getNative(root, 'Promise'),\n Set = getNative(root, 'Set'),\n WeakMap = getNative(root, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\n/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(array);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length &&\n (typeof value == 'number' || reIsUint.test(value)) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = isEqual;\n","export const SUCCESS = 'SUCCESS';\nexport const ERROR = 'ERROR';\nexport const RESET = 'RESET';\n\nexport const successType = (type) => `${type}_${SUCCESS}`;\nexport const errorType = (type) => `${type}_${ERROR}`;\nexport const resetType = (type) => `${type}_${RESET}`;\n\nexport const getTypes = (type) => ({\n pending: type,\n success: successType(type),\n error: errorType(type),\n reset: resetType(type),\n});\n","import * as requestStatuses from '@clearscore/constants.request-statuses';\n\nimport { getTypes } from './types';\n\nexport default (TYPE) => {\n const TYPES = getTypes(TYPE);\n const initialState = {\n status: requestStatuses.INITIAL,\n };\n return (state = initialState, action = {}) => {\n const { payload = {}, type = '' } = action;\n switch (type) {\n case TYPES.pending:\n return {\n ...state,\n status: requestStatuses.PENDING,\n statusCode: undefined,\n request: action.requestData,\n meta: payload?.request?.meta,\n };\n case TYPES.success:\n return {\n ...state,\n status: requestStatuses.SUCCESS,\n data: payload?.data || payload,\n statusCode: action.statusCode,\n request: action.requestData,\n meta: action.requestMeta,\n };\n case TYPES.error:\n return {\n ...state,\n status: requestStatuses.ERROR,\n data: payload?.data || payload,\n statusCode: action.statusCode || payload?.status,\n request: action.requestData,\n meta: action.requestMeta,\n };\n case TYPES.reset:\n return {\n ...state,\n status: requestStatuses.INITIAL,\n statusCode: undefined,\n request: undefined,\n meta: undefined,\n };\n default:\n return state;\n }\n };\n};\n","/* eslint-disable guard-for-in, no-restricted-syntax */\nimport clonedeep from 'ramda.clone';\nimport isEqual from 'lodash.isequal';\n\nimport requestReducerFactory from './request-reducer';\n\nconst reducersFactory = (actionTypes) =>\n Object.keys(actionTypes).reduce(\n (prev, actionType) => ({\n ...prev,\n [actionType]: requestReducerFactory(actionTypes[actionType]),\n }),\n {},\n );\n\nconst createReducers = (actionTypes) => {\n const reducers = reducersFactory(actionTypes);\n\n const reduce = (stateValue, action) => {\n const mutatableCopy = clonedeep(stateValue);\n for (const currentReducerKey in reducers) {\n // eslint-disable-next-line no-param-reassign\n mutatableCopy[currentReducerKey] = reducers[currentReducerKey](mutatableCopy[currentReducerKey], action);\n }\n return isEqual(stateValue, mutatableCopy) ? stateValue : mutatableCopy;\n };\n return (state = {}, action = {}) => reduce(state, action);\n};\n\nexport default createReducers;\n","import createAction from '@clearscore/helpers.create-action';\nimport { createSelector } from 'reselect';\nimport resolveRequest, { getRequestStatus } from '@clearscore/helpers.resolve-request';\n\nimport createReducers from './reducers';\nimport { getTypes } from './types';\n\nconst snakify = (input) =>\n input\n .split(/(?=[A-Z])/)\n .join('_')\n .toUpperCase();\n\nconst createActionSelector = (moduleName, type) =>\n createSelector(\n (state) => resolveRequest(state, `${moduleName}.${type}`),\n (result) => result,\n );\nconst createStatusSelector = (moduleName, type) =>\n createSelector(createActionSelector(moduleName, type), ({ status, statusCode }) =>\n getRequestStatus(status, statusCode),\n );\n\nexport default ({ moduleName, actionCreators, customReducer }) => {\n // eslint-disable-next-line default-param-last\n const createActionType = (prev = {}, actionName) => ({\n ...prev,\n [actionName]: `CS/${snakify(moduleName)}_${snakify(actionName)}`,\n });\n const createType = (prev, actionName, actionTypes) => ({\n ...prev,\n [actionName]: getTypes(actionTypes[actionName]),\n });\n const createActions = (prev, actionName, types) => ({\n ...prev,\n [actionName]: actionCreators[actionName](types[actionName].pending),\n [`${actionName}Reset`]: (payload) => createAction(types[actionName].reset, payload),\n });\n const createSelectors = (prev, actionName) => ({\n ...prev,\n [actionName]: {\n getState: createActionSelector(moduleName, actionName),\n getStatus: createStatusSelector(moduleName, actionName),\n },\n });\n\n const { types, actions, selectors, actionTypes } = Object.keys(actionCreators).reduce((prev, actionName) => {\n const newActionTypes = createActionType(prev.actionTypes, actionName);\n const newType = createType(prev.types, actionName, newActionTypes);\n const newActions = createActions(prev.actions, actionName, newType);\n const newSelectors = createSelectors(prev.selectors, actionName);\n return {\n ...prev,\n actionTypes: newActionTypes,\n types: newType,\n actions: newActions,\n selectors: newSelectors,\n };\n }, {});\n\n return {\n reducers: {\n domain: createReducers(actionTypes, customReducer),\n },\n types,\n actionTypes,\n actions,\n selectors,\n };\n};\n","import createReduxModule from '@clearscore/redux.create-requests';\n\nimport * as actionCreators from './actions';\n\nconst redux = createReduxModule({ moduleName: 'login', actionCreators });\n\nexport const { types } = redux;\nexport const { actions } = redux;\nexport const { reducers } = redux;\nexport const { selectors } = redux;\n","import createAction from '@clearscore/helpers.create-action';\nimport createRequestPayload from '@clearscore/helpers.create-request-payload';\n\nexport const showSentCodeAlert = (TYPE) => (mobileNumber) => ({ type: TYPE, payload: mobileNumber });\n\nexport const showTwoFactorAppAlert = (TYPE) => () => ({ type: TYPE });\n\nexport const resendTwoFactorAuth =\n (TYPE) =>\n ({ twoFactorAuthState, mobileNumber }, meta) =>\n createAction(\n TYPE,\n createRequestPayload(\n 'international',\n '/login-service/v3/resend-2fa',\n 'post',\n {\n '2fa_state': twoFactorAuthState,\n },\n { ...meta, mobileNumber },\n ),\n );\n\nexport const verifyTwoFactorAuth =\n (TYPE) =>\n ({ code, twoFactorAuthState, ...restData }, meta) =>\n createAction(\n TYPE,\n createRequestPayload(\n 'international',\n '/login-service/v3/verify-2fa',\n 'post',\n {\n ...restData,\n '2fa_state': twoFactorAuthState,\n '2fa_response': code,\n },\n meta,\n ),\n );\n","import { reducers as session } from '@clearscore/redux.session';\nimport { reducers as prospect } from '@clearscore/redux.prospect';\nimport { reducers as alerts } from '@clearscore/redux.alerts';\n\nimport { reducers } from '../redux';\n\nexport default {\n session: session.domain,\n alerts: alerts.domain,\n prospect: prospect.domain,\n login: reducers.domain,\n};\n","// Generate UUID\nfunction s4() {\n return Math.floor((1 + Math.random()) * 0x10000)\n .toString(16)\n .substring(1);\n}\n\nfunction getId() {\n // eslint-disable-next-line no-undef\n return typeof crypto !== 'undefined' && typeof crypto?.randomUUID === 'function'\n ? // eslint-disable-next-line no-undef\n crypto.randomUUID()\n : // TODO: remove when everything is on node 16 and browser support is stable\n `${s4() + s4()}-${s4()}-${s4()}-${s4()}-${s4()}${s4()}${s4()}`;\n}\n\nexport default getId;\n\nexport function addIdToItem(item) {\n return {\n ...item,\n id: item.id ? item.id : getId(),\n };\n}\n\nexport function addIdToCollectionItems(collection) {\n return collection.map(addIdToItem);\n}\n","import React from 'react';\nimport uid from '@clearscore/helpers.uid';\n// Match and extract values for 3 groups. For <0>foo bar it will match:\n// 1. Opening brackets for component - <0>\n// 2. Children component - foo bar\n// 3. Closing brackets for component - \nconst ELEMENT_MATCH_REGEX = /<(\\d)>(.*?)<\\/(\\d)>/;\n\n// Match whole group with closing brackets e.g. <0>foo bar\nconst GROUP_MATCH_REGEX = /(<\\d>.*?<\\/\\d>)/;\n\n/**\n * Given a string parsers xml tags and maps indexes to components array values\n * to render appropriate component.\n *\n * @param {string} lang content which might contain special tags\n * @param {{ Component: import('react').ComponentType, props: object }[]} components array of components and\n * props to pass if they are rendered\n *\n * @returns {import('react').ReactNodeArray} array of renderable elements\n */\nconst interpolateString = (lang, components) => {\n const interpolations = lang.match(GROUP_MATCH_REGEX);\n if (!interpolations) return lang;\n return lang.split(GROUP_MATCH_REGEX).map((str) => {\n const componentMatch = str.match(ELEMENT_MATCH_REGEX);\n if (!componentMatch) return str;\n\n const [, ComponentOpeningIndex, children, ComponentClosingIndex] = componentMatch;\n const componentIndex = ComponentOpeningIndex === ComponentClosingIndex ? ComponentOpeningIndex : null;\n\n if (!componentIndex) return str;\n\n const { Component, props = {} } = components[componentIndex];\n\n return React.createElement(Component, { ...props, key: props.key || uid() }, children);\n });\n};\n\nexport default interpolateString;\n","import interpolateValues from '@clearscore/helpers.interpolate-values';\n\nconst CONFIG_SUBSTRING = '{(.*)}';\n\nconst interpolateKey = (key, state, message) => {\n const { interpolated } = interpolateValues(state, { interpolated: key });\n return message.replace(`{${key}}`, interpolated);\n};\n\nexport default (message, state) => {\n if (!message) throw new Error('Alert passed as configuration without a message');\n const keyFromMessage = message.match(new RegExp(CONFIG_SUBSTRING));\n return keyFromMessage ? interpolateKey(keyFromMessage[1], state, message) : message;\n};\n","/* eslint-disable camelcase */\nimport { push } from 'connected-react-router';\nimport { ofType } from 'redux-observable';\nimport { of, concat } from 'rxjs';\nimport { flatMap, filter } from 'rxjs/operators';\nimport { actions as marketActions } from '@clearscore/redux.market';\nimport { types as sessionTypes, actions as sessionActions } from '@clearscore/redux.session';\nimport getEnv from '@clearscore/helpers.envs';\nimport { actions as alertsActions } from '@clearscore/redux.alerts';\nimport i18n from 'i18next';\n\nimport { types, actions } from '../../redux';\nimport { RESPONSE_REQUIRES_2FA } from '../constants';\n\n/**\n * Helper function for determining if market is set to maintenance mode.\n *\n * MAINTENANCE_MODE_LOGIN env var is a string allowing to set multiple markets by\n * definining comma separated string (e.g. \"gb,za,in\").\n *\n * @param {object} action$ - action object\n * @param {object} action$.payload - payload object\n * @param {string} action$.payload.marketId - marketID\n */\nconst isMarketInMaintenanceMode = ({ requestMeta }) => {\n const marketId = requestMeta?.market_id ?? '';\n\n const maintenanceMode = getEnv('MAINTENANCE_MODE_LOGIN');\n const isValidMaintenanceMode = typeof maintenanceMode === 'string' && maintenanceMode.length > 0;\n const isValidMarketId = typeof marketId === 'string' && marketId.length > 0;\n\n if (!isValidMaintenanceMode || !isValidMarketId || maintenanceMode === 'VOID') return false;\n\n return maintenanceMode.toUpperCase().includes(marketId.toUpperCase());\n};\n\n/**\n * Checks if a market dashboard (not signup route) is in maintenance mode\n */\nconst maintenanceModeEpic = (action$) =>\n action$.pipe(\n ofType(sessionTypes.LOGIN_OAUTH_AUTHORISE_SUCCESS),\n filter(isMarketInMaintenanceMode),\n flatMap(() => of(push('/maintenance'))),\n );\n\n/**\n *\n * @param {object} action$\n */\nconst oauthTokenTransfer = (action$, state$) =>\n action$.pipe(\n ofType(sessionTypes.LOGIN_OAUTH_SUBMIT_SUCCESS, types.verifyTwoFactorAuth.success),\n flatMap(\n ({\n payload: {\n code,\n market_id,\n response_type,\n '2fa_state': twoFactorAuthState,\n '2fa_hint': mobileNumber,\n '2fa_type': twoFactorType,\n cool_down_seconds: coolDownSeconds,\n sso_token,\n },\n requestData: { client_id, remember },\n requestMeta: { session_id },\n }) => {\n const market = market_id.toLowerCase();\n\n if (response_type === RESPONSE_REQUIRES_2FA) {\n const locationQuery = state$.value.router.location.search;\n\n return concat(\n of(\n push(`/login/verify${locationQuery}`, {\n twoFactorAuthState,\n mobileNumber,\n coolDownSeconds,\n twoFactorType,\n client_id,\n remember,\n requestMeta: {\n market,\n session_id,\n },\n }),\n ),\n of(\n twoFactorType === 'sm'\n ? actions.showSentCodeAlert(mobileNumber)\n : actions.showTwoFactorAppAlert(),\n ),\n );\n }\n\n return concat(\n of(alertsActions.dismissAlert()),\n of(\n sessionActions.authorise(\n {\n code,\n client_id,\n session_id,\n },\n {\n market,\n market_id,\n remember,\n sso_token,\n },\n ),\n ),\n );\n },\n ),\n );\n\n/**\n * Epic called when oauth authorise is successful, here market id is setup and\n * an action to signify login has been successful is achieved\n * @param {object} action$ redux action\n */\nconst oauthTokenSuccess = (action$) =>\n action$.pipe(\n ofType(sessionTypes.LOGIN_OAUTH_AUTHORISE_SUCCESS),\n flatMap(\n // eslint-disable-next-line camelcase\n ({ requestMeta: { market } }) => {\n // todo: get locale from user-preference or dropdown on login\n const [language] = i18n.language.split('-');\n const validLocale = i18n.languages.find((lang) => lang === `${language}-${market}`);\n if (validLocale) {\n i18n.changeLanguage(validLocale);\n } else {\n i18n.changeLanguage(`en-${market}`);\n }\n return concat(of(alertsActions.dismissAlert()), of(marketActions.setActiveMarket(market)));\n },\n ),\n );\n\nexport default {\n maintenanceModeEpic,\n oauthTokenTransfer,\n oauthTokenSuccess,\n};\n","import getEnv from '@clearscore/helpers.envs';\nimport { types as sessionTypes } from '@clearscore/redux.session';\nimport { constants } from '@clearscore/redux.alerts';\nimport Text from '@clearscore/rainbow.text';\nimport i18next from 'i18next';\n\nimport { types } from '../redux';\nimport { PAGE_NAMESPACE } from './constants';\n\nconst alertMessageWithComponents = (message, props) => ({\n message,\n alertType: constants.WARNING,\n Components: [{ Component: Text.Link, props: { ...props, key: 'link' } }],\n});\n\nconst alertWithMessage = (message, alertType = constants.WARNING) => ({\n message,\n alertType,\n ...(alertType === constants.ALERT_INFO && { dismissTimeout: 5000 }),\n});\n\nconst alertWithCtaLink = ({ message, href, ctaText, isNewTab = false }) => ({\n message,\n alertType: constants.WARNING,\n href,\n ctaText,\n isNewTab,\n});\n\nconst alertWithSentCodeMessage = (locale, mobileNumber) => {\n const t = i18next.getFixedT(locale, PAGE_NAMESPACE);\n return alertWithMessage(t('successSentCode', { mobileNumber }), constants.ALERT_INFO);\n};\n\nconst alertWithAppVerifyMessage = (locale) => {\n const t = i18next.getFixedT(locale, PAGE_NAMESPACE);\n return alertWithMessage(t('appCodeCopy'), constants.ALERT_INFO);\n};\n\nexport default {\n [sessionTypes.LOGIN_OAUTH_SUBMIT_ERROR]: ({ payload: { data, status }, locale }) => {\n const t = i18next.getFixedT(locale, PAGE_NAMESPACE);\n switch (status) {\n case 503:\n return alertWithMessage(t('maintenanceMode'));\n case 400:\n if (data.final_attempt) {\n return alertWithCtaLink({\n message: t('finalAttempt'),\n href: '/reset',\n ctaText: t('wrongPasswordCta'),\n });\n }\n\n if (data.reason === 'temp_locked') {\n return alertWithCtaLink({\n message: t('error400TempLocked'),\n href: '/reset',\n ctaText: t('error400TempLockedCta'),\n });\n }\n\n if (data.reason === 'locked') {\n return alertMessageWithComponents(t('error400Locked'), {\n isNewTab: true,\n href: `${getEnv('INTERNATIONAL_WEBSITE')}/askaquestion`,\n });\n }\n\n if (data.reason === 'dup_locked') {\n return alertMessageWithComponents(t('error400Duplocked'), {\n isNewTab: true,\n href: `${getEnv('INTERNATIONAL_WEBSITE')}/askaquestion`,\n });\n }\n\n if (data.reason === 'blocked') {\n return alertMessageWithComponents(t('blockedUserError'), {\n isNewTab: true,\n href: `${getEnv('INTERNATIONAL_WEBSITE')}/askaquestion`,\n });\n }\n\n return alertWithCtaLink({\n message: t('wrongPassword'),\n href: '/reset',\n ctaText: t('wrongPasswordCta'),\n });\n case 429:\n return alertWithMessage(t('error429'));\n\n default:\n return alertWithMessage(t('defaultError', { status }));\n }\n },\n\n [types.verifyTwoFactorAuth.error]: ({ locale }) => {\n const t = i18next.getFixedT(locale, PAGE_NAMESPACE);\n return alertWithMessage(t('errorVerifyIncorrect'));\n },\n [types.resendTwoFactorAuth.error]: ({ locale }) => {\n const t = i18next.getFixedT(locale, PAGE_NAMESPACE);\n return alertWithMessage(t('errorSentCode'));\n },\n [types.resendTwoFactorAuth.success]: ({ requestMeta, locale }) =>\n alertWithSentCodeMessage(locale, requestMeta.mobileNumber),\n [types.showSentCodeAlert.pending]: ({ payload, locale }) => alertWithSentCodeMessage(locale, payload),\n [types.showTwoFactorAppAlert.pending]: ({ locale }) => alertWithAppVerifyMessage(locale),\n};\n","import { alertsEpic } from '@clearscore/epic.alerts';\n\nimport loginEpics from './epics/login-epics';\nimport config from './alerts-config';\n\nexport default {\n ...loginEpics,\n alertsEpic: alertsEpic(config),\n};\n","import { filter, flatMap, map, delayWhen } from 'rxjs/operators';\nimport { of, timer } from 'rxjs';\nimport { ofType, combineEpics } from 'redux-observable';\nimport interpolateWithComponents from '@clearscore/helpers.interpolate-with-components';\nimport { selectors as marketSelectors } from '@clearscore/redux.market';\nimport { types, actions, constants } from '@clearscore/redux.alerts';\n\nimport interpolateMessageValues from './lib/interpolate-message-values';\nimport callConfigMethod from './lib/call-config-method';\n\nconst isConfiguredAlert =\n (alertActionsConfig) =>\n ({ type }) =>\n alertActionsConfig[type];\n\nconst getState = (state$) => state$.value;\n\n/**\n * @description Middleware to handle displaying generic alerts based on action configuration\n */\n\nconst alertsEpic = (alertActionsConfig = {}) => {\n const showAlertEpic = (action$, state$) => {\n const processAlert = ({ type, payload = {}, requestData = {}, requestMeta = {} }) => {\n const alertConfigParams = {\n locale: marketSelectors.getActiveLocale(getState(state$)),\n market: marketSelectors.getActiveMarket(getState(state$)),\n payload,\n requestData,\n requestMeta,\n };\n return callConfigMethod(alertActionsConfig, type, alertConfigParams);\n };\n\n const showAlert = ({ alertType, message, Components, title, ...alert }) => {\n const interpolatedMessage = interpolateMessageValues(message, getState(state$));\n const interpolatedTitle = title ? interpolateMessageValues(title, getState(state$)) : '';\n\n return of(\n actions.showAlert({\n ...alert,\n alertType: alertType || constants.WARNING,\n alertContent: interpolateWithComponents(interpolatedMessage, Components),\n ...(title ? { title: interpolateWithComponents(interpolatedTitle, Components) } : {}),\n }),\n );\n };\n\n return action$.pipe(\n filter(isConfiguredAlert(alertActionsConfig)),\n map(processAlert),\n filter((alert) => alert),\n flatMap(showAlert),\n );\n };\n\n const dismissTimeoutAlertEpic = (action$) =>\n action$.pipe(\n ofType(types.ALERTS_SHOW_ALERT),\n map(({ payload: { dismissTimeout } }) => dismissTimeout),\n filter((dismissTimeout) => !!dismissTimeout),\n delayWhen((dismissTimeout) => timer(dismissTimeout)),\n flatMap(() => of(actions.dismissAlert())),\n );\n\n return combineEpics(showAlertEpic, dismissTimeoutAlertEpic);\n};\n\nexport default alertsEpic;\n","export default (obj, method, params) => (typeof obj[method] === 'function' ? obj[method](params) : null);\n","import * as sessionTypes from '@clearscore/constants.session-action-types';\nimport { constants, getCookie, setSessionCookie } from '@clearscore/helpers.cookies';\n\nconst { CS_CURRENT_LANGUAGE } = constants;\n\n/**\n * Check if action has login success type required required for middleware\n * @param {object} action redux action\n * @returns {boolean} if action structure is correct\n */\nfunction _isLoginSuccess(action) {\n return action.type === sessionTypes.LOGIN_OAUTH_AUTHORISE_SUCCESS;\n}\n\n/**\n * Handle the storing the session within the cookie\n * @param {function} next next middleware func\n * @param {object} action redux action\n * @returns {void}\n */\nfunction _handleStoringSession(next, action) {\n setSessionCookie({\n access_token: action.payload.access_token,\n refresh_token: action.payload.refresh_token,\n session_id: action.requestData.session_id,\n market: action.requestMeta.market_id,\n remember: action.requestMeta.remember,\n o_token: action.requestMeta.sso_token,\n locale: getCookie(CS_CURRENT_LANGUAGE),\n });\n next(action);\n}\n\n/**\n * If action has correct signature, perform cookie storage\n * @returns {Function} middleware\n */\nconst sessionMiddleware = () => () => (next) => (action) =>\n _isLoginSuccess(action) ? _handleStoringSession(next, action) : next(action);\n\nexport default sessionMiddleware;\n","import { loginMiddleware } from '@clearscore/redux.session-middleware';\n\nexport default [loginMiddleware()];\n","import { types as marketTypes } from '@clearscore/redux.market';\nimport { types as sessionTypes } from '@clearscore/redux.session';\nimport { types as alertTypes } from '@clearscore/redux.alerts';\n\nexport default [\n marketTypes.MARKET_SET_ACTIVE_MARKET,\n marketTypes.MARKET_FETCH_CONFIG_SUCCESS,\n marketTypes.MARKET_SET_ACTIVE_LOCALE,\n sessionTypes.SET_SESSION,\n sessionTypes.LOGIN_OAUTH_AUTHORISE_SUCCESS,\n alertTypes.ALERTS_SHOW_ALERT,\n alertTypes.ALERTS_HIDE_ALERT,\n];\n","export default function _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}","import deepmerge from 'deepmerge';\nimport { useSelector } from 'react-redux';\nimport { EN_GB } from '@clearscore/config.i18n';\nimport { selectors as marketSelectors } from '@clearscore/redux.market';\n\nconst isObject = (value) => value && typeof value === 'object' && value.constructor === Object;\nconst ignoreArrays = (_, source) => source;\n\nconst useLanguage = (language, forceLocale) => {\n if (!language || !isObject(language)) throw new Error('A language object must be provided');\n\n const activeLocale = useSelector(marketSelectors.getActiveLocale);\n const locale = forceLocale || activeLocale;\n\n if (language[locale]) {\n return language[EN_GB]\n ? deepmerge(language[EN_GB], language[locale], { arrayMerge: ignoreArrays })\n : language[locale];\n }\n\n return language[EN_GB] || null;\n};\n\nexport default useLanguage;\n","import deepmerge from 'deepmerge';\nimport type { DefaultRootState } from 'react-redux';\nimport { useSelector } from 'react-redux';\nimport type { MARKETS } from '@clearscore/config.i18n';\nimport { GB } from '@clearscore/config.i18n';\nimport { selectors as marketSelectors } from '@clearscore/redux.market';\n\ntype TMarketConfigKey = typeof MARKETS[number] | 'common';\ntype TMarketConfig = Partial>;\n\nconst isObject = (value: unknown): value is TMarketConfig =>\n !!value && typeof value === 'object' && value.constructor === Object;\n\nconst useMarketConfig = (marketConfig: T): T extends TMarketConfig ? T[keyof T] : never => {\n if (!marketConfig || !isObject(marketConfig)) throw new Error('A market config object must be provided');\n const market = useSelector(marketSelectors.getActiveMarket);\n\n // GB market defaulting is temporary and will be removed.\n // Common config should be placed under a 'common' property.\n const baseConfig = marketConfig.common || marketConfig[GB];\n\n if (marketConfig[market]) {\n return baseConfig\n ? deepmerge(baseConfig, marketConfig[market], {\n arrayMerge: (_, sourceArray) => sourceArray,\n })\n : marketConfig[market];\n }\n\n return baseConfig || null;\n};\n\nexport default useMarketConfig;\n","\n","export const breakpointNames = ['all', 'small', 'phablet', 'medium', 'large', 'huge'] as const;\n\nexport const spacing = {\n NONE: 'none',\n MICRO: 'micro',\n TINY: 'tiny',\n SMALL: 'small',\n MEDIUM: 'medium',\n LARGE: 'large',\n BIG: 'big',\n HUGE: 'huge',\n SUPER: 'super',\n JUMBO: 'jumbo',\n} as const;\n\nexport type ValueOf = T[keyof T];\nexport type Spacing = ValueOf;\n","import React from 'react';\nimport cx from 'classnames';\n\nimport styles from './spacer.module.css';\nimport type { Spacing } from './constants';\nimport { spacing } from './constants';\n\ninterface MarginTypes {\n vertical?: Spacing;\n horizontal?: Spacing;\n top?: Spacing;\n right?: Spacing;\n bottom?: Spacing;\n left?: Spacing;\n}\n\ntype GetClassNamesArg = Pick;\n\n// todo: use selector to cache results?\nconst getCSSVars = (breakpoints: GetClassNamesArg): Record =>\n Object.entries(breakpoints).reduce>(\n (prevBP, [breakpoint, bpConfig]) => ({\n ...prevBP,\n ...Object.keys(bpConfig).reduce>((prevSize, marginType) => {\n const marginSize = bpConfig[marginType as keyof MarginTypes];\n if (marginType === 'vertical') {\n return Object.assign(prevSize, {\n [`--rnbs-${breakpoint}-top`]: `var(--rnb-spacing-${marginSize}, 0)`,\n [`--rnbs-${breakpoint}-bottom`]: `var(--rnb-spacing-${marginSize}, 0)`,\n });\n }\n if (marginType === 'horizontal') {\n return Object.assign(prevSize, {\n ...prevSize,\n [`--rnbs-${breakpoint}-left`]: `var(--rnb-spacing-${marginSize}, 0)`,\n [`--rnbs-${breakpoint}-right`]: `var(--rnb-spacing-${marginSize}, 0)`,\n });\n }\n return Object.assign(prevSize, {\n [`--rnbs-${breakpoint}-${marginType}`]: `var(--rnb-spacing-${marginSize}, 0)`,\n });\n }, {}),\n }),\n {},\n );\n\nexport interface SpacerProps {\n all?: MarginTypes;\n small?: MarginTypes;\n phablet?: MarginTypes;\n medium?: MarginTypes;\n large?: MarginTypes;\n huge?: MarginTypes;\n dataId?: string;\n}\n\nconst Spacer: React.FC & { spacings: typeof spacing } = ({\n children = null,\n all = {},\n small = {},\n phablet = {},\n medium = {},\n large = {},\n huge = {},\n dataId,\n ...props\n}) => {\n const breakpointsWithAllShorthand = { all, small, phablet, medium, large, huge };\n const customProperties = getCSSVars(breakpointsWithAllShorthand);\n return (\n
(styles))} data-id={dataId}>\n {children}\n
\n );\n};\n\nSpacer.spacings = spacing;\n\nexport default Spacer;\n","export const Size = {\n TINY: 'TINY',\n SMALL: 'SMALL',\n MEDIUM: 'MEDIUM',\n LARGE: 'LARGE',\n FULL_WIDTH: 'FULL_WIDTH',\n} as const;\n\nexport const Theme = {\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n} as const;\n","import type { ReactElement, ReactNode } from 'react';\nimport React from 'react';\nimport cx from 'classnames';\nimport toTitleCase from '@clearscore/normalize.title-case';\nimport { timing } from '@clearscore/rainbow.tokens';\n\nimport { Size, Theme } from './constants';\nimport styles from './loader.module.css';\n\ninterface LoaderProps {\n size?: keyof typeof Size;\n animationDuration?: string;\n isFullPage?: boolean;\n theme?: keyof typeof Theme;\n children?: ReactNode;\n}\n\nexport interface LoaderExport {\n (props: LoaderProps): ReactElement;\n Size: typeof Size;\n Theme: typeof Theme;\n}\n\nconst Loader: LoaderExport = ({\n size = Size.MEDIUM,\n animationDuration = timing['rnb-timing-normal'],\n isFullPage,\n theme,\n children,\n}): ReactElement => {\n const inlineStyles = {\n animationDuration,\n };\n\n const loader = (\n \n {children || 'loading'}\n \n );\n\n if (isFullPage) {\n return (\n
\n {loader}\n
\n );\n }\n\n return loader;\n};\n\nLoader.Size = Size;\nLoader.Theme = Theme;\n\nexport default Loader;\n","export const types = {\n PRIMARY: 'PRIMARY',\n SECONDARY: 'SECONDARY',\n TERTIARY: 'TERTIARY',\n STICKY: 'STICKY',\n} as const;\n\nexport const sizes = {\n TINY: 'TINY',\n SMALL: 'SMALL',\n LARGE: 'LARGE',\n} as const;\n\nexport const themes = {\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n INHERIT: 'INHERIT',\n} as const;\n","import type { HTMLAttributeAnchorTarget, MouseEvent, ReactElement } from 'react';\nimport React, { PureComponent } from 'react';\nimport cx from 'classnames';\nimport { Link as RouterLink } from 'react-router-dom';\nimport Loader from '@clearscore/rainbow.loader';\nimport Text from '@clearscore/rainbow.text';\nimport toTitleCase from '@clearscore/normalize.title-case';\nimport type { LocationDescriptorObject } from 'history';\n\nimport { types, sizes, themes } from './constants';\nimport styles from './button.module.css';\nimport type { IButtonProps } from './types';\n\nconst getReactRouterLinkToProps = (href: string | undefined): LocationDescriptorObject => {\n if (href) {\n const [hashPathname, hash] = href.split('#');\n const [pathname, search] = hashPathname.split('?');\n return {\n pathname,\n hash,\n search,\n };\n }\n\n return {\n pathname: '',\n hash: '',\n search: '',\n };\n};\n\nexport default class Button extends PureComponent {\n // eslint-disable-next-line react/static-property-placement\n static defaultProps = {\n type: types.PRIMARY,\n size: sizes.SMALL,\n theme: themes.LIGHT,\n isWide: false,\n isNarrow: false,\n isFlat: false,\n isResponsive: false,\n isDisabled: false,\n isLoading: false,\n loadingLabel: 'loading',\n onClick: undefined,\n href: undefined,\n newTab: false,\n htmlType: 'button',\n dataId: undefined,\n routerTrackingSource: undefined,\n routerTrackingProps: undefined,\n state: undefined,\n download: false,\n };\n\n static types = types;\n static sizes = sizes;\n static themes = themes;\n\n get isDisabled(): boolean {\n const { isDisabled, isLoading } = this.props;\n return (isDisabled || isLoading) === true;\n }\n\n handleClick = (event: MouseEvent): void => {\n const { onClick } = this.props;\n\n if (!this.isDisabled && onClick) {\n onClick(event);\n }\n };\n\n get target(): HTMLAttributeAnchorTarget | undefined {\n const { href, newTab } = this.props;\n if (!href) {\n return undefined;\n }\n\n return newTab ? '_blank' : '_self';\n }\n\n get ButtonText(): ReactElement {\n const { isLoading, size, children, loadingLabel } = this.props;\n const sizeClass = styles[`isSize${toTitleCase(size)}`];\n const loaderClass: string = cx(styles.loaderWrapper, sizeClass);\n const TextButton: typeof Text.Button1 | typeof Text.Button2 =\n size === sizes.LARGE ? Text.Button1 : Text.Button2;\n\n return (\n \n {isLoading ? (\n
\n
\n {loadingLabel}\n
\n {'\\u00A0'}\n
\n ) : (\n children\n )}\n
\n );\n }\n\n render(): ReactElement {\n const {\n type,\n size,\n theme,\n isWide,\n isNarrow,\n isFlat,\n isResponsive,\n isDisabled,\n href,\n dataId,\n htmlType,\n newTab,\n routerTrackingSource,\n routerTrackingProps,\n state,\n download,\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n loadingLabel, // suppressed to prevent being spread onto html\n ...props\n } = this.props;\n\n const typeClass: string = styles[`isType${toTitleCase(type)}`];\n const sizeClass: string = styles[`isSize${toTitleCase(size)}`];\n const themeClass: string = styles[`isTheme${toTitleCase(theme)}`];\n const CustomTag: 'a' | 'button' = href ? 'a' : 'button';\n const buttonProps = {\n ...props,\n className: cx(styles.button, typeClass, sizeClass, themeClass, {\n [styles.isWide]: isWide,\n [styles.isNarrow]: isNarrow,\n [styles.isFlat]: isFlat,\n [styles.isDisabled]: isDisabled,\n [styles.isResponsive]: isResponsive,\n }),\n disabled: this.isDisabled,\n onClick: this.handleClick,\n };\n /**\n * We need to remove incompatible HTML attributes,\n * from our button/anchor/link.\n */\n delete buttonProps.isLoading;\n\n const isInternalLink: boolean = (!newTab && href && !href.startsWith('http')) === true;\n if (isInternalLink && href) {\n /**\n * Checks the route and updates the UI without reloading the full page in the browser.\n */\n const getToPropValues = (): LocationDescriptorObject => {\n const toProps = getReactRouterLinkToProps(href);\n if (state && (routerTrackingSource || routerTrackingProps)) {\n return {\n ...toProps,\n state: {\n ...state,\n tracking: {\n source: routerTrackingSource,\n props: routerTrackingProps,\n },\n },\n };\n }\n\n if (state) {\n return {\n ...toProps,\n state,\n };\n }\n\n return {\n ...toProps,\n state: {\n tracking: {\n source: routerTrackingSource,\n props: routerTrackingProps,\n },\n },\n };\n };\n\n const hasState = state || routerTrackingSource || routerTrackingProps;\n const to: LocationDescriptorObject | string = hasState ? getToPropValues() : href;\n\n return (\n \n {this.ButtonText}\n \n );\n }\n\n return (\n \n {this.ButtonText}\n \n );\n }\n}\n","import { GB } from '@clearscore/config.i18n';\n\nexport default {\n [GB]: {\n isEnabled: true,\n },\n};\n","import { EN_GB } from '@clearscore/config.i18n';\n\nexport default {\n [EN_GB]: {\n defaultCtaText: 'Use the app',\n },\n};\n","import React, { useEffect, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport cx from 'classnames';\nimport { isAndroidBrowser, isIOSBrowser } from '@clearscore/helpers.device';\nimport useLanguage from '@clearscore/hooks.use-language';\nimport useMarketConfig from '@clearscore/hooks.use-market-config-deprecated';\nimport ClearscoreIcon from '@clearscore/rainbow.icons.clearscore-logo-symbol';\nimport Text from '@clearscore/rainbow.text';\nimport Spacer from '@clearscore/rainbow.spacer';\nimport Button from '@clearscore/rainbow.button';\nimport useAsyncClickout from '@clearscore/hooks.use-async-clickout';\n\nimport marketConfig from './lib/market-config';\nimport lang from './lib/lang';\nimport styles from './styles.module.css';\n\nconst ButtonCta = ({ onClick, ctaText }) => (\n \n {ctaText}\n \n);\n\nButtonCta.propTypes = {\n onClick: PropTypes.func.isRequired,\n ctaText: PropTypes.string.isRequired,\n};\n\nconst ContextualAppDownloadBanner = ({\n text,\n playStoreLink,\n iosStoreLink,\n hasBorderTop,\n hasBorderBottom,\n onBannerClick,\n onBannerView,\n setOpenModal,\n showOnDesktop,\n}) => {\n const { isEnabled } = useMarketConfig(marketConfig);\n const { title, description, ctaText } = text;\n const { defaultCtaText } = useLanguage(lang);\n\n const isAndroid = isAndroidBrowser();\n const isIOS = isIOSBrowser();\n\n const appStoreLink = isAndroid ? playStoreLink : iosStoreLink;\n const shouldShow = isEnabled && (isAndroid || isIOS || showOnDesktop);\n\n const [shouldOpenAppStoreLink, setShouldOpenAppStoreLink] = useState(false);\n\n useAsyncClickout({ externalUrl: appStoreLink, trigger: shouldOpenAppStoreLink });\n\n useEffect(() => {\n if (shouldOpenAppStoreLink) {\n setShouldOpenAppStoreLink(false);\n }\n }, [shouldOpenAppStoreLink]);\n\n useEffect(() => {\n if (shouldShow) {\n onBannerView();\n }\n }, [shouldShow]);\n\n if (!shouldShow) {\n return null;\n }\n return (\n \n
\n
\n \n
\n
\n \n
\n
\n
\n \n \n {title}\n \n {description ? (\n \n {description}\n \n ) : null}\n \n
\n
\n \n {\n onBannerClick();\n showOnDesktop ? setOpenModal(true) : setShouldOpenAppStoreLink(true);\n }}\n ctaText={ctaText || defaultCtaText}\n isAndroid={isAndroid}\n />\n \n
\n
\n \n );\n};\n\nContextualAppDownloadBanner.propTypes = {\n text: PropTypes.shape({\n title: PropTypes.string.isRequired,\n description: PropTypes.string,\n ctaText: PropTypes.string,\n }),\n playStoreLink: PropTypes.string.isRequired,\n iosStoreLink: PropTypes.string.isRequired,\n hasBorderTop: PropTypes.bool,\n hasBorderBottom: PropTypes.bool,\n onBannerClick: PropTypes.func.isRequired,\n onBannerView: PropTypes.func.isRequired,\n setOpenModal: PropTypes.func,\n showOnDesktop: PropTypes.bool,\n};\n\nContextualAppDownloadBanner.defaultProps = {\n text: {\n description: null,\n ctaText: null,\n },\n hasBorderTop: false,\n hasBorderBottom: false,\n setOpenModal: null,\n showOnDesktop: false,\n};\n\nexport default ContextualAppDownloadBanner;\n","import { useEffect } from 'react';\n\nconst useAsyncClickout = ({ externalUrl, trigger, onOpen }) => {\n useEffect(() => {\n if (externalUrl && trigger) {\n const newWindow = window.open(externalUrl, '_blank');\n\n if (!newWindow || newWindow.closed || newWindow.closed === 'undefined') {\n window.location.assign(externalUrl);\n }\n\n if (onOpen) onOpen();\n }\n }, [externalUrl, trigger, onOpen]);\n};\n\nexport default useAsyncClickout;\n","const blacklistedSearchParams = ['email', 'firstName', 'lastName', 'dob'];\n\n/* eslint-disable import/prefer-default-export */\nexport const getSanitisedUrl = () => {\n const { location } = window;\n const url = new URL(location.href);\n blacklistedSearchParams.forEach((p) => url.searchParams.delete(p));\n const search = !url.search && location.search ? '?' : url.search;\n const urlString = `${url.protocol}//${url.host}${url.pathname}${search}`;\n\n return { url: urlString, search };\n};\n","import { useMemo } from 'react';\nimport { useSelector } from 'react-redux';\nimport { selectors as marketSelectors } from '@clearscore/redux.market';\nimport getDevice, { getBrowser } from '@clearscore/helpers.device';\n\nlet _device;\nconst device = () => {\n if (!_device) {\n _device = getDevice();\n }\n\n return _device;\n};\n\n/**\n * Hook to get the default segment props that must be pulled from the redux store\n */\nconst useDefaultSegmentProps = () => {\n const market = useSelector(marketSelectors.getActiveMarket);\n const browser = getBrowser();\n return useMemo(\n () => ({\n device: device(),\n cs_site: market,\n browserName: browser.name,\n browserVersion: browser.version,\n }),\n [market, browser],\n );\n};\n\nexport default useDefaultSegmentProps;\n","import { useCallback } from 'react';\nimport monitoring from '@clearscore/helpers.monitoring';\n\nimport { getSanitisedUrl } from './lib/helpers';\nimport useDefaultSegmentProps from './lib/hooks/use-default-segment-props';\n\n/**\n * Get the default segment props that must be generated at event send time\n */\nconst getWindowSegmentProps = () => {\n const { url } = getSanitisedUrl();\n\n return {\n location: url,\n referrer: document.referrer || 'Direct',\n };\n};\n\nconst useTracking = () => {\n const defaultSegmentProps = useDefaultSegmentProps();\n\n const track = useCallback(\n ({ name, props = {}, event = 'track', onComplete } = {}) => {\n const hasTracking = typeof window?.analytics?.track === 'function';\n\n if (!hasTracking && monitoring.hasMonitoring()) {\n monitoring.log(`Cannot send tracking event ${name} - no window.analytics available`);\n }\n\n if (!hasTracking) {\n return;\n }\n let hasFiredOnComplete = false;\n\n const fallbackTimeout = setTimeout(() => {\n if (onComplete && !hasFiredOnComplete) onComplete();\n }, 100);\n\n const customOnComplete = () => {\n hasFiredOnComplete = true;\n clearTimeout(fallbackTimeout);\n onComplete();\n };\n\n window.analytics[event](\n name,\n {\n ...getWindowSegmentProps(),\n ...defaultSegmentProps,\n ...props,\n },\n // analytics.js \"options\" object - not needed for us (yet!)\n {},\n // An optional function called when the analytics request completes\n onComplete ? customOnComplete : undefined,\n );\n },\n [defaultSegmentProps],\n );\n\n return track;\n};\n\nexport default useTracking;\n","import { useCallback } from 'react';\nimport { useSelector } from 'react-redux';\nimport useTracking from '@clearscore/hooks.use-tracking';\nimport { getCookie } from '@clearscore/helpers.cookies';\n\nconst useScoreBand = () => useSelector((state) => state.dashboard?.data?.creditReportInfo?.scoreBand);\n\nconst useWebappTracking = () => {\n const TRACK_FBP = getCookie('_fbp');\n const TRACK_FBC = getCookie('_fbc');\n const track = useTracking();\n const scoreBand = useScoreBand();\n\n const webappTrack = useCallback(\n ({ name, props = {}, onComplete } = {}) =>\n track({\n name,\n props: {\n score_band: scoreBand,\n ...(TRACK_FBP && { fbp: TRACK_FBP }),\n ...(TRACK_FBC && { fbc: TRACK_FBC }),\n ...props,\n },\n onComplete,\n }),\n [track, scoreBand, TRACK_FBP, TRACK_FBC],\n );\n\n return webappTrack;\n};\n\nexport default useWebappTracking;\n","import React from 'react';\nimport ContextualAppDownloadBanner from '@clearscore/ui.shared.contextual-app-download-banner';\n\nimport useTracking from './lib/hooks/tracking';\n\nconst WebappAppDownloadBanner = ({ ...props }) => {\n const { trackBannerViewed, trackBannerClicked } = useTracking();\n\n return (\n \n );\n};\n\nexport default WebappAppDownloadBanner;\n","export default function _objectDestructuringEmpty(obj) {\n if (obj == null) throw new TypeError(\"Cannot destructure \" + obj);\n}","import { useCallback } from 'react';\nimport useWebappTracking from '@clearscore/hooks.use-webapp-tracking';\n\nconst getWindowProps = () => ({\n source: window.location.pathname,\n});\n\nexport default () => {\n const track = useWebappTracking();\n\n const trackBannerViewed = useCallback(\n () =>\n track({\n name: 'fe_mobile_web_smart_banner_viewed',\n // Removed other variants, so variant will always be BUTTON now\n props: { variant: 'BUTTON', ...getWindowProps() },\n }),\n [track],\n );\n\n const trackBannerClicked = useCallback(\n () =>\n track({\n name: 'fe_mobile_web_smart_banner_clicked',\n // Removed other variants, so variant will always be BUTTON now\n props: { variant: 'BUTTON', ...getWindowProps() },\n }),\n [track],\n );\n\n return { trackBannerViewed, trackBannerClicked };\n};\n","import React from 'react';\nimport WebappAppDownloadBanner from '@clearscore/ui.webapp.app-download-banner';\nimport Spacer from '@clearscore/rainbow.spacer';\nimport { useTranslation } from 'react-i18next';\n\nimport styles from './app-download-banner.module.css';\nimport { PAGE_NAMESPACE } from '../../lib/constants';\n\n// These do not need to live in market-config at the moment as app store links and tracking are global\nconst PLAY_STORE_LINK = 'https://clearscore.app.link/GAFiEG2pTbb';\nconst IOS_STORE_LINK = 'https://clearscore.app.link/FxpHNO5pTbb';\n\nconst AppDownloadBanner = (): React.ReactElement => {\n const { t } = useTranslation(PAGE_NAMESPACE);\n\n return (\n
\n \n \n \n
\n );\n};\n\nexport default AppDownloadBanner;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\n\n// \nvar keysCache = {};\nvar keysRegex = /[.[\\]]+/;\n\nvar toPath = function toPath(key) {\n if (key === null || key === undefined || !key.length) {\n return [];\n }\n\n if (typeof key !== 'string') {\n throw new Error('toPath() expects a string');\n }\n\n if (keysCache[key] == null) {\n keysCache[key] = key.split(keysRegex).filter(Boolean);\n }\n\n return keysCache[key];\n};\n\n// \n\nvar getIn = function getIn(state, complexKey) {\n // Intentionally using iteration rather than recursion\n var path = toPath(complexKey);\n var current = state;\n\n for (var i = 0; i < path.length; i++) {\n var key = path[i];\n\n if (current === undefined || current === null || typeof current !== 'object' || Array.isArray(current) && isNaN(key)) {\n return undefined;\n }\n\n current = current[key];\n }\n\n return current;\n};\n\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\n\nfunction _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); }\n\nvar setInRecursor = function setInRecursor(current, index, path, value, destroyArrays) {\n if (index >= path.length) {\n // end of recursion\n return value;\n }\n\n var key = path[index]; // determine type of key\n\n if (isNaN(key)) {\n var _extends2;\n\n // object set\n if (current === undefined || current === null) {\n var _ref;\n\n // recurse\n var _result2 = setInRecursor(undefined, index + 1, path, value, destroyArrays); // delete or create an object\n\n\n return _result2 === undefined ? undefined : (_ref = {}, _ref[key] = _result2, _ref);\n }\n\n if (Array.isArray(current)) {\n throw new Error('Cannot set a non-numeric property on an array');\n } // current exists, so make a copy of all its values, and add/update the new one\n\n\n var _result = setInRecursor(current[key], index + 1, path, value, destroyArrays);\n\n if (_result === undefined) {\n var numKeys = Object.keys(current).length;\n\n if (current[key] === undefined && numKeys === 0) {\n // object was already empty\n return undefined;\n }\n\n if (current[key] !== undefined && numKeys <= 1) {\n // only key we had was the one we are deleting\n if (!isNaN(path[index - 1]) && !destroyArrays) {\n // we are in an array, so return an empty object\n return {};\n } else {\n return undefined;\n }\n }\n\n var _removed = current[key],\n _final = _objectWithoutPropertiesLoose(current, [key].map(_toPropertyKey));\n\n return _final;\n } // set result in key\n\n\n return _extends({}, current, (_extends2 = {}, _extends2[key] = _result, _extends2));\n } // array set\n\n\n var numericKey = Number(key);\n\n if (current === undefined || current === null) {\n // recurse\n var _result3 = setInRecursor(undefined, index + 1, path, value, destroyArrays); // if nothing returned, delete it\n\n\n if (_result3 === undefined) {\n return undefined;\n } // create an array\n\n\n var _array = [];\n _array[numericKey] = _result3;\n return _array;\n }\n\n if (!Array.isArray(current)) {\n throw new Error('Cannot set a numeric property on an object');\n } // recurse\n\n\n var existingValue = current[numericKey];\n var result = setInRecursor(existingValue, index + 1, path, value, destroyArrays); // current exists, so make a copy of all its values, and add/update the new one\n\n var array = [].concat(current);\n\n if (destroyArrays && result === undefined) {\n array.splice(numericKey, 1);\n\n if (array.length === 0) {\n return undefined;\n }\n } else {\n array[numericKey] = result;\n }\n\n return array;\n};\n\nvar setIn = function setIn(state, key, value, destroyArrays) {\n if (destroyArrays === void 0) {\n destroyArrays = false;\n }\n\n if (state === undefined || state === null) {\n throw new Error(\"Cannot call setIn() with \" + String(state) + \" state\");\n }\n\n if (key === undefined || key === null) {\n throw new Error(\"Cannot call setIn() with \" + String(key) + \" key\");\n } // Recursive function needs to accept and return State, but public API should\n // only deal with Objects\n\n\n return setInRecursor(state, 0, toPath(key), value, destroyArrays);\n};\n\nvar FORM_ERROR = 'FINAL_FORM/form-error';\nvar ARRAY_ERROR = 'FINAL_FORM/array-error';\n\n// \n/**\n * Converts internal field state to published field state\n */\n\nfunction publishFieldState(formState, field) {\n var errors = formState.errors,\n initialValues = formState.initialValues,\n lastSubmittedValues = formState.lastSubmittedValues,\n submitErrors = formState.submitErrors,\n submitFailed = formState.submitFailed,\n submitSucceeded = formState.submitSucceeded,\n submitting = formState.submitting,\n values = formState.values;\n var active = field.active,\n blur = field.blur,\n change = field.change,\n data = field.data,\n focus = field.focus,\n modified = field.modified,\n modifiedSinceLastSubmit = field.modifiedSinceLastSubmit,\n name = field.name,\n touched = field.touched,\n validating = field.validating,\n visited = field.visited;\n var value = getIn(values, name);\n var error = getIn(errors, name);\n\n if (error && error[ARRAY_ERROR]) {\n error = error[ARRAY_ERROR];\n }\n\n var submitError = submitErrors && getIn(submitErrors, name);\n var initial = initialValues && getIn(initialValues, name);\n var pristine = field.isEqual(initial, value);\n var dirtySinceLastSubmit = !!(lastSubmittedValues && !field.isEqual(getIn(lastSubmittedValues, name), value));\n var valid = !error && !submitError;\n return {\n active: active,\n blur: blur,\n change: change,\n data: data,\n dirty: !pristine,\n dirtySinceLastSubmit: dirtySinceLastSubmit,\n error: error,\n focus: focus,\n initial: initial,\n invalid: !valid,\n length: Array.isArray(value) ? value.length : undefined,\n modified: modified,\n modifiedSinceLastSubmit: modifiedSinceLastSubmit,\n name: name,\n pristine: pristine,\n submitError: submitError,\n submitFailed: submitFailed,\n submitSucceeded: submitSucceeded,\n submitting: submitting,\n touched: touched,\n valid: valid,\n value: value,\n visited: visited,\n validating: validating\n };\n}\n\n// \nvar fieldSubscriptionItems = ['active', 'data', 'dirty', 'dirtySinceLastSubmit', 'error', 'initial', 'invalid', 'length', 'modified', 'modifiedSinceLastSubmit', 'pristine', 'submitError', 'submitFailed', 'submitSucceeded', 'submitting', 'touched', 'valid', 'value', 'visited', 'validating'];\n\n// \nvar shallowEqual = function shallowEqual(a, b) {\n if (a === b) {\n return true;\n }\n\n if (typeof a !== 'object' || !a || typeof b !== 'object' || !b) {\n return false;\n }\n\n var keysA = Object.keys(a);\n var keysB = Object.keys(b);\n\n if (keysA.length !== keysB.length) {\n return false;\n }\n\n var bHasOwnProperty = Object.prototype.hasOwnProperty.bind(b);\n\n for (var idx = 0; idx < keysA.length; idx++) {\n var key = keysA[idx];\n\n if (!bHasOwnProperty(key) || a[key] !== b[key]) {\n return false;\n }\n }\n\n return true;\n};\n\n// \nfunction subscriptionFilter (dest, src, previous, subscription, keys, shallowEqualKeys) {\n var different = false;\n keys.forEach(function (key) {\n if (subscription[key]) {\n dest[key] = src[key];\n\n if (!previous || (~shallowEqualKeys.indexOf(key) ? !shallowEqual(src[key], previous[key]) : src[key] !== previous[key])) {\n different = true;\n }\n }\n });\n return different;\n}\n\n// \nvar shallowEqualKeys = ['data'];\n/**\n * Filters items in a FieldState based on a FieldSubscription\n */\n\nvar filterFieldState = function filterFieldState(state, previousState, subscription, force) {\n var result = {\n blur: state.blur,\n change: state.change,\n focus: state.focus,\n name: state.name\n };\n var different = subscriptionFilter(result, state, previousState, subscription, fieldSubscriptionItems, shallowEqualKeys) || !previousState;\n return different || force ? result : undefined;\n};\n\n// \nvar formSubscriptionItems = ['active', 'dirty', 'dirtyFields', 'dirtyFieldsSinceLastSubmit', 'dirtySinceLastSubmit', 'error', 'errors', 'hasSubmitErrors', 'hasValidationErrors', 'initialValues', 'invalid', 'modified', 'modifiedSinceLastSubmit', 'pristine', 'submitting', 'submitError', 'submitErrors', 'submitFailed', 'submitSucceeded', 'touched', 'valid', 'validating', 'values', 'visited'];\n\n// \nvar shallowEqualKeys$1 = ['touched', 'visited'];\n/**\n * Filters items in a FormState based on a FormSubscription\n */\n\nfunction filterFormState(state, previousState, subscription, force) {\n var result = {};\n var different = subscriptionFilter(result, state, previousState, subscription, formSubscriptionItems, shallowEqualKeys$1) || !previousState;\n return different || force ? result : undefined;\n}\n\n// \n\nvar memoize = function memoize(fn) {\n var lastArgs;\n var lastResult;\n return function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n if (!lastArgs || args.length !== lastArgs.length || args.some(function (arg, index) {\n return !shallowEqual(lastArgs[index], arg);\n })) {\n lastArgs = args;\n lastResult = fn.apply(void 0, args);\n }\n\n return lastResult;\n };\n};\n\nvar isPromise = (function (obj) {\n return !!obj && (typeof obj === 'object' || typeof obj === 'function') && typeof obj.then === 'function';\n});\n\nvar version = \"4.20.2\";\n\nvar configOptions = ['debug', 'initialValues', 'keepDirtyOnReinitialize', 'mutators', 'onSubmit', 'validate', 'validateOnBlur'];\n\nvar tripleEquals = function tripleEquals(a, b) {\n return a === b;\n};\n\nvar hasAnyError = function hasAnyError(errors) {\n return Object.keys(errors).some(function (key) {\n var value = errors[key];\n\n if (value && typeof value === 'object' && !(value instanceof Error)) {\n return hasAnyError(value);\n }\n\n return typeof value !== 'undefined';\n });\n};\n\nfunction convertToExternalFormState(_ref) {\n var active = _ref.active,\n dirtySinceLastSubmit = _ref.dirtySinceLastSubmit,\n modifiedSinceLastSubmit = _ref.modifiedSinceLastSubmit,\n error = _ref.error,\n errors = _ref.errors,\n initialValues = _ref.initialValues,\n pristine = _ref.pristine,\n submitting = _ref.submitting,\n submitFailed = _ref.submitFailed,\n submitSucceeded = _ref.submitSucceeded,\n submitError = _ref.submitError,\n submitErrors = _ref.submitErrors,\n valid = _ref.valid,\n validating = _ref.validating,\n values = _ref.values;\n return {\n active: active,\n dirty: !pristine,\n dirtySinceLastSubmit: dirtySinceLastSubmit,\n modifiedSinceLastSubmit: modifiedSinceLastSubmit,\n error: error,\n errors: errors,\n hasSubmitErrors: !!(submitError || submitErrors && hasAnyError(submitErrors)),\n hasValidationErrors: !!(error || hasAnyError(errors)),\n invalid: !valid,\n initialValues: initialValues,\n pristine: pristine,\n submitting: submitting,\n submitFailed: submitFailed,\n submitSucceeded: submitSucceeded,\n submitError: submitError,\n submitErrors: submitErrors,\n valid: valid,\n validating: validating > 0,\n values: values\n };\n}\n\nfunction notifySubscriber(subscriber, subscription, state, lastState, filter, force) {\n var notification = filter(state, lastState, subscription, force);\n\n if (notification) {\n subscriber(notification);\n return true;\n }\n\n return false;\n}\n\nfunction notify(_ref2, state, lastState, filter, force) {\n var entries = _ref2.entries;\n Object.keys(entries).forEach(function (key) {\n var entry = entries[Number(key)]; // istanbul ignore next\n\n if (entry) {\n var subscription = entry.subscription,\n subscriber = entry.subscriber,\n notified = entry.notified;\n\n if (notifySubscriber(subscriber, subscription, state, lastState, filter, force || !notified)) {\n entry.notified = true;\n }\n }\n });\n}\n\nfunction createForm(config) {\n if (!config) {\n throw new Error('No config specified');\n }\n\n var debug = config.debug,\n destroyOnUnregister = config.destroyOnUnregister,\n keepDirtyOnReinitialize = config.keepDirtyOnReinitialize,\n initialValues = config.initialValues,\n mutators = config.mutators,\n onSubmit = config.onSubmit,\n validate = config.validate,\n validateOnBlur = config.validateOnBlur;\n\n if (!onSubmit) {\n throw new Error('No onSubmit function specified');\n }\n\n var state = {\n subscribers: {\n index: 0,\n entries: {}\n },\n fieldSubscribers: {},\n fields: {},\n formState: {\n dirtySinceLastSubmit: false,\n modifiedSinceLastSubmit: false,\n errors: {},\n initialValues: initialValues && _extends({}, initialValues),\n invalid: false,\n pristine: true,\n submitting: false,\n submitFailed: false,\n submitSucceeded: false,\n resetWhileSubmitting: false,\n valid: true,\n validating: 0,\n values: initialValues ? _extends({}, initialValues) : {}\n },\n lastFormState: undefined\n };\n var inBatch = 0;\n var validationPaused = false;\n var validationBlocked = false;\n var preventNotificationWhileValidationPaused = false;\n var nextAsyncValidationKey = 0;\n var asyncValidationPromises = {};\n\n var clearAsyncValidationPromise = function clearAsyncValidationPromise(key) {\n return function (result) {\n delete asyncValidationPromises[key];\n return result;\n };\n };\n\n var changeValue = function changeValue(state, name, mutate) {\n var before = getIn(state.formState.values, name);\n var after = mutate(before);\n state.formState.values = setIn(state.formState.values, name, after) || {};\n };\n\n var renameField = function renameField(state, from, to) {\n if (state.fields[from]) {\n var _extends2, _extends3;\n\n state.fields = _extends({}, state.fields, (_extends2 = {}, _extends2[to] = _extends({}, state.fields[from], {\n name: to,\n // rebind event handlers\n blur: function blur() {\n return api.blur(to);\n },\n change: function change(value) {\n return api.change(to, value);\n },\n focus: function focus() {\n return api.focus(to);\n },\n lastFieldState: undefined\n }), _extends2));\n delete state.fields[from];\n state.fieldSubscribers = _extends({}, state.fieldSubscribers, (_extends3 = {}, _extends3[to] = state.fieldSubscribers[from], _extends3));\n delete state.fieldSubscribers[from];\n var value = getIn(state.formState.values, from);\n state.formState.values = setIn(state.formState.values, from, undefined) || {};\n state.formState.values = setIn(state.formState.values, to, value);\n delete state.lastFormState;\n }\n }; // bind state to mutators\n\n\n var getMutatorApi = function getMutatorApi(key) {\n return function () {\n // istanbul ignore next\n if (mutators) {\n // ^^ causes branch coverage warning, but needed to appease the Flow gods\n var mutatableState = {\n formState: state.formState,\n fields: state.fields,\n fieldSubscribers: state.fieldSubscribers,\n lastFormState: state.lastFormState\n };\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var returnValue = mutators[key](args, mutatableState, {\n changeValue: changeValue,\n getIn: getIn,\n renameField: renameField,\n resetFieldState: api.resetFieldState,\n setIn: setIn,\n shallowEqual: shallowEqual\n });\n state.formState = mutatableState.formState;\n state.fields = mutatableState.fields;\n state.fieldSubscribers = mutatableState.fieldSubscribers;\n state.lastFormState = mutatableState.lastFormState;\n runValidation(undefined, function () {\n notifyFieldListeners();\n notifyFormListeners();\n });\n return returnValue;\n }\n };\n };\n\n var mutatorsApi = mutators ? Object.keys(mutators).reduce(function (result, key) {\n result[key] = getMutatorApi(key);\n return result;\n }, {}) : {};\n\n var runRecordLevelValidation = function runRecordLevelValidation(setErrors) {\n var promises = [];\n\n if (validate) {\n var errorsOrPromise = validate(_extends({}, state.formState.values)); // clone to avoid writing\n\n if (isPromise(errorsOrPromise)) {\n promises.push(errorsOrPromise.then(setErrors));\n } else {\n setErrors(errorsOrPromise);\n }\n }\n\n return promises;\n };\n\n var getValidators = function getValidators(field) {\n return Object.keys(field.validators).reduce(function (result, index) {\n var validator = field.validators[Number(index)]();\n\n if (validator) {\n result.push(validator);\n }\n\n return result;\n }, []);\n };\n\n var runFieldLevelValidation = function runFieldLevelValidation(name, setError) {\n var promises = [];\n var validators = getValidators(state.fields[name]);\n\n if (validators.length) {\n var error;\n validators.forEach(function (validator) {\n var errorOrPromise = validator(getIn(state.formState.values, name), state.formState.values, validator.length === 0 || validator.length === 3 ? publishFieldState(state.formState, state.fields[name]) : undefined);\n\n if (errorOrPromise && isPromise(errorOrPromise)) {\n state.fields[name].validating = true;\n var promise = errorOrPromise.then(function (error) {\n state.fields[name].validating = false;\n setError(error);\n }); // errors must be resolved, not rejected\n\n promises.push(promise);\n } else if (!error) {\n // first registered validator wins\n error = errorOrPromise;\n }\n });\n setError(error);\n }\n\n return promises;\n };\n\n var runValidation = function runValidation(fieldChanged, callback) {\n if (validationPaused) {\n validationBlocked = true;\n callback();\n return;\n }\n\n var fields = state.fields,\n formState = state.formState;\n\n var safeFields = _extends({}, fields);\n\n var fieldKeys = Object.keys(safeFields);\n\n if (!validate && !fieldKeys.some(function (key) {\n return getValidators(safeFields[key]).length;\n })) {\n callback();\n return; // no validation rules\n } // pare down field keys to actually validate\n\n\n var limitedFieldLevelValidation = false;\n\n if (fieldChanged) {\n var changedField = safeFields[fieldChanged];\n\n if (changedField) {\n var validateFields = changedField.validateFields;\n\n if (validateFields) {\n limitedFieldLevelValidation = true;\n fieldKeys = validateFields.length ? validateFields.concat(fieldChanged) : [fieldChanged];\n }\n }\n }\n\n var recordLevelErrors = {};\n var fieldLevelErrors = {};\n var promises = [].concat(runRecordLevelValidation(function (errors) {\n recordLevelErrors = errors || {};\n }), fieldKeys.reduce(function (result, name) {\n return result.concat(runFieldLevelValidation(name, function (error) {\n fieldLevelErrors[name] = error;\n }));\n }, []));\n var hasAsyncValidations = promises.length > 0;\n var asyncValidationPromiseKey = ++nextAsyncValidationKey;\n var promise = Promise.all(promises).then(clearAsyncValidationPromise(asyncValidationPromiseKey)); // backwards-compat: add promise to submit-blocking promises iff there are any promises to await\n\n if (hasAsyncValidations) {\n asyncValidationPromises[asyncValidationPromiseKey] = promise;\n }\n\n var processErrors = function processErrors() {\n var merged = _extends({}, limitedFieldLevelValidation ? formState.errors : {}, recordLevelErrors);\n\n var forEachError = function forEachError(fn) {\n fieldKeys.forEach(function (name) {\n if (fields[name]) {\n // make sure field is still registered\n // field-level errors take precedent over record-level errors\n var recordLevelError = getIn(recordLevelErrors, name);\n var errorFromParent = getIn(merged, name);\n var hasFieldLevelValidation = getValidators(safeFields[name]).length;\n var fieldLevelError = fieldLevelErrors[name];\n fn(name, hasFieldLevelValidation && fieldLevelError || validate && recordLevelError || (!recordLevelError && !limitedFieldLevelValidation ? errorFromParent : undefined));\n }\n });\n };\n\n forEachError(function (name, error) {\n merged = setIn(merged, name, error) || {};\n });\n forEachError(function (name, error) {\n if (error && error[ARRAY_ERROR]) {\n var existing = getIn(merged, name);\n var copy = [].concat(existing);\n copy[ARRAY_ERROR] = error[ARRAY_ERROR];\n merged = setIn(merged, name, copy);\n }\n });\n\n if (!shallowEqual(formState.errors, merged)) {\n formState.errors = merged;\n }\n\n formState.error = recordLevelErrors[FORM_ERROR];\n }; // process sync errors\n\n\n processErrors(); // sync errors have been set. notify listeners while we wait for others\n\n callback();\n\n if (hasAsyncValidations) {\n state.formState.validating++;\n callback();\n\n var afterPromise = function afterPromise() {\n state.formState.validating--;\n callback();\n };\n\n promise.then(function () {\n if (nextAsyncValidationKey > asyncValidationPromiseKey) {\n // if this async validator has been superseded by another, ignore its results\n return;\n }\n\n processErrors();\n }).then(afterPromise, afterPromise);\n }\n };\n\n var notifyFieldListeners = function notifyFieldListeners(name) {\n if (inBatch) {\n return;\n }\n\n var fields = state.fields,\n fieldSubscribers = state.fieldSubscribers,\n formState = state.formState;\n\n var safeFields = _extends({}, fields);\n\n var notifyField = function notifyField(name) {\n var field = safeFields[name];\n var fieldState = publishFieldState(formState, field);\n var lastFieldState = field.lastFieldState;\n field.lastFieldState = fieldState;\n var fieldSubscriber = fieldSubscribers[name];\n\n if (fieldSubscriber) {\n notify(fieldSubscriber, fieldState, lastFieldState, filterFieldState, lastFieldState === undefined);\n }\n };\n\n if (name) {\n notifyField(name);\n } else {\n Object.keys(safeFields).forEach(notifyField);\n }\n };\n\n var markAllFieldsTouched = function markAllFieldsTouched() {\n Object.keys(state.fields).forEach(function (key) {\n state.fields[key].touched = true;\n });\n };\n\n var hasSyncErrors = function hasSyncErrors() {\n return !!(state.formState.error || hasAnyError(state.formState.errors));\n };\n\n var calculateNextFormState = function calculateNextFormState() {\n var fields = state.fields,\n formState = state.formState,\n lastFormState = state.lastFormState;\n\n var safeFields = _extends({}, fields);\n\n var safeFieldKeys = Object.keys(safeFields); // calculate dirty/pristine\n\n var foundDirty = false;\n var dirtyFields = safeFieldKeys.reduce(function (result, key) {\n var dirty = !safeFields[key].isEqual(getIn(formState.values, key), getIn(formState.initialValues || {}, key));\n\n if (dirty) {\n foundDirty = true;\n result[key] = true;\n }\n\n return result;\n }, {});\n var dirtyFieldsSinceLastSubmit = safeFieldKeys.reduce(function (result, key) {\n // istanbul ignore next\n var nonNullLastSubmittedValues = formState.lastSubmittedValues || {}; // || {} is for flow, but causes branch coverage complaint\n\n if (!safeFields[key].isEqual(getIn(formState.values, key), getIn(nonNullLastSubmittedValues, key))) {\n result[key] = true;\n }\n\n return result;\n }, {});\n formState.pristine = !foundDirty;\n formState.dirtySinceLastSubmit = !!(formState.lastSubmittedValues && Object.values(dirtyFieldsSinceLastSubmit).some(function (value) {\n return value;\n }));\n formState.modifiedSinceLastSubmit = !!(formState.lastSubmittedValues && // Object.values would treat values as mixed (facebook/flow#2221)\n Object.keys(safeFields).some(function (value) {\n return safeFields[value].modifiedSinceLastSubmit;\n }));\n formState.valid = !formState.error && !formState.submitError && !hasAnyError(formState.errors) && !(formState.submitErrors && hasAnyError(formState.submitErrors));\n var nextFormState = convertToExternalFormState(formState);\n\n var _safeFieldKeys$reduce = safeFieldKeys.reduce(function (result, key) {\n result.modified[key] = safeFields[key].modified;\n result.touched[key] = safeFields[key].touched;\n result.visited[key] = safeFields[key].visited;\n return result;\n }, {\n modified: {},\n touched: {},\n visited: {}\n }),\n modified = _safeFieldKeys$reduce.modified,\n touched = _safeFieldKeys$reduce.touched,\n visited = _safeFieldKeys$reduce.visited;\n\n nextFormState.dirtyFields = lastFormState && shallowEqual(lastFormState.dirtyFields, dirtyFields) ? lastFormState.dirtyFields : dirtyFields;\n nextFormState.dirtyFieldsSinceLastSubmit = lastFormState && shallowEqual(lastFormState.dirtyFieldsSinceLastSubmit, dirtyFieldsSinceLastSubmit) ? lastFormState.dirtyFieldsSinceLastSubmit : dirtyFieldsSinceLastSubmit;\n nextFormState.modified = lastFormState && shallowEqual(lastFormState.modified, modified) ? lastFormState.modified : modified;\n nextFormState.touched = lastFormState && shallowEqual(lastFormState.touched, touched) ? lastFormState.touched : touched;\n nextFormState.visited = lastFormState && shallowEqual(lastFormState.visited, visited) ? lastFormState.visited : visited;\n return lastFormState && shallowEqual(lastFormState, nextFormState) ? lastFormState : nextFormState;\n };\n\n var callDebug = function callDebug() {\n return debug && \"development\" !== 'production' && debug(calculateNextFormState(), Object.keys(state.fields).reduce(function (result, key) {\n result[key] = state.fields[key];\n return result;\n }, {}));\n };\n\n var notifying = false;\n var scheduleNotification = false;\n\n var notifyFormListeners = function notifyFormListeners() {\n if (notifying) {\n scheduleNotification = true;\n } else {\n notifying = true;\n callDebug();\n\n if (!inBatch && !(validationPaused && preventNotificationWhileValidationPaused)) {\n var lastFormState = state.lastFormState;\n var nextFormState = calculateNextFormState();\n\n if (nextFormState !== lastFormState) {\n state.lastFormState = nextFormState;\n notify(state.subscribers, nextFormState, lastFormState, filterFormState);\n }\n }\n\n notifying = false;\n\n if (scheduleNotification) {\n scheduleNotification = false;\n notifyFormListeners();\n }\n }\n };\n\n var beforeSubmit = function beforeSubmit() {\n return Object.keys(state.fields).some(function (name) {\n return state.fields[name].beforeSubmit && state.fields[name].beforeSubmit() === false;\n });\n };\n\n var afterSubmit = function afterSubmit() {\n return Object.keys(state.fields).forEach(function (name) {\n return state.fields[name].afterSubmit && state.fields[name].afterSubmit();\n });\n };\n\n var resetModifiedAfterSubmit = function resetModifiedAfterSubmit() {\n return Object.keys(state.fields).forEach(function (key) {\n return state.fields[key].modifiedSinceLastSubmit = false;\n });\n }; // generate initial errors\n\n\n runValidation(undefined, function () {\n notifyFormListeners();\n });\n var api = {\n batch: function batch(fn) {\n inBatch++;\n fn();\n inBatch--;\n notifyFieldListeners();\n notifyFormListeners();\n },\n blur: function blur(name) {\n var fields = state.fields,\n formState = state.formState;\n var previous = fields[name];\n\n if (previous) {\n // can only blur registered fields\n delete formState.active;\n fields[name] = _extends({}, previous, {\n active: false,\n touched: true\n });\n\n if (validateOnBlur) {\n runValidation(name, function () {\n notifyFieldListeners();\n notifyFormListeners();\n });\n } else {\n notifyFieldListeners();\n notifyFormListeners();\n }\n }\n },\n change: function change(name, value) {\n var fields = state.fields,\n formState = state.formState;\n\n if (getIn(formState.values, name) !== value) {\n changeValue(state, name, function () {\n return value;\n });\n var previous = fields[name];\n\n if (previous) {\n // only track modified for registered fields\n fields[name] = _extends({}, previous, {\n modified: true,\n modifiedSinceLastSubmit: !!formState.lastSubmittedValues\n });\n }\n\n if (validateOnBlur) {\n notifyFieldListeners();\n notifyFormListeners();\n } else {\n runValidation(name, function () {\n notifyFieldListeners();\n notifyFormListeners();\n });\n }\n }\n },\n\n get destroyOnUnregister() {\n return !!destroyOnUnregister;\n },\n\n set destroyOnUnregister(value) {\n destroyOnUnregister = value;\n },\n\n focus: function focus(name) {\n var field = state.fields[name];\n\n if (field && !field.active) {\n state.formState.active = name;\n field.active = true;\n field.visited = true;\n notifyFieldListeners();\n notifyFormListeners();\n }\n },\n mutators: mutatorsApi,\n getFieldState: function getFieldState(name) {\n var field = state.fields[name];\n return field && field.lastFieldState;\n },\n getRegisteredFields: function getRegisteredFields() {\n return Object.keys(state.fields);\n },\n getState: function getState() {\n return calculateNextFormState();\n },\n initialize: function initialize(data) {\n var fields = state.fields,\n formState = state.formState;\n\n var safeFields = _extends({}, fields);\n\n var values = typeof data === 'function' ? data(formState.values) : data;\n\n if (!keepDirtyOnReinitialize) {\n formState.values = values;\n }\n /**\n * Hello, inquisitive code reader! Thanks for taking the time to dig in!\n *\n * The following code is the way it is to allow for non-registered deep\n * field values to be set via initialize()\n */\n // save dirty values\n\n\n var savedDirtyValues = keepDirtyOnReinitialize ? Object.keys(safeFields).reduce(function (result, key) {\n var field = safeFields[key];\n var pristine = field.isEqual(getIn(formState.values, key), getIn(formState.initialValues || {}, key));\n\n if (!pristine) {\n result[key] = getIn(formState.values, key);\n }\n\n return result;\n }, {}) : {}; // update initalValues and values\n\n formState.initialValues = values;\n formState.values = values; // restore the dirty values\n\n Object.keys(savedDirtyValues).forEach(function (key) {\n formState.values = setIn(formState.values, key, savedDirtyValues[key]);\n });\n runValidation(undefined, function () {\n notifyFieldListeners();\n notifyFormListeners();\n });\n },\n isValidationPaused: function isValidationPaused() {\n return validationPaused;\n },\n pauseValidation: function pauseValidation(preventNotification) {\n if (preventNotification === void 0) {\n preventNotification = true;\n }\n\n validationPaused = true;\n preventNotificationWhileValidationPaused = preventNotification;\n },\n registerField: function registerField(name, subscriber, subscription, fieldConfig) {\n if (subscription === void 0) {\n subscription = {};\n }\n\n if (!state.fieldSubscribers[name]) {\n state.fieldSubscribers[name] = {\n index: 0,\n entries: {}\n };\n }\n\n var index = state.fieldSubscribers[name].index++; // save field subscriber callback\n\n state.fieldSubscribers[name].entries[index] = {\n subscriber: memoize(subscriber),\n subscription: subscription,\n notified: false\n };\n\n if (!state.fields[name]) {\n // create initial field state\n state.fields[name] = {\n active: false,\n afterSubmit: fieldConfig && fieldConfig.afterSubmit,\n beforeSubmit: fieldConfig && fieldConfig.beforeSubmit,\n blur: function blur() {\n return api.blur(name);\n },\n change: function change(value) {\n return api.change(name, value);\n },\n data: fieldConfig && fieldConfig.data || {},\n focus: function focus() {\n return api.focus(name);\n },\n isEqual: fieldConfig && fieldConfig.isEqual || tripleEquals,\n lastFieldState: undefined,\n modified: false,\n modifiedSinceLastSubmit: false,\n name: name,\n touched: false,\n valid: true,\n validateFields: fieldConfig && fieldConfig.validateFields,\n validators: {},\n validating: false,\n visited: false\n };\n }\n\n var haveValidator = false;\n var silent = fieldConfig && fieldConfig.silent;\n\n var notify = function notify() {\n if (silent) {\n notifyFieldListeners(name);\n } else {\n notifyFormListeners();\n notifyFieldListeners();\n }\n };\n\n if (fieldConfig) {\n haveValidator = !!(fieldConfig.getValidator && fieldConfig.getValidator());\n\n if (fieldConfig.getValidator) {\n state.fields[name].validators[index] = fieldConfig.getValidator;\n }\n\n var noValueInFormState = getIn(state.formState.values, name) === undefined;\n\n if (fieldConfig.initialValue !== undefined && noValueInFormState && (getIn(state.formState.values, name) === undefined || getIn(state.formState.values, name) === getIn(state.formState.initialValues, name)) // only initialize if we don't yet have any value for this field\n ) {\n state.formState.initialValues = setIn(state.formState.initialValues || {}, name, fieldConfig.initialValue);\n state.formState.values = setIn(state.formState.values, name, fieldConfig.initialValue);\n runValidation(undefined, notify);\n } // only use defaultValue if we don't yet have any value for this field\n\n\n if (fieldConfig.defaultValue !== undefined && fieldConfig.initialValue === undefined && getIn(state.formState.initialValues, name) === undefined && noValueInFormState) {\n state.formState.values = setIn(state.formState.values, name, fieldConfig.defaultValue);\n }\n }\n\n if (haveValidator) {\n runValidation(undefined, notify);\n } else {\n notify();\n }\n\n return function () {\n var validatorRemoved = false; // istanbul ignore next\n\n if (state.fields[name]) {\n // state.fields[name] may have been removed by a mutator\n validatorRemoved = !!(state.fields[name].validators[index] && state.fields[name].validators[index]());\n delete state.fields[name].validators[index];\n }\n\n var hasFieldSubscribers = !!state.fieldSubscribers[name];\n\n if (hasFieldSubscribers) {\n // state.fieldSubscribers[name] may have been removed by a mutator\n delete state.fieldSubscribers[name].entries[index];\n }\n\n var lastOne = hasFieldSubscribers && !Object.keys(state.fieldSubscribers[name].entries).length;\n\n if (lastOne) {\n delete state.fieldSubscribers[name];\n delete state.fields[name];\n\n if (validatorRemoved) {\n state.formState.errors = setIn(state.formState.errors, name, undefined) || {};\n }\n\n if (destroyOnUnregister) {\n state.formState.values = setIn(state.formState.values, name, undefined, true) || {};\n }\n }\n\n if (!silent) {\n if (validatorRemoved) {\n runValidation(undefined, function () {\n notifyFormListeners();\n notifyFieldListeners();\n });\n } else if (lastOne) {\n // values or errors may have changed\n notifyFormListeners();\n }\n }\n };\n },\n reset: function reset(initialValues) {\n if (initialValues === void 0) {\n initialValues = state.formState.initialValues;\n }\n\n if (state.formState.submitting) {\n state.formState.resetWhileSubmitting = true;\n }\n\n state.formState.submitFailed = false;\n state.formState.submitSucceeded = false;\n delete state.formState.submitError;\n delete state.formState.submitErrors;\n delete state.formState.lastSubmittedValues;\n api.initialize(initialValues || {});\n },\n\n /**\n * Resets all field flags (e.g. touched, visited, etc.) to their initial state\n */\n resetFieldState: function resetFieldState(name) {\n state.fields[name] = _extends({}, state.fields[name], {\n active: false,\n lastFieldState: undefined,\n modified: false,\n touched: false,\n valid: true,\n validating: false,\n visited: false\n });\n runValidation(undefined, function () {\n notifyFieldListeners();\n notifyFormListeners();\n });\n },\n\n /**\n * Returns the form to a clean slate; that is:\n * - Clear all values\n * - Resets all fields to their initial state\n */\n restart: function restart(initialValues) {\n if (initialValues === void 0) {\n initialValues = state.formState.initialValues;\n }\n\n api.batch(function () {\n for (var name in state.fields) {\n api.resetFieldState(name);\n state.fields[name] = _extends({}, state.fields[name], {\n active: false,\n lastFieldState: undefined,\n modified: false,\n modifiedSinceLastSubmit: false,\n touched: false,\n valid: true,\n validating: false,\n visited: false\n });\n }\n\n api.reset(initialValues);\n });\n },\n resumeValidation: function resumeValidation() {\n validationPaused = false;\n preventNotificationWhileValidationPaused = false;\n\n if (validationBlocked) {\n // validation was attempted while it was paused, so run it now\n runValidation(undefined, function () {\n notifyFieldListeners();\n notifyFormListeners();\n });\n }\n\n validationBlocked = false;\n },\n setConfig: function setConfig(name, value) {\n switch (name) {\n case 'debug':\n debug = value;\n break;\n\n case 'destroyOnUnregister':\n destroyOnUnregister = value;\n break;\n\n case 'initialValues':\n api.initialize(value);\n break;\n\n case 'keepDirtyOnReinitialize':\n keepDirtyOnReinitialize = value;\n break;\n\n case 'mutators':\n mutators = value;\n\n if (value) {\n Object.keys(mutatorsApi).forEach(function (key) {\n if (!(key in value)) {\n delete mutatorsApi[key];\n }\n });\n Object.keys(value).forEach(function (key) {\n mutatorsApi[key] = getMutatorApi(key);\n });\n } else {\n Object.keys(mutatorsApi).forEach(function (key) {\n delete mutatorsApi[key];\n });\n }\n\n break;\n\n case 'onSubmit':\n onSubmit = value;\n break;\n\n case 'validate':\n validate = value;\n runValidation(undefined, function () {\n notifyFieldListeners();\n notifyFormListeners();\n });\n break;\n\n case 'validateOnBlur':\n validateOnBlur = value;\n break;\n\n default:\n throw new Error('Unrecognised option ' + name);\n }\n },\n submit: function submit() {\n var formState = state.formState;\n\n if (formState.submitting) {\n return;\n }\n\n delete formState.submitErrors;\n delete formState.submitError;\n formState.lastSubmittedValues = _extends({}, formState.values);\n\n if (hasSyncErrors()) {\n markAllFieldsTouched();\n state.formState.submitFailed = true;\n notifyFormListeners();\n notifyFieldListeners();\n return; // no submit for you!!\n }\n\n var asyncValidationPromisesKeys = Object.keys(asyncValidationPromises);\n\n if (asyncValidationPromisesKeys.length) {\n // still waiting on async validation to complete...\n Promise.all(asyncValidationPromisesKeys.map(function (key) {\n return asyncValidationPromises[Number(key)];\n })).then(api.submit, console.error);\n return;\n }\n\n var submitIsBlocked = beforeSubmit();\n\n if (submitIsBlocked) {\n return;\n }\n\n var resolvePromise;\n var completeCalled = false;\n\n var complete = function complete(errors) {\n formState.submitting = false;\n var resetWhileSubmitting = formState.resetWhileSubmitting;\n\n if (resetWhileSubmitting) {\n formState.resetWhileSubmitting = false;\n }\n\n if (errors && hasAnyError(errors)) {\n formState.submitFailed = true;\n formState.submitSucceeded = false;\n formState.submitErrors = errors;\n formState.submitError = errors[FORM_ERROR];\n markAllFieldsTouched();\n } else {\n if (!resetWhileSubmitting) {\n formState.submitFailed = false;\n formState.submitSucceeded = true;\n }\n\n afterSubmit();\n }\n\n notifyFormListeners();\n notifyFieldListeners();\n completeCalled = true;\n\n if (resolvePromise) {\n resolvePromise(errors);\n }\n\n return errors;\n };\n\n formState.submitting = true;\n formState.submitFailed = false;\n formState.submitSucceeded = false;\n formState.lastSubmittedValues = _extends({}, formState.values);\n resetModifiedAfterSubmit(); // onSubmit is either sync, callback or async with a Promise\n\n var result = onSubmit(formState.values, api, complete);\n\n if (!completeCalled) {\n if (result && isPromise(result)) {\n // onSubmit is async with a Promise\n notifyFormListeners(); // let everyone know we are submitting\n\n notifyFieldListeners(); // notify fields also\n\n return result.then(complete, function (error) {\n complete();\n throw error;\n });\n } else if (onSubmit.length >= 3) {\n // must be async, so we should return a Promise\n notifyFormListeners(); // let everyone know we are submitting\n\n notifyFieldListeners(); // notify fields also\n\n return new Promise(function (resolve) {\n resolvePromise = resolve;\n });\n } else {\n // onSubmit is sync\n complete(result);\n }\n }\n },\n subscribe: function subscribe(subscriber, subscription) {\n if (!subscriber) {\n throw new Error('No callback given.');\n }\n\n if (!subscription) {\n throw new Error('No subscription provided. What values do you want to listen to?');\n }\n\n var memoized = memoize(subscriber);\n var subscribers = state.subscribers;\n var index = subscribers.index++;\n subscribers.entries[index] = {\n subscriber: memoized,\n subscription: subscription,\n notified: false\n };\n var nextFormState = calculateNextFormState();\n notifySubscriber(memoized, subscription, nextFormState, nextFormState, filterFormState, true);\n return function () {\n delete subscribers.entries[index];\n };\n }\n };\n return api;\n}\n\nexport { ARRAY_ERROR, FORM_ERROR, configOptions, createForm, fieldSubscriptionItems, formSubscriptionItems, getIn, setIn, version };\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport _objectWithoutPropertiesLoose from '@babel/runtime/helpers/esm/objectWithoutPropertiesLoose';\nimport * as React from 'react';\nimport React__default from 'react';\nimport { formSubscriptionItems, createForm, version as version$1, fieldSubscriptionItems } from 'final-form';\n\n// shared logic between components that use either render prop,\n// children render function, or component prop\nfunction renderComponent(props, lazyProps, name) {\n var render = props.render,\n children = props.children,\n component = props.component,\n rest = _objectWithoutPropertiesLoose(props, [\"render\", \"children\", \"component\"]);\n\n if (component) {\n return /*#__PURE__*/React.createElement(component, Object.assign(lazyProps, rest, {\n children: children,\n render: render\n }));\n }\n\n if (render) {\n return render(children === undefined ? Object.assign(lazyProps, rest) : // inject children back in\n Object.assign(lazyProps, rest, {\n children: children\n }));\n }\n\n if (typeof children !== 'function') {\n throw new Error(\"Must specify either a render prop, a render function as children, or a component prop to \" + name);\n }\n\n return children(Object.assign(lazyProps, rest));\n}\n\nfunction useWhenValueChanges(value, callback, isEqual) {\n if (isEqual === void 0) {\n isEqual = function isEqual(a, b) {\n return a === b;\n };\n }\n\n var previous = React__default.useRef(value);\n React__default.useEffect(function () {\n if (!isEqual(value, previous.current)) {\n callback();\n previous.current = value;\n }\n });\n}\n\n/**\n * A simple hook to create a constant value that lives for\n * the lifetime of the component.\n *\n * Plagiarized from https://github.com/Andarist/use-constant\n *\n * Do NOT reuse this code unless you know what you're doing.\n * Use Andarist's hook; it's more fault tolerant to things like\n * falsy values.\n *\n * @param {Function} init - A function to generate the value\n */\n\nfunction useConstant(init) {\n var ref = React__default.useRef();\n\n if (!ref.current) {\n ref.current = init();\n }\n\n return ref.current;\n}\n\nvar shallowEqual = function shallowEqual(a, b) {\n if (a === b) {\n return true;\n }\n\n if (typeof a !== 'object' || !a || typeof b !== 'object' || !b) {\n return false;\n }\n\n var keysA = Object.keys(a);\n var keysB = Object.keys(b);\n\n if (keysA.length !== keysB.length) {\n return false;\n }\n\n var bHasOwnProperty = Object.prototype.hasOwnProperty.bind(b);\n\n for (var idx = 0; idx < keysA.length; idx++) {\n var key = keysA[idx];\n\n if (!bHasOwnProperty(key) || a[key] !== b[key]) {\n return false;\n }\n }\n\n return true;\n};\n\nvar isSyntheticEvent = function isSyntheticEvent(candidate) {\n return !!(candidate && typeof candidate.stopPropagation === 'function');\n};\n\nvar ReactFinalFormContext = /*#__PURE__*/React.createContext();\n\nfunction useLatest(value) {\n var ref = React__default.useRef(value);\n React__default.useEffect(function () {\n ref.current = value;\n });\n return ref;\n}\n\nvar version = \"6.5.3\";\n\nvar addLazyState = function addLazyState(dest, state, keys) {\n keys.forEach(function (key) {\n Object.defineProperty(dest, key, {\n get: function get() {\n return state[key];\n },\n enumerable: true\n });\n });\n};\n\nvar addLazyFormState = function addLazyFormState(dest, state) {\n return addLazyState(dest, state, ['active', 'dirty', 'dirtyFields', 'dirtySinceLastSubmit', 'dirtyFieldsSinceLastSubmit', 'error', 'errors', 'hasSubmitErrors', 'hasValidationErrors', 'initialValues', 'invalid', 'modified', 'modifiedSinceLastSubmit', 'pristine', 'submitError', 'submitErrors', 'submitFailed', 'submitSucceeded', 'submitting', 'touched', 'valid', 'validating', 'values', 'visited']);\n};\nvar addLazyFieldMetaState = function addLazyFieldMetaState(dest, state) {\n return addLazyState(dest, state, ['active', 'data', 'dirty', 'dirtySinceLastSubmit', 'error', 'initial', 'invalid', 'length', 'modified', 'modifiedSinceLastSubmit', 'pristine', 'submitError', 'submitFailed', 'submitSucceeded', 'submitting', 'touched', 'valid', 'validating', 'visited']);\n};\n\nvar versions = {\n 'final-form': version$1,\n 'react-final-form': version\n};\nvar all$1 = formSubscriptionItems.reduce(function (result, key) {\n result[key] = true;\n return result;\n}, {});\n\nfunction ReactFinalForm(_ref) {\n var debug = _ref.debug,\n decorators = _ref.decorators,\n destroyOnUnregister = _ref.destroyOnUnregister,\n alternateFormApi = _ref.form,\n initialValues = _ref.initialValues,\n initialValuesEqual = _ref.initialValuesEqual,\n keepDirtyOnReinitialize = _ref.keepDirtyOnReinitialize,\n mutators = _ref.mutators,\n onSubmit = _ref.onSubmit,\n _ref$subscription = _ref.subscription,\n subscription = _ref$subscription === void 0 ? all$1 : _ref$subscription,\n validate = _ref.validate,\n validateOnBlur = _ref.validateOnBlur,\n rest = _objectWithoutPropertiesLoose(_ref, [\"debug\", \"decorators\", \"destroyOnUnregister\", \"form\", \"initialValues\", \"initialValuesEqual\", \"keepDirtyOnReinitialize\", \"mutators\", \"onSubmit\", \"subscription\", \"validate\", \"validateOnBlur\"]);\n\n var config = {\n debug: debug,\n destroyOnUnregister: destroyOnUnregister,\n initialValues: initialValues,\n keepDirtyOnReinitialize: keepDirtyOnReinitialize,\n mutators: mutators,\n onSubmit: onSubmit,\n validate: validate,\n validateOnBlur: validateOnBlur\n };\n var form = useConstant(function () {\n var f = alternateFormApi || createForm(config); // pause validation until children register all fields on first render (unpaused in useEffect() below)\n\n f.pauseValidation();\n return f;\n }); // synchronously register and unregister to query form state for our subscription on first render\n\n var _React$useState = React.useState(function () {\n var initialState = {};\n form.subscribe(function (state) {\n initialState = state;\n }, subscription)();\n return initialState;\n }),\n state = _React$useState[0],\n setState = _React$useState[1]; // save a copy of state that can break through the closure\n // on the shallowEqual() line below.\n\n\n var stateRef = useLatest(state);\n React.useEffect(function () {\n // We have rendered, so all fields are now registered, so we can unpause validation\n form.isValidationPaused() && form.resumeValidation();\n var unsubscriptions = [form.subscribe(function (s) {\n if (!shallowEqual(s, stateRef.current)) {\n setState(s);\n }\n }, subscription)].concat(decorators ? decorators.map(function (decorator) {\n return (// this noop ternary is to appease the flow gods\n // istanbul ignore next\n decorator(form)\n );\n }) : []);\n return function () {\n form.pauseValidation(); // pause validation so we don't revalidate on every field deregistration\n\n unsubscriptions.reverse().forEach(function (unsubscribe) {\n return unsubscribe();\n }); // don't need to resume validation here; either unmounting, or will re-run this hook with new deps\n }; // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [decorators]); // warn about decorator changes\n // istanbul ignore next\n\n if (process.env.NODE_ENV !== 'production') {\n // You're never supposed to use hooks inside a conditional, but in this\n // case we can be certain that you're not going to be changing your\n // NODE_ENV between renders, so this is safe.\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useWhenValueChanges(decorators, function () {\n console.error('Form decorators should not change from one render to the next as new values will be ignored');\n }, shallowEqual);\n } // allow updatable config\n\n\n useWhenValueChanges(debug, function () {\n form.setConfig('debug', debug);\n });\n useWhenValueChanges(destroyOnUnregister, function () {\n form.destroyOnUnregister = !!destroyOnUnregister;\n });\n useWhenValueChanges(keepDirtyOnReinitialize, function () {\n form.setConfig('keepDirtyOnReinitialize', keepDirtyOnReinitialize);\n });\n useWhenValueChanges(initialValues, function () {\n form.setConfig('initialValues', initialValues);\n }, initialValuesEqual || shallowEqual);\n useWhenValueChanges(mutators, function () {\n form.setConfig('mutators', mutators);\n });\n useWhenValueChanges(onSubmit, function () {\n form.setConfig('onSubmit', onSubmit);\n });\n useWhenValueChanges(validate, function () {\n form.setConfig('validate', validate);\n });\n useWhenValueChanges(validateOnBlur, function () {\n form.setConfig('validateOnBlur', validateOnBlur);\n });\n\n var handleSubmit = function handleSubmit(event) {\n if (event) {\n // sometimes not true, e.g. React Native\n if (typeof event.preventDefault === 'function') {\n event.preventDefault();\n }\n\n if (typeof event.stopPropagation === 'function') {\n // prevent any outer forms from receiving the event too\n event.stopPropagation();\n }\n }\n\n return form.submit();\n };\n\n var renderProps = {\n form: _extends({}, form, {\n reset: function reset(eventOrValues) {\n if (isSyntheticEvent(eventOrValues)) {\n // it's a React SyntheticEvent, call reset with no arguments\n form.reset();\n } else {\n form.reset(eventOrValues);\n }\n }\n }),\n handleSubmit: handleSubmit\n };\n addLazyFormState(renderProps, state);\n return /*#__PURE__*/React.createElement(ReactFinalFormContext.Provider, {\n value: form\n }, renderComponent(_extends({}, rest, {\n __versions: versions\n }), renderProps, 'ReactFinalForm'));\n}\n\nfunction useForm(componentName) {\n var form = React.useContext(ReactFinalFormContext);\n\n if (!form) {\n throw new Error((componentName || 'useForm') + \" must be used inside of a
component\");\n }\n\n return form;\n}\n\nfunction useFormState(_temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n onChange = _ref.onChange,\n _ref$subscription = _ref.subscription,\n subscription = _ref$subscription === void 0 ? all$1 : _ref$subscription;\n\n var form = useForm('useFormState');\n var firstRender = React.useRef(true);\n var onChangeRef = React.useRef(onChange);\n onChangeRef.current = onChange; // synchronously register and unregister to query field state for our subscription on first render\n\n var _React$useState = React.useState(function () {\n var initialState = {};\n form.subscribe(function (state) {\n initialState = state;\n }, subscription)();\n\n if (onChange) {\n onChange(initialState);\n }\n\n return initialState;\n }),\n state = _React$useState[0],\n setState = _React$useState[1];\n\n React.useEffect(function () {\n return form.subscribe(function (newState) {\n if (firstRender.current) {\n firstRender.current = false;\n } else {\n setState(newState);\n\n if (onChangeRef.current) {\n onChangeRef.current(newState);\n }\n }\n }, subscription);\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n []);\n var lazyState = {};\n addLazyFormState(lazyState, state);\n return lazyState;\n}\n\nfunction FormSpy(_ref) {\n var onChange = _ref.onChange,\n subscription = _ref.subscription,\n rest = _objectWithoutPropertiesLoose(_ref, [\"onChange\", \"subscription\"]);\n\n var reactFinalForm = useForm('FormSpy');\n var state = useFormState({\n onChange: onChange,\n subscription: subscription\n });\n\n if (onChange) {\n return null;\n }\n\n var renderProps = {\n form: _extends({}, reactFinalForm, {\n reset: function reset(eventOrValues) {\n if (isSyntheticEvent(eventOrValues)) {\n // it's a React SyntheticEvent, call reset with no arguments\n reactFinalForm.reset();\n } else {\n reactFinalForm.reset(eventOrValues);\n }\n }\n })\n };\n return renderComponent(_extends({}, rest, renderProps), state, 'FormSpy');\n}\n\nvar isReactNative = typeof window !== 'undefined' && window.navigator && window.navigator.product && window.navigator.product === 'ReactNative';\n\nvar getSelectedValues = function getSelectedValues(options) {\n var result = [];\n\n if (options) {\n for (var index = 0; index < options.length; index++) {\n var option = options[index];\n\n if (option.selected) {\n result.push(option.value);\n }\n }\n }\n\n return result;\n};\n\nvar getValue = function getValue(event, currentValue, valueProp, isReactNative) {\n if (!isReactNative && event.nativeEvent && event.nativeEvent.text !== undefined) {\n return event.nativeEvent.text;\n }\n\n if (isReactNative && event.nativeEvent) {\n return event.nativeEvent.text;\n }\n\n var detypedEvent = event;\n var _detypedEvent$target = detypedEvent.target,\n type = _detypedEvent$target.type,\n value = _detypedEvent$target.value,\n checked = _detypedEvent$target.checked;\n\n switch (type) {\n case 'checkbox':\n if (valueProp !== undefined) {\n // we are maintaining an array, not just a boolean\n if (checked) {\n // add value to current array value\n return Array.isArray(currentValue) ? currentValue.concat(valueProp) : [valueProp];\n } else {\n // remove value from current array value\n if (!Array.isArray(currentValue)) {\n return currentValue;\n }\n\n var index = currentValue.indexOf(valueProp);\n\n if (index < 0) {\n return currentValue;\n } else {\n return currentValue.slice(0, index).concat(currentValue.slice(index + 1));\n }\n }\n } else {\n // it's just a boolean\n return !!checked;\n }\n\n case 'select-multiple':\n return getSelectedValues(event.target.options);\n\n default:\n return value;\n }\n};\n\nvar all = fieldSubscriptionItems.reduce(function (result, key) {\n result[key] = true;\n return result;\n}, {});\n\nvar defaultFormat = function defaultFormat(value, name) {\n return value === undefined ? '' : value;\n};\n\nvar defaultParse = function defaultParse(value, name) {\n return value === '' ? undefined : value;\n};\n\nvar defaultIsEqual = function defaultIsEqual(a, b) {\n return a === b;\n};\n\nfunction useField(name, config) {\n if (config === void 0) {\n config = {};\n }\n\n var _config = config,\n afterSubmit = _config.afterSubmit,\n allowNull = _config.allowNull,\n component = _config.component,\n data = _config.data,\n defaultValue = _config.defaultValue,\n _config$format = _config.format,\n format = _config$format === void 0 ? defaultFormat : _config$format,\n formatOnBlur = _config.formatOnBlur,\n initialValue = _config.initialValue,\n multiple = _config.multiple,\n _config$parse = _config.parse,\n parse = _config$parse === void 0 ? defaultParse : _config$parse,\n _config$subscription = _config.subscription,\n subscription = _config$subscription === void 0 ? all : _config$subscription,\n type = _config.type,\n validateFields = _config.validateFields,\n _value = _config.value;\n var form = useForm('useField');\n var configRef = useLatest(config);\n\n var register = function register(callback, silent) {\n return (// avoid using `state` const in any closures created inside `register`\n // because they would refer `state` from current execution context\n // whereas actual `state` would defined in the subsequent `useField` hook\n // execution\n // (that would be caused by `setState` call performed in `register` callback)\n form.registerField(name, callback, subscription, {\n afterSubmit: afterSubmit,\n beforeSubmit: function beforeSubmit() {\n var _configRef$current = configRef.current,\n beforeSubmit = _configRef$current.beforeSubmit,\n formatOnBlur = _configRef$current.formatOnBlur,\n _configRef$current$fo = _configRef$current.format,\n format = _configRef$current$fo === void 0 ? defaultFormat : _configRef$current$fo;\n\n if (formatOnBlur) {\n var _ref = form.getFieldState(name),\n value = _ref.value;\n\n var formatted = format(value, name);\n\n if (formatted !== value) {\n form.change(name, formatted);\n }\n }\n\n return beforeSubmit && beforeSubmit();\n },\n data: data,\n defaultValue: defaultValue,\n getValidator: function getValidator() {\n return configRef.current.validate;\n },\n initialValue: initialValue,\n isEqual: function isEqual(a, b) {\n return (configRef.current.isEqual || defaultIsEqual)(a, b);\n },\n silent: silent,\n validateFields: validateFields\n })\n );\n };\n\n var firstRender = React.useRef(true); // synchronously register and unregister to query field state for our subscription on first render\n\n var _React$useState = React.useState(function () {\n var initialState = {}; // temporarily disable destroyOnUnregister\n\n var destroyOnUnregister = form.destroyOnUnregister;\n form.destroyOnUnregister = false;\n register(function (state) {\n initialState = state;\n }, true)(); // return destroyOnUnregister to its original value\n\n form.destroyOnUnregister = destroyOnUnregister;\n return initialState;\n }),\n state = _React$useState[0],\n setState = _React$useState[1];\n\n React.useEffect(function () {\n return register(function (state) {\n if (firstRender.current) {\n firstRender.current = false;\n } else {\n setState(state);\n }\n }, false);\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [name, data, defaultValue, // If we want to allow inline fat-arrow field-level validation functions, we\n // cannot reregister field every time validate function !==.\n // validate,\n initialValue // The validateFields array is often passed as validateFields={[]}, creating\n // a !== new array every time. If it needs to be changed, a rerender/reregister\n // can be forced by changing the key prop\n // validateFields\n ]);\n var handlers = {\n onBlur: React.useCallback(function (event) {\n state.blur();\n\n if (formatOnBlur) {\n /**\n * Here we must fetch the value directly from Final Form because we cannot\n * trust that our `state` closure has the most recent value. This is a problem\n * if-and-only-if the library consumer has called `onChange()` immediately\n * before calling `onBlur()`, but before the field has had a chance to receive\n * the value update from Final Form.\n */\n var fieldState = form.getFieldState(state.name);\n state.change(format(fieldState.value, state.name));\n }\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [state.blur, state.name, format, formatOnBlur]),\n onChange: React.useCallback(function (event) {\n // istanbul ignore next\n if (process.env.NODE_ENV !== 'production' && event && event.target) {\n var targetType = event.target.type;\n var unknown = ~['checkbox', 'radio', 'select-multiple'].indexOf(targetType) && !type && component !== 'select';\n\n var _value2 = targetType === 'select-multiple' ? state.value : _value;\n\n if (unknown) {\n console.error(\"You must pass `type=\\\"\" + (targetType === 'select-multiple' ? 'select' : targetType) + \"\\\"` prop to your Field(\" + name + \") component.\\n\" + (\"Without it we don't know how to unpack your `value` prop - \" + (Array.isArray(_value2) ? \"[\" + _value2 + \"]\" : \"\\\"\" + _value2 + \"\\\"\") + \".\"));\n }\n }\n\n var value = event && event.target ? getValue(event, state.value, _value, isReactNative) : event;\n state.change(parse(value, name));\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [_value, name, parse, state.change, state.value, type]),\n onFocus: React.useCallback(function (event) {\n state.focus();\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [state.focus])\n };\n var meta = {};\n addLazyFieldMetaState(meta, state);\n\n var input = _extends({\n name: name,\n\n get value() {\n var value = state.value;\n\n if (formatOnBlur) {\n if (component === 'input') {\n value = defaultFormat(value);\n }\n } else {\n value = format(value, name);\n }\n\n if (value === null && !allowNull) {\n value = '';\n }\n\n if (type === 'checkbox' || type === 'radio') {\n return _value;\n } else if (component === 'select' && multiple) {\n return value || [];\n }\n\n return value;\n },\n\n get checked() {\n var value = state.value;\n\n if (type === 'checkbox') {\n value = format(value, name);\n\n if (_value === undefined) {\n return !!value;\n } else {\n return !!(Array.isArray(value) && ~value.indexOf(_value));\n }\n } else if (type === 'radio') {\n return format(value, name) === _value;\n }\n\n return undefined;\n }\n\n }, handlers);\n\n if (multiple) {\n input.multiple = multiple;\n }\n\n if (type !== undefined) {\n input.type = type;\n }\n\n var renderProps = {\n input: input,\n meta: meta\n }; // assign to force Flow check\n\n return renderProps;\n}\n\nvar Field = /*#__PURE__*/React.forwardRef(function Field(_ref, ref) {\n var afterSubmit = _ref.afterSubmit,\n allowNull = _ref.allowNull,\n beforeSubmit = _ref.beforeSubmit,\n children = _ref.children,\n component = _ref.component,\n data = _ref.data,\n defaultValue = _ref.defaultValue,\n format = _ref.format,\n formatOnBlur = _ref.formatOnBlur,\n initialValue = _ref.initialValue,\n isEqual = _ref.isEqual,\n multiple = _ref.multiple,\n name = _ref.name,\n parse = _ref.parse,\n subscription = _ref.subscription,\n type = _ref.type,\n validate = _ref.validate,\n validateFields = _ref.validateFields,\n value = _ref.value,\n rest = _objectWithoutPropertiesLoose(_ref, [\"afterSubmit\", \"allowNull\", \"beforeSubmit\", \"children\", \"component\", \"data\", \"defaultValue\", \"format\", \"formatOnBlur\", \"initialValue\", \"isEqual\", \"multiple\", \"name\", \"parse\", \"subscription\", \"type\", \"validate\", \"validateFields\", \"value\"]);\n\n var field = useField(name, {\n afterSubmit: afterSubmit,\n allowNull: allowNull,\n beforeSubmit: beforeSubmit,\n children: children,\n component: component,\n data: data,\n defaultValue: defaultValue,\n format: format,\n formatOnBlur: formatOnBlur,\n initialValue: initialValue,\n isEqual: isEqual,\n multiple: multiple,\n parse: parse,\n subscription: subscription,\n type: type,\n validate: validate,\n validateFields: validateFields,\n value: value\n });\n\n if (typeof children === 'function') {\n return children(_extends({}, field, rest));\n }\n\n if (typeof component === 'string') {\n // ignore meta, combine input with any other props\n return /*#__PURE__*/React.createElement(component, _extends({}, field.input, {\n children: children,\n ref: ref\n }, rest));\n }\n\n if (!name) {\n throw new Error('prop name cannot be undefined in component');\n }\n\n return renderComponent(_extends({\n children: children,\n component: component,\n ref: ref\n }, rest), field, \"Field(\" + name + \")\");\n});\n\nfunction withTypes() {\n return {\n Form: ReactFinalForm,\n FormSpy: FormSpy\n };\n}\n\nexport { Field, ReactFinalForm as Form, FormSpy, useField, useForm, useFormState, version, withTypes };\n","","/*\n * isNumber Validation\n * isNumber checks to see if the value is a number\n * isNumberValidation returns the DEFAULT_MESSAGE if no numbers were found\n */\nexport const DEFAULT_MESSAGE = 'Number required';\n\nfunction isNumber(value) {\n return /^[0-9]+$/g.test(value);\n}\n\nexport function isNumberValidation() {\n const errorMessage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : DEFAULT_MESSAGE;\n return function error(value) {\n return !isNumber(value) ? errorMessage : undefined;\n };\n}\n\nexport default isNumber;\n","","","import type { ReactElement, SVGProps } from 'react';\nimport React from 'react';\nimport cx from 'classnames';\nimport TickIcon from '@clearscore/rainbow.icons.success-inline';\nimport WarningIcon from '@clearscore/rainbow.icons.warning-inline';\nimport ErrorIcon from '@clearscore/rainbow.icons.error-inline';\nimport Text from '@clearscore/rainbow.text';\nimport toTitleCase from '@clearscore/normalize.title-case';\n\nimport styles from './criteria.module.css';\n\nconst Theme = {\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n} as const;\n\nconst DisplayState = {\n SUCCESS: 'SUCCESS',\n WARNING: 'WARNING',\n ERROR: 'ERROR',\n} as const;\n\ntype IconType = (props: SVGProps & { title?: string }) => ReactElement;\n\nconst getIcon = (displayState: keyof typeof DisplayState): IconType => {\n if (displayState === DisplayState.WARNING) {\n return WarningIcon;\n }\n if (displayState === DisplayState.ERROR) {\n return ErrorIcon;\n }\n return TickIcon;\n};\n\ninterface CriteriaProps {\n displayState: keyof typeof DisplayState;\n children?: string;\n theme?: typeof Theme[keyof typeof Theme];\n dataId?: string;\n}\n\nexport interface CriteriaExport {\n (props: CriteriaProps): ReactElement;\n DisplayState: typeof DisplayState;\n Theme: typeof Theme;\n}\n\nconst Criteria: CriteriaExport = ({ children = '', theme = Theme.LIGHT, displayState, dataId = '' }) => {\n const Icon = getIcon(displayState);\n const themeClass = styles[`isTheme${toTitleCase(theme)}`];\n const typeClass = styles[`isType${toTitleCase(displayState)}`];\n const iconTitle = `${children} icon`;\n\n return (\n \n \n \n \n {children}\n \n );\n};\n\nCriteria.DisplayState = DisplayState;\nCriteria.Theme = Theme;\n\nexport default Criteria;\n","export const Theme = {\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n} as const;\n\nexport const Type = {\n EMAIL: 'email',\n NUMBER: 'number',\n PASSWORD: 'password',\n TEXT: 'text',\n DATE: 'date',\n TEL: 'tel',\n} as const;\n","import type {\n ChangeEvent,\n HTMLAttributes,\n LegacyRef,\n MutableRefObject,\n ReactElement,\n ReactNode,\n RefObject,\n} from 'react';\nimport React, { isValidElement } from 'react';\nimport cx from 'classnames';\nimport Text from '@clearscore/rainbow.text';\nimport Criteria from '@clearscore/rainbow.criteria';\nimport toTitleCase from '@clearscore/normalize.title-case';\n\nimport styles from './text-input.module.css';\nimport { Theme, Type } from './constants';\n\nexport interface ITextInputProps extends HTMLAttributes {\n name: string;\n value: string | number;\n id?: string;\n dataId?: string;\n suffix?: ReactNode;\n prepend?: string;\n isDirty?: boolean;\n isValid?: boolean;\n isLightBg?: boolean;\n isInvalid?: boolean;\n isDisabled?: boolean;\n autoComplete?: string;\n errorMessage?: string;\n isDockedTop?: boolean;\n elementRef?:\n | RefObject\n | LegacyRef\n | MutableRefObject\n | undefined;\n type?: typeof Type[keyof typeof Type];\n theme?: typeof Theme[keyof typeof Theme];\n onChange?: (event: ChangeEvent) => void;\n pattern?: string;\n}\n\nexport interface TextInputExport {\n (props: ITextInputProps): ReactElement;\n Theme: typeof Theme;\n Type: typeof Type;\n}\n\nconst TextInput: TextInputExport = ({\n autoComplete = 'off',\n errorMessage = '',\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n isDirty = false, // keep isDirty prop, even though it's not used, so integration with final-form is smoooth.\n isDisabled = false,\n isInvalid = false,\n isValid = false,\n name,\n id = '',\n onChange,\n pattern,\n suffix = null,\n prepend = null,\n type = Type.TEXT,\n theme = Theme.LIGHT,\n value,\n dataId,\n elementRef = null,\n isLightBg = false,\n isDockedTop = false,\n ...restProps\n}) => {\n const themeClass = styles[`isTheme${toTitleCase(theme)}`];\n const inputClass = cx(styles.inputWrapper, themeClass, {\n [styles.isDisabled]: isDisabled,\n [styles.isInvalid]: isInvalid,\n [styles.isValid]: isValid,\n [styles.isLightBg]: isLightBg,\n [styles.shortPrepend]: prepend && prepend.length === 1,\n [styles.mediumPrepend]: prepend && prepend.length === 2,\n [styles.longPrepend]: prepend && prepend.length > 2,\n [styles.isDockedTop]: isDockedTop,\n });\n const prependClass = cx(styles.prependWrapper, themeClass, {\n [styles.isInvalid]: isInvalid,\n [styles.isDisabled]: isDisabled,\n [styles.isValid]: isValid,\n });\n const suffixClass = cx(styles.suffixWrapper, themeClass, {\n [styles.isDisabled]: isDisabled,\n });\n\n return (\n
\n
\n {prepend && (\n
\n {prepend}\n
\n )}\n\n \n\n {suffix && (\n
\n {isValidElement(suffix) ? suffix : {suffix}}\n
\n )}\n
\n\n {errorMessage && (\n
\n \n {errorMessage}\n \n
\n )}\n
\n );\n};\n\nTextInput.Theme = Theme;\nTextInput.Type = Type;\n\nexport default TextInput;\n","import React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport TextInput from '@clearscore/rainbow.text-input';\nimport isNumber from '@clearscore/validation.is-number';\n\nimport styles from './multiple-single-digits.module.css';\n\nclass MultipleSingleDigits extends Component {\n inputRefs = {};\n\n fields = [...Array(this.props.numberOfFields)].map((_a, index) => ({\n name: `field${index}`,\n }));\n\n // state required for keeping track of fields meta,\n // where the value is required in order to be valid\n state = this.fields.reduce(\n (fields, field) => ({\n ...fields,\n [field.name]: '',\n }),\n {},\n );\n\n componentDidMount() {\n this.inputRefs.field0.focus();\n }\n\n getInputValue = () => this.fields.map((field) => this.state[field.name] || '').join('');\n\n getInputValuesWithIndexes = () => this.fields.map((field) => this.state[field.name]);\n\n onKeyDown = (event, index) => {\n if (event.key === 'Backspace') {\n this.handleBackspace(index);\n return event;\n }\n\n return event;\n };\n\n handleBackspace = (fieldIndex) => {\n const currField = this.fields[fieldIndex];\n const prevField = this.fields[fieldIndex - 1];\n\n if (currField && prevField) {\n const currentHasValue = !!this.state[currField.name];\n this.setState(\n (prevState) => ({\n [currField.name]: '',\n [prevField.name]: currentHasValue ? prevState[prevField.name] : '',\n }),\n () => {\n this.props.input.onChange({\n individualInputs: this.getInputValuesWithIndexes(),\n inputValue: this.getInputValue(),\n });\n const fieldToFocus = currentHasValue ? currField : prevField;\n this.inputRefs[fieldToFocus.name].focus();\n },\n );\n }\n };\n\n onChange = (value, fieldIndex) => {\n const { input: { onChange } = {} } = this.props;\n\n const isCopyAndPaste = value.length > 2;\n\n if (isCopyAndPaste) return;\n\n const currentField = this.fields[fieldIndex];\n const nextField = this.fields[fieldIndex + 1];\n\n const newFieldValues = this.handleSingleEntry(value, currentField, this.state[currentField.name]);\n\n this.setState(newFieldValues, () => {\n onChange({\n individualInputs: this.getInputValuesWithIndexes(),\n inputValue: this.getInputValue(),\n });\n\n // check if current field has value, in case user has backspaced on first input\n if (!isCopyAndPaste && !!this.state[currentField.name] && nextField) {\n this.inputRefs[nextField.name].focus();\n }\n });\n };\n\n handleCopyAndPaste = (event, inputFieldIndex) => {\n const eventValue = event.clipboardData.getData('text');\n const values = eventValue.split('');\n const newFieldValues = values.reduce((accumulatedValue, fieldValue, index) => {\n const currField = this.fields[inputFieldIndex + index];\n const nextField = this.fields[inputFieldIndex + index + 1];\n\n if (!currField) {\n return accumulatedValue;\n }\n\n if (nextField) {\n this.inputRefs[nextField.name].focus();\n }\n\n return { ...accumulatedValue, [currField.name]: fieldValue };\n }, {});\n\n this.setState(newFieldValues, () => {\n this.props.input.onChange({\n individualInputs: this.getInputValuesWithIndexes(),\n inputValue: this.getInputValue(),\n });\n });\n };\n\n handleSingleEntry = (value, currentField, currentInputValue) => {\n // last input field should contain only the last typed value\n const fieldValue = value.replace(currentInputValue, '');\n return {\n [currentField.name]: fieldValue,\n };\n };\n\n render() {\n const { placeholder, isDisabled, isDirtyAfterError } = this.props;\n\n return (\n
\n {this.fields.map((field, fieldIndex) => {\n const fieldValue = this.state[this.fields[fieldIndex].name];\n const dirty = !!fieldValue;\n\n return (\n this.handleCopyAndPaste(event, fieldIndex)}\n onChange={(event) => this.onChange(event.target.value, fieldIndex)}\n onKeyDown={(event) => this.onKeyDown(event, fieldIndex)}\n elementRef={(inputRef) => {\n this.inputRefs[field.name] = inputRef;\n }}\n />\n );\n })}\n
\n );\n }\n}\n\nMultipleSingleDigits.propTypes = {\n input: PropTypes.shape({\n onChange: PropTypes.func.isRequired,\n }).isRequired,\n isDirtyAfterError: PropTypes.bool.isRequired,\n numberOfFields: PropTypes.number.isRequired,\n placeholder: PropTypes.string,\n isDisabled: PropTypes.bool,\n};\n\nMultipleSingleDigits.defaultProps = {\n placeholder: null,\n isDisabled: false,\n};\n\nexport default MultipleSingleDigits;\n","// https://overreacted.io/making-setinterval-declarative-with-react-hooks/\nimport { useEffect, useRef } from 'react';\n\nfunction useInterval(callback, delay) {\n const savedCallback = useRef();\n\n // Remember the latest callback.\n useEffect(() => {\n savedCallback.current = callback;\n });\n\n // Set up the interval.\n // eslint-disable-next-line consistent-return\n useEffect(() => {\n function tick() {\n savedCallback.current();\n }\n if (delay !== null) {\n const id = setInterval(tick, delay);\n return () => clearInterval(id);\n }\n }, [delay]);\n}\n\nexport default useInterval;\n","import React, { useState, useEffect } from 'react';\nimport PropTypes from 'prop-types';\nimport useInterval from '@clearscore/hooks.use-interval';\nimport Button from '@clearscore/rainbow.button';\n\nconst Resend = ({ generateOtp, generateOtpStatus, otpCoolDownSeconds, language }) => {\n const [remainingRegenerationTime, setRemainingRegenerationTime] = useState(otpCoolDownSeconds);\n\n useInterval(() => {\n if (remainingRegenerationTime > 0) {\n setRemainingRegenerationTime(remainingRegenerationTime - 1);\n }\n }, 1000);\n\n useEffect(() => {\n // N.B we want to reset the timer when API has not been called yet or when the request was successful\n if (generateOtpStatus.isInitial || generateOtpStatus.isComplete) {\n setRemainingRegenerationTime(otpCoolDownSeconds);\n }\n }, [generateOtpStatus, otpCoolDownSeconds]);\n\n return (\n \n {remainingRegenerationTime === 0 ? language.link : null}\n\n {remainingRegenerationTime > 0 ? (\n \n {language.timeText} {remainingRegenerationTime}\n {language.timeDelimiter}\n \n ) : null}\n \n );\n};\n\nResend.propTypes = {\n generateOtp: PropTypes.func.isRequired,\n otpCoolDownSeconds: PropTypes.number.isRequired,\n language: PropTypes.shape({\n link: PropTypes.string.isRequired,\n timeText: PropTypes.string.isRequired,\n timeDelimiter: PropTypes.string.isRequired,\n }).isRequired,\n generateOtpStatus: PropTypes.shape({\n isInitial: PropTypes.bool,\n isComplete: PropTypes.bool,\n isPending: PropTypes.bool,\n }).isRequired,\n};\n\nexport default Resend;\n","import React, { useState, useEffect } from 'react';\nimport PropTypes from 'prop-types';\nimport useInterval from '@clearscore/hooks.use-interval';\nimport Button from '@clearscore/rainbow.button';\n\nconst SUBMIT_COOL_DOWN_SECONDS = 5;\n\nconst Submit = ({ verifyOtpStatus, isSubmitDisabled, language }) => {\n const [remainingDisabledTime, setRemainingDisabledTime] = useState(0);\n\n useInterval(() => {\n if (remainingDisabledTime > 0) {\n setRemainingDisabledTime(remainingDisabledTime - 1);\n }\n }, 1000);\n\n useEffect(() => {\n if (verifyOtpStatus.hasFailed) {\n setRemainingDisabledTime(SUBMIT_COOL_DOWN_SECONDS);\n }\n }, [verifyOtpStatus]);\n\n return (\n 0 || isSubmitDisabled}\n isResponsive\n >\n {language.next}\n \n );\n};\n\nSubmit.propTypes = {\n isSubmitDisabled: PropTypes.bool.isRequired,\n language: PropTypes.shape({\n next: PropTypes.string.isRequired,\n }).isRequired,\n verifyOtpStatus: PropTypes.shape({\n isPending: PropTypes.bool.isRequired,\n isComplete: PropTypes.bool.isRequired,\n hasFailed: PropTypes.bool.isRequired,\n }).isRequired,\n};\n\nexport default Submit;\n","import { EN_GB, EN_AU } from '@clearscore/config.i18n';\n\nexport default {\n [EN_AU]: {\n next: 'Verify',\n },\n [EN_GB]: {\n timeText: 'Resend in',\n timeDelimiter: 's',\n link: 'Resend code',\n next: 'Next',\n pleaseEnter: 'Please enter a number into',\n boxSingular: 'box',\n boxesPlural: 'boxes',\n and: 'and',\n lastAttempt: 'You have one attempt remaining.',\n },\n};\n","import React, { useState, useEffect } from 'react';\nimport PropTypes from 'prop-types';\nimport { Form, Field } from 'react-final-form';\nimport useLanguage from '@clearscore/hooks.use-language';\nimport Text from '@clearscore/rainbow.text';\nimport Icon from '@clearscore/rainbow.icons.warning-inline';\nimport isNumber from '@clearscore/validation.is-number';\n\nimport MultipleSingleDigits from './components/multiple-single-digits';\nimport Resend from './components/resend';\nimport Submit from './components/submit';\nimport styles from './index.module.css';\nimport lang from './lib/lang';\n\nconst NUMBER_OF_INPUT_FIELDS = 6;\nconst FIELD_NAME = 'otpCandidate';\n\nconst getErrorText = (boxIndexes, language) => {\n const { length } = boxIndexes;\n if (length === 1) return `${language.boxSingular} ${boxIndexes[0]}`;\n\n if (length === 2) return `${language.boxesPlural} ${boxIndexes[0]} ${language.and} ${boxIndexes[1]}`;\n\n return boxIndexes.reduce((accumulator, currentValue, index) => {\n if (length - 1 === index) {\n const accumulatorWithoutLastComma = accumulator.slice(0, -1);\n return `${language.boxesPlural}${accumulatorWithoutLastComma} ${language.and} ${currentValue}`;\n }\n\n return `${accumulator} ${currentValue},`;\n }, '');\n};\n\nconst getNonNumericIndexes = ({ individualInputs = [] } = {}) =>\n individualInputs.reduce((accumulator, currentValue, index) => {\n if (currentValue === '') return accumulator;\n\n const isNotNumber = isNumber(currentValue) === false;\n\n if (isNotNumber) {\n return [...accumulator, index + 1];\n }\n\n return accumulator;\n }, []);\n\nconst validateFormValue = (values) => {\n const currentValue = values && values.inputValue;\n const isFormMissingValues = currentValue && currentValue.length !== NUMBER_OF_INPUT_FIELDS;\n\n if (isFormMissingValues || isNumber(currentValue) === false) {\n return { [FIELD_NAME]: 'error' };\n }\n\n return {};\n};\n\nconst FormInner = ({\n generateOtp,\n generateOtpStatus,\n verifyOtpStatus,\n otpCoolDownSeconds,\n isResendLastAttempt,\n resetFormWhen,\n handleSubmit,\n shouldShowResend,\n form,\n}) => {\n const language = useLanguage(lang);\n const [fieldKey, setFieldKey] = useState(0);\n const clearOtpField = () => setFieldKey(fieldKey + 1);\n\n const { submitSucceeded, submitFailed, dirtySinceLastSubmit, ...formState } = form.getState();\n const nonNumericIndexes = getNonNumericIndexes(formState.values[FIELD_NAME]);\n const isFormInvalid = formState.invalid;\n\n const isFormDirty = formState.modified[FIELD_NAME];\n const wasFormSubmittedBefore = submitSucceeded || submitFailed;\n const isDirtyAfterError = wasFormSubmittedBefore ? dirtySinceLastSubmit && verifyOtpStatus.hasFailed : true;\n\n const resetForm = () => {\n form.reset();\n clearOtpField();\n };\n\n useEffect(() => {\n if (resetFormWhen) resetForm();\n }, [resetFormWhen]);\n\n const handleGenerateOtp = () => {\n resetForm();\n generateOtp();\n };\n\n return (\n \n \n\n
\n {nonNumericIndexes && nonNumericIndexes.length >= 1 ? (\n \n \n \n {`${language.pleaseEnter} ${getErrorText(nonNumericIndexes, language)}`}\n \n \n ) : null}\n
\n\n
\n \n {shouldShowResend && (\n \n )}\n
\n\n {isResendLastAttempt ? (\n {language.lastAttempt}\n ) : null}\n \n );\n};\n\nFormInner.propTypes = {\n isResendLastAttempt: PropTypes.bool.isRequired,\n generateOtp: PropTypes.func.isRequired,\n generateOtpStatus: PropTypes.any.isRequired,\n verifyOtpStatus: PropTypes.any.isRequired,\n otpCoolDownSeconds: PropTypes.any,\n resetFormWhen: PropTypes.bool,\n handleSubmit: PropTypes.func.isRequired,\n form: PropTypes.shape({\n getState: PropTypes.func,\n reset: PropTypes.func,\n }).isRequired,\n shouldShowResend: PropTypes.bool,\n};\n\nFormInner.defaultProps = {\n resetFormWhen: false,\n otpCoolDownSeconds: null,\n shouldShowResend: true,\n};\n\nconst Component = ({ verifyOtp, ...rest }) => (\n validateFormValue(formData[FIELD_NAME])}\n onSubmit={(formData) => verifyOtp(formData[FIELD_NAME].inputValue)}\n render={({ handleSubmit, form }) => }\n />\n);\n\nComponent.propTypes = {\n verifyOtp: PropTypes.func.isRequired,\n};\n\nexport default Component;\nexport const langFormOtp = lang;\n","import { GB, ZA, AU, CA } from '@clearscore/config.i18n';\n\nexport default {\n [ZA]: {\n linkCantGetCode: 'https://help.clearscore.co.za/hc/en-us/articles/360010196839-I-can-t-get-my-code',\n },\n [GB]: {\n linkCantGetCode: 'https://help.clearscore.com/hc/en-us/articles/360010196719-I-can-t-get-my-code',\n },\n [AU]: {\n linkCantGetCode: 'https://help.clearscore.com.au/hc/en-us/articles/360015490699-I-can-t-get-my-code-2FA',\n },\n [CA]: {\n linkCantGetCode: 'https://help.clearscore.ca/hc/en-us/articles/8403001596562-I-can-t-get-my-code-2FA',\n },\n};\n","import React from 'react';\nimport { Redirect } from 'react-router-dom';\nimport { useDispatch, useSelector } from 'react-redux';\nimport FormOtp from '@clearscore-group/ui.shared.form-otp';\nimport Text from '@clearscore/rainbow.text';\nimport { useTranslation } from 'react-i18next';\nimport { GB } from '@clearscore/config.i18n';\n\nimport { actions, selectors } from '../../redux';\nimport marketConfig from './lib/market-config';\nimport styles from './screen-verify.module.css';\nimport { PAGE_NAMESPACE } from '../../lib/constants';\n\ninterface IScreenVerify {\n location: {\n state: {\n requestMeta: Record;\n mobileNumber?: string;\n twoFactorType: string;\n coolDownSeconds: number;\n };\n };\n}\n\ninterface IStatus {\n isInitial: boolean;\n isPending: boolean;\n isComplete: boolean;\n hasFailed: boolean;\n statusCode?: number;\n}\n\ninterface IState {\n status?: 'initial' | 'pending' | 'success';\n data?: Record;\n statusCode?: number;\n request?: Record;\n meta: Record;\n}\n\nconst TWO_FACTOR_MOBILE_NUMBER_TYPE = 'sm';\n\nconst ScreenVerify = ({ location: { state } }: IScreenVerify): React.ReactElement => {\n const { t } = useTranslation(PAGE_NAMESPACE);\n const { requestMeta, coolDownSeconds, twoFactorType, ...restState } = state || {};\n const hasLocationState = state && !!Object.keys(state).length;\n const market = requestMeta?.market || GB;\n // @ts-expect-error adjust for config.i18n ts types\n const { linkCantGetCode } = marketConfig[market];\n const dispatch = useDispatch();\n const resendStatus: IStatus = useSelector(selectors.resendTwoFactorAuth.getStatus);\n const resendState: IState = useSelector(selectors.resendTwoFactorAuth.getState);\n const verifyStatus: IStatus = useSelector(selectors.verifyTwoFactorAuth.getStatus);\n const verifyState: IState = useSelector(selectors.verifyTwoFactorAuth.getState);\n const handleResend = (): void => dispatch(actions.resendTwoFactorAuth(restState, requestMeta));\n const handleVerify = (code: string): void =>\n dispatch(actions.verifyTwoFactorAuth({ ...restState, code }, requestMeta));\n const isMobileType = twoFactorType === TWO_FACTOR_MOBILE_NUMBER_TYPE;\n\n if (!hasLocationState) {\n return ;\n }\n return (\n \n
\n {t('screenVerify.title')}\n
\n\n
\n \n {isMobileType\n ? t('screenVerify.description', { mobileNumber: state.mobileNumber })\n : t('screenVerify.appDescription')}\n \n
\n\n \n\n
\n \n {t('screenVerify.cantGetCode')}\n \n
\n
\n );\n};\n\nexport default ScreenVerify;\n","/*\n Check to see if an value is empty, for example null, undefined, '', or an object with no keys\n */\nfunction isEmpty(value) {\n if (value === undefined || value === null || value === '') {\n return true;\n }\n\n return typeof value === 'object' && Object.keys(value).length === 0;\n}\n\nexport default isEmpty;\n","import isEmpty from '@clearscore/validation.is-empty';\n\nexport const DEFAULT_MESSAGE = 'Required field';\n\n/*\n * isRequired Validation\n * isRequired checks to see if there is any content\n * isRequired returns the DEFAULT_MESSAGE if no content\n */\nfunction isRequired(value) {\n if (value === 'false' || typeof value === 'object') {\n return false;\n }\n if (typeof value === 'boolean') {\n return value;\n }\n return value === '-1' || !isEmpty(value);\n}\n\nexport function isRequiredValidation() {\n const errorMessage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : DEFAULT_MESSAGE;\n return function error(value) {\n return !isRequired(value) ? errorMessage : undefined;\n };\n}\n\nexport function isRequiredEmailConfirmValidation(errorMessage) {\n return function error(value, allValues) {\n return allValues.email_confirm !== allValues.email ? errorMessage : undefined;\n };\n}\n\nexport default isRequired;\n","import isEmpty from '@clearscore/validation.is-empty';\n\n/*\n * isEmail Validation\n * isEmail checks to see if a value is in an email format\n * isEmailValidation returns the DEFAULT_MESSAGE if value is not an email\n */\nexport const DEFAULT_MESSAGE = 'Valid email format required';\nconst emailRegEx = /^[A-Z0-9._%\\-']+@[A-Z0-9.-]+\\.[A-Z]{2,6}$/i;\n\nfunction isEmail(value) {\n return !isEmpty(value) && emailRegEx.test(value);\n}\n\nexport function isEmailValidation() {\n const errorMessage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : DEFAULT_MESSAGE;\n return function error(value) {\n return !isEmail(value) ? errorMessage : undefined;\n };\n}\n\nexport default isEmail;\n","function normalizeAddress(value) {\n if (value) {\n return value.toLowerCase().replace(/ /g, '');\n }\n return '';\n}\n\nexport default normalizeAddress;\n","","","/* eslint-disable import/prefer-default-export */\n\nexport const Theme = {\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n} as const;\n","import type { ChangeEvent, ReactElement } from 'react';\nimport React, { useState } from 'react';\nimport cx from 'classnames';\nimport Criteria from '@clearscore/rainbow.criteria';\nimport Eye from '@clearscore/rainbow.icons.show';\nimport EyeClosed from '@clearscore/rainbow.icons.show-disabled';\nimport TextInput from '@clearscore/rainbow.text-input';\nimport toTitleCase from '@clearscore/normalize.title-case';\n\nimport styles from './password.module.css';\nimport { Theme } from './constants';\n\ninterface PasswordRequirement {\n id: string;\n text: string;\n validator: (value?: string) => boolean;\n}\ninterface ProcessedRequirement {\n id: string;\n text: string;\n isValid: boolean;\n}\n\ninterface IconTitles {\n eye: string;\n eyeClosed: string;\n}\n\nexport interface PasswordProps {\n name: string;\n value: string;\n dataId?: string;\n errorMessage?: string;\n iconTitles?: IconTitles;\n onChange: (value: string) => void;\n requirements?: PasswordRequirement[];\n theme?: typeof Theme[keyof typeof Theme];\n // everything else that is being passed to \n [prop: string]: unknown;\n}\n\nexport interface PasswordExport {\n (props: PasswordProps): ReactElement;\n Theme: typeof Theme;\n}\n\nconst processRequirements = (requirements: PasswordRequirement[], inputValue = ''): ProcessedRequirement[] => {\n if (Array.isArray(requirements) && requirements.length) {\n return requirements.map(({ id, text, validator }) => ({\n id,\n text,\n isValid: validator(inputValue),\n }));\n }\n return [];\n};\n\nconst defaultIconTitles = {\n eye: 'hide password',\n eyeClosed: 'show password',\n};\n\nconst Password: PasswordExport = ({\n theme = Theme.LIGHT,\n dataId,\n requirements: rawRequirements = [],\n onChange,\n iconTitles = defaultIconTitles,\n errorMessage: inputErrorMessage = '',\n ...inputProps\n}) => {\n const [isEyeOpen, setIsEyeOpen] = useState(false);\n const [requirements, setRequirements] = useState(processRequirements(rawRequirements));\n\n const type = isEyeOpen ? 'text' : 'password';\n const Icon = isEyeOpen ? Eye : EyeClosed;\n const title = isEyeOpen ? iconTitles.eye : iconTitles.eyeClosed;\n const themeClass = styles[`isTheme${toTitleCase(theme)}`];\n const errorMessage = requirements.length ? '' : inputErrorMessage;\n\n return (\n
\n
\n ): void => {\n onChange(target.value);\n setRequirements(processRequirements(rawRequirements, target.value));\n }}\n errorMessage={errorMessage}\n />\n setIsEyeOpen(!isEyeOpen)}\n data-qa=\"password-eye\"\n >\n \n \n
\n {requirements.map(({ id, text, isValid }) => {\n const criteriaType = isValid ? Criteria.DisplayState.SUCCESS : Criteria.DisplayState.ERROR;\n return (\n \n {text}\n \n );\n })}\n
\n );\n};\n\nPassword.Theme = Theme;\n\nexport default Password;\n","import type { ReactElement, ChangeEvent, InputHTMLAttributes } from 'react';\nimport React from 'react';\nimport cx from 'classnames';\nimport Icon from '@clearscore/rainbow.icons.success-inline';\nimport Text from '@clearscore/rainbow.text';\nimport Criteria from '@clearscore/rainbow.criteria';\nimport toTitleCase from '@clearscore/normalize.title-case';\n\nimport styles from './checkbox.module.css';\n\nlet uid = 0;\n\nexport const Theme = {\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n} as const;\n\nexport const Size = {\n COMPACT: 'COMPACT',\n REGULAR: 'REGULAR',\n} as const;\n\ninterface CheckboxProps extends Omit, 'size'> {\n children: ReactElement | string;\n name: string;\n isDisabled?: boolean;\n id?: string;\n onChange?: (event: ChangeEvent) => void;\n onClick?: () => void;\n theme: keyof typeof Theme;\n size: keyof typeof Size;\n checked?: boolean;\n dataId?: string;\n dataWalkthrough?: string;\n errorMessage?: string;\n}\n\nexport interface CheckboxExport {\n (props: CheckboxProps): ReactElement;\n Size: typeof Size;\n Theme: typeof Theme;\n}\n\nconst Checkbox: CheckboxExport = ({\n children,\n isDisabled = false,\n onChange,\n onClick,\n theme = Theme.LIGHT,\n checked,\n dataId,\n size = Size.REGULAR,\n id,\n name,\n errorMessage = '',\n dataWalkthrough,\n ...restProps\n}) => {\n const themeClass = styles[`isTheme${toTitleCase(theme)}`];\n\n const inputClass = cx(styles.input, themeClass, {\n [styles.checked]: checked,\n [styles.disabled]: isDisabled,\n });\n\n const tickClass = cx(styles.tick, themeClass, {\n [styles.checked]: checked,\n [styles.disabled]: isDisabled,\n });\n const labelClass = cx(styles.label, themeClass, {\n [styles.disabled]: isDisabled,\n });\n const elId = id || `checkbox${(uid += 1)}`;\n const Label = size === Size.REGULAR ? Text.Body1 : Text.Body2;\n\n return (\n
\n \n {errorMessage && (\n
\n \n {errorMessage}\n \n
\n )}\n
\n );\n};\n\nCheckbox.Theme = Theme;\nCheckbox.Size = Size;\n\nexport default Checkbox;\n","/* eslint-disable jsx-a11y/label-has-for */\nimport type { ReactElement, ReactNode } from 'react';\nimport React from 'react';\nimport cx from 'classnames';\nimport Text from '@clearscore/rainbow.text';\nimport toTitleCase from '@clearscore/normalize.title-case';\n\nimport styles from './label.module.css';\n\nexport const Theme = {\n LIGHT: 'LIGHT',\n DARK: 'DARK',\n};\ninterface LabelProps {\n children: ReactNode;\n description?: string | ReactNode;\n htmlFor?: string;\n isLegend?: boolean;\n theme?: keyof typeof Theme;\n dataId?: string;\n}\n\nexport interface LabelExport {\n (props: LabelProps): ReactElement;\n}\n\nconst Label: LabelExport & {\n Theme: typeof Theme;\n} = ({ children, description = '', htmlFor = '', isLegend = false, theme = Theme.LIGHT, dataId = undefined }) => {\n const themeClass = styles[`isTheme${toTitleCase(theme)}`];\n const wrapperClass = cx(styles.wrapper, themeClass);\n const descriptionClass = cx(styles.description, themeClass);\n const Tag = isLegend ? 'legend' : 'label';\n\n return (\n
\n \n {children}\n \n {description ? (\n
\n {description}\n
\n ) : null}\n
\n );\n};\n\nexport const Legend: LabelExport = ({ ...props }): ReactElement =>