{"version":3,"file":"chunk-fqyvdant.js","sources":["node_modules/qrcode/lib/can-promise.js","node_modules/qrcode/lib/core/utils.js","node_modules/qrcode/lib/core/error-correction-level.js","node_modules/qrcode/lib/core/bit-buffer.js","node_modules/qrcode/lib/core/bit-matrix.js","node_modules/qrcode/lib/core/alignment-pattern.js","node_modules/qrcode/lib/core/finder-pattern.js","node_modules/qrcode/lib/core/mask-pattern.js","node_modules/qrcode/lib/core/error-correction-code.js","node_modules/qrcode/lib/core/galois-field.js","node_modules/qrcode/lib/core/polynomial.js","node_modules/qrcode/lib/core/reed-solomon-encoder.js","node_modules/qrcode/lib/core/version-check.js","node_modules/qrcode/lib/core/regex.js","node_modules/qrcode/lib/core/mode.js","node_modules/qrcode/lib/core/version.js","node_modules/qrcode/lib/core/format-info.js","node_modules/qrcode/lib/core/numeric-data.js","node_modules/qrcode/lib/core/alphanumeric-data.js","node_modules/encode-utf8/index.js","node_modules/qrcode/lib/core/byte-data.js","node_modules/qrcode/lib/core/kanji-data.js","node_modules/dijkstrajs/dijkstra.js","node_modules/qrcode/lib/core/segments.js","node_modules/qrcode/lib/core/qrcode.js","node_modules/qrcode/lib/renderer/utils.js","node_modules/qrcode/lib/renderer/canvas.js","node_modules/qrcode/lib/renderer/svg-tag.js","node_modules/qrcode/lib/browser.js","node_modules/braintree-web/dist/browser/index.js","packages/vanilla/lib/features/cashier/src/cashier.client-config.ts","packages/vanilla/lib/features/cashier/src/cashier.models.ts","packages/vanilla/lib/features/cashier/src/cashier-resource.service.ts","packages/vanilla/lib/features/cashier/src/quick-deposit/quick-deposit.models.ts","packages/vanilla/lib/features/cashier/src/quick-deposit/quick-deposit.service.ts","packages/vanilla/lib/features/cashier/src/cashier.service.ts","node_modules/@ngx-translate/core/dist/fesm2022/ngx-translate-core.mjs","packages/payments/common-utils/src/http/custom-http-client.service.ts","packages/payments/common-utils/src/auth/auth-details-store.ts","packages/payments/common-utils/src/client-config/client-config.models.ts","packages/payments/common-utils/src/api/payments-authentication.service.ts","packages/payments/common-utils/src/api/payments-custom-api.service.ts","packages/payments/quickdeposit-feature/src/feature/client-config/client-config.models.ts","packages/payments/quickdeposit-feature/src/feature/config/appConstants.ts","packages/payments/quickdeposit-feature/src/feature/service/behaviorData.service.ts","packages/payments/quickdeposit-feature/src/feature/service/loader.service.ts","packages/payments/quickdeposit-feature/src/feature/core/loader/loader.component.html","packages/payments/quickdeposit-feature/src/feature/core/loader/loader.component.ts","packages/payments/quickdeposit-feature/src/feature/config/urlConstants.ts","packages/payments/quickdeposit-feature/src/feature/shared/error.constants.ts","packages/payments/quickdeposit-feature/src/feature/service/data.service.ts","packages/payments/quickdeposit-feature/src/feature/model/gtm-event-model.ts","packages/payments/quickdeposit-feature/src/feature/service/userDataService.ts","packages/payments/quickdeposit-feature/src/feature/service/gtm.service.ts","packages/payments/quickdeposit-feature/src/feature/service/qd.service.ts","packages/payments/quickdeposit-feature/src/feature/service/quick-deposit-message.service.ts","packages/payments/quickdeposit-feature/src/feature/service/depositRedirect.service.ts","packages/payments/quickdeposit-feature/src/feature/core/loader/loader.interceptor.ts","packages/payments/ngpgcard-utils/src/data/data-store.ts","packages/payments/ngpgcard-utils/src/utils/origin-validation-service.ts","packages/payments/ngpgcard-utils/src/utils/utils.ts","packages/payments/ngpgcard-utils/src/utils/sanitizer.ts","node_modules/mitt/dist/mitt.mjs","packages/payments/ngpgcard-utils/src/events/emitter.ts","packages/payments/ngpgcard-utils/src/events/events-models.ts","packages/payments/ngpgcard-utils/src/events/event-bridge.ts","packages/payments/ngpgcard-utils/src/models/models.ts","packages/payments/ngpgcard-utils/src/iframe/iframe-service.ts","packages/payments/quickdeposit-feature/src/feature/service/card-iframe-service.ts","packages/payments/quickdeposit-feature/src/feature/model/depositInfo.model.ts","packages/payments/quickdeposit-feature/src/feature/service/optionList.service.ts","packages/payments/quickdeposit-feature/src/feature/service/resize.service.ts","packages/payments/quickdeposit-feature/src/feature/service/stakeAmount.service.ts","packages/payments/quickdeposit-feature/src/feature/service/deposit.service.ts","packages/payments/quickdeposit-feature/src/feature/service/geocomply.service.ts","packages/payments/quickdeposit-feature/src/feature/service/event.service.ts","packages/payments/quickdeposit-feature/src/feature/core/header/header.component.html","packages/payments/quickdeposit-feature/src/feature/core/header/header.component.ts","packages/payments/quickdeposit-feature/src/feature/service/apple-pay-direct.service.ts","packages/payments/quickdeposit-feature/src/feature/service/apple-pay-validator.service.ts","packages/payments/quickdeposit-feature/src/feature/service/ccDepositSubmit.service.ts","packages/payments/quickdeposit-feature/src/feature/service/worldPayFetchSessionId.service.ts","packages/payments/quickdeposit-feature/src/feature/shared/components/deposit-declined/deposit-declined.component.html","packages/payments/quickdeposit-feature/src/feature/shared/components/deposit-declined/deposit-declined.component.ts","packages/payments/quickdeposit-feature/src/feature/model/message.model.ts","packages/payments/quickdeposit-feature/src/feature/shared/components/messages/message-component.html","packages/payments/quickdeposit-feature/src/feature/shared/components/messages/message-component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/ada-message/ada-message.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/ada-message/ada-message.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/arc-message/arc-message.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/arc-message/arc-message.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/pl-verification-message/pl-verification-message.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/pl-verification-message/pl-verification-message.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/play-break-message/play-break-message.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/play-break-message/play-break-message.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/reversal-notification/reversal-notification.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/reversal-notification/reversal-notification.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/session-limits/session-limits.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/session-limits/session-limits.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/additional-messages.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/additional-messages.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/bottom-messages/bottom-messages.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/bottom-messages/bottom-messages.component.ts","packages/payments/quickdeposit-feature/src/feature/service/chat.service.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-failure/deposit-failure.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-failure/deposit-failure.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-process/pix-status-process/pix-status-process.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-process/pix-status-process/pix-status-process.component.html","node_modules/@angular/cdk/fesm2022/accordion.mjs","node_modules/@angular/material/fesm2022/expansion.mjs","node_modules/angularx-qrcode/fesm2022/angularx-qrcode.mjs","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-process/wallet-process/wallet-process.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-process/wallet-process/wallet-process.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-process/deposit-process.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-process/deposit-process.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-success/deposit-success.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-success/deposit-success.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/options-list/options-list.component.ts","node_modules/ngx-popperjs/fesm2022/ngx-popperjs.mjs","packages/payments/quickdeposit-feature/src/feature/model/common.model.ts","packages/payments/quickdeposit-feature/src/feature/shared/components/pipes/account-mask.pipe.ts","packages/payments/quickdeposit-feature/src/feature/shared/components/threshold-limit-messages/threshold-limit-messages.component.html","packages/payments/quickdeposit-feature/src/feature/shared/components/threshold-limit-messages/threshold-limit-messages.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/redirect-message/redirect-message.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/redirect-message/redirect-message.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/transaction-currency/transaction-currency.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/additional-messages/transaction-currency/transaction-currency.component.html","packages/payments/quickdeposit-feature/src/feature/shared/validators/custom.validator.ts","packages/payments/quickdeposit-feature/src/feature/shared/validators/prepaidLimit.validator.ts","packages/payments/quickdeposit-feature/src/feature/shared/validators/providerbalance.validator.ts","packages/payments/quickdeposit-feature/src/feature/shared/validators/selfsetlimit.validator.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/amount/amount.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/amount/amount.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/cc-input/cc-input.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/cc-input/cc-input.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/cc-input/password-block/password-block.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/cc-input/password-block/password-block.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-limit-message/deposit-limit-message.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit-limit-message/deposit-limit-message.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/flash1voucher/flash1voucher-input.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/flash1voucher/flash1voucher-input.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/options-list/option-content/option-content.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/options-list/option-content/option-content.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/options-list/product-preference/product-preference.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/options-list/product-preference/product-preference.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/options-list/options-list.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/deposit/deposit.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/odPopup/od-popup.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/odPopup/od-popup.component.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit/qd.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit/qd.component.ts","packages/payments/quickdeposit-feature/src/feature/api/payments.api.sevice.ts","packages/payments/quickdeposit-feature/src/feature/service/custom-translate-loader.service.ts","packages/payments/quickdeposit-feature/src/feature/service/qd-authentication.service.ts","packages/payments/quickdeposit-feature/src/feature/quick-deposit-feature.component.html","packages/payments/quickdeposit-feature/src/feature/quick-deposit-feature.component.ts","packages/vanilla/lib/features/cashier/src/cashier-iframe.models.ts","packages/vanilla/lib/features/cashier/src/cashier-iframe.component.ts","packages/vanilla/lib/features/cashier/src/cashier-iframe.html","packages/vanilla/lib/features/cashier/src/quick-deposit/quick-deposit-responsive.component.html","packages/vanilla/lib/features/cashier/src/quick-deposit/quick-deposit-responsive.component.ts","packages/vanilla/lib/features/cashier/src/quick-deposit/quick-deposit-overlay.service.ts","packages/vanilla/lib/features/cashier/src/cashier-bootstrap.service.ts","packages/vanilla/lib/features/cashier/src/cashier.feature.ts","packages/vanilla/lib/features/cashier/src/cashier.component.ts","packages/vanilla/lib/features/cashier/src/cashier.guard.ts","packages/vanilla/lib/features/cashier/src/quick-deposit/quick-deposit.guard.ts","packages/vanilla/lib/features/cashier/src/cashier-routing.ts"],"sourcesContent":["// can-promise has a crash in some versions of react native that dont have\n// standard global objects\n// https://github.com/soldair/node-qrcode/issues/157\n\nmodule.exports = function () {\n return typeof Promise === 'function' && Promise.prototype && Promise.prototype.then;\n};","let toSJISFunction;\nconst CODEWORDS_COUNT = [0,\n// Not used\n26, 44, 70, 100, 134, 172, 196, 242, 292, 346, 404, 466, 532, 581, 655, 733, 815, 901, 991, 1085, 1156, 1258, 1364, 1474, 1588, 1706, 1828, 1921, 2051, 2185, 2323, 2465, 2611, 2761, 2876, 3034, 3196, 3362, 3532, 3706];\n\n/**\n * Returns the QR Code size for the specified version\n *\n * @param {Number} version QR Code version\n * @return {Number} size of QR code\n */\nexports.getSymbolSize = function getSymbolSize(version) {\n if (!version) throw new Error('\"version\" cannot be null or undefined');\n if (version < 1 || version > 40) throw new Error('\"version\" should be in range from 1 to 40');\n return version * 4 + 17;\n};\n\n/**\n * Returns the total number of codewords used to store data and EC information.\n *\n * @param {Number} version QR Code version\n * @return {Number} Data length in bits\n */\nexports.getSymbolTotalCodewords = function getSymbolTotalCodewords(version) {\n return CODEWORDS_COUNT[version];\n};\n\n/**\n * Encode data with Bose-Chaudhuri-Hocquenghem\n *\n * @param {Number} data Value to encode\n * @return {Number} Encoded value\n */\nexports.getBCHDigit = function (data) {\n let digit = 0;\n while (data !== 0) {\n digit++;\n data >>>= 1;\n }\n return digit;\n};\nexports.setToSJISFunction = function setToSJISFunction(f) {\n if (typeof f !== 'function') {\n throw new Error('\"toSJISFunc\" is not a valid function.');\n }\n toSJISFunction = f;\n};\nexports.isKanjiModeEnabled = function () {\n return typeof toSJISFunction !== 'undefined';\n};\nexports.toSJIS = function toSJIS(kanji) {\n return toSJISFunction(kanji);\n};","exports.L = {\n bit: 1\n};\nexports.M = {\n bit: 0\n};\nexports.Q = {\n bit: 3\n};\nexports.H = {\n bit: 2\n};\nfunction fromString(string) {\n if (typeof string !== 'string') {\n throw new Error('Param is not a string');\n }\n const lcStr = string.toLowerCase();\n switch (lcStr) {\n case 'l':\n case 'low':\n return exports.L;\n case 'm':\n case 'medium':\n return exports.M;\n case 'q':\n case 'quartile':\n return exports.Q;\n case 'h':\n case 'high':\n return exports.H;\n default:\n throw new Error('Unknown EC Level: ' + string);\n }\n}\nexports.isValid = function isValid(level) {\n return level && typeof level.bit !== 'undefined' && level.bit >= 0 && level.bit < 4;\n};\nexports.from = function from(value, defaultValue) {\n if (exports.isValid(value)) {\n return value;\n }\n try {\n return fromString(value);\n } catch (e) {\n return defaultValue;\n }\n};","function BitBuffer() {\n this.buffer = [];\n this.length = 0;\n}\nBitBuffer.prototype = {\n get: function (index) {\n const bufIndex = Math.floor(index / 8);\n return (this.buffer[bufIndex] >>> 7 - index % 8 & 1) === 1;\n },\n put: function (num, length) {\n for (let i = 0; i < length; i++) {\n this.putBit((num >>> length - i - 1 & 1) === 1);\n }\n },\n getLengthInBits: function () {\n return this.length;\n },\n putBit: function (bit) {\n const bufIndex = Math.floor(this.length / 8);\n if (this.buffer.length <= bufIndex) {\n this.buffer.push(0);\n }\n if (bit) {\n this.buffer[bufIndex] |= 0x80 >>> this.length % 8;\n }\n this.length++;\n }\n};\nmodule.exports = BitBuffer;","/**\n * Helper class to handle QR Code symbol modules\n *\n * @param {Number} size Symbol size\n */\nfunction BitMatrix(size) {\n if (!size || size < 1) {\n throw new Error('BitMatrix size must be defined and greater than 0');\n }\n this.size = size;\n this.data = new Uint8Array(size * size);\n this.reservedBit = new Uint8Array(size * size);\n}\n\n/**\n * Set bit value at specified location\n * If reserved flag is set, this bit will be ignored during masking process\n *\n * @param {Number} row\n * @param {Number} col\n * @param {Boolean} value\n * @param {Boolean} reserved\n */\nBitMatrix.prototype.set = function (row, col, value, reserved) {\n const index = row * this.size + col;\n this.data[index] = value;\n if (reserved) this.reservedBit[index] = true;\n};\n\n/**\n * Returns bit value at specified location\n *\n * @param {Number} row\n * @param {Number} col\n * @return {Boolean}\n */\nBitMatrix.prototype.get = function (row, col) {\n return this.data[row * this.size + col];\n};\n\n/**\n * Applies xor operator at specified location\n * (used during masking process)\n *\n * @param {Number} row\n * @param {Number} col\n * @param {Boolean} value\n */\nBitMatrix.prototype.xor = function (row, col, value) {\n this.data[row * this.size + col] ^= value;\n};\n\n/**\n * Check if bit at specified location is reserved\n *\n * @param {Number} row\n * @param {Number} col\n * @return {Boolean}\n */\nBitMatrix.prototype.isReserved = function (row, col) {\n return this.reservedBit[row * this.size + col];\n};\nmodule.exports = BitMatrix;","/**\n * Alignment pattern are fixed reference pattern in defined positions\n * in a matrix symbology, which enables the decode software to re-synchronise\n * the coordinate mapping of the image modules in the event of moderate amounts\n * of distortion of the image.\n *\n * Alignment patterns are present only in QR Code symbols of version 2 or larger\n * and their number depends on the symbol version.\n */\n\nconst getSymbolSize = require('./utils').getSymbolSize;\n\n/**\n * Calculate the row/column coordinates of the center module of each alignment pattern\n * for the specified QR Code version.\n *\n * The alignment patterns are positioned symmetrically on either side of the diagonal\n * running from the top left corner of the symbol to the bottom right corner.\n *\n * Since positions are simmetrical only half of the coordinates are returned.\n * Each item of the array will represent in turn the x and y coordinate.\n * @see {@link getPositions}\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinate\n */\nexports.getRowColCoords = function getRowColCoords(version) {\n if (version === 1) return [];\n const posCount = Math.floor(version / 7) + 2;\n const size = getSymbolSize(version);\n const intervals = size === 145 ? 26 : Math.ceil((size - 13) / (2 * posCount - 2)) * 2;\n const positions = [size - 7]; // Last coord is always (size - 7)\n\n for (let i = 1; i < posCount - 1; i++) {\n positions[i] = positions[i - 1] - intervals;\n }\n positions.push(6); // First coord is always 6\n\n return positions.reverse();\n};\n\n/**\n * Returns an array containing the positions of each alignment pattern.\n * Each array's element represent the center point of the pattern as (x, y) coordinates\n *\n * Coordinates are calculated expanding the row/column coordinates returned by {@link getRowColCoords}\n * and filtering out the items that overlaps with finder pattern\n *\n * @example\n * For a Version 7 symbol {@link getRowColCoords} returns values 6, 22 and 38.\n * The alignment patterns, therefore, are to be centered on (row, column)\n * positions (6,22), (22,6), (22,22), (22,38), (38,22), (38,38).\n * Note that the coordinates (6,6), (6,38), (38,6) are occupied by finder patterns\n * and are not therefore used for alignment patterns.\n *\n * let pos = getPositions(7)\n * // [[6,22], [22,6], [22,22], [22,38], [38,22], [38,38]]\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinates\n */\nexports.getPositions = function getPositions(version) {\n const coords = [];\n const pos = exports.getRowColCoords(version);\n const posLength = pos.length;\n for (let i = 0; i < posLength; i++) {\n for (let j = 0; j < posLength; j++) {\n // Skip if position is occupied by finder patterns\n if (i === 0 && j === 0 ||\n // top-left\n i === 0 && j === posLength - 1 ||\n // bottom-left\n i === posLength - 1 && j === 0) {\n // top-right\n continue;\n }\n coords.push([pos[i], pos[j]]);\n }\n }\n return coords;\n};","const getSymbolSize = require('./utils').getSymbolSize;\nconst FINDER_PATTERN_SIZE = 7;\n\n/**\n * Returns an array containing the positions of each finder pattern.\n * Each array's element represent the top-left point of the pattern as (x, y) coordinates\n *\n * @param {Number} version QR Code version\n * @return {Array} Array of coordinates\n */\nexports.getPositions = function getPositions(version) {\n const size = getSymbolSize(version);\n return [\n // top-left\n [0, 0],\n // top-right\n [size - FINDER_PATTERN_SIZE, 0],\n // bottom-left\n [0, size - FINDER_PATTERN_SIZE]];\n};","/**\n * Data mask pattern reference\n * @type {Object}\n */\nexports.Patterns = {\n PATTERN000: 0,\n PATTERN001: 1,\n PATTERN010: 2,\n PATTERN011: 3,\n PATTERN100: 4,\n PATTERN101: 5,\n PATTERN110: 6,\n PATTERN111: 7\n};\n\n/**\n * Weighted penalty scores for the undesirable features\n * @type {Object}\n */\nconst PenaltyScores = {\n N1: 3,\n N2: 3,\n N3: 40,\n N4: 10\n};\n\n/**\n * Check if mask pattern value is valid\n *\n * @param {Number} mask Mask pattern\n * @return {Boolean} true if valid, false otherwise\n */\nexports.isValid = function isValid(mask) {\n return mask != null && mask !== '' && !isNaN(mask) && mask >= 0 && mask <= 7;\n};\n\n/**\n * Returns mask pattern from a value.\n * If value is not valid, returns undefined\n *\n * @param {Number|String} value Mask pattern value\n * @return {Number} Valid mask pattern or undefined\n */\nexports.from = function from(value) {\n return exports.isValid(value) ? parseInt(value, 10) : undefined;\n};\n\n/**\n* Find adjacent modules in row/column with the same color\n* and assign a penalty value.\n*\n* Points: N1 + i\n* i is the amount by which the number of adjacent modules of the same color exceeds 5\n*/\nexports.getPenaltyN1 = function getPenaltyN1(data) {\n const size = data.size;\n let points = 0;\n let sameCountCol = 0;\n let sameCountRow = 0;\n let lastCol = null;\n let lastRow = null;\n for (let row = 0; row < size; row++) {\n sameCountCol = sameCountRow = 0;\n lastCol = lastRow = null;\n for (let col = 0; col < size; col++) {\n let module = data.get(row, col);\n if (module === lastCol) {\n sameCountCol++;\n } else {\n if (sameCountCol >= 5) points += PenaltyScores.N1 + (sameCountCol - 5);\n lastCol = module;\n sameCountCol = 1;\n }\n module = data.get(col, row);\n if (module === lastRow) {\n sameCountRow++;\n } else {\n if (sameCountRow >= 5) points += PenaltyScores.N1 + (sameCountRow - 5);\n lastRow = module;\n sameCountRow = 1;\n }\n }\n if (sameCountCol >= 5) points += PenaltyScores.N1 + (sameCountCol - 5);\n if (sameCountRow >= 5) points += PenaltyScores.N1 + (sameCountRow - 5);\n }\n return points;\n};\n\n/**\n * Find 2x2 blocks with the same color and assign a penalty value\n *\n * Points: N2 * (m - 1) * (n - 1)\n */\nexports.getPenaltyN2 = function getPenaltyN2(data) {\n const size = data.size;\n let points = 0;\n for (let row = 0; row < size - 1; row++) {\n for (let col = 0; col < size - 1; col++) {\n const last = data.get(row, col) + data.get(row, col + 1) + data.get(row + 1, col) + data.get(row + 1, col + 1);\n if (last === 4 || last === 0) points++;\n }\n }\n return points * PenaltyScores.N2;\n};\n\n/**\n * Find 1:1:3:1:1 ratio (dark:light:dark:light:dark) pattern in row/column,\n * preceded or followed by light area 4 modules wide\n *\n * Points: N3 * number of pattern found\n */\nexports.getPenaltyN3 = function getPenaltyN3(data) {\n const size = data.size;\n let points = 0;\n let bitsCol = 0;\n let bitsRow = 0;\n for (let row = 0; row < size; row++) {\n bitsCol = bitsRow = 0;\n for (let col = 0; col < size; col++) {\n bitsCol = bitsCol << 1 & 0x7FF | data.get(row, col);\n if (col >= 10 && (bitsCol === 0x5D0 || bitsCol === 0x05D)) points++;\n bitsRow = bitsRow << 1 & 0x7FF | data.get(col, row);\n if (col >= 10 && (bitsRow === 0x5D0 || bitsRow === 0x05D)) points++;\n }\n }\n return points * PenaltyScores.N3;\n};\n\n/**\n * Calculate proportion of dark modules in entire symbol\n *\n * Points: N4 * k\n *\n * k is the rating of the deviation of the proportion of dark modules\n * in the symbol from 50% in steps of 5%\n */\nexports.getPenaltyN4 = function getPenaltyN4(data) {\n let darkCount = 0;\n const modulesCount = data.data.length;\n for (let i = 0; i < modulesCount; i++) darkCount += data.data[i];\n const k = Math.abs(Math.ceil(darkCount * 100 / modulesCount / 5) - 10);\n return k * PenaltyScores.N4;\n};\n\n/**\n * Return mask value at given position\n *\n * @param {Number} maskPattern Pattern reference value\n * @param {Number} i Row\n * @param {Number} j Column\n * @return {Boolean} Mask value\n */\nfunction getMaskAt(maskPattern, i, j) {\n switch (maskPattern) {\n case exports.Patterns.PATTERN000:\n return (i + j) % 2 === 0;\n case exports.Patterns.PATTERN001:\n return i % 2 === 0;\n case exports.Patterns.PATTERN010:\n return j % 3 === 0;\n case exports.Patterns.PATTERN011:\n return (i + j) % 3 === 0;\n case exports.Patterns.PATTERN100:\n return (Math.floor(i / 2) + Math.floor(j / 3)) % 2 === 0;\n case exports.Patterns.PATTERN101:\n return i * j % 2 + i * j % 3 === 0;\n case exports.Patterns.PATTERN110:\n return (i * j % 2 + i * j % 3) % 2 === 0;\n case exports.Patterns.PATTERN111:\n return (i * j % 3 + (i + j) % 2) % 2 === 0;\n default:\n throw new Error('bad maskPattern:' + maskPattern);\n }\n}\n\n/**\n * Apply a mask pattern to a BitMatrix\n *\n * @param {Number} pattern Pattern reference number\n * @param {BitMatrix} data BitMatrix data\n */\nexports.applyMask = function applyMask(pattern, data) {\n const size = data.size;\n for (let col = 0; col < size; col++) {\n for (let row = 0; row < size; row++) {\n if (data.isReserved(row, col)) continue;\n data.xor(row, col, getMaskAt(pattern, row, col));\n }\n }\n};\n\n/**\n * Returns the best mask pattern for data\n *\n * @param {BitMatrix} data\n * @return {Number} Mask pattern reference number\n */\nexports.getBestMask = function getBestMask(data, setupFormatFunc) {\n const numPatterns = Object.keys(exports.Patterns).length;\n let bestPattern = 0;\n let lowerPenalty = Infinity;\n for (let p = 0; p < numPatterns; p++) {\n setupFormatFunc(p);\n exports.applyMask(p, data);\n\n // Calculate penalty\n const penalty = exports.getPenaltyN1(data) + exports.getPenaltyN2(data) + exports.getPenaltyN3(data) + exports.getPenaltyN4(data);\n\n // Undo previously applied mask\n exports.applyMask(p, data);\n if (penalty < lowerPenalty) {\n lowerPenalty = penalty;\n bestPattern = p;\n }\n }\n return bestPattern;\n};","const ECLevel = require('./error-correction-level');\nconst EC_BLOCKS_TABLE = [\n// L M Q H\n1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 1, 2, 2, 4, 1, 2, 4, 4, 2, 4, 4, 4, 2, 4, 6, 5, 2, 4, 6, 6, 2, 5, 8, 8, 4, 5, 8, 8, 4, 5, 8, 11, 4, 8, 10, 11, 4, 9, 12, 16, 4, 9, 16, 16, 6, 10, 12, 18, 6, 10, 17, 16, 6, 11, 16, 19, 6, 13, 18, 21, 7, 14, 21, 25, 8, 16, 20, 25, 8, 17, 23, 25, 9, 17, 23, 34, 9, 18, 25, 30, 10, 20, 27, 32, 12, 21, 29, 35, 12, 23, 34, 37, 12, 25, 34, 40, 13, 26, 35, 42, 14, 28, 38, 45, 15, 29, 40, 48, 16, 31, 43, 51, 17, 33, 45, 54, 18, 35, 48, 57, 19, 37, 51, 60, 19, 38, 53, 63, 20, 40, 56, 66, 21, 43, 59, 70, 22, 45, 62, 74, 24, 47, 65, 77, 25, 49, 68, 81];\nconst EC_CODEWORDS_TABLE = [\n// L M Q H\n7, 10, 13, 17, 10, 16, 22, 28, 15, 26, 36, 44, 20, 36, 52, 64, 26, 48, 72, 88, 36, 64, 96, 112, 40, 72, 108, 130, 48, 88, 132, 156, 60, 110, 160, 192, 72, 130, 192, 224, 80, 150, 224, 264, 96, 176, 260, 308, 104, 198, 288, 352, 120, 216, 320, 384, 132, 240, 360, 432, 144, 280, 408, 480, 168, 308, 448, 532, 180, 338, 504, 588, 196, 364, 546, 650, 224, 416, 600, 700, 224, 442, 644, 750, 252, 476, 690, 816, 270, 504, 750, 900, 300, 560, 810, 960, 312, 588, 870, 1050, 336, 644, 952, 1110, 360, 700, 1020, 1200, 390, 728, 1050, 1260, 420, 784, 1140, 1350, 450, 812, 1200, 1440, 480, 868, 1290, 1530, 510, 924, 1350, 1620, 540, 980, 1440, 1710, 570, 1036, 1530, 1800, 570, 1064, 1590, 1890, 600, 1120, 1680, 1980, 630, 1204, 1770, 2100, 660, 1260, 1860, 2220, 720, 1316, 1950, 2310, 750, 1372, 2040, 2430];\n\n/**\r\n * Returns the number of error correction block that the QR Code should contain\r\n * for the specified version and error correction level.\r\n *\r\n * @param {Number} version QR Code version\r\n * @param {Number} errorCorrectionLevel Error correction level\r\n * @return {Number} Number of error correction blocks\r\n */\nexports.getBlocksCount = function getBlocksCount(version, errorCorrectionLevel) {\n switch (errorCorrectionLevel) {\n case ECLevel.L:\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 0];\n case ECLevel.M:\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 1];\n case ECLevel.Q:\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 2];\n case ECLevel.H:\n return EC_BLOCKS_TABLE[(version - 1) * 4 + 3];\n default:\n return undefined;\n }\n};\n\n/**\r\n * Returns the number of error correction codewords to use for the specified\r\n * version and error correction level.\r\n *\r\n * @param {Number} version QR Code version\r\n * @param {Number} errorCorrectionLevel Error correction level\r\n * @return {Number} Number of error correction codewords\r\n */\nexports.getTotalCodewordsCount = function getTotalCodewordsCount(version, errorCorrectionLevel) {\n switch (errorCorrectionLevel) {\n case ECLevel.L:\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 0];\n case ECLevel.M:\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 1];\n case ECLevel.Q:\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 2];\n case ECLevel.H:\n return EC_CODEWORDS_TABLE[(version - 1) * 4 + 3];\n default:\n return undefined;\n }\n};","const EXP_TABLE = new Uint8Array(512);\nconst LOG_TABLE = new Uint8Array(256)\n/**\n * Precompute the log and anti-log tables for faster computation later\n *\n * For each possible value in the galois field 2^8, we will pre-compute\n * the logarithm and anti-logarithm (exponential) of this value\n *\n * ref {@link https://en.wikiversity.org/wiki/Reed%E2%80%93Solomon_codes_for_coders#Introduction_to_mathematical_fields}\n */;\n(function initTables() {\n let x = 1;\n for (let i = 0; i < 255; i++) {\n EXP_TABLE[i] = x;\n LOG_TABLE[x] = i;\n x <<= 1; // multiply by 2\n\n // The QR code specification says to use byte-wise modulo 100011101 arithmetic.\n // This means that when a number is 256 or larger, it should be XORed with 0x11D.\n if (x & 0x100) {\n // similar to x >= 256, but a lot faster (because 0x100 == 256)\n x ^= 0x11D;\n }\n }\n\n // Optimization: double the size of the anti-log table so that we don't need to mod 255 to\n // stay inside the bounds (because we will mainly use this table for the multiplication of\n // two GF numbers, no more).\n // @see {@link mul}\n for (let i = 255; i < 512; i++) {\n EXP_TABLE[i] = EXP_TABLE[i - 255];\n }\n})();\n\n/**\n * Returns log value of n inside Galois Field\n *\n * @param {Number} n\n * @return {Number}\n */\nexports.log = function log(n) {\n if (n < 1) throw new Error('log(' + n + ')');\n return LOG_TABLE[n];\n};\n\n/**\n * Returns anti-log value of n inside Galois Field\n *\n * @param {Number} n\n * @return {Number}\n */\nexports.exp = function exp(n) {\n return EXP_TABLE[n];\n};\n\n/**\n * Multiplies two number inside Galois Field\n *\n * @param {Number} x\n * @param {Number} y\n * @return {Number}\n */\nexports.mul = function mul(x, y) {\n if (x === 0 || y === 0) return 0;\n\n // should be EXP_TABLE[(LOG_TABLE[x] + LOG_TABLE[y]) % 255] if EXP_TABLE wasn't oversized\n // @see {@link initTables}\n return EXP_TABLE[LOG_TABLE[x] + LOG_TABLE[y]];\n};","const GF = require('./galois-field');\n\n/**\n * Multiplies two polynomials inside Galois Field\n *\n * @param {Uint8Array} p1 Polynomial\n * @param {Uint8Array} p2 Polynomial\n * @return {Uint8Array} Product of p1 and p2\n */\nexports.mul = function mul(p1, p2) {\n const coeff = new Uint8Array(p1.length + p2.length - 1);\n for (let i = 0; i < p1.length; i++) {\n for (let j = 0; j < p2.length; j++) {\n coeff[i + j] ^= GF.mul(p1[i], p2[j]);\n }\n }\n return coeff;\n};\n\n/**\n * Calculate the remainder of polynomials division\n *\n * @param {Uint8Array} divident Polynomial\n * @param {Uint8Array} divisor Polynomial\n * @return {Uint8Array} Remainder\n */\nexports.mod = function mod(divident, divisor) {\n let result = new Uint8Array(divident);\n while (result.length - divisor.length >= 0) {\n const coeff = result[0];\n for (let i = 0; i < divisor.length; i++) {\n result[i] ^= GF.mul(divisor[i], coeff);\n }\n\n // remove all zeros from buffer head\n let offset = 0;\n while (offset < result.length && result[offset] === 0) offset++;\n result = result.slice(offset);\n }\n return result;\n};\n\n/**\n * Generate an irreducible generator polynomial of specified degree\n * (used by Reed-Solomon encoder)\n *\n * @param {Number} degree Degree of the generator polynomial\n * @return {Uint8Array} Buffer containing polynomial coefficients\n */\nexports.generateECPolynomial = function generateECPolynomial(degree) {\n let poly = new Uint8Array([1]);\n for (let i = 0; i < degree; i++) {\n poly = exports.mul(poly, new Uint8Array([1, GF.exp(i)]));\n }\n return poly;\n};","const Polynomial = require('./polynomial');\nfunction ReedSolomonEncoder(degree) {\n this.genPoly = undefined;\n this.degree = degree;\n if (this.degree) this.initialize(this.degree);\n}\n\n/**\n * Initialize the encoder.\n * The input param should correspond to the number of error correction codewords.\n *\n * @param {Number} degree\n */\nReedSolomonEncoder.prototype.initialize = function initialize(degree) {\n // create an irreducible generator polynomial\n this.degree = degree;\n this.genPoly = Polynomial.generateECPolynomial(this.degree);\n};\n\n/**\n * Encodes a chunk of data\n *\n * @param {Uint8Array} data Buffer containing input data\n * @return {Uint8Array} Buffer containing encoded data\n */\nReedSolomonEncoder.prototype.encode = function encode(data) {\n if (!this.genPoly) {\n throw new Error('Encoder not initialized');\n }\n\n // Calculate EC for this data block\n // extends data size to data+genPoly size\n const paddedData = new Uint8Array(data.length + this.degree);\n paddedData.set(data);\n\n // The error correction codewords are the remainder after dividing the data codewords\n // by a generator polynomial\n const remainder = Polynomial.mod(paddedData, this.genPoly);\n\n // return EC data blocks (last n byte, where n is the degree of genPoly)\n // If coefficients number in remainder are less than genPoly degree,\n // pad with 0s to the left to reach the needed number of coefficients\n const start = this.degree - remainder.length;\n if (start > 0) {\n const buff = new Uint8Array(this.degree);\n buff.set(remainder, start);\n return buff;\n }\n return remainder;\n};\nmodule.exports = ReedSolomonEncoder;","/**\n * Check if QR Code version is valid\n *\n * @param {Number} version QR Code version\n * @return {Boolean} true if valid version, false otherwise\n */\nexports.isValid = function isValid(version) {\n return !isNaN(version) && version >= 1 && version <= 40;\n};","const numeric = '[0-9]+';\nconst alphanumeric = '[A-Z $%*+\\\\-./:]+';\nlet kanji = '(?:[u3000-u303F]|[u3040-u309F]|[u30A0-u30FF]|' + '[uFF00-uFFEF]|[u4E00-u9FAF]|[u2605-u2606]|[u2190-u2195]|u203B|' + '[u2010u2015u2018u2019u2025u2026u201Cu201Du2225u2260]|' + '[u0391-u0451]|[u00A7u00A8u00B1u00B4u00D7u00F7])+';\nkanji = kanji.replace(/u/g, '\\\\u');\nconst byte = '(?:(?![A-Z0-9 $%*+\\\\-./:]|' + kanji + ')(?:.|[\\r\\n]))+';\nexports.KANJI = new RegExp(kanji, 'g');\nexports.BYTE_KANJI = new RegExp('[^A-Z0-9 $%*+\\\\-./:]+', 'g');\nexports.BYTE = new RegExp(byte, 'g');\nexports.NUMERIC = new RegExp(numeric, 'g');\nexports.ALPHANUMERIC = new RegExp(alphanumeric, 'g');\nconst TEST_KANJI = new RegExp('^' + kanji + '$');\nconst TEST_NUMERIC = new RegExp('^' + numeric + '$');\nconst TEST_ALPHANUMERIC = new RegExp('^[A-Z0-9 $%*+\\\\-./:]+$');\nexports.testKanji = function testKanji(str) {\n return TEST_KANJI.test(str);\n};\nexports.testNumeric = function testNumeric(str) {\n return TEST_NUMERIC.test(str);\n};\nexports.testAlphanumeric = function testAlphanumeric(str) {\n return TEST_ALPHANUMERIC.test(str);\n};","const VersionCheck = require('./version-check');\nconst Regex = require('./regex');\n\n/**\n * Numeric mode encodes data from the decimal digit set (0 - 9)\n * (byte values 30HEX to 39HEX).\n * Normally, 3 data characters are represented by 10 bits.\n *\n * @type {Object}\n */\nexports.NUMERIC = {\n id: 'Numeric',\n bit: 1 << 0,\n ccBits: [10, 12, 14]\n};\n\n/**\n * Alphanumeric mode encodes data from a set of 45 characters,\n * i.e. 10 numeric digits (0 - 9),\n * 26 alphabetic characters (A - Z),\n * and 9 symbols (SP, $, %, *, +, -, ., /, :).\n * Normally, two input characters are represented by 11 bits.\n *\n * @type {Object}\n */\nexports.ALPHANUMERIC = {\n id: 'Alphanumeric',\n bit: 1 << 1,\n ccBits: [9, 11, 13]\n};\n\n/**\n * In byte mode, data is encoded at 8 bits per character.\n *\n * @type {Object}\n */\nexports.BYTE = {\n id: 'Byte',\n bit: 1 << 2,\n ccBits: [8, 16, 16]\n};\n\n/**\n * The Kanji mode efficiently encodes Kanji characters in accordance with\n * the Shift JIS system based on JIS X 0208.\n * The Shift JIS values are shifted from the JIS X 0208 values.\n * JIS X 0208 gives details of the shift coded representation.\n * Each two-byte character value is compacted to a 13-bit binary codeword.\n *\n * @type {Object}\n */\nexports.KANJI = {\n id: 'Kanji',\n bit: 1 << 3,\n ccBits: [8, 10, 12]\n};\n\n/**\n * Mixed mode will contain a sequences of data in a combination of any of\n * the modes described above\n *\n * @type {Object}\n */\nexports.MIXED = {\n bit: -1\n};\n\n/**\n * Returns the number of bits needed to store the data length\n * according to QR Code specifications.\n *\n * @param {Mode} mode Data mode\n * @param {Number} version QR Code version\n * @return {Number} Number of bits\n */\nexports.getCharCountIndicator = function getCharCountIndicator(mode, version) {\n if (!mode.ccBits) throw new Error('Invalid mode: ' + mode);\n if (!VersionCheck.isValid(version)) {\n throw new Error('Invalid version: ' + version);\n }\n if (version >= 1 && version < 10) return mode.ccBits[0];else if (version < 27) return mode.ccBits[1];\n return mode.ccBits[2];\n};\n\n/**\n * Returns the most efficient mode to store the specified data\n *\n * @param {String} dataStr Input data string\n * @return {Mode} Best mode\n */\nexports.getBestModeForData = function getBestModeForData(dataStr) {\n if (Regex.testNumeric(dataStr)) return exports.NUMERIC;else if (Regex.testAlphanumeric(dataStr)) return exports.ALPHANUMERIC;else if (Regex.testKanji(dataStr)) return exports.KANJI;else return exports.BYTE;\n};\n\n/**\n * Return mode name as string\n *\n * @param {Mode} mode Mode object\n * @returns {String} Mode name\n */\nexports.toString = function toString(mode) {\n if (mode && mode.id) return mode.id;\n throw new Error('Invalid mode');\n};\n\n/**\n * Check if input param is a valid mode object\n *\n * @param {Mode} mode Mode object\n * @returns {Boolean} True if valid mode, false otherwise\n */\nexports.isValid = function isValid(mode) {\n return mode && mode.bit && mode.ccBits;\n};\n\n/**\n * Get mode object from its name\n *\n * @param {String} string Mode name\n * @returns {Mode} Mode object\n */\nfunction fromString(string) {\n if (typeof string !== 'string') {\n throw new Error('Param is not a string');\n }\n const lcStr = string.toLowerCase();\n switch (lcStr) {\n case 'numeric':\n return exports.NUMERIC;\n case 'alphanumeric':\n return exports.ALPHANUMERIC;\n case 'kanji':\n return exports.KANJI;\n case 'byte':\n return exports.BYTE;\n default:\n throw new Error('Unknown mode: ' + string);\n }\n}\n\n/**\n * Returns mode from a value.\n * If value is not a valid mode, returns defaultValue\n *\n * @param {Mode|String} value Encoding mode\n * @param {Mode} defaultValue Fallback value\n * @return {Mode} Encoding mode\n */\nexports.from = function from(value, defaultValue) {\n if (exports.isValid(value)) {\n return value;\n }\n try {\n return fromString(value);\n } catch (e) {\n return defaultValue;\n }\n};","const Utils = require('./utils');\nconst ECCode = require('./error-correction-code');\nconst ECLevel = require('./error-correction-level');\nconst Mode = require('./mode');\nconst VersionCheck = require('./version-check');\n\n// Generator polynomial used to encode version information\nconst G18 = 1 << 12 | 1 << 11 | 1 << 10 | 1 << 9 | 1 << 8 | 1 << 5 | 1 << 2 | 1 << 0;\nconst G18_BCH = Utils.getBCHDigit(G18);\nfunction getBestVersionForDataLength(mode, length, errorCorrectionLevel) {\n for (let currentVersion = 1; currentVersion <= 40; currentVersion++) {\n if (length <= exports.getCapacity(currentVersion, errorCorrectionLevel, mode)) {\n return currentVersion;\n }\n }\n return undefined;\n}\nfunction getReservedBitsCount(mode, version) {\n // Character count indicator + mode indicator bits\n return Mode.getCharCountIndicator(mode, version) + 4;\n}\nfunction getTotalBitsFromDataArray(segments, version) {\n let totalBits = 0;\n segments.forEach(function (data) {\n const reservedBits = getReservedBitsCount(data.mode, version);\n totalBits += reservedBits + data.getBitsLength();\n });\n return totalBits;\n}\nfunction getBestVersionForMixedData(segments, errorCorrectionLevel) {\n for (let currentVersion = 1; currentVersion <= 40; currentVersion++) {\n const length = getTotalBitsFromDataArray(segments, currentVersion);\n if (length <= exports.getCapacity(currentVersion, errorCorrectionLevel, Mode.MIXED)) {\n return currentVersion;\n }\n }\n return undefined;\n}\n\n/**\n * Returns version number from a value.\n * If value is not a valid version, returns defaultValue\n *\n * @param {Number|String} value QR Code version\n * @param {Number} defaultValue Fallback value\n * @return {Number} QR Code version number\n */\nexports.from = function from(value, defaultValue) {\n if (VersionCheck.isValid(value)) {\n return parseInt(value, 10);\n }\n return defaultValue;\n};\n\n/**\n * Returns how much data can be stored with the specified QR code version\n * and error correction level\n *\n * @param {Number} version QR Code version (1-40)\n * @param {Number} errorCorrectionLevel Error correction level\n * @param {Mode} mode Data mode\n * @return {Number} Quantity of storable data\n */\nexports.getCapacity = function getCapacity(version, errorCorrectionLevel, mode) {\n if (!VersionCheck.isValid(version)) {\n throw new Error('Invalid QR Code version');\n }\n\n // Use Byte mode as default\n if (typeof mode === 'undefined') mode = Mode.BYTE;\n\n // Total codewords for this QR code version (Data + Error correction)\n const totalCodewords = Utils.getSymbolTotalCodewords(version);\n\n // Total number of error correction codewords\n const ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel);\n\n // Total number of data codewords\n const dataTotalCodewordsBits = (totalCodewords - ecTotalCodewords) * 8;\n if (mode === Mode.MIXED) return dataTotalCodewordsBits;\n const usableBits = dataTotalCodewordsBits - getReservedBitsCount(mode, version);\n\n // Return max number of storable codewords\n switch (mode) {\n case Mode.NUMERIC:\n return Math.floor(usableBits / 10 * 3);\n case Mode.ALPHANUMERIC:\n return Math.floor(usableBits / 11 * 2);\n case Mode.KANJI:\n return Math.floor(usableBits / 13);\n case Mode.BYTE:\n default:\n return Math.floor(usableBits / 8);\n }\n};\n\n/**\n * Returns the minimum version needed to contain the amount of data\n *\n * @param {Segment} data Segment of data\n * @param {Number} [errorCorrectionLevel=H] Error correction level\n * @param {Mode} mode Data mode\n * @return {Number} QR Code version\n */\nexports.getBestVersionForData = function getBestVersionForData(data, errorCorrectionLevel) {\n let seg;\n const ecl = ECLevel.from(errorCorrectionLevel, ECLevel.M);\n if (Array.isArray(data)) {\n if (data.length > 1) {\n return getBestVersionForMixedData(data, ecl);\n }\n if (data.length === 0) {\n return 1;\n }\n seg = data[0];\n } else {\n seg = data;\n }\n return getBestVersionForDataLength(seg.mode, seg.getLength(), ecl);\n};\n\n/**\n * Returns version information with relative error correction bits\n *\n * The version information is included in QR Code symbols of version 7 or larger.\n * It consists of an 18-bit sequence containing 6 data bits,\n * with 12 error correction bits calculated using the (18, 6) Golay code.\n *\n * @param {Number} version QR Code version\n * @return {Number} Encoded version info bits\n */\nexports.getEncodedBits = function getEncodedBits(version) {\n if (!VersionCheck.isValid(version) || version < 7) {\n throw new Error('Invalid QR Code version');\n }\n let d = version << 12;\n while (Utils.getBCHDigit(d) - G18_BCH >= 0) {\n d ^= G18 << Utils.getBCHDigit(d) - G18_BCH;\n }\n return version << 12 | d;\n};","const Utils = require('./utils');\nconst G15 = 1 << 10 | 1 << 8 | 1 << 5 | 1 << 4 | 1 << 2 | 1 << 1 | 1 << 0;\nconst G15_MASK = 1 << 14 | 1 << 12 | 1 << 10 | 1 << 4 | 1 << 1;\nconst G15_BCH = Utils.getBCHDigit(G15);\n\n/**\n * Returns format information with relative error correction bits\n *\n * The format information is a 15-bit sequence containing 5 data bits,\n * with 10 error correction bits calculated using the (15, 5) BCH code.\n *\n * @param {Number} errorCorrectionLevel Error correction level\n * @param {Number} mask Mask pattern\n * @return {Number} Encoded format information bits\n */\nexports.getEncodedBits = function getEncodedBits(errorCorrectionLevel, mask) {\n const data = errorCorrectionLevel.bit << 3 | mask;\n let d = data << 10;\n while (Utils.getBCHDigit(d) - G15_BCH >= 0) {\n d ^= G15 << Utils.getBCHDigit(d) - G15_BCH;\n }\n\n // xor final data with mask pattern in order to ensure that\n // no combination of Error Correction Level and data mask pattern\n // will result in an all-zero data string\n return (data << 10 | d) ^ G15_MASK;\n};","const Mode = require('./mode');\nfunction NumericData(data) {\n this.mode = Mode.NUMERIC;\n this.data = data.toString();\n}\nNumericData.getBitsLength = function getBitsLength(length) {\n return 10 * Math.floor(length / 3) + (length % 3 ? length % 3 * 3 + 1 : 0);\n};\nNumericData.prototype.getLength = function getLength() {\n return this.data.length;\n};\nNumericData.prototype.getBitsLength = function getBitsLength() {\n return NumericData.getBitsLength(this.data.length);\n};\nNumericData.prototype.write = function write(bitBuffer) {\n let i, group, value;\n\n // The input data string is divided into groups of three digits,\n // and each group is converted to its 10-bit binary equivalent.\n for (i = 0; i + 3 <= this.data.length; i += 3) {\n group = this.data.substr(i, 3);\n value = parseInt(group, 10);\n bitBuffer.put(value, 10);\n }\n\n // If the number of input digits is not an exact multiple of three,\n // the final one or two digits are converted to 4 or 7 bits respectively.\n const remainingNum = this.data.length - i;\n if (remainingNum > 0) {\n group = this.data.substr(i);\n value = parseInt(group, 10);\n bitBuffer.put(value, remainingNum * 3 + 1);\n }\n};\nmodule.exports = NumericData;","const Mode = require('./mode');\n\n/**\n * Array of characters available in alphanumeric mode\n *\n * As per QR Code specification, to each character\n * is assigned a value from 0 to 44 which in this case coincides\n * with the array index\n *\n * @type {Array}\n */\nconst ALPHA_NUM_CHARS = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', ' ', '$', '%', '*', '+', '-', '.', '/', ':'];\nfunction AlphanumericData(data) {\n this.mode = Mode.ALPHANUMERIC;\n this.data = data;\n}\nAlphanumericData.getBitsLength = function getBitsLength(length) {\n return 11 * Math.floor(length / 2) + 6 * (length % 2);\n};\nAlphanumericData.prototype.getLength = function getLength() {\n return this.data.length;\n};\nAlphanumericData.prototype.getBitsLength = function getBitsLength() {\n return AlphanumericData.getBitsLength(this.data.length);\n};\nAlphanumericData.prototype.write = function write(bitBuffer) {\n let i;\n\n // Input data characters are divided into groups of two characters\n // and encoded as 11-bit binary codes.\n for (i = 0; i + 2 <= this.data.length; i += 2) {\n // The character value of the first character is multiplied by 45\n let value = ALPHA_NUM_CHARS.indexOf(this.data[i]) * 45;\n\n // The character value of the second digit is added to the product\n value += ALPHA_NUM_CHARS.indexOf(this.data[i + 1]);\n\n // The sum is then stored as 11-bit binary number\n bitBuffer.put(value, 11);\n }\n\n // If the number of input data characters is not a multiple of two,\n // the character value of the final character is encoded as a 6-bit binary number.\n if (this.data.length % 2) {\n bitBuffer.put(ALPHA_NUM_CHARS.indexOf(this.data[i]), 6);\n }\n};\nmodule.exports = AlphanumericData;","'use strict';\n\nmodule.exports = function encodeUtf8(input) {\n var result = [];\n var size = input.length;\n for (var index = 0; index < size; index++) {\n var point = input.charCodeAt(index);\n if (point >= 0xD800 && point <= 0xDBFF && size > index + 1) {\n var second = input.charCodeAt(index + 1);\n if (second >= 0xDC00 && second <= 0xDFFF) {\n // https://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\n point = (point - 0xD800) * 0x400 + second - 0xDC00 + 0x10000;\n index += 1;\n }\n }\n\n // US-ASCII\n if (point < 0x80) {\n result.push(point);\n continue;\n }\n\n // 2-byte UTF-8\n if (point < 0x800) {\n result.push(point >> 6 | 192);\n result.push(point & 63 | 128);\n continue;\n }\n\n // 3-byte UTF-8\n if (point < 0xD800 || point >= 0xE000 && point < 0x10000) {\n result.push(point >> 12 | 224);\n result.push(point >> 6 & 63 | 128);\n result.push(point & 63 | 128);\n continue;\n }\n\n // 4-byte UTF-8\n if (point >= 0x10000 && point <= 0x10FFFF) {\n result.push(point >> 18 | 240);\n result.push(point >> 12 & 63 | 128);\n result.push(point >> 6 & 63 | 128);\n result.push(point & 63 | 128);\n continue;\n }\n\n // Invalid character\n result.push(0xEF, 0xBF, 0xBD);\n }\n return new Uint8Array(result).buffer;\n};","const encodeUtf8 = require('encode-utf8');\nconst Mode = require('./mode');\nfunction ByteData(data) {\n this.mode = Mode.BYTE;\n if (typeof data === 'string') {\n data = encodeUtf8(data);\n }\n this.data = new Uint8Array(data);\n}\nByteData.getBitsLength = function getBitsLength(length) {\n return length * 8;\n};\nByteData.prototype.getLength = function getLength() {\n return this.data.length;\n};\nByteData.prototype.getBitsLength = function getBitsLength() {\n return ByteData.getBitsLength(this.data.length);\n};\nByteData.prototype.write = function (bitBuffer) {\n for (let i = 0, l = this.data.length; i < l; i++) {\n bitBuffer.put(this.data[i], 8);\n }\n};\nmodule.exports = ByteData;","const Mode = require('./mode');\nconst Utils = require('./utils');\nfunction KanjiData(data) {\n this.mode = Mode.KANJI;\n this.data = data;\n}\nKanjiData.getBitsLength = function getBitsLength(length) {\n return length * 13;\n};\nKanjiData.prototype.getLength = function getLength() {\n return this.data.length;\n};\nKanjiData.prototype.getBitsLength = function getBitsLength() {\n return KanjiData.getBitsLength(this.data.length);\n};\nKanjiData.prototype.write = function (bitBuffer) {\n let i;\n\n // In the Shift JIS system, Kanji characters are represented by a two byte combination.\n // These byte values are shifted from the JIS X 0208 values.\n // JIS X 0208 gives details of the shift coded representation.\n for (i = 0; i < this.data.length; i++) {\n let value = Utils.toSJIS(this.data[i]);\n\n // For characters with Shift JIS values from 0x8140 to 0x9FFC:\n if (value >= 0x8140 && value <= 0x9FFC) {\n // Subtract 0x8140 from Shift JIS value\n value -= 0x8140;\n\n // For characters with Shift JIS values from 0xE040 to 0xEBBF\n } else if (value >= 0xE040 && value <= 0xEBBF) {\n // Subtract 0xC140 from Shift JIS value\n value -= 0xC140;\n } else {\n throw new Error('Invalid SJIS character: ' + this.data[i] + '\\n' + 'Make sure your charset is UTF-8');\n }\n\n // Multiply most significant byte of result by 0xC0\n // and add least significant byte to product\n value = (value >>> 8 & 0xff) * 0xC0 + (value & 0xff);\n\n // Convert result to a 13-bit binary string\n bitBuffer.put(value, 13);\n }\n};\nmodule.exports = KanjiData;","'use strict';\n\n/******************************************************************************\n * Created 2008-08-19.\n *\n * Dijkstra path-finding functions. Adapted from the Dijkstar Python project.\n *\n * Copyright (C) 2008\n * Wyatt Baldwin data
, is the returned server data. If no callback is provided, `getRewardsBalance` returns a promise that resolves with the server data.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n * @example\n * var americanExpress = require('braintree-web/american-express');\n *\n * americanExpress.create({client: clientInstance}, function (createErr, americanExpressInstance) {\n * var options = {nonce: existingBraintreeNonce};\n * americanExpressInstance.getRewardsBalance(options, function (getErr, payload) {\n * if (getErr || payload.error) {\n * // Handle error\n * return;\n * }\n *\n * console.log('Rewards amount: ' + payload.rewardsAmount);\n * });\n * });\n */\n AmericanExpress.prototype.getRewardsBalance = function (options) {\n var nonce = options.nonce;\n var data;\n if (!nonce) {\n return Promise.reject(new BraintreeError({\n type: errors.AMEX_NONCE_REQUIRED.type,\n code: errors.AMEX_NONCE_REQUIRED.code,\n message: \"getRewardsBalance must be called with a nonce.\"\n }));\n }\n data = assign({\n _meta: {\n source: \"american-express\"\n },\n paymentMethodNonce: nonce\n }, options);\n delete data.nonce;\n return this._client.request({\n method: \"get\",\n endpoint: \"payment_methods/amex_rewards_balance\",\n data: data\n }).catch(function (err) {\n return Promise.reject(new BraintreeError({\n type: errors.AMEX_NETWORK_ERROR.type,\n code: errors.AMEX_NETWORK_ERROR.code,\n message: \"A network error occurred when getting the American Express rewards balance.\",\n details: {\n originalError: err\n }\n }));\n });\n };\n\n /**\n * Gets the Express Checkout nonce profile given a nonce from American Express.\n * @public\n * @param {object} options Request options\n * @param {string} options.nonce An existing nonce from American Express (note that this is not a nonce from Braintree).\n * @param {callback} [callback] The second argument, data
, is the returned server data. If no callback is provided, `getExpressCheckoutProfile` returns a promise that resolves with the server data.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n * @example\n * var americanExpress = require('braintree-web/american-express');\n *\n * americanExpress.create({client: clientInstance}, function (createErr, americanExpressInstance) {\n * var options = {nonce: existingAmericanExpressNonce};\n * americanExpressInstance.getExpressCheckoutProfile(options, function (getErr, payload) {\n * if (getErr) {\n * // Handle error\n * return;\n * }\n *\n * console.log('Number of cards: ' + payload.amexExpressCheckoutCards.length);\n * });\n * });\n */\n AmericanExpress.prototype.getExpressCheckoutProfile = function (options) {\n if (!options.nonce) {\n return Promise.reject(new BraintreeError({\n type: errors.AMEX_NONCE_REQUIRED.type,\n code: errors.AMEX_NONCE_REQUIRED.code,\n message: \"getExpressCheckoutProfile must be called with a nonce.\"\n }));\n }\n return this._client.request({\n method: \"get\",\n endpoint: \"payment_methods/amex_express_checkout_cards/\" + options.nonce,\n data: {\n _meta: {\n source: \"american-express\"\n },\n paymentMethodNonce: options.nonce\n }\n }).catch(function (err) {\n return Promise.reject(new BraintreeError({\n type: errors.AMEX_NETWORK_ERROR.type,\n code: errors.AMEX_NETWORK_ERROR.code,\n message: \"A network error occurred when getting the American Express Checkout nonce profile.\",\n details: {\n originalError: err\n }\n }));\n });\n };\n\n /**\n * Cleanly tear down anything set up by {@link module:braintree-web/american-express.create|create}.\n * @public\n * @param {callback} [callback] Called once teardown is complete. No data is returned if teardown completes successfully.\n * @example\n * americanExpressInstance.teardown();\n * @example data
, is the Apple Pay merchant session object. If no callback is provided, `performValidation` returns a promise.\n * Pass the merchant session to your Apple Pay session's `completeMerchantValidation` method.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n * @example\n * var applePay = require('braintree-web/apple-pay');\n *\n * applePay.create({client: clientInstance}, function (applePayErr, applePayInstance) {\n * if (applePayErr) {\n * // Handle error here\n * return;\n * }\n *\n * var paymentRequest = applePayInstance.createPaymentRequest({\n * total: {\n * label: 'My Company',\n * amount: '19.99'\n * }\n * });\n * var session = new ApplePaySession(3, paymentRequest);\n *\n * session.onvalidatemerchant = function (event) {\n * applePayInstance.performValidation({\n * validationURL: event.validationURL,\n * displayName: 'My Great Store'\n * }, function (validationErr, validationData) {\n * if (validationErr) {\n * console.error(validationErr);\n * session.abort();\n * return;\n * }\n *\n * session.completeMerchantValidation(validationData);\n * });\n * };\n * });\n */\n ApplePay.prototype.performValidation = function (options) {\n var self = this;\n if (!options || !options.validationURL) {\n return Promise.reject(new BraintreeError(errors.APPLE_PAY_VALIDATION_URL_REQUIRED));\n }\n return this._waitForClient().then(function () {\n var applePayWebSession = {\n validationUrl: options.validationURL,\n domainName: options.domainName || window.location.hostname,\n merchantIdentifier: options.merchantIdentifier || self.merchantIdentifier\n };\n if (options.displayName != null) {\n applePayWebSession.displayName = options.displayName;\n }\n return self._client.request({\n method: \"post\",\n endpoint: \"apple_pay_web/sessions\",\n data: {\n _meta: {\n source: \"apple-pay\"\n },\n applePayWebSession: applePayWebSession\n }\n });\n }).then(function (response) {\n analytics.sendEvent(self._client, \"applepay.performValidation.succeeded\");\n return Promise.resolve(response);\n }).catch(function (err) {\n analytics.sendEvent(self._client, \"applepay.performValidation.failed\");\n if (err.code === \"CLIENT_REQUEST_ERROR\") {\n return Promise.reject(new BraintreeError({\n type: errors.APPLE_PAY_MERCHANT_VALIDATION_FAILED.type,\n code: errors.APPLE_PAY_MERCHANT_VALIDATION_FAILED.code,\n message: errors.APPLE_PAY_MERCHANT_VALIDATION_FAILED.message,\n details: {\n originalError: err.details.originalError\n }\n }));\n }\n return Promise.reject(new BraintreeError({\n type: errors.APPLE_PAY_MERCHANT_VALIDATION_NETWORK.type,\n code: errors.APPLE_PAY_MERCHANT_VALIDATION_NETWORK.code,\n message: errors.APPLE_PAY_MERCHANT_VALIDATION_NETWORK.message,\n details: {\n originalError: err\n }\n }));\n });\n };\n\n /**\n * Tokenizes an Apple Pay payment. This will likely be called in your `ApplePaySession`'s `onpaymentauthorized` callback.\n * @public\n * @param {object} options Options\n * @param {object} options.token The `payment.token` property of an {@link external:ApplePayPaymentAuthorizedEvent}.\n * @param {callback} [callback] The second argument, data
, is a {@link ApplePay~tokenizePayload|tokenizePayload}. If no callback is provided, `tokenize` returns a promise that resolves with a {@link ApplePay~tokenizePayload|tokenizePayload}.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n * @example\n * var applePay = require('braintree-web/apple-pay');\n *\n * applePay.create({client: clientInstance}, function (applePayErr, applePayInstance) {\n * if (applePayErr) {\n * // Handle error here\n * return;\n * }\n *\n * var paymentRequest = applePayInstance.createPaymentRequest({\n * total: {\n * label: 'My Company',\n * amount: '19.99'\n * }\n * });\n * var session = new ApplePaySession(3, paymentRequest);\n *\n * session.onpaymentauthorized = function (event) {\n * applePayInstance.tokenize({\n * token: event.payment.token\n * }, function (tokenizeErr, tokenizedPayload) {\n * if (tokenizeErr) {\n * session.completePayment(ApplePaySession.STATUS_FAILURE);\n * return;\n * }\n * // Send the tokenizedPayload to your server here!\n *\n * // Once the transaction is complete, call completePayment\n * // to close the Apple Pay sheet\n * session.completePayment(ApplePaySession.STATUS_SUCCESS);\n * });\n * };\n *\n * // ...\n * });\n */\n ApplePay.prototype.tokenize = function (options) {\n var self = this;\n if (!options.token) {\n return Promise.reject(new BraintreeError(errors.APPLE_PAY_PAYMENT_TOKEN_REQUIRED));\n }\n return this._waitForClient().then(function () {\n return self._client.request({\n method: \"post\",\n endpoint: \"payment_methods/apple_payment_tokens\",\n data: {\n _meta: {\n source: \"apple-pay\"\n },\n applePaymentToken: Object.assign({}, options.token, {\n // The gateway requires this key to be base64-encoded.\n paymentData: btoa(JSON.stringify(options.token.paymentData))\n })\n }\n });\n }).then(function (response) {\n analytics.sendEvent(self._client, \"applepay.tokenize.succeeded\");\n return Promise.resolve(response.applePayCards[0]);\n }).catch(function (err) {\n analytics.sendEvent(self._client, \"applepay.tokenize.failed\");\n return Promise.reject(new BraintreeError({\n type: errors.APPLE_PAY_TOKENIZATION.type,\n code: errors.APPLE_PAY_TOKENIZATION.code,\n message: errors.APPLE_PAY_TOKENIZATION.message,\n details: {\n originalError: err\n }\n }));\n });\n };\n\n /**\n * Cleanly tear down anything set up by {@link module:braintree-web/apple-pay.create|create}.\n * @public\n * @param {callback} [callback] Called once teardown is complete. No data is returned if teardown completes successfully.\n * @example\n * applePayInstance.teardown();\n * @example data
, is the returned server data.\n * @example\n * braintree.client
module. It is used for creating {@link Client} instances that service communication to Braintree servers.\n * @param {object} options Object containing all {@link Client} options:\n * @param {string} options.authorization A tokenizationKey or clientToken.\n * @param {callback} [callback] The second argument, data
, is the {@link Client} instance.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n * @example\n * var createClient = require('braintree-web/client').create;\n *\n * createClient({\n * authorization: CLIENT_AUTHORIZATION\n * }, function (createErr, clientInstance) {\n * if (createErr) {\n * if (createErr.code === 'CLIENT_AUTHORIZATION_INVALID') {\n * // either the client token has expired, and a new one should be generated\n * // or the tokenization key was deactivated or deleted\n * } else {\n * console.log('something went wrong creating the client instance', createErr);\n * }\n * return;\n * }\n *\n * // set up other components\n * });\n * @static\n */\n function create(options) {\n if (!options.authorization) {\n return Promise.reject(new BraintreeError({\n type: sharedErrors.INSTANTIATION_OPTION_REQUIRED.type,\n code: sharedErrors.INSTANTIATION_OPTION_REQUIRED.code,\n message: \"options.authorization is required when instantiating a client.\"\n }));\n }\n return Client.initialize(options);\n }\n module.exports = {\n create: wrapPromise(create),\n /**\n * @description The current version of the SDK, i.e. `{@pkg version}`.\n * @type {string}\n */\n VERSION: VERSION\n };\n }, {\n \"../lib/braintree-error\": 143,\n \"../lib/errors\": 154,\n \"./client\": 92,\n \"@braintree/wrap-promise\": 40\n }],\n 97: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var querystring = _dereq_(\"../../lib/querystring\");\n var assign = _dereq_(\"../../lib/assign\").assign;\n var prepBody = _dereq_(\"./prep-body\");\n var parseBody = _dereq_(\"./parse-body\");\n var xhr = _dereq_(\"./xhr\");\n var isXHRAvailable = xhr.isAvailable;\n var GraphQLRequest = _dereq_(\"./graphql/request\");\n var DefaultRequest = _dereq_(\"./default-request\");\n var MAX_TCP_RETRYCOUNT = 1;\n var TCP_PRECONNECT_BUG_STATUS_CODE = 408;\n function requestShouldRetry(status) {\n return !status || status === TCP_PRECONNECT_BUG_STATUS_CODE;\n }\n function graphQLRequestShouldRetryWithClientApi(body) {\n var errorClass = !body.data && body.errors && body.errors[0] && body.errors[0].extensions && body.errors[0].extensions.errorClass;\n return errorClass === \"UNKNOWN\" || errorClass === \"INTERNAL\";\n }\n function _requestWithRetry(options, tcpRetryCount, cb) {\n var status, resBody, ajaxRequest, body, method, headers, parsedBody;\n var url = options.url;\n var graphQL = options.graphQL;\n var timeout = options.timeout;\n var req = xhr.getRequestObject();\n var callback = cb;\n var isGraphQLRequest = Boolean(graphQL && graphQL.isGraphQLRequest(url, options.data));\n options.headers = assign({\n \"Content-Type\": \"application/json\"\n }, options.headers);\n if (isGraphQLRequest) {\n ajaxRequest = new GraphQLRequest(options);\n } else {\n ajaxRequest = new DefaultRequest(options);\n }\n url = ajaxRequest.getUrl();\n body = ajaxRequest.getBody();\n method = ajaxRequest.getMethod();\n headers = ajaxRequest.getHeaders();\n if (method === \"GET\") {\n url = querystring.queryify(url, body);\n body = null;\n }\n if (isXHRAvailable) {\n req.onreadystatechange = function () {\n if (req.readyState !== 4) {\n return;\n }\n if (req.status === 0 && isGraphQLRequest) {\n // If a merchant experiences a connection\n // issue to the GraphQL endpoint (possibly\n // due to a Content Security Policy), retry\n // the request against the old client API.\n delete options.graphQL;\n _requestWithRetry(options, tcpRetryCount, cb);\n return;\n }\n parsedBody = parseBody(req.responseText);\n resBody = ajaxRequest.adaptResponseBody(parsedBody);\n status = ajaxRequest.determineStatus(req.status, parsedBody);\n if (status >= 400 || status < 200) {\n if (isGraphQLRequest && graphQLRequestShouldRetryWithClientApi(parsedBody)) {\n delete options.graphQL;\n _requestWithRetry(options, tcpRetryCount, cb);\n return;\n }\n if (tcpRetryCount < MAX_TCP_RETRYCOUNT && requestShouldRetry(status)) {\n tcpRetryCount++;\n _requestWithRetry(options, tcpRetryCount, cb);\n return;\n }\n callback(resBody || \"error\", null, status || 500);\n } else {\n callback(null, resBody, status);\n }\n };\n } else {\n if (options.headers) {\n url = querystring.queryify(url, headers);\n }\n req.onload = function () {\n callback(null, parseBody(req.responseText), req.status);\n };\n req.onerror = function () {\n // XDomainRequest does not report a body or status for errors, so\n // hardcode to 'error' and 500, respectively\n callback(\"error\", null, 500);\n };\n\n // This must remain for IE9 to work\n req.onprogress = function () {};\n req.ontimeout = function () {\n callback(\"timeout\", null, -1);\n };\n }\n try {\n req.open(method, url, true);\n } catch (requestOpenError) {\n // If a merchant has a Content Security Policy and they have\n // not allowed our endpoints, some browsers may\n // synchronously throw an error. If it is not a GraphQL\n // request, we throw the error. If it is a GraphQL request\n // we remove the GraphQL option and try the request against\n // the old client API.\n if (!isGraphQLRequest) {\n throw requestOpenError;\n }\n delete options.graphQL;\n _requestWithRetry(options, tcpRetryCount, cb);\n return;\n }\n req.timeout = timeout;\n if (isXHRAvailable) {\n Object.keys(headers).forEach(function (headerKey) {\n req.setRequestHeader(headerKey, headers[headerKey]);\n });\n }\n try {\n req.send(prepBody(method, body));\n } catch (e) {\n /* ignored */\n }\n }\n function request(options, cb) {\n _requestWithRetry(options, 0, cb);\n }\n module.exports = {\n request: request\n };\n }, {\n \"../../lib/assign\": 140,\n \"../../lib/querystring\": 177,\n \"./default-request\": 98,\n \"./graphql/request\": 107,\n \"./parse-body\": 109,\n \"./prep-body\": 110,\n \"./xhr\": 111\n }],\n 98: [function (_dereq_, module, exports) {\n \"use strict\";\n\n function DefaultRequest(options) {\n this._url = options.url;\n this._data = options.data;\n this._method = options.method;\n this._headers = options.headers;\n }\n DefaultRequest.prototype.getUrl = function () {\n return this._url;\n };\n DefaultRequest.prototype.getBody = function () {\n return this._data;\n };\n DefaultRequest.prototype.getMethod = function () {\n return this._method;\n };\n DefaultRequest.prototype.getHeaders = function () {\n return this._headers;\n };\n DefaultRequest.prototype.adaptResponseBody = function (parsedBody) {\n return parsedBody;\n };\n DefaultRequest.prototype.determineStatus = function (status) {\n return status;\n };\n module.exports = DefaultRequest;\n }, {}],\n 99: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var errorResponseAdapter = _dereq_(\"./error\");\n var assign = _dereq_(\"../../../../lib/assign\").assign;\n\n /* eslint-disable camelcase */\n var cardTypeTransforms = {\n creditCard: {\n AMERICAN_EXPRESS: \"American Express\",\n DISCOVER: \"Discover\",\n INTERNATIONAL_MAESTRO: \"Maestro\",\n JCB: \"JCB\",\n MASTERCARD: \"MasterCard\",\n SOLO: \"Solo\",\n UK_MAESTRO: \"UK Maestro\",\n UNION_PAY: \"UnionPay\",\n VISA: \"Visa\",\n ELO: \"Elo\",\n HIPER: \"Hiper\",\n HIPERCARD: \"Hipercard\"\n },\n applePayWeb: {\n VISA: \"visa\",\n MASTERCARD: \"mastercard\",\n DISCOVER: \"discover\",\n AMERICAN_EXPRESS: \"amex\",\n INTERNATIONAL_MAESTRO: \"maestro\",\n ELO: \"elo\"\n },\n visaCheckout: {\n VISA: \"Visa\",\n MASTERCARD: \"MasterCard\",\n DISCOVER: \"Discover\",\n AMERICAN_EXPRESS: \"American Express\"\n },\n googlePay: {\n VISA: \"visa\",\n MASTERCARD: \"mastercard\",\n DISCOVER: \"discover\",\n AMERICAN_EXPRESS: \"amex\",\n INTERNATIONAL_MAESTRO: \"maestro\",\n ELO: \"elo\"\n },\n masterpass: {\n VISA: \"visa\",\n MASTERCARD: \"master\",\n DISCOVER: \"discover\",\n AMERICAN_EXPRESS: \"amex\",\n DINERS: \"diners\",\n INTERNATIONAL_MAESTRO: \"maestro\",\n JCB: \"jcb\"\n }\n };\n /* eslint-enable camelcase */\n\n function configurationResponseAdapter(responseBody, ctx) {\n var adaptedResponse;\n if (responseBody.data && !responseBody.errors) {\n adaptedResponse = adaptConfigurationResponseBody(responseBody, ctx);\n } else {\n adaptedResponse = errorResponseAdapter(responseBody);\n }\n return adaptedResponse;\n }\n function adaptConfigurationResponseBody(body, ctx) {\n var configuration = body.data.clientConfiguration;\n var response;\n response = {\n environment: configuration.environment.toLowerCase(),\n clientApiUrl: configuration.clientApiUrl,\n assetsUrl: configuration.assetsUrl,\n analytics: {\n url: configuration.analyticsUrl\n },\n merchantId: configuration.merchantId,\n venmo: \"off\"\n };\n if (configuration.supportedFeatures) {\n response.graphQL = {\n url: ctx._graphQL._config.url,\n features: configuration.supportedFeatures.map(function (feature) {\n return feature.toLowerCase();\n })\n };\n }\n if (configuration.braintreeApi) {\n response.braintreeApi = configuration.braintreeApi;\n }\n if (configuration.applePayWeb) {\n response.applePayWeb = configuration.applePayWeb;\n response.applePayWeb.supportedNetworks = mapCardTypes(configuration.applePayWeb.supportedCardBrands, cardTypeTransforms.applePayWeb);\n delete response.applePayWeb.supportedCardBrands;\n }\n if (configuration.fastlane) {\n response.fastlane = configuration.fastlane;\n }\n if (configuration.ideal) {\n response.ideal = configuration.ideal;\n }\n if (configuration.kount) {\n response.kount = {\n kountMerchantId: configuration.kount.merchantId\n };\n }\n if (configuration.creditCard) {\n response.challenges = configuration.creditCard.challenges.map(function (challenge) {\n return challenge.toLowerCase();\n });\n response.creditCards = {\n supportedCardTypes: mapCardTypes(configuration.creditCard.supportedCardBrands, cardTypeTransforms.creditCard)\n };\n response.threeDSecureEnabled = configuration.creditCard.threeDSecureEnabled;\n response.threeDSecure = configuration.creditCard.threeDSecure;\n } else {\n response.challenges = [];\n response.creditCards = {\n supportedCardTypes: []\n };\n response.threeDSecureEnabled = false;\n }\n if (configuration.googlePay) {\n response.androidPay = {\n displayName: configuration.googlePay.displayName,\n enabled: true,\n environment: configuration.googlePay.environment.toLowerCase(),\n googleAuthorizationFingerprint: configuration.googlePay.googleAuthorization,\n paypalClientId: configuration.googlePay.paypalClientId,\n supportedNetworks: mapCardTypes(configuration.googlePay.supportedCardBrands, cardTypeTransforms.googlePay)\n };\n }\n if (configuration.venmo) {\n response.payWithVenmo = {\n merchantId: configuration.venmo.merchantId,\n accessToken: configuration.venmo.accessToken,\n environment: configuration.venmo.environment.toLowerCase(),\n enrichedCustomerDataEnabled: configuration.venmo.enrichedCustomerDataEnabled\n };\n }\n if (configuration.paypal) {\n response.paypalEnabled = true;\n response.paypal = assign({}, configuration.paypal);\n response.paypal.currencyIsoCode = response.paypal.currencyCode;\n response.paypal.environment = response.paypal.environment.toLowerCase();\n delete response.paypal.currencyCode;\n } else {\n response.paypalEnabled = false;\n }\n if (configuration.unionPay) {\n response.unionPay = {\n enabled: true,\n merchantAccountId: configuration.unionPay.merchantAccountId\n };\n }\n if (configuration.visaCheckout) {\n response.visaCheckout = {\n apikey: configuration.visaCheckout.apiKey,\n encryptionKey: configuration.visaCheckout.encryptionKey,\n externalClientId: configuration.visaCheckout.externalClientId,\n supportedCardTypes: mapCardTypes(configuration.visaCheckout.supportedCardBrands, cardTypeTransforms.visaCheckout)\n };\n }\n if (configuration.masterpass) {\n response.masterpass = {\n merchantCheckoutId: configuration.masterpass.merchantCheckoutId,\n supportedNetworks: mapCardTypes(configuration.masterpass.supportedCardBrands, cardTypeTransforms.masterpass)\n };\n }\n if (configuration.usBankAccount) {\n response.usBankAccount = {\n routeId: configuration.usBankAccount.routeId,\n plaid: {\n publicKey: configuration.usBankAccount.plaidPublicKey\n }\n };\n }\n return response;\n }\n function mapCardTypes(cardTypes, cardTypeTransformMap) {\n return cardTypes.reduce(function (acc, type) {\n if (cardTypeTransformMap.hasOwnProperty(type)) {\n return acc.concat(cardTypeTransformMap[type]);\n }\n return acc;\n }, []);\n }\n module.exports = configurationResponseAdapter;\n }, {\n \"../../../../lib/assign\": 140,\n \"./error\": 102\n }],\n 100: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var errorResponseAdapter = _dereq_(\"./error\");\n var CARD_BRAND_MAP = {\n /* eslint-disable camelcase */\n AMERICAN_EXPRESS: \"American Express\",\n DINERS: \"Discover\",\n DISCOVER: \"Discover\",\n ELO: \"Elo\",\n HIPER: \"Hiper\",\n HIPERCARD: \"Hipercard\",\n INTERNATIONAL_MAESTRO: \"Maestro\",\n JCB: \"JCB\",\n MASTERCARD: \"MasterCard\",\n UK_MAESTRO: \"Maestro\",\n UNION_PAY: \"UnionPay\",\n VISA: \"Visa\"\n /* eslint-enable camelcase */\n };\n var BIN_DATA_MAP = {\n YES: \"Yes\",\n NO: \"No\",\n UNKNOWN: \"Unknown\"\n };\n var AUTHENTICATION_INSIGHT_MAP = {\n PSDTWO: \"psd2\"\n };\n function creditCardTokenizationFastlaneResponseAdapter(responseBody) {\n var adaptedResponse;\n if (responseBody.data && !responseBody.errors) {\n adaptedResponse = adaptTokenizeCreditCardForFastlaneResponseBody(responseBody);\n } else {\n adaptedResponse = errorResponseAdapter(responseBody);\n }\n return adaptedResponse;\n }\n function adaptTokenizeCreditCardForFastlaneResponseBody(body) {\n var data = body.data.tokenizeCreditCardForPayPalConnect;\n var creditCard = data.paymentMethod.details;\n var lastTwo = creditCard.last4 ? creditCard.last4.substr(2, 4) : \"\";\n var binData = creditCard.binData;\n var response, regulationEnvironment;\n if (binData) {\n [\"commercial\", \"debit\", \"durbinRegulated\", \"healthcare\", \"payroll\", \"prepaid\"].forEach(function (key) {\n if (binData[key]) {\n binData[key] = BIN_DATA_MAP[binData[key]];\n } else {\n binData[key] = \"Unknown\";\n }\n });\n [\"issuingBank\", \"countryOfIssuance\", \"productId\"].forEach(function (key) {\n if (!binData[key]) {\n binData[key] = \"Unknown\";\n }\n });\n }\n response = {\n creditCards: [{\n binData: binData,\n consumed: false,\n description: lastTwo ? \"ending in \" + lastTwo : \"\",\n nonce: data.paymentMethod.id,\n details: {\n cardholderName: creditCard.cardholderName,\n expirationMonth: creditCard.expirationMonth,\n expirationYear: creditCard.expirationYear,\n bin: creditCard.bin || \"\",\n cardType: CARD_BRAND_MAP[creditCard.brandCode] || \"Unknown\",\n lastFour: creditCard.last4 || \"\",\n lastTwo: lastTwo\n },\n type: \"CreditCard\",\n threeDSecureInfo: null\n }]\n };\n if (data.authenticationInsight) {\n regulationEnvironment = data.authenticationInsight.customerAuthenticationRegulationEnvironment;\n response.creditCards[0].authenticationInsight = {\n regulationEnvironment: AUTHENTICATION_INSIGHT_MAP[regulationEnvironment] || regulationEnvironment.toLowerCase()\n };\n }\n return response;\n }\n module.exports = creditCardTokenizationFastlaneResponseAdapter;\n }, {\n \"./error\": 102\n }],\n 101: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var errorResponseAdapter = _dereq_(\"./error\");\n var CARD_BRAND_MAP = {\n /* eslint-disable camelcase */\n AMERICAN_EXPRESS: \"American Express\",\n DINERS: \"Discover\",\n DISCOVER: \"Discover\",\n ELO: \"Elo\",\n HIPER: \"Hiper\",\n HIPERCARD: \"Hipercard\",\n INTERNATIONAL_MAESTRO: \"Maestro\",\n JCB: \"JCB\",\n MASTERCARD: \"MasterCard\",\n UK_MAESTRO: \"Maestro\",\n UNION_PAY: \"UnionPay\",\n VISA: \"Visa\"\n /* eslint-enable camelcase */\n };\n var BIN_DATA_MAP = {\n YES: \"Yes\",\n NO: \"No\",\n UNKNOWN: \"Unknown\"\n };\n var AUTHENTICATION_INSIGHT_MAP = {\n PSDTWO: \"psd2\"\n };\n function creditCardTokenizationResponseAdapter(responseBody) {\n var adaptedResponse;\n if (responseBody.data && !responseBody.errors) {\n adaptedResponse = adaptTokenizeCreditCardResponseBody(responseBody);\n } else {\n adaptedResponse = errorResponseAdapter(responseBody);\n }\n return adaptedResponse;\n }\n function adaptTokenizeCreditCardResponseBody(body) {\n var data = body.data.tokenizeCreditCard;\n var creditCard = data.creditCard;\n var lastTwo = creditCard.last4 ? creditCard.last4.substr(2, 4) : \"\";\n var binData = creditCard.binData;\n var response, regulationEnvironment;\n if (binData) {\n [\"commercial\", \"debit\", \"durbinRegulated\", \"healthcare\", \"payroll\", \"prepaid\"].forEach(function (key) {\n if (binData[key]) {\n binData[key] = BIN_DATA_MAP[binData[key]];\n } else {\n binData[key] = \"Unknown\";\n }\n });\n [\"issuingBank\", \"countryOfIssuance\", \"productId\"].forEach(function (key) {\n if (!binData[key]) {\n binData[key] = \"Unknown\";\n }\n });\n }\n response = {\n creditCards: [{\n binData: binData,\n consumed: false,\n description: lastTwo ? \"ending in \" + lastTwo : \"\",\n nonce: data.token,\n details: {\n cardholderName: creditCard.cardholderName,\n expirationMonth: creditCard.expirationMonth,\n expirationYear: creditCard.expirationYear,\n bin: creditCard.bin || \"\",\n cardType: CARD_BRAND_MAP[creditCard.brandCode] || \"Unknown\",\n lastFour: creditCard.last4 || \"\",\n lastTwo: lastTwo\n },\n type: \"CreditCard\",\n threeDSecureInfo: null\n }]\n };\n if (data.authenticationInsight) {\n regulationEnvironment = data.authenticationInsight.customerAuthenticationRegulationEnvironment;\n response.creditCards[0].authenticationInsight = {\n regulationEnvironment: AUTHENTICATION_INSIGHT_MAP[regulationEnvironment] || regulationEnvironment.toLowerCase()\n };\n }\n return response;\n }\n module.exports = creditCardTokenizationResponseAdapter;\n }, {\n \"./error\": 102\n }],\n 102: [function (_dereq_, module, exports) {\n \"use strict\";\n\n function errorResponseAdapter(responseBody) {\n var response;\n var errorClass = responseBody.errors && responseBody.errors[0] && responseBody.errors[0].extensions && responseBody.errors[0].extensions.errorClass;\n if (errorClass === \"VALIDATION\") {\n response = userErrorResponseAdapter(responseBody);\n } else if (errorClass) {\n response = errorWithClassResponseAdapter(responseBody);\n } else {\n response = {\n error: {\n message: \"There was a problem serving your request\"\n },\n fieldErrors: []\n };\n }\n return response;\n }\n function errorWithClassResponseAdapter(responseBody) {\n return {\n error: {\n message: responseBody.errors[0].message\n },\n fieldErrors: []\n };\n }\n function userErrorResponseAdapter(responseBody) {\n var fieldErrors = buildFieldErrors(responseBody.errors);\n if (fieldErrors.length === 0) {\n return {\n error: {\n message: responseBody.errors[0].message\n }\n };\n }\n return {\n error: {\n message: getLegacyMessage(fieldErrors)\n },\n fieldErrors: fieldErrors\n };\n }\n function buildFieldErrors(errors) {\n var fieldErrors = [];\n errors.forEach(function (error) {\n if (!(error.extensions && error.extensions.inputPath)) {\n return;\n }\n addFieldError(error.extensions.inputPath.slice(1), error, fieldErrors);\n });\n return fieldErrors;\n }\n function addFieldError(inputPath, errorDetail, fieldErrors) {\n var fieldError;\n var legacyCode = errorDetail.extensions.legacyCode;\n var inputField = inputPath[0];\n if (inputPath.length === 1) {\n fieldErrors.push({\n code: legacyCode,\n field: inputField,\n message: errorDetail.message\n });\n return;\n }\n fieldErrors.forEach(function (candidate) {\n if (candidate.field === inputField) {\n fieldError = candidate;\n }\n });\n if (!fieldError) {\n fieldError = {\n field: inputField,\n fieldErrors: []\n };\n fieldErrors.push(fieldError);\n }\n addFieldError(inputPath.slice(1), errorDetail, fieldError.fieldErrors);\n }\n function getLegacyMessage(errors) {\n var legacyMessages = {\n creditCard: \"Credit card is invalid\"\n };\n var field = errors[0].field;\n return legacyMessages[field];\n }\n module.exports = errorResponseAdapter;\n }, {}],\n 103: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var CONFIGURATION_QUERY = \"query ClientConfiguration { \" + \" clientConfiguration { \" + \" analyticsUrl \" + \" environment \" + \" merchantId \" + \" assetsUrl \" + \" clientApiUrl \" + \" creditCard { \" + \" supportedCardBrands \" + \" challenges \" + \" threeDSecureEnabled \" + \" threeDSecure { \" + \" cardinalAuthenticationJWT \" + \" } \" + \" } \" + \" applePayWeb { \" + \" countryCode \" + \" currencyCode \" + \" merchantIdentifier \" + \" supportedCardBrands \" + \" } \" + \" fastlane { \" + \" enabled \" + \" } \" + \" googlePay { \" + \" displayName \" + \" supportedCardBrands \" + \" environment \" + \" googleAuthorization \" + \" paypalClientId \" + \" } \" + \" ideal { \" + \" routeId \" + \" assetsUrl \" + \" } \" + \" kount { \" + \" merchantId \" + \" } \" + \" masterpass { \" + \" merchantCheckoutId \" + \" supportedCardBrands \" + \" } \" + \" paypal { \" + \" displayName \" + \" clientId \" + \" assetsUrl \" + \" environment \" + \" environmentNoNetwork \" + \" unvettedMerchant \" + \" braintreeClientId \" + \" billingAgreementsEnabled \" + \" merchantAccountId \" + \" currencyCode \" + \" payeeEmail \" + \" } \" + \" unionPay { \" + \" merchantAccountId \" + \" } \" + \" usBankAccount { \" + \" routeId \" + \" plaidPublicKey \" + \" } \" + \" venmo { \" + \" merchantId \" + \" accessToken \" + \" environment \" + \" enrichedCustomerDataEnabled\" + \" } \" + \" visaCheckout { \" + \" apiKey \" + \" externalClientId \" + \" supportedCardBrands \" + \" } \" + \" braintreeApi { \" + \" accessToken \" + \" url \" + \" } \" + \" supportedFeatures \" + \" } \" + \"}\";\n function configuration() {\n return {\n query: CONFIGURATION_QUERY,\n operationName: \"ClientConfiguration\"\n };\n }\n module.exports = configuration;\n }, {}],\n 104: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var assign = _dereq_(\"../../../../lib/assign\").assign;\n function createMutation(config) {\n var hasAuthenticationInsight = config.hasAuthenticationInsight;\n var mutation = \"mutation TokenizeCreditCardForPayPalConnect($input: TokenizeCreditCardForPayPalConnectInput!\";\n if (hasAuthenticationInsight) {\n mutation += \", $authenticationInsightInput: AuthenticationInsightInput!\";\n }\n mutation += \") { \" + \" tokenizeCreditCardForPayPalConnect(input: $input) { \" + \" clientMutationId \" + \" paymentMethod { \" + \" id \" + \" details { \" + \" ... on CreditCardDetails { \" + \" bin \" + \" brandCode \" + \" last4 \" + \" cardholderName \" + \" expirationMonth\" + \" expirationYear\" + \" binData { \" + \" prepaid \" + \" healthcare \" + \" debit \" + \" durbinRegulated \" + \" commercial \" + \" payroll \" + \" issuingBank \" + \" countryOfIssuance \" + \" productId \" + \" } \" + \" } \" + \" } \" + \" }\";\n if (hasAuthenticationInsight) {\n mutation += \" authenticationInsight(input: $authenticationInsightInput) {\" + \" customerAuthenticationRegulationEnvironment\" + \" }\";\n }\n mutation += \" } }\";\n return mutation;\n }\n function createCreditCardForFastlaneTokenizationBody(body, options) {\n var creditCard = body.creditCard;\n var fastlane = creditCard.fastlane || {};\n var termsAndConditionsVersion = \"fastlane\" in creditCard && \"termsAndConditionsVersion\" in creditCard.fastlane && creditCard.fastlane.termsAndConditionsVersion;\n var email = creditCard.email;\n var optIn = \"hasBuyerConsent\" in fastlane && fastlane.hasBuyerConsent;\n var shippingAddress = creditCard.shippingAddress;\n var variables = createCreditCardTokenizationBody(body, options);\n var ccpcVariables = assign({}, variables.input, {\n email: email,\n optIn: optIn,\n phone: creditCard.phone,\n termsAndConditionsVersion: termsAndConditionsVersion\n });\n if (\"authAssertion\" in fastlane) {\n ccpcVariables.authAssertion = fastlane.authAssertion;\n }\n if (shippingAddress) {\n ccpcVariables.shippingAddress = shippingAddress;\n }\n return {\n input: ccpcVariables\n };\n }\n function createCreditCardTokenizationBody(body, options) {\n var cc = body.creditCard;\n var billingAddress = cc && cc.billingAddress;\n var expDate = cc && cc.expirationDate;\n var expirationMonth = cc && (cc.expirationMonth || expDate && expDate.split(\"/\")[0].trim());\n var expirationYear = cc && (cc.expirationYear || expDate && expDate.split(\"/\")[1].trim());\n var variables = {\n input: {\n creditCard: {\n number: cc && cc.number,\n expirationMonth: expirationMonth,\n expirationYear: expirationYear,\n cvv: cc && cc.cvv,\n cardholderName: cc && cc.cardholderName\n },\n options: {}\n }\n };\n if (options.hasAuthenticationInsight) {\n variables.authenticationInsightInput = {\n merchantAccountId: body.merchantAccountId\n };\n }\n if (billingAddress) {\n variables.input.creditCard.billingAddress = billingAddress;\n }\n variables.input = addValidationRule(body, variables.input);\n return variables;\n }\n function addValidationRule(body, input) {\n var validate;\n if (body.creditCard && body.creditCard.options && typeof body.creditCard.options.validate === \"boolean\") {\n validate = body.creditCard.options.validate;\n } else if (body.authorizationFingerprint && body.tokenizationKey || body.authorizationFingerprint) {\n validate = true;\n } else if (body.tokenizationKey) {\n validate = false;\n }\n if (typeof validate === \"boolean\") {\n input.options = assign({\n validate: validate\n }, input.options);\n }\n return input;\n }\n function creditCardForFastlaneTokenization(body) {\n var options = {\n hasAuthenticationInsight: Boolean(body.authenticationInsight && body.merchantAccountId)\n };\n return {\n query: createMutation(options),\n variables: createCreditCardForFastlaneTokenizationBody(body, options),\n operationName: \"TokenizeCreditCardForPayPalConnect\"\n };\n }\n module.exports = creditCardForFastlaneTokenization;\n }, {\n \"../../../../lib/assign\": 140\n }],\n 105: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var assign = _dereq_(\"../../../../lib/assign\").assign;\n function createMutation(config) {\n var hasAuthenticationInsight = config.hasAuthenticationInsight;\n var mutation = \"mutation TokenizeCreditCard($input: TokenizeCreditCardInput!\";\n if (hasAuthenticationInsight) {\n mutation += \", $authenticationInsightInput: AuthenticationInsightInput!\";\n }\n mutation += \") { \" + \" tokenizeCreditCard(input: $input) { \" + \" token \" + \" creditCard { \" + \" bin \" + \" brandCode \" + \" last4 \" + \" cardholderName \" + \" expirationMonth\" + \" expirationYear\" + \" binData { \" + \" prepaid \" + \" healthcare \" + \" debit \" + \" durbinRegulated \" + \" commercial \" + \" payroll \" + \" issuingBank \" + \" countryOfIssuance \" + \" productId \" + \" } \" + \" } \";\n if (hasAuthenticationInsight) {\n mutation += \" authenticationInsight(input: $authenticationInsightInput) {\" + \" customerAuthenticationRegulationEnvironment\" + \" }\";\n }\n mutation += \" } }\";\n return mutation;\n }\n function createCreditCardTokenizationBody(body, options) {\n var cc = body.creditCard;\n var billingAddress = cc && cc.billingAddress;\n var expDate = cc && cc.expirationDate;\n var expirationMonth = cc && (cc.expirationMonth || expDate && expDate.split(\"/\")[0].trim());\n var expirationYear = cc && (cc.expirationYear || expDate && expDate.split(\"/\")[1].trim());\n var variables = {\n input: {\n creditCard: {\n number: cc && cc.number,\n expirationMonth: expirationMonth,\n expirationYear: expirationYear,\n cvv: cc && cc.cvv,\n cardholderName: cc && cc.cardholderName\n },\n options: {}\n }\n };\n if (options.hasAuthenticationInsight) {\n variables.authenticationInsightInput = {\n merchantAccountId: body.merchantAccountId\n };\n }\n if (billingAddress) {\n variables.input.creditCard.billingAddress = billingAddress;\n }\n variables.input = addValidationRule(body, variables.input);\n return variables;\n }\n function addValidationRule(body, input) {\n var validate;\n if (body.creditCard && body.creditCard.options && typeof body.creditCard.options.validate === \"boolean\") {\n validate = body.creditCard.options.validate;\n } else if (body.authorizationFingerprint && body.tokenizationKey || body.authorizationFingerprint) {\n validate = true;\n } else if (body.tokenizationKey) {\n validate = false;\n }\n if (typeof validate === \"boolean\") {\n input.options = assign({\n validate: validate\n }, input.options);\n }\n return input;\n }\n function creditCardTokenization(body) {\n var options = {\n hasAuthenticationInsight: Boolean(body.authenticationInsight && body.merchantAccountId)\n };\n return {\n query: createMutation(options),\n variables: createCreditCardTokenizationBody(body, options),\n operationName: \"TokenizeCreditCard\"\n };\n }\n module.exports = creditCardTokenization;\n }, {\n \"../../../../lib/assign\": 140\n }],\n 106: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var features = {\n tokenize_credit_cards: \"payment_methods/credit_cards\",\n // eslint-disable-line camelcase\n configuration: \"configuration\"\n };\n var disallowedInputPaths = [\"creditCard.options.unionPayEnrollment\"];\n function GraphQL(config) {\n this._config = config.graphQL;\n }\n GraphQL.prototype.getGraphQLEndpoint = function () {\n return this._config.url;\n };\n GraphQL.prototype.isGraphQLRequest = function (url, body) {\n var featureEnabled;\n var path = this.getClientApiPath(url);\n if (!this._isGraphQLEnabled() || !path) {\n return false;\n }\n featureEnabled = this._config.features.some(function (feature) {\n return features[feature] === path;\n });\n if (containsDisallowedlistedKeys(body)) {\n return false;\n }\n return featureEnabled;\n };\n GraphQL.prototype.getClientApiPath = function (url) {\n var path;\n var clientApiPrefix = \"/client_api/v1/\";\n var pathParts = url.split(clientApiPrefix);\n if (pathParts.length > 1) {\n path = pathParts[1].split(\"?\")[0];\n }\n return path;\n };\n GraphQL.prototype._isGraphQLEnabled = function () {\n return Boolean(this._config);\n };\n function containsDisallowedlistedKeys(body) {\n return disallowedInputPaths.some(function (keys) {\n var value = keys.split(\".\").reduce(function (accumulator, key) {\n return accumulator && accumulator[key];\n }, body);\n return value !== undefined; // eslint-disable-line no-undefined\n });\n }\n module.exports = GraphQL;\n }, {}],\n 107: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var BRAINTREE_VERSION = _dereq_(\"../../constants\").BRAINTREE_VERSION;\n var assign = _dereq_(\"../../../lib/assign\").assign;\n var snakeCaseToCamelCase = _dereq_(\"../../../lib/snake-case-to-camel-case\");\n var isFastlaneCheckout = _dereq_(\"../../../lib/is-fastlane-checkout\");\n var creditCardTokenizationBodyGenerator = _dereq_(\"./generators/credit-card-tokenization\");\n var creditCardTokenizationResponseAdapter = _dereq_(\"./adapters/credit-card-tokenization\");\n var creditCardTokenizationFastlaneResponseAdapter = _dereq_(\"./adapters/credit-card-tokenization-fastlane\");\n var creditCardForFastlaneTokenizationBodyGenerator = _dereq_(\"./generators/credit-card-for-fastlane-tokenization\");\n var configurationBodyGenerator = _dereq_(\"./generators/configuration\");\n var configurationResponseAdapter = _dereq_(\"./adapters/configuration\");\n var generators = {\n \"payment_methods/credit_cards\": function (data, isFastlane) {\n if (isFastlane) {\n // Only want to use this generator when using the Fastlane flow\n return creditCardForFastlaneTokenizationBodyGenerator(data);\n }\n return creditCardTokenizationBodyGenerator(data);\n },\n configuration: configurationBodyGenerator\n };\n var adapters = {\n \"payment_methods/credit_cards\": function (parsedBody, context, isFastlane) {\n if (isFastlane) {\n // Only want to use this adapter when using the Fastlane flow\n return creditCardTokenizationFastlaneResponseAdapter(parsedBody, context);\n }\n return creditCardTokenizationResponseAdapter(parsedBody, context);\n },\n configuration: configurationResponseAdapter\n };\n function GraphQLRequest(options) {\n var clientApiPath = options.graphQL.getClientApiPath(options.url);\n this._graphQL = options.graphQL;\n this._data = options.data;\n this._method = options.method;\n this._headers = options.headers;\n this._clientSdkMetadata = {\n source: options.metadata.source,\n integration: options.metadata.integration,\n sessionId: options.metadata.sessionId\n };\n this._sendAnalyticsEvent = options.sendAnalyticsEvent || Function.prototype;\n this._generator = generators[clientApiPath];\n this._adapter = adapters[clientApiPath];\n this._sendAnalyticsEvent(\"graphql.init\");\n }\n GraphQLRequest.prototype.getUrl = function () {\n return this._graphQL.getGraphQLEndpoint();\n };\n GraphQLRequest.prototype.getBody = function () {\n var formattedBody = formatBodyKeys(this._data);\n var generatedBody = this._generator(formattedBody,\n // Since this is used for all GQL requests, we only want this if it's a Fastlane Tokenization request\n isFastlaneCheckout(this._data.creditCard));\n var body = assign({\n clientSdkMetadata: this._clientSdkMetadata\n }, generatedBody);\n return JSON.stringify(body);\n };\n GraphQLRequest.prototype.getMethod = function () {\n return \"POST\";\n };\n GraphQLRequest.prototype.getHeaders = function () {\n var authorization, headers;\n if (this._data.authorizationFingerprint) {\n this._sendAnalyticsEvent(\"graphql.authorization-fingerprint\");\n authorization = this._data.authorizationFingerprint;\n } else {\n this._sendAnalyticsEvent(\"graphql.tokenization-key\");\n authorization = this._data.tokenizationKey;\n }\n headers = {\n Authorization: \"Bearer \" + authorization,\n \"Braintree-Version\": BRAINTREE_VERSION\n };\n return assign({}, this._headers, headers);\n };\n GraphQLRequest.prototype.adaptResponseBody = function (parsedBody) {\n return this._adapter(parsedBody, this,\n // Since this is used for all GQL requests, we only want this if it's a Fastlane Checkout Tokenization request\n \"creditCard\" in this._data && isFastlaneCheckout(this._data.creditCard));\n };\n GraphQLRequest.prototype.determineStatus = function (httpStatus, parsedResponse) {\n var status, errorClass;\n if (httpStatus === 200) {\n errorClass = parsedResponse.errors && parsedResponse.errors[0] && parsedResponse.errors[0].extensions && parsedResponse.errors[0].extensions.errorClass;\n if (parsedResponse.data && !parsedResponse.errors) {\n status = 200;\n } else if (errorClass === \"VALIDATION\") {\n status = 422;\n } else if (errorClass === \"AUTHORIZATION\") {\n status = 403;\n } else if (errorClass === \"AUTHENTICATION\") {\n status = 401;\n } else if (isGraphQLError(errorClass, parsedResponse)) {\n status = 403;\n } else {\n status = 500;\n }\n } else if (!httpStatus) {\n status = 500;\n } else {\n status = httpStatus;\n }\n this._sendAnalyticsEvent(\"graphql.status.\" + httpStatus);\n this._sendAnalyticsEvent(\"graphql.determinedStatus.\" + status);\n return status;\n };\n function isGraphQLError(errorClass, parsedResponse) {\n return !errorClass && parsedResponse.errors[0].message;\n }\n\n /**\n * @ignore\n * This function formats the body consistently so _everything_ is camelCase.\n * @param {object} originalBody the body to format\n * @returns {object} The formatted object\n */\n function formatBodyKeys(originalBody) {\n var body = {};\n Object.keys(originalBody).forEach(function (key) {\n var camelCaseKey = snakeCaseToCamelCase(key);\n if (typeof originalBody[key] === \"object\") {\n body[camelCaseKey] = formatBodyKeys(originalBody[key]);\n } else if (typeof originalBody[key] === \"number\") {\n body[camelCaseKey] = String(originalBody[key]);\n } else {\n body[camelCaseKey] = originalBody[key];\n }\n });\n return body;\n }\n module.exports = GraphQLRequest;\n }, {\n \"../../../lib/assign\": 140,\n \"../../../lib/is-fastlane-checkout\": 171,\n \"../../../lib/snake-case-to-camel-case\": 179,\n \"../../constants\": 93,\n \"./adapters/configuration\": 99,\n \"./adapters/credit-card-tokenization\": 101,\n \"./adapters/credit-card-tokenization-fastlane\": 100,\n \"./generators/configuration\": 103,\n \"./generators/credit-card-for-fastlane-tokenization\": 104,\n \"./generators/credit-card-tokenization\": 105\n }],\n 108: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var once = _dereq_(\"../../lib/once\");\n var AJAXDriver = _dereq_(\"./ajax-driver\");\n module.exports = function (options, cb) {\n cb = once(cb || Function.prototype);\n options.method = (options.method || \"GET\").toUpperCase();\n options.timeout = options.timeout == null ? 60000 : options.timeout;\n options.data = options.data || {};\n AJAXDriver.request(options, cb);\n };\n }, {\n \"../../lib/once\": 176,\n \"./ajax-driver\": 97\n }],\n 109: [function (_dereq_, module, exports) {\n \"use strict\";\n\n module.exports = function (body) {\n try {\n body = JSON.parse(body);\n } catch (e) {\n /* ignored */\n }\n return body;\n };\n }, {}],\n 110: [function (_dereq_, module, exports) {\n \"use strict\";\n\n module.exports = function (method, body) {\n if (typeof method !== \"string\") {\n throw new Error(\"Method must be a string\");\n }\n if (method.toLowerCase() !== \"get\" && body != null) {\n body = typeof body === \"string\" ? body : JSON.stringify(body);\n }\n return body;\n };\n }, {}],\n 111: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var isXHRAvailable = typeof window !== \"undefined\" && window.XMLHttpRequest && \"withCredentials\" in new window.XMLHttpRequest();\n function getRequestObject() {\n return isXHRAvailable ? new window.XMLHttpRequest() : new window.XDomainRequest();\n }\n module.exports = {\n isAvailable: isXHRAvailable,\n getRequestObject: getRequestObject\n };\n }, {}],\n 112: [function (_dereq_, module, exports) {\n \"use strict\";\n\n /**\n * @name BraintreeError.Data Collector - Creation Error Codes\n * @description Errors that occur when [creating the Data Collector component](./module-braintree-web_data-collector.html#.create).\n * @property {MERCHANT} DATA_COLLECTOR_KOUNT_NOT_ENABLED Occurs when Kount is enabled in creation options but is not enabled on the Braintree control panel.\n * @property {MERCHANT} DATA_COLLECTOR_KOUNT_ERROR Occurs when Kount errors while setting up.\n * @property {MERCHANT} DATA_COLLECTOR_REQUIRES_CREATE_OPTIONS Occurs when Kount or PayPal Fraudnet could not be enabled.\n */\n var BraintreeError = _dereq_(\"../lib/braintree-error\");\n module.exports = {\n DATA_COLLECTOR_KOUNT_NOT_ENABLED: {\n type: BraintreeError.types.MERCHANT,\n code: \"DATA_COLLECTOR_KOUNT_NOT_ENABLED\",\n message: \"Kount is not enabled for this merchant.\"\n },\n DATA_COLLECTOR_KOUNT_ERROR: {\n type: BraintreeError.types.MERCHANT,\n code: \"DATA_COLLECTOR_KOUNT_ERROR\"\n },\n DATA_COLLECTOR_REQUIRES_CREATE_OPTIONS: {\n type: BraintreeError.types.MERCHANT,\n code: \"DATA_COLLECTOR_REQUIRES_CREATE_OPTIONS\",\n message: \"Data Collector must be created with Kount and/or PayPal.\"\n }\n };\n }, {\n \"../lib/braintree-error\": 143\n }],\n 113: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var FRAUDNET_FNCLS = _dereq_(\"../lib/constants\").FRAUDNET_FNCLS;\n var FRAUDNET_SOURCE = _dereq_(\"../lib/constants\").FRAUDNET_SOURCE;\n var FRAUDNET_URL = _dereq_(\"../lib/constants\").FRAUDNET_URL;\n var loadScript = _dereq_(\"../lib/assets\").loadScript;\n var TRUNCATION_LENGTH = 32;\n var cachedSessionId;\n function setup(options) {\n var fraudNet = new Fraudnet();\n options = options || {};\n if (!options.sessionId && cachedSessionId) {\n fraudNet.sessionId = cachedSessionId;\n return Promise.resolve(fraudNet);\n }\n return fraudNet.initialize(options);\n }\n function clearSessionIdCache() {\n cachedSessionId = null;\n }\n function Fraudnet() {}\n Fraudnet.prototype.initialize = function (options) {\n var environment = options.environment;\n var self = this;\n this.sessionId = options.sessionId || options.clientSessionId;\n if (this.sessionId) {\n this.sessionId = this.sessionId.substring(0, TRUNCATION_LENGTH);\n }\n if (!options.sessionId) {\n cachedSessionId = this.sessionId;\n }\n this._beaconId = _generateBeaconId(this.sessionId);\n this._parameterBlock = _createParameterBlock(this.sessionId, this._beaconId, environment);\n return loadScript({\n src: FRAUDNET_URL\n }).then(function (block) {\n self._thirdPartyBlock = block;\n return self;\n }).catch(function () {\n // if the fraudnet script fails to load\n // we just resolve with nothing\n // and data collector ignores it\n return null;\n });\n };\n Fraudnet.prototype.teardown = function () {\n removeElementIfOnPage(document.querySelector('iframe[title=\"ppfniframe\"]'));\n removeElementIfOnPage(document.querySelector('iframe[title=\"pbf\"]'));\n removeElementIfOnPage(this._parameterBlock);\n removeElementIfOnPage(this._thirdPartyBlock);\n };\n function removeElementIfOnPage(element) {\n if (element && element.parentNode) {\n element.parentNode.removeChild(element);\n }\n }\n function _generateBeaconId(sessionId) {\n var timestamp = new Date().getTime() / 1000;\n return \"https://b.stats.paypal.com/counter.cgi\" + \"?i=127.0.0.1\" + \"&p=\" + sessionId + \"&t=\" + timestamp + \"&a=14\";\n }\n function _createParameterBlock(sessionId, beaconId, environment) {\n var el = document.body.appendChild(document.createElement(\"script\"));\n var config = {\n f: sessionId,\n s: FRAUDNET_SOURCE,\n b: beaconId\n };\n\n // for some reason, the presence of the sandbox\n // attribute in a production environment causes\n // some weird behavior with what url paths are\n // hit, so instead, we only apply this attribute\n // when it is not a production environment\n if (environment !== \"production\") {\n config.sandbox = true;\n }\n el.type = \"application/json\";\n el.setAttribute(\"fncls\", FRAUDNET_FNCLS);\n el.text = JSON.stringify(config);\n return el;\n }\n module.exports = {\n setup: setup,\n clearSessionIdCache: clearSessionIdCache\n };\n }, {\n \"../lib/assets\": 139,\n \"../lib/constants\": 145\n }],\n 114: [function (_dereq_, module, exports) {\n \"use strict\";\n\n /** @module braintree-web/data-collector */\n var kount = _dereq_(\"./kount\");\n var fraudnet = _dereq_(\"./fraudnet\");\n var BraintreeError = _dereq_(\"../lib/braintree-error\");\n var basicComponentVerification = _dereq_(\"../lib/basic-component-verification\");\n var createDeferredClient = _dereq_(\"../lib/create-deferred-client\");\n var createAssetsUrl = _dereq_(\"../lib/create-assets-url\");\n var methods = _dereq_(\"../lib/methods\");\n var convertMethodsToError = _dereq_(\"../lib/convert-methods-to-error\");\n var VERSION = \"3.112.0\";\n var wrapPromise = _dereq_(\"@braintree/wrap-promise\");\n var errors = _dereq_(\"./errors\");\n\n /**\n * @class\n * @global\n * @name DataCollector\n * @description Do not use this constructor directly. Use {@link module:braintree-web/data-collector.create|braintree-web.data-collector.create} instead.\n * @classdesc This class is used for fraud integration with PayPal and Kount. Instances of this class have {@link DataCollector#deviceData|deviceData} which is used to correlate user sessions with server transactions.\n */\n\n /**\n * @memberof DataCollector\n * @name deviceData\n * @type string\n * @description JSON string to pass with server transactions.\n * @instance\n */\n\n /**\n * @memberof DataCollector\n * @name rawDeviceData\n * @type object\n * @description The device data as an object instead of a string.\n * @instance\n */\n\n /**\n * @memberof DataCollector\n * @name teardown\n * @function\n * @description Cleanly remove anything set up by {@link module:braintree-web/data-collector.create|create}.\n * @param {callback} [callback] Called on completion. If no callback is provided, `teardown` returns a promise.\n * @instance\n * @example\n * dataCollectorInstance.teardown();\n * @example ';\n }, 10);\n return iframe;\n };\n Kount.prototype._initializeEnvironment = function (options) {\n var url = environmentUrls[options.environment];\n if (url == null) {\n throw new Error(options.environment + \" is not a valid environment for kount.environment\");\n }\n return {\n url: url,\n name: options.environment,\n id: options.merchantId\n };\n };\n module.exports = {\n setup: setup,\n Kount: Kount,\n environmentUrls: environmentUrls\n };\n }, {\n \"../lib/camel-case-to-snake-case\": 144,\n \"./vendor/sjcl\": 116\n }],\n 116: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var sjcl = {\n cipher: {},\n hash: {},\n keyexchange: {},\n mode: {},\n misc: {},\n codec: {},\n exception: {\n corrupt: function (a) {\n this.toString = function () {\n return \"CORRUPT: \" + this.message;\n };\n this.message = a;\n },\n invalid: function (a) {\n this.toString = function () {\n return \"INVALID: \" + this.message;\n };\n this.message = a;\n },\n bug: function (a) {\n this.toString = function () {\n return \"BUG: \" + this.message;\n };\n this.message = a;\n },\n notReady: function (a) {\n this.toString = function () {\n return \"NOT READY: \" + this.message;\n };\n this.message = a;\n }\n }\n };\n sjcl.cipher.aes = function (a) {\n this.l[0][0][0] || this.G();\n var b,\n c,\n d,\n e,\n f = this.l[0][4],\n g = this.l[1];\n b = a.length;\n var k = 1;\n if (4 !== b && 6 !== b && 8 !== b) throw new sjcl.exception.invalid(\"invalid aes key size\");\n this.b = [d = a.slice(0), e = []];\n for (a = b; a < 4 * b + 28; a++) {\n c = d[a - 1];\n if (0 === a % b || 8 === b && 4 === a % b) c = f[c >>> 24] << 24 ^ f[c >> 16 & 255] << 16 ^ f[c >> 8 & 255] << 8 ^ f[c & 255], 0 === a % b && (c = c << 8 ^ c >>> 24 ^ k << 24, k = k << 1 ^ 283 * (k >> 7));\n d[a] = d[a - b] ^ c;\n }\n for (b = 0; a; b++, a--) c = d[b & 3 ? a : a - 4], e[b] = 4 >= a || 4 > b ? c : g[0][f[c >>> 24]] ^ g[1][f[c >> 16 & 255]] ^ g[2][f[c >> 8 & 255]] ^ g[3][f[c & 255]];\n };\n sjcl.cipher.aes.prototype = {\n encrypt: function (a) {\n return t(this, a, 0);\n },\n decrypt: function (a) {\n return t(this, a, 1);\n },\n l: [[[], [], [], [], []], [[], [], [], [], []]],\n G: function () {\n var a = this.l[0],\n b = this.l[1],\n c = a[4],\n d = b[4],\n e,\n f,\n g,\n k = [],\n l = [],\n p,\n n,\n h,\n m;\n for (e = 0; 0x100 > e; e++) l[(k[e] = e << 1 ^ 283 * (e >> 7)) ^ e] = e;\n for (f = g = 0; !c[f]; f ^= p || 1, g = l[g] || 1) for (h = g ^ g << 1 ^ g << 2 ^ g << 3 ^ g << 4, h = h >> 8 ^ h & 255 ^ 99, c[f] = h, d[h] = f, n = k[e = k[p = k[f]]], m = 0x1010101 * n ^ 0x10001 * e ^ 0x101 * p ^ 0x1010100 * f, n = 0x101 * k[h] ^ 0x1010100 * h, e = 0; 4 > e; e++) a[e][f] = n = n << 24 ^ n >>> 8, b[e][h] = m = m << 24 ^ m >>> 8;\n for (e = 0; 5 > e; e++) a[e] = a[e].slice(0), b[e] = b[e].slice(0);\n }\n };\n function t(a, b, c) {\n if (4 !== b.length) throw new sjcl.exception.invalid(\"invalid aes block size\");\n var d = a.b[c],\n e = b[0] ^ d[0],\n f = b[c ? 3 : 1] ^ d[1],\n g = b[2] ^ d[2];\n b = b[c ? 1 : 3] ^ d[3];\n var k,\n l,\n p,\n n = d.length / 4 - 2,\n h,\n m = 4,\n q = [0, 0, 0, 0];\n k = a.l[c];\n a = k[0];\n var r = k[1],\n v = k[2],\n w = k[3],\n x = k[4];\n for (h = 0; h < n; h++) k = a[e >>> 24] ^ r[f >> 16 & 255] ^ v[g >> 8 & 255] ^ w[b & 255] ^ d[m], l = a[f >>> 24] ^ r[g >> 16 & 255] ^ v[b >> 8 & 255] ^ w[e & 255] ^ d[m + 1], p = a[g >>> 24] ^ r[b >> 16 & 255] ^ v[e >> 8 & 255] ^ w[f & 255] ^ d[m + 2], b = a[b >>> 24] ^ r[e >> 16 & 255] ^ v[f >> 8 & 255] ^ w[g & 255] ^ d[m + 3], m += 4, e = k, f = l, g = p;\n for (h = 0; 4 > h; h++) q[c ? 3 & -h : h] = x[e >>> 24] << 24 ^ x[f >> 16 & 255] << 16 ^ x[g >> 8 & 255] << 8 ^ x[b & 255] ^ d[m++], k = e, e = f, f = g, g = b, b = k;\n return q;\n }\n sjcl.bitArray = {\n bitSlice: function (a, b, c) {\n a = sjcl.bitArray.M(a.slice(b / 32), 32 - (b & 31)).slice(1);\n return void 0 === c ? a : sjcl.bitArray.clamp(a, c - b);\n },\n extract: function (a, b, c) {\n var d = Math.floor(-b - c & 31);\n return ((b + c - 1 ^ b) & -32 ? a[b / 32 | 0] << 32 - d ^ a[b / 32 + 1 | 0] >>> d : a[b / 32 | 0] >>> d) & (1 << c) - 1;\n },\n concat: function (a, b) {\n if (0 === a.length || 0 === b.length) return a.concat(b);\n var c = a[a.length - 1],\n d = sjcl.bitArray.getPartial(c);\n return 32 === d ? a.concat(b) : sjcl.bitArray.M(b, d, c | 0, a.slice(0, a.length - 1));\n },\n bitLength: function (a) {\n var b = a.length;\n return 0 === b ? 0 : 32 * (b - 1) + sjcl.bitArray.getPartial(a[b - 1]);\n },\n clamp: function (a, b) {\n if (32 * a.length < b) return a;\n a = a.slice(0, Math.ceil(b / 32));\n var c = a.length;\n b = b & 31;\n 0 < c && b && (a[c - 1] = sjcl.bitArray.partial(b, a[c - 1] & 2147483648 >> b - 1, 1));\n return a;\n },\n partial: function (a, b, c) {\n return 32 === a ? b : (c ? b | 0 : b << 32 - a) + 0x10000000000 * a;\n },\n getPartial: function (a) {\n return Math.round(a / 0x10000000000) || 32;\n },\n equal: function (a, b) {\n if (sjcl.bitArray.bitLength(a) !== sjcl.bitArray.bitLength(b)) return !1;\n var c = 0,\n d;\n for (d = 0; d < a.length; d++) c |= a[d] ^ b[d];\n return 0 === c;\n },\n M: function (a, b, c, d) {\n var e;\n e = 0;\n for (void 0 === d && (d = []); 32 <= b; b -= 32) d.push(c), c = 0;\n if (0 === b) return d.concat(a);\n for (e = 0; e < a.length; e++) d.push(c | a[e] >>> b), c = a[e] << 32 - b;\n e = a.length ? a[a.length - 1] : 0;\n a = sjcl.bitArray.getPartial(e);\n d.push(sjcl.bitArray.partial(b + a & 31, 32 < b + a ? c : d.pop(), 1));\n return d;\n },\n Y: function (a, b) {\n return [a[0] ^ b[0], a[1] ^ b[1], a[2] ^ b[2], a[3] ^ b[3]];\n },\n byteswapM: function (a) {\n var b, c;\n for (b = 0; b < a.length; ++b) c = a[b], a[b] = c >>> 24 | c >>> 8 & 0xff00 | (c & 0xff00) << 8 | c << 24;\n return a;\n }\n };\n sjcl.codec.utf8String = {\n fromBits: function (a) {\n var b = \"\",\n c = sjcl.bitArray.bitLength(a),\n d,\n e;\n for (d = 0; d < c / 8; d++) 0 === (d & 3) && (e = a[d / 4]), b += String.fromCharCode(e >>> 8 >>> 8 >>> 8), e <<= 8;\n return decodeURIComponent(escape(b));\n },\n toBits: function (a) {\n a = unescape(encodeURIComponent(a));\n var b = [],\n c,\n d = 0;\n for (c = 0; c < a.length; c++) d = d << 8 | a.charCodeAt(c), 3 === (c & 3) && (b.push(d), d = 0);\n c & 3 && b.push(sjcl.bitArray.partial(8 * (c & 3), d));\n return b;\n }\n };\n sjcl.codec.hex = {\n fromBits: function (a) {\n var b = \"\",\n c;\n for (c = 0; c < a.length; c++) b += ((a[c] | 0) + 0xf00000000000).toString(16).substr(4);\n return b.substr(0, sjcl.bitArray.bitLength(a) / 4);\n },\n toBits: function (a) {\n var b,\n c = [],\n d;\n a = a.replace(/\\s|0x/g, \"\");\n d = a.length;\n a = a + \"00000000\";\n for (b = 0; b < a.length; b += 8) c.push(parseInt(a.substr(b, 8), 16) ^ 0);\n return sjcl.bitArray.clamp(c, 4 * d);\n }\n };\n sjcl.hash.sha256 = function (a) {\n this.b[0] || this.G();\n a ? (this.u = a.u.slice(0), this.o = a.o.slice(0), this.h = a.h) : this.reset();\n };\n sjcl.hash.sha256.hash = function (a) {\n return new sjcl.hash.sha256().update(a).finalize();\n };\n sjcl.hash.sha256.prototype = {\n blockSize: 512,\n reset: function () {\n this.u = this.K.slice(0);\n this.o = [];\n this.h = 0;\n return this;\n },\n update: function (a) {\n \"string\" === typeof a && (a = sjcl.codec.utf8String.toBits(a));\n var b,\n c = this.o = sjcl.bitArray.concat(this.o, a);\n b = this.h;\n a = this.h = b + sjcl.bitArray.bitLength(a);\n if (0x1fffffffffffff < a) throw new sjcl.exception.invalid(\"Cannot hash more than 2^53 - 1 bits\");\n if (\"undefined\" !== typeof Uint32Array) {\n var d = new Uint32Array(c),\n e = 0;\n for (b = 512 + b - (512 + b & 0x1ff); b <= a; b += 512) u(this, d.subarray(16 * e, 16 * (e + 1))), e += 1;\n c.splice(0, 16 * e);\n } else for (b = 512 + b - (512 + b & 0x1ff); b <= a; b += 512) u(this, c.splice(0, 16));\n return this;\n },\n finalize: function () {\n var a,\n b = this.o,\n c = this.u,\n b = sjcl.bitArray.concat(b, [sjcl.bitArray.partial(1, 1)]);\n for (a = b.length + 2; a & 15; a++) b.push(0);\n b.push(Math.floor(this.h / 0x100000000));\n for (b.push(this.h | 0); b.length;) u(this, b.splice(0, 16));\n this.reset();\n return c;\n },\n K: [],\n b: [],\n G: function () {\n function a(a) {\n return 0x100000000 * (a - Math.floor(a)) | 0;\n }\n for (var b = 0, c = 2, d, e; 64 > b; c++) {\n e = !0;\n for (d = 2; d * d <= c; d++) if (0 === c % d) {\n e = !1;\n break;\n }\n e && (8 > b && (this.K[b] = a(Math.pow(c, 0.5))), this.b[b] = a(Math.pow(c, 1 / 3)), b++);\n }\n }\n };\n function u(a, b) {\n var c,\n d,\n e,\n f = a.u,\n g = a.b,\n k = f[0],\n l = f[1],\n p = f[2],\n n = f[3],\n h = f[4],\n m = f[5],\n q = f[6],\n r = f[7];\n for (c = 0; 64 > c; c++) 16 > c ? d = b[c] : (d = b[c + 1 & 15], e = b[c + 14 & 15], d = b[c & 15] = (d >>> 7 ^ d >>> 18 ^ d >>> 3 ^ d << 25 ^ d << 14) + (e >>> 17 ^ e >>> 19 ^ e >>> 10 ^ e << 15 ^ e << 13) + b[c & 15] + b[c + 9 & 15] | 0), d = d + r + (h >>> 6 ^ h >>> 11 ^ h >>> 25 ^ h << 26 ^ h << 21 ^ h << 7) + (q ^ h & (m ^ q)) + g[c], r = q, q = m, m = h, h = n + d | 0, n = p, p = l, l = k, k = d + (l & p ^ n & (l ^ p)) + (l >>> 2 ^ l >>> 13 ^ l >>> 22 ^ l << 30 ^ l << 19 ^ l << 10) | 0;\n f[0] = f[0] + k | 0;\n f[1] = f[1] + l | 0;\n f[2] = f[2] + p | 0;\n f[3] = f[3] + n | 0;\n f[4] = f[4] + h | 0;\n f[5] = f[5] + m | 0;\n f[6] = f[6] + q | 0;\n f[7] = f[7] + r | 0;\n }\n sjcl.prng = function (a) {\n this.c = [new sjcl.hash.sha256()];\n this.i = [0];\n this.H = 0;\n this.v = {};\n this.F = 0;\n this.J = {};\n this.L = this.f = this.j = this.T = 0;\n this.b = [0, 0, 0, 0, 0, 0, 0, 0];\n this.g = [0, 0, 0, 0];\n this.C = void 0;\n this.D = a;\n this.s = !1;\n this.B = {\n progress: {},\n seeded: {}\n };\n this.m = this.S = 0;\n this.w = 1;\n this.A = 2;\n this.O = 0x10000;\n this.I = [0, 48, 64, 96, 128, 192, 0x100, 384, 512, 768, 1024];\n this.P = 3e4;\n this.N = 80;\n };\n sjcl.prng.prototype = {\n randomWords: function (a, b) {\n var c = [],\n d;\n d = this.isReady(b);\n var e;\n if (d === this.m) throw new sjcl.exception.notReady(\"generator isn't seeded\");\n if (d & this.A) {\n d = !(d & this.w);\n e = [];\n var f = 0,\n g;\n this.L = e[0] = new Date().valueOf() + this.P;\n for (g = 0; 16 > g; g++) e.push(0x100000000 * Math.random() | 0);\n for (g = 0; g < this.c.length && (e = e.concat(this.c[g].finalize()), f += this.i[g], this.i[g] = 0, d || !(this.H & 1 << g)); g++);\n this.H >= 1 << this.c.length && (this.c.push(new sjcl.hash.sha256()), this.i.push(0));\n this.f -= f;\n f > this.j && (this.j = f);\n this.H++;\n this.b = sjcl.hash.sha256.hash(this.b.concat(e));\n this.C = new sjcl.cipher.aes(this.b);\n for (d = 0; 4 > d && (this.g[d] = this.g[d] + 1 | 0, !this.g[d]); d++);\n }\n for (d = 0; d < a; d += 4) 0 === (d + 1) % this.O && y(this), e = z(this), c.push(e[0], e[1], e[2], e[3]);\n y(this);\n return c.slice(0, a);\n },\n setDefaultParanoia: function (a, b) {\n if (0 === a && \"Setting paranoia=0 will ruin your security; use it only for testing\" !== b) throw new sjcl.exception.invalid(\"Setting paranoia=0 will ruin your security; use it only for testing\");\n this.D = a;\n },\n addEntropy: function (a, b, c) {\n c = c || \"user\";\n var d,\n e,\n f = new Date().valueOf(),\n g = this.v[c],\n k = this.isReady(),\n l = 0;\n d = this.J[c];\n void 0 === d && (d = this.J[c] = this.T++);\n void 0 === g && (g = this.v[c] = 0);\n this.v[c] = (this.v[c] + 1) % this.c.length;\n switch (typeof a) {\n case \"number\":\n void 0 === b && (b = 1);\n this.c[g].update([d, this.F++, 1, b, f, 1, a | 0]);\n break;\n case \"object\":\n c = Object.prototype.toString.call(a);\n if (\"[object Uint32Array]\" === c) {\n e = [];\n for (c = 0; c < a.length; c++) e.push(a[c]);\n a = e;\n } else for (\"[object Array]\" !== c && (l = 1), c = 0; c < a.length && !l; c++) \"number\" !== typeof a[c] && (l = 1);\n if (!l) {\n if (void 0 === b) for (c = b = 0; c < a.length; c++) for (e = a[c]; 0 < e;) b++, e = e >>> 1;\n this.c[g].update([d, this.F++, 2, b, f, a.length].concat(a));\n }\n break;\n case \"string\":\n void 0 === b && (b = a.length);\n this.c[g].update([d, this.F++, 3, b, f, a.length]);\n this.c[g].update(a);\n break;\n default:\n l = 1;\n }\n if (l) throw new sjcl.exception.bug(\"random: addEntropy only supports number, array of numbers or string\");\n this.i[g] += b;\n this.f += b;\n k === this.m && (this.isReady() !== this.m && A(\"seeded\", Math.max(this.j, this.f)), A(\"progress\", this.getProgress()));\n },\n isReady: function (a) {\n a = this.I[void 0 !== a ? a : this.D];\n return this.j && this.j >= a ? this.i[0] > this.N && new Date().valueOf() > this.L ? this.A | this.w : this.w : this.f >= a ? this.A | this.m : this.m;\n },\n getProgress: function (a) {\n a = this.I[a ? a : this.D];\n return this.j >= a ? 1 : this.f > a ? 1 : this.f / a;\n },\n startCollectors: function () {\n if (!this.s) {\n this.a = {\n loadTimeCollector: B(this, this.V),\n mouseCollector: B(this, this.W),\n keyboardCollector: B(this, this.U),\n accelerometerCollector: B(this, this.R),\n touchCollector: B(this, this.X)\n };\n if (window.addEventListener) window.addEventListener(\"load\", this.a.loadTimeCollector, !1), window.addEventListener(\"mousemove\", this.a.mouseCollector, !1), window.addEventListener(\"keypress\", this.a.keyboardCollector, !1), window.addEventListener(\"devicemotion\", this.a.accelerometerCollector, !1), window.addEventListener(\"touchmove\", this.a.touchCollector, !1);else if (document.attachEvent) document.attachEvent(\"onload\", this.a.loadTimeCollector), document.attachEvent(\"onmousemove\", this.a.mouseCollector), document.attachEvent(\"keypress\", this.a.keyboardCollector);else throw new sjcl.exception.bug(\"can't attach event\");\n this.s = !0;\n }\n },\n stopCollectors: function () {\n this.s && (window.removeEventListener ? (window.removeEventListener(\"load\", this.a.loadTimeCollector, !1), window.removeEventListener(\"mousemove\", this.a.mouseCollector, !1), window.removeEventListener(\"keypress\", this.a.keyboardCollector, !1), window.removeEventListener(\"devicemotion\", this.a.accelerometerCollector, !1), window.removeEventListener(\"touchmove\", this.a.touchCollector, !1)) : document.detachEvent && (document.detachEvent(\"onload\", this.a.loadTimeCollector), document.detachEvent(\"onmousemove\", this.a.mouseCollector), document.detachEvent(\"keypress\", this.a.keyboardCollector)), this.s = !1);\n },\n addEventListener: function (a, b) {\n this.B[a][this.S++] = b;\n },\n removeEventListener: function (a, b) {\n var c,\n d,\n e = this.B[a],\n f = [];\n for (d in e) e.hasOwnProperty(d) && e[d] === b && f.push(d);\n for (c = 0; c < f.length; c++) d = f[c], delete e[d];\n },\n U: function () {\n C(this, 1);\n },\n W: function (a) {\n var b, c;\n try {\n b = a.x || a.clientX || a.offsetX || 0, c = a.y || a.clientY || a.offsetY || 0;\n } catch (d) {\n c = b = 0;\n }\n 0 != b && 0 != c && this.addEntropy([b, c], 2, \"mouse\");\n C(this, 0);\n },\n X: function (a) {\n a = a.touches[0] || a.changedTouches[0];\n this.addEntropy([a.pageX || a.clientX, a.pageY || a.clientY], 1, \"touch\");\n C(this, 0);\n },\n V: function () {\n C(this, 2);\n },\n R: function (a) {\n a = a.accelerationIncludingGravity.x || a.accelerationIncludingGravity.y || a.accelerationIncludingGravity.z;\n if (window.orientation) {\n var b = window.orientation;\n \"number\" === typeof b && this.addEntropy(b, 1, \"accelerometer\");\n }\n a && this.addEntropy(a, 2, \"accelerometer\");\n C(this, 0);\n }\n };\n function A(a, b) {\n var c,\n d = sjcl.random.B[a],\n e = [];\n for (c in d) d.hasOwnProperty(c) && e.push(d[c]);\n for (c = 0; c < e.length; c++) e[c](b);\n }\n function C(a, b) {\n \"undefined\" !== typeof window && window.performance && \"function\" === typeof window.performance.now ? a.addEntropy(window.performance.now(), b, \"loadtime\") : a.addEntropy(new Date().valueOf(), b, \"loadtime\");\n }\n function y(a) {\n a.b = z(a).concat(z(a));\n a.C = new sjcl.cipher.aes(a.b);\n }\n function z(a) {\n for (var b = 0; 4 > b && (a.g[b] = a.g[b] + 1 | 0, !a.g[b]); b++);\n return a.C.encrypt(a.g);\n }\n function B(a, b) {\n return function () {\n b.apply(a, arguments);\n };\n }\n sjcl.random = new sjcl.prng(6);\n a: try {\n var D, E, F, G;\n if (G = \"undefined\" !== typeof module && module.exports) {\n var H;\n try {\n H = _dereq_(\"crypto\");\n } catch (a) {\n H = null;\n }\n G = E = H;\n }\n if (G && E.randomBytes) D = E.randomBytes(128), D = new Uint32Array(new Uint8Array(D).buffer), sjcl.random.addEntropy(D, 1024, \"crypto['randomBytes']\");else if (\"undefined\" !== typeof window && \"undefined\" !== typeof Uint32Array) {\n F = new Uint32Array(32);\n if (window.crypto && window.crypto.getRandomValues) window.crypto.getRandomValues(F);else if (window.msCrypto && window.msCrypto.getRandomValues) window.msCrypto.getRandomValues(F);else break a;\n sjcl.random.addEntropy(F, 1024, \"crypto['getRandomValues']\");\n }\n } catch (a) {\n \"undefined\" !== typeof window && window.console && (console.log(\"There was an error collecting entropy from the browser:\"), console.log(a));\n }\n \"undefined\" !== typeof module && module.exports && (module.exports = sjcl);\n \"function\" === typeof define && define([], function () {\n return sjcl;\n });\n }, {\n \"crypto\": undefined\n }],\n 117: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var BraintreeError = _dereq_(\"../lib/braintree-error\");\n module.exports = {\n FASTLANE_SDK_LOAD_ERROR: {\n type: BraintreeError.types.MERCHANT,\n code: \"FASTLANE_SDK_LOAD_ERROR\"\n }\n };\n }, {\n \"../lib/braintree-error\": 143\n }],\n 118: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var BraintreeError = _dereq_(\"../lib/braintree-error\");\n var errors = _dereq_(\"./errors\");\n var loadFastlane = _dereq_(\"../lib/assets\").loadFastlane;\n var wrapPromise = _dereq_(\"@braintree/wrap-promise\");\n var assign = _dereq_(\"../lib/assign\").assign;\n function fastlane(options) {\n var config = options.client.getConfiguration();\n var sdkVersion = options.client.getVersion();\n var environment = config.gatewayConfiguration.environment;\n var minified = true;\n if (environment !== \"production\") {\n minified = false;\n }\n return loadFastlane(assign({\n platform: \"BT\",\n btSdkVersion: sdkVersion,\n minified: minified\n }, options)).then(function (result) {\n var platformOptions = {\n platform: \"BT\",\n authorization: options.authorization,\n client: options.client,\n deviceData: options.deviceData\n };\n\n // We need the following options to be nested inside platformOptions rather than\n // top level\n delete options.authorization;\n delete options.client;\n delete options.deviceData;\n\n // The following are options that we know are needed for the Fastlane Loader, but which\n // we know are not needed for initializing the fastlane sdk.\n delete options.minified;\n delete options.btSdkVersion;\n return window.braintree.fastlane.create(assign({\n platformOptions: platformOptions\n }, options, result.metadata));\n }).catch(function (err) {\n return Promise.reject(new BraintreeError({\n type: errors.FASTLANE_SDK_LOAD_ERROR.type,\n code: errors.FASTLANE_SDK_LOAD_ERROR.code,\n message: err.message\n }));\n });\n }\n module.exports = wrapPromise(fastlane);\n }, {\n \"../lib/assets\": 139,\n \"../lib/assign\": 140,\n \"../lib/braintree-error\": 143,\n \"./errors\": 117,\n \"@braintree/wrap-promise\": 40\n }],\n 119: [function (_dereq_, module, exports) {\n \"use strict\";\n\n /** @module braintree-web/fastlane */\n var basicComponentVerification = _dereq_(\"../lib/basic-component-verification\");\n var fastlane = _dereq_(\"./fastlane\");\n var createAssetsUrl = _dereq_(\"../lib/create-assets-url\");\n var createDeferredClient = _dereq_(\"../lib/create-deferred-client\");\n var wrapPromise = _dereq_(\"@braintree/wrap-promise\");\n var VERSION = \"3.112.0\";\n var assign = _dereq_(\"../lib/assign\").assign;\n\n /**\n * @static\n * @function create\n * @param {object} options Creation options:\n * @param {Client} [options.client] A {@link Client} instance.\n * @param {string} [options.authorization] A tokenizationKey or clientToken. Can be used in place of `options.client`.\n * @param {string} [options.deviceData] A {@link DataCollector} instance.\n * @example\n * braintree.fastlane.create({\n * client: clientInstance,\n * deviceData: dataCollectorInstance\n * }).then(function (fastlaneInstance) {\n * // fastlaneInstance is ready to create an identity instance.\n * identity = fastlaneInstance.identity\n * }).catch(function (createErr) {\n * console.error('Error creating fastlane instance', createErr);\n * });\n * @example
data
, is a {@link GooglePay~tokenizePayload|tokenizePayload}. If no callback is provided, `parseResponse` returns a promise that resolves with a {@link GooglePayment~tokenizePayload|tokenizePayload}.\n * @example with callback\n * var paymentsClient = new google.payments.api.PaymentsClient({\n * environment: 'TEST' // or 'PRODUCTION'\n * })\n *\n * paymentsClient.loadPaymentData(paymentDataRequestFromCreatePaymentDataRequest).then(function (response) {\n * googlePaymentInstance.parseResponse(response, function (err, data) {\n * if (err) {\n * // handle errors\n * }\n * // send parsedResponse.nonce to your server\n * });\n * });\n * @example with promise\n * var paymentsClient = new google.payments.api.PaymentsClient({\n * environment: 'TEST' // or 'PRODUCTION'\n * })\n *\n * paymentsClient.loadPaymentData(paymentDataRequestFromCreatePaymentDataRequest).then(function (response) {\n * return googlePaymentInstance.parseResponse(response);\n * }).then(function (parsedResponse) {\n * // send parsedResponse.nonce to your server\n * }).catch(function (err) {\n * // handle errors\n * });\n * @returns {(Promise|void)} Returns a promise that resolves the parsed response if no callback is provided.\n */\n GooglePayment.prototype.parseResponse = function (response) {\n var self = this;\n return Promise.resolve().then(function () {\n var payload;\n var rawResponse = response.apiVersion === 2 ? response.paymentMethodData.tokenizationData.token : response.paymentMethodToken.token;\n var parsedResponse = JSON.parse(rawResponse);\n var error = parsedResponse.error;\n if (error) {\n return Promise.reject(error);\n }\n analytics.sendEvent(self._createPromise, \"google-payment.parseResponse.succeeded\");\n if (parsedResponse.paypalAccounts) {\n payload = parsedResponse.paypalAccounts[0];\n analytics.sendEvent(self._createPromise, \"google-payment.parseResponse.succeeded.paypal\");\n return Promise.resolve({\n nonce: payload.nonce,\n type: payload.type,\n description: payload.description\n });\n }\n payload = parsedResponse.androidPayCards[0];\n analytics.sendEvent(self._createPromise, \"google-payment.parseResponse.succeeded.google-payment\");\n return Promise.resolve({\n nonce: payload.nonce,\n type: payload.type,\n description: payload.description,\n details: {\n cardType: payload.details.cardType,\n lastFour: payload.details.lastFour,\n lastTwo: payload.details.lastTwo,\n isNetworkTokenized: payload.details.isNetworkTokenized,\n bin: payload.details.bin\n },\n binData: payload.binData\n });\n }).catch(function (error) {\n analytics.sendEvent(self._createPromise, \"google-payment.parseResponse.failed\");\n return Promise.reject(new BraintreeError({\n code: errors.GOOGLE_PAYMENT_GATEWAY_ERROR.code,\n message: errors.GOOGLE_PAYMENT_GATEWAY_ERROR.message,\n type: errors.GOOGLE_PAYMENT_GATEWAY_ERROR.type,\n details: {\n originalError: error\n }\n }));\n });\n };\n\n /**\n * Cleanly tear down anything set up by {@link module:braintree-web/google-payment.create|create}.\n * @public\n * @param {callback} [callback] Called once teardown is complete. No data is returned if teardown completes successfully.\n * @example\n * googlePaymentInstance.teardown();\n * @example
\n * - `\"number\"`\n * - `\"cvv\"`\n * - `\"expirationDate\"`\n * - `\"expirationMonth\"`\n * - `\"expirationYear\"`\n * - `\"postalCode\"`\n * - `\"cardholderName\"`\n * @property {object} fields\n * @property {?HostedFields~hostedFieldsFieldData} fields.number {@link HostedFields~hostedFieldsFieldData|hostedFieldsFieldData} for the number field, if it is present.\n * @property {?HostedFields~hostedFieldsFieldData} fields.cvv {@link HostedFields~hostedFieldsFieldData|hostedFieldsFieldData} for the CVV field, if it is present.\n * @property {?HostedFields~hostedFieldsFieldData} fields.expirationDate {@link HostedFields~hostedFieldsFieldData|hostedFieldsFieldData} for the expiration date field, if it is present.\n * @property {?HostedFields~hostedFieldsFieldData} fields.expirationMonth {@link HostedFields~hostedFieldsFieldData|hostedFieldsFieldData} for the expiration month field, if it is present.\n * @property {?HostedFields~hostedFieldsFieldData} fields.expirationYear {@link HostedFields~hostedFieldsFieldData|hostedFieldsFieldData} for the expiration year field, if it is present.\n * @property {?HostedFields~hostedFieldsFieldData} fields.postalCode {@link HostedFields~hostedFieldsFieldData|hostedFieldsFieldData} for the postal code field, if it is present.\n * @property {?HostedFields~hostedFieldsFieldData} fields.cardholderName {@link HostedFields~hostedFieldsFieldData|hostedFieldsFieldData} for the cardholder name field, if it is present.\n */\n\n /**\n * @typedef {object} HostedFields~binPayload\n * @description The event payload sent from {@link HostedFields#on|on} when the {@link HostedFields#event:binAvailable|binAvailable} event is emitted.\n * @property {string} bin The first 6 digits of the card number.\n */\n\n /**\n * @typedef {object} HostedFields~hostedFieldsFieldData\n * @description Data about Hosted Fields fields, sent in {@link HostedFields~stateObject|stateObjects}.\n * @property {HTMLElement} container Reference to the container DOM element on your page associated with the current event.\n * @property {boolean} isFocused Whether or not the input is currently focused.\n * @property {boolean} isEmpty Whether or not the user has entered a value in the input.\n * @property {boolean} isPotentiallyValid\n * A determination based on the future validity of the input value.\n * This is helpful when a user is entering a card number and types \"41\"
.\n * While that value is not valid for submission, it is still possible for\n * it to become a fully qualified entry. However, if the user enters \"4x\"
\n * it is clear that the card number can never become valid and isPotentiallyValid will\n * return false.\n * @property {boolean} isValid Whether or not the value of the associated input is fully qualified for submission.\n */\n\n /**\n * @typedef {object} HostedFields~hostedFieldsCard\n * @description Information about the card type, sent in {@link HostedFields~stateObject|stateObjects}.\n * @property {string} type The code-friendly representation of the card type. It will be one of the following strings:\n * - `american-express`\n * - `diners-club`\n * - `discover`\n * - `jcb`\n * - `maestro`\n * - `master-card`\n * - `unionpay`\n * - `visa`\n * @property {string} niceType The pretty-printed card type. It will be one of the following strings:\n * - `American Express`\n * - `Diners Club`\n * - `Discover`\n * - `JCB`\n * - `Maestro`\n * - `MasterCard`\n * - `UnionPay`\n * - `Visa`\n * @property {object} code\n * This object contains data relevant to the security code requirements of the card brand.\n * For example, on a Visa card there will be a CVV
of 3 digits, whereas an\n * American Express card requires a 4-digit CID
.\n * @property {string} code.name \"CVV\"
\"CID\"
\"CVC\"
\n * @property {number} code.size The expected length of the security code. Typically, this is 3 or 4.\n */\n\n /**\n * @name HostedFields#on\n * @function\n * @param {string} event The name of the event to which you are subscribing.\n * @param {function} handler A callback to handle the event.\n * @description Subscribes a handler function to a named event.\n *\n * **Events that emit a {@link HostedFields~stateObject|stateObject}.**\n * * {@link HostedFields#event:blur|blur}\n * * {@link HostedFields#event:focus|focus}\n * * {@link HostedFields#event:empty|empty}\n * * {@link HostedFields#event:notEmpty|notEmpty}\n * * {@link HostedFields#event:cardTypeChange|cardTypeChange}\n * * {@link HostedFields#event:validityChange|validityChange}\n * * {@link HostedFields#event:inputSubmitRequest|inputSubmitRequest}\n *\n * **Other Events**\n * * {@link HostedFields#event:binAvailable|binAvailable} - emits a {@link HostedFields~binPayload|bin payload}. Note: If you are using a [Referrer-Policy](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Referrer-Policy) header that prevents the origin from being sent, this event will not fire.\n * @example\n * data
, is a {@link HostedFields~tokenizePayload|tokenizePayload}. If no callback is provided, `tokenize` returns a function that resolves with a {@link HostedFields~tokenizePayload|tokenizePayload}.\n * @example
data
, is a {@link UnionPay~enrollPayload|enrollPayload}. If no callback is provided, `enroll` returns a promise that resolves with {@link UnionPay~enrollPayload|enrollPayload}.\n * @returns {void}\n */\n UnionPay.prototype.enroll = function (options) {\n var self = this;\n var client = this._options.client;\n var card = options.card;\n var mobile = options.mobile;\n var hostedFields = options.hostedFields;\n var data;\n if (!mobile) {\n return Promise.reject(new BraintreeError(errors.UNIONPAY_MISSING_MOBILE_PHONE_DATA));\n }\n if (hostedFields) {\n if (!hostedFields._bus) {\n return Promise.reject(new BraintreeError(errors.UNIONPAY_HOSTED_FIELDS_INSTANCE_INVALID));\n } else if (card) {\n return Promise.reject(new BraintreeError(errors.UNIONPAY_CARD_AND_HOSTED_FIELDS_INSTANCES));\n }\n return new Promise(function (resolve, reject) {\n self._initializeHostedFields().then(function () {\n self._bus.emit(events.HOSTED_FIELDS_ENROLL, {\n hostedFields: hostedFields,\n mobile: mobile\n }, function (response) {\n if (response.err) {\n reject(new BraintreeError(response.err));\n return;\n }\n resolve(response.payload);\n });\n });\n });\n } else if (card && card.number) {\n data = {\n _meta: {\n source: \"unionpay\"\n },\n unionPayEnrollment: {\n number: card.number,\n mobileCountryCode: mobile.countryCode,\n mobileNumber: mobile.number\n }\n };\n if (card.expirationDate) {\n data.unionPayEnrollment.expirationDate = card.expirationDate;\n } else if (card.expirationMonth || card.expirationYear) {\n if (card.expirationMonth && card.expirationYear) {\n data.unionPayEnrollment.expirationYear = card.expirationYear;\n data.unionPayEnrollment.expirationMonth = card.expirationMonth;\n } else {\n return Promise.reject(new BraintreeError(errors.UNIONPAY_EXPIRATION_DATE_INCOMPLETE));\n }\n }\n return client.request({\n method: \"post\",\n endpoint: \"union_pay_enrollments\",\n data: data\n }).then(function (response) {\n analytics.sendEvent(client, \"unionpay.enrollment-succeeded\");\n return {\n enrollmentId: response.unionPayEnrollmentId,\n smsCodeRequired: response.smsCodeRequired\n };\n }).catch(function (err) {\n var error;\n var status = err.details && err.details.httpStatus;\n if (status === 403) {\n error = err;\n } else if (status < 500) {\n error = new BraintreeError(errors.UNIONPAY_ENROLLMENT_CUSTOMER_INPUT_INVALID);\n error.details = {\n originalError: err\n };\n } else {\n error = new BraintreeError(errors.UNIONPAY_ENROLLMENT_NETWORK_ERROR);\n error.details = {\n originalError: err\n };\n }\n analytics.sendEvent(client, \"unionpay.enrollment-failed\");\n return Promise.reject(error);\n });\n }\n return Promise.reject(new BraintreeError(errors.UNIONPAY_CARD_OR_HOSTED_FIELDS_INSTANCE_REQUIRED));\n };\n\n /**\n * @typedef {object} UnionPay~tokenizePayload\n * @property {string} nonce The payment method nonce.\n * @property {string} type Always CreditCard
.\n * @property {object} details Additional account details:\n * @property {string} details.cardType Type of card, ex: Visa, MasterCard.\n * @property {string} details.lastFour Last four digits of card number.\n * @property {string} details.lastTwo Last two digits of card number.\n * @property {string} description A human-readable description.\n */\n\n /**\n * Tokenizes a UnionPay card and returns a nonce payload.\n * @public\n * @param {object} options UnionPay tokenization options:\n * @param {object} [options.card] The card to enroll. Required if you are not using the `hostedFields` option.\n * @param {string} options.card.number The card number.\n * @param {string} [options.card.expirationDate] The card's expiration date. May be in the form `MM/YY` or `MM/YYYY`. When defined `expirationMonth` and `expirationYear` are ignored.\n * @param {string} [options.card.expirationMonth] The card's expiration month. This should be used with the `expirationYear` parameter. When `expirationDate` is defined this parameter is ignored.\n * @param {string} [options.card.expirationYear] The card's expiration year. This should be used with the `expirationMonth` parameter. When `expirationDate` is defined this parameter is ignored.\n * @param {string} [options.card.cvv] The card's security number.\n * @param {HostedFields} [options.hostedFields] The Hosted Fields instance used to collect card data. Required if you are not using the `card` option.\n * @param {string} options.enrollmentId The enrollment ID from {@link UnionPay#enroll}.\n * @param {string} [options.smsCode] The SMS code received from the user if {@link UnionPay#enroll} payload have `smsCodeRequired`. if `smsCodeRequired` is false, smsCode should not be passed.\n * @param {callback} [callback] The second argument, data
, is a {@link UnionPay~tokenizePayload|tokenizePayload}. If no callback is provided, `tokenize` returns a promise that resolves with a {@link UnionPay~tokenizePayload|tokenizePayload}.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n */\n UnionPay.prototype.tokenize = function (options) {\n var data;\n var self = this;\n var client = this._options.client;\n var card = options.card;\n var hostedFields = options.hostedFields;\n if (card && hostedFields) {\n return Promise.reject(new BraintreeError(errors.UNIONPAY_CARD_AND_HOSTED_FIELDS_INSTANCES));\n } else if (card) {\n data = {\n _meta: {\n source: \"unionpay\"\n },\n creditCard: {\n number: options.card.number,\n options: {\n unionPayEnrollment: {\n id: options.enrollmentId\n }\n }\n }\n };\n if (options.smsCode) {\n data.creditCard.options.unionPayEnrollment.smsCode = options.smsCode;\n }\n if (card.expirationDate) {\n data.creditCard.expirationDate = card.expirationDate;\n } else if (card.expirationMonth && card.expirationYear) {\n data.creditCard.expirationYear = card.expirationYear;\n data.creditCard.expirationMonth = card.expirationMonth;\n }\n if (options.card.cvv) {\n data.creditCard.cvv = options.card.cvv;\n }\n return client.request({\n method: \"post\",\n endpoint: \"payment_methods/credit_cards\",\n data: data\n }).then(function (response) {\n var tokenizedCard = response.creditCards[0];\n delete tokenizedCard.consumed;\n delete tokenizedCard.threeDSecureInfo;\n analytics.sendEvent(client, \"unionpay.nonce-received\");\n return tokenizedCard;\n }).catch(function (err) {\n var error;\n var status = err.details && err.details.httpStatus;\n analytics.sendEvent(client, \"unionpay.nonce-failed\");\n if (status === 403) {\n error = err;\n } else if (status < 500) {\n error = new BraintreeError(errors.UNIONPAY_FAILED_TOKENIZATION);\n error.details = {\n originalError: err\n };\n } else {\n error = new BraintreeError(errors.UNIONPAY_TOKENIZATION_NETWORK_ERROR);\n error.details = {\n originalError: err\n };\n }\n return Promise.reject(error);\n });\n } else if (hostedFields) {\n if (!hostedFields._bus) {\n return Promise.reject(new BraintreeError(errors.UNIONPAY_HOSTED_FIELDS_INSTANCE_INVALID));\n }\n return new Promise(function (resolve, reject) {\n self._initializeHostedFields().then(function () {\n self._bus.emit(events.HOSTED_FIELDS_TOKENIZE, options, function (response) {\n if (response.err) {\n reject(new BraintreeError(response.err));\n return;\n }\n resolve(response.payload);\n });\n });\n });\n }\n return Promise.reject(new BraintreeError(errors.UNIONPAY_CARD_OR_HOSTED_FIELDS_INSTANCE_REQUIRED));\n };\n\n /**\n * Cleanly remove anything set up by {@link module:braintree-web/unionpay.create|create}. This only needs to be called when using UnionPay with Hosted Fields.\n * @public\n * @param {callback} [callback] Called on completion. If no callback is provided, returns a promise.\n * @example\n * unionpayInstance.teardown();\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n */\n UnionPay.prototype.teardown = function () {\n if (this._bus) {\n this._hostedFieldsFrame.parentNode.removeChild(this._hostedFieldsFrame);\n this._bus.teardown();\n }\n convertMethodsToError(this, methods(UnionPay.prototype));\n return Promise.resolve();\n };\n UnionPay.prototype._initializeHostedFields = function () {\n var assetsUrl, isDebug;\n var componentId = uuid();\n var self = this;\n if (this._hostedFieldsInitializePromise) {\n return this._hostedFieldsInitializePromise;\n }\n this._hostedFieldsInitializePromise = new Promise(function (resolve) {\n assetsUrl = self._options.client.getConfiguration().gatewayConfiguration.assetsUrl;\n isDebug = self._options.client.getConfiguration().isDebug;\n self._bus = new Bus({\n channel: componentId,\n verifyDomain: isVerifiedDomain\n });\n self._hostedFieldsFrame = iFramer({\n name: constants.HOSTED_FIELDS_FRAME_NAME + \"_\" + componentId,\n src: assetsUrl + \"/web/\" + VERSION + \"/html/unionpay-hosted-fields-frame\" + useMin(isDebug) + \".html\",\n height: 0,\n width: 0\n });\n self._bus.on(BUS_CONFIGURATION_REQUEST_EVENT, function (reply) {\n reply(self._options.client);\n resolve();\n });\n document.body.appendChild(self._hostedFieldsFrame);\n });\n return this._hostedFieldsInitializePromise;\n };\n module.exports = wrapPromise.wrapPrototype(UnionPay);\n }, {\n \"../../lib/analytics\": 138,\n \"../../lib/braintree-error\": 143,\n \"../../lib/constants\": 145,\n \"../../lib/convert-methods-to-error\": 146,\n \"../../lib/is-verified-domain\": 173,\n \"../../lib/methods\": 175,\n \"../../lib/use-min\": 180,\n \"./constants\": 223,\n \"./errors\": 224,\n \"@braintree/iframer\": 32,\n \"@braintree/uuid\": 36,\n \"@braintree/wrap-promise\": 40,\n \"framebus\": 50\n }],\n 226: [function (_dereq_, module, exports) {\n \"use strict\";\n\n module.exports = {\n PLAID_LINK_JS: \"https://cdn.plaid.com/link/v2/stable/link-initialize.js\"\n };\n }, {}],\n 227: [function (_dereq_, module, exports) {\n \"use strict\";\n\n /**\n * @name BraintreeError.Us Bank Account - Creation Error Codes\n * @description Errors that occur when [creating the Us Bank Account component](./module-braintree-web_us-bank-account.html#.create).\n * @property {MERCHANT} US_BANK_ACCOUNT_NOT_ENABLED Occurs when US Bank Account is not enabled in the Braintree control panel.\n */\n\n /**\n * @name BraintreeError.Us Bank Account - tokenize Error Codes\n * @description Errors that occur when using the [`tokenize` method](./UsBankAccount.html#tokenize).\n * @property {MERCHANT} US_BANK_ACCOUNT_OPTION_REQUIRED Occurs when a required option is not passed.\n * @property {MERCHANT} US_BANK_ACCOUNT_MUTUALLY_EXCLUSIVE_OPTIONS Occurs when 1 or more incompatible options are passed.\n * @property {NETWORK} US_BANK_ACCOUNT_LOGIN_LOAD_FAILED Occurs when bank login flow fails.\n * @property {CUSTOMER} US_BANK_ACCOUNT_LOGIN_CLOSED Occurs when bank login window is closed.\n * @property {MERCHANT} US_BANK_ACCOUNT_LOGIN_REQUEST_ACTIVE Occurs when a bank login flow is already active.\n * @property {NETWORK} US_BANK_ACCOUNT_TOKENIZATION_NETWORK_ERROR Occurs when payment details could not be tokenized.\n * @property {CUSTOMER} US_BANK_ACCOUNT_FAILED_TOKENIZATION Occurs when payment details failed to be tokenized.\n * @property {MERCHANT} US_BANK_ACCOUNT_BANK_LOGIN_NOT_ENABLED Occurs when bank login flow is not enabled in the Braintree control panel.\n */\n var BraintreeError = _dereq_(\"../lib/braintree-error\");\n module.exports = {\n US_BANK_ACCOUNT_OPTION_REQUIRED: {\n type: BraintreeError.types.MERCHANT,\n code: \"US_BANK_ACCOUNT_OPTION_REQUIRED\"\n },\n US_BANK_ACCOUNT_MUTUALLY_EXCLUSIVE_OPTIONS: {\n type: BraintreeError.types.MERCHANT,\n code: \"US_BANK_ACCOUNT_MUTUALLY_EXCLUSIVE_OPTIONS\"\n },\n US_BANK_ACCOUNT_LOGIN_LOAD_FAILED: {\n type: BraintreeError.types.NETWORK,\n code: \"US_BANK_ACCOUNT_LOGIN_LOAD_FAILED\",\n message: \"Bank login flow failed to load.\"\n },\n US_BANK_ACCOUNT_LOGIN_CLOSED: {\n type: BraintreeError.types.CUSTOMER,\n code: \"US_BANK_ACCOUNT_LOGIN_CLOSED\",\n message: \"Customer closed bank login flow before authorizing.\"\n },\n US_BANK_ACCOUNT_LOGIN_REQUEST_ACTIVE: {\n type: BraintreeError.types.MERCHANT,\n code: \"US_BANK_ACCOUNT_LOGIN_REQUEST_ACTIVE\",\n message: \"Another bank login tokenization request is active.\"\n },\n US_BANK_ACCOUNT_TOKENIZATION_NETWORK_ERROR: {\n type: BraintreeError.types.NETWORK,\n code: \"US_BANK_ACCOUNT_TOKENIZATION_NETWORK_ERROR\",\n message: \"A tokenization network error occurred.\"\n },\n US_BANK_ACCOUNT_FAILED_TOKENIZATION: {\n type: BraintreeError.types.CUSTOMER,\n code: \"US_BANK_ACCOUNT_FAILED_TOKENIZATION\",\n message: \"The supplied data failed tokenization.\"\n },\n US_BANK_ACCOUNT_NOT_ENABLED: {\n type: BraintreeError.types.MERCHANT,\n code: \"US_BANK_ACCOUNT_NOT_ENABLED\",\n message: \"US bank account is not enabled.\"\n },\n US_BANK_ACCOUNT_BANK_LOGIN_NOT_ENABLED: {\n type: BraintreeError.types.MERCHANT,\n code: \"US_BANK_ACCOUNT_BANK_LOGIN_NOT_ENABLED\",\n message: \"Bank login is not enabled.\"\n }\n };\n }, {\n \"../lib/braintree-error\": 143\n }],\n 228: [function (_dereq_, module, exports) {\n \"use strict\";\n\n /**\n * @module braintree-web/us-bank-account\n * @description This module is for accepting payments of US bank accounts.\n */\n var basicComponentVerification = _dereq_(\"../lib/basic-component-verification\");\n var BraintreeError = _dereq_(\"../lib/braintree-error\");\n var createDeferredClient = _dereq_(\"../lib/create-deferred-client\");\n var createAssetsUrl = _dereq_(\"../lib/create-assets-url\");\n var errors = _dereq_(\"./errors\");\n var USBankAccount = _dereq_(\"./us-bank-account\");\n var VERSION = \"3.112.0\";\n var wrapPromise = _dereq_(\"@braintree/wrap-promise\");\n\n /**\n * @static\n * @function create\n * @param {object} options Creation options:\n * @param {Client} [options.client] A {@link Client} instance.\n * @param {string} [options.authorization] A tokenizationKey or clientToken. Can be used in place of `options.client`.\n * @param {callback} [callback] The second argument, `data`, is the {@link USBankAccount} instance. If no callback is provided, `create` returns a promise that resolves with the {@link USBankAccount} instance.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n */\n function create(options) {\n var name = \"US Bank Account\";\n return basicComponentVerification.verify({\n name: name,\n client: options.client,\n authorization: options.authorization\n }).then(function () {\n return createDeferredClient.create({\n authorization: options.authorization,\n client: options.client,\n debug: options.debug,\n assetsUrl: createAssetsUrl.create(options.authorization),\n name: name\n });\n }).then(function (client) {\n var usBankAccount;\n options.client = client;\n usBankAccount = options.client.getConfiguration().gatewayConfiguration.usBankAccount;\n if (!usBankAccount) {\n return Promise.reject(new BraintreeError(errors.US_BANK_ACCOUNT_NOT_ENABLED));\n }\n return new USBankAccount(options);\n });\n }\n module.exports = {\n create: wrapPromise(create),\n /**\n * @description The current version of the SDK, i.e. `{@pkg version}`.\n * @type {string}\n */\n VERSION: VERSION\n };\n }, {\n \"../lib/basic-component-verification\": 141,\n \"../lib/braintree-error\": 143,\n \"../lib/create-assets-url\": 148,\n \"../lib/create-deferred-client\": 150,\n \"./errors\": 227,\n \"./us-bank-account\": 229,\n \"@braintree/wrap-promise\": 40\n }],\n 229: [function (_dereq_, module, exports) {\n \"use strict\";\n\n var BraintreeError = _dereq_(\"../lib/braintree-error\");\n var constants = _dereq_(\"./constants\");\n var errors = _dereq_(\"./errors\");\n var sharedErrors = _dereq_(\"../lib/errors\");\n var analytics = _dereq_(\"../lib/analytics\");\n var once = _dereq_(\"../lib/once\");\n var convertMethodsToError = _dereq_(\"../lib/convert-methods-to-error\");\n var methods = _dereq_(\"../lib/methods\");\n var wrapPromise = _dereq_(\"@braintree/wrap-promise\");\n var TOKENIZE_BANK_DETAILS_MUTATION = createGraphQLMutation(\"UsBankAccount\");\n var TOKENIZE_BANK_LOGIN_MUTATION = createGraphQLMutation(\"UsBankLogin\");\n\n /**\n * @typedef {object} USBankAccount~tokenizePayload\n * @property {string} nonce The payment method nonce.\n * @property {string} type The payment method type, always `us_bank_account`.\n * @property {object} details Additional account details. Currently empty.\n */\n\n /**\n * @class\n * @param {object} options See {@link module:braintree-web/us-bank-account.create|us-bank-account.create}.\n * @classdesc This class represents a US Bank Account component. Instances of this class can tokenize raw bank details or present a bank login. You cannot use this constructor directly. Use {@link module:braintree-web/us-bank-account.create|braintree.us-bank-account.create} instead.\n */\n function USBankAccount(options) {\n this._client = options.client;\n this._isTokenizingBankLogin = false;\n analytics.sendEvent(this._client, \"usbankaccount.initialized\");\n }\n\n /**\n * Tokenizes bank information to return a payment method nonce. You can tokenize bank details by providing information like account and routing numbers. You can also tokenize with a bank login UI that prompts the customer to log into their bank account.\n * @public\n * @param {object} options All tokenization options for the US Bank Account component.\n * @param {string} options.mandateText A string for proof of customer authorization. For example, `'I authorize Braintree to debit my bank account on behalf of My Online Store.'`.\n * @param {object} [options.bankDetails] Bank detail information (such as account and routing numbers). `bankDetails` or `bankLogin` option must be provided.\n * @param {string} options.bankDetails.routingNumber The customer's bank routing number, such as `'307075259'`.\n * @param {string} options.bankDetails.accountNumber The customer's bank account number, such as `'999999999'`.\n * @param {string} options.bankDetails.accountType The customer's bank account type. Must be `'checking'` or `'savings'`.\n * @param {string} options.bankDetails.ownershipType The customer's bank account ownership type. Must be `'personal'` or `'business'`.\n * @param {string} [options.bankDetails.firstName] The customer's first name. Required when account ownership type is `personal`.\n * @param {string} [options.bankDetails.lastName] The customer's last name. Required when account ownership type is `personal`.\n * @param {string} [options.bankDetails.businessName] The customer's business name. Required when account ownership type is `business`.\n * @param {object} options.bankDetails.billingAddress The customer's billing address.\n * @param {string} options.bankDetails.billingAddress.streetAddress The street address for the customer's billing address, such as `'123 Fake St'`.\n * @param {string} [options.bankDetails.billingAddress.extendedAddress] The extended street address for the customer's billing address, such as `'Apartment B'`.\n * @param {string} options.bankDetails.billingAddress.locality The locality for the customer's billing address. This is typically a city, such as `'San Francisco'`.\n * @param {string} options.bankDetails.billingAddress.region The region for the customer's billing address. This is typically a state, such as `'CA'`.\n * @param {string} options.bankDetails.billingAddress.postalCode The postal code for the customer's billing address. This is typically a ZIP code, such as `'94119'`.\n * @param {object} [options.bankLogin] Bank login information. `bankLogin` or `bankDetails` option must be provided.\n * @param {string} options.bankLogin.displayName Display name for the bank login UI, such as `'My Store'`.\n * @param {string} options.bankLogin.ownershipType The customer's bank account ownership type. Must be `'personal'` or `'business'`.\n * @param {string} [options.bankLogin.firstName] The customer's first name. Required when account ownership type is `personal`.\n * @param {string} [options.bankLogin.lastName] The customer's last name. Required when account ownership type is `personal`.\n * @param {string} [options.bankLogin.businessName] The customer's business name. Required when account ownership type is `business`.\n * @param {object} options.bankLogin.billingAddress The customer's billing address.\n * @param {string} options.bankLogin.billingAddress.streetAddress The street address for the customer's billing address, such as `'123 Fake St'`.\n * @param {string} [options.bankLogin.billingAddress.extendedAddress] The extended street address for the customer's billing address, such as `'Apartment B'`.\n * @param {string} options.bankLogin.billingAddress.locality The locality for the customer's billing address. This is typically a city, such as `'San Francisco'`.\n * @param {string} options.bankLogin.billingAddress.region The region for the customer's billing address. This is typically a state, such as `'CA'`.\n * @param {string} options.bankLogin.billingAddress.postalCode The postal code for the customer's billing address. This is typically a ZIP code, such as `'94119'`.\n * @param {callback} [callback] The second argument, data
, is a {@link USBankAccount~tokenizePayload|tokenizePayload}. If no callback is provided, `tokenize` returns a promise that resolves with {@link USBankAccount~tokenizePayload|tokenizePayload}.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n * @example\n * data
, is a {@link Venmo~tokenizePayload|tokenizePayload}. If no callback is provided, the method will return a Promise that resolves with a {@link Venmo~tokenizePayload|tokenizePayload}.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n * @example\n * button.addEventListener('click', function () {\n * // Disable the button so that we don't attempt to open multiple popups.\n * button.setAttribute('disabled', 'disabled');\n *\n * // Because tokenize opens a new window, this must be called\n * // as a result of a user action, such as a button click.\n * venmoInstance.tokenize().then(function (payload) {\n * // Submit payload.nonce to your server\n * // Use payload.username to get the Venmo username and display any UI\n * }).catch(function (tokenizeError) {\n * // Handle flow errors or premature flow closure\n * switch (tokenizeErr.code) {\n * case 'VENMO_APP_CANCELED':\n * console.log('User canceled Venmo flow.');\n * break;\n * case 'VENMO_CANCELED':\n * console.log('User canceled Venmo, or Venmo app is not available.');\n * break;\n * default:\n * console.error('Error!', tokenizeErr);\n * }\n * }).then(function () {\n * button.removeAttribute('disabled');\n * });\n * });\n */\n Venmo.prototype.tokenize = function (options) {\n var self = this;\n var tokenizationPromise;\n options = options || {};\n if (this._tokenizationInProgress === true) {\n return Promise.reject(new BraintreeError(errors.VENMO_TOKENIZATION_REQUEST_ACTIVE));\n }\n this._tokenizationInProgress = true;\n if (this._useDesktopQRFlow) {\n // for the desktop flow, we create a venmo payment\n // context and then present a qr code modal to the\n // customer and they will open up their venmo app\n // and scan it and approve the purchase on their\n // mobile device. The sdk will start polling\n // in order to determine when the status of the\n // payment context has updated and then pass the\n // resulting nonce back to the merchant.\n tokenizationPromise = this._tokenizeForDesktopQRFlow(options);\n } else if (this._useAllowDesktopWebLogin) {\n /**\n * For Desktop Web Login, we open a browser popup to allow for authorization. Once authorized, the redirect urls are used by Venmo, and we query the API for a payment context status update.\n *\n * - Payment context is created on initialization\n * - Popup is opened to Venmo login url.\n * - The payment is authorized or canceled, and the popup is closed\n * - Once the popup is closed, we query the API for a payment context status update\n *\n * This is an alternate, opt-in flow to be used the Desktop QR Flow is not desired for Pay with Venmo desktop experiences.\n */\n tokenizationPromise = this._tokenizeWebLoginWithRedirect();\n } else if (this._cannotHaveReturnUrls) {\n // in the manual return strategy, we create the payment\n // context on initialization, then continually poll once\n // the app switch begins until we get a response indiciating\n // the payment context was approved by the customer on the\n // Venmo app. The payment context response also includes a\n // nonce. There are 2 cases where we use the manual return\n // strategy:\n // 1. the sdk is instantiated in an iframe, because\n // the venmo app is unable to redirect automatically\n // when that is the case so we rely on the customer\n // to do a manual redirect and continunally poll for\n // updates on the payment context to get the nonce\n // 2. same deal for when `requireManualReturn` is configured\n tokenizationPromise = this._tokenizeForMobileWithManualReturn();\n } else {\n // the default mobile flow is to app switch to the\n // venmo app, and then have the venmo app switch\n // back to the page with the venmo nonce details\n // encoded into the hash portion of the url. If\n // `paymentMethodUsage` is provided when instantiating\n // the sdk, we also create a payment context and pass\n // the resource id to the Venmo app during the app switch.\n // Once we get a succesful return, we ping the payment\n // context query to get any additional data needed\n // to send back to the merchant.\n tokenizationPromise = this._tokenizeForMobileWithHashChangeListeners(options);\n }\n return tokenizationPromise.then(function (payload) {\n return self._createPromise.then(function (client) {\n return self._createVenmoPaymentContext(client);\n }).then(function () {\n self._tokenizationInProgress = false;\n return formatTokenizePayload(payload);\n });\n }).catch(function (err) {\n return self._createPromise.then(function (client) {\n // We create a new Payment Context because if the last one failed, then presumably we don't want to use it again.\n // On the first pass, we create the payment context at initialization, and since we used that first one we now need to create a new one\n // for the next time someone tries to tokenize.\n return self._createVenmoPaymentContext(client);\n }).then(function () {\n self._tokenizationInProgress = false;\n return Promise.reject(err);\n });\n });\n };\n\n /**\n * Cancels the venmo tokenization process\n *\n * @public\n * @function Venmo~cancelTokenization\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n * @example\n * venmoTokenizeButton.addEventListener('click', function () {\n * venmoInstance.tokenize().then(function (payload) {\n * // handle payload\n * }).catch(function (err) {\n * if (err.code === 'VENMO_TOKENIZATION_CANCELED_BY_MERCHANT') {\n * // tokenization was canceled by calling cancelTokenization\n * }\n * });\n * });\n *\n * venmoCancelButton.addEventListener('click', function () {\n * // Hide the button when the venmo flow is not in progress\n * venmoCancelButton.style.display = \"none\";\n *\n * venmoInstance.cancelTokenization().then(function () {\n * // done canceling the flow\n * }).catch(function (err) {\n * // should only get here if there is no tokenization in progress\n * });\n * });\n */\n Venmo.prototype.cancelTokenization = function () {\n if (!this._tokenizationInProgress) {\n return Promise.reject(new BraintreeError(errors.VENMO_TOKENIZATION_REQUEST_NOT_ACTIVE));\n }\n this._removeVisibilityEventListener();\n\n // important to reject the tokenization promise first\n // so the tokenize method rejects with this error\n // rather than a customer canceled error in the mobile\n // polling and desktop flows\n if (this._tokenizePromise) {\n this._tokenizePromise.reject(new BraintreeError(errors.VENMO_TOKENIZATION_CANCELED_BY_MERCHANT));\n }\n return Promise.all([this._cancelMobilePaymentContext(), this._cancelVenmoDesktopContext()]);\n };\n Venmo.prototype._tokenizeWebLoginWithRedirect = function () {\n var self = this;\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.web-login.start\");\n this._tokenizePromise = new ExtendedPromise();\n return this.getUrl().then(function (url) {\n desktopWebLogin.runWebLogin({\n checkForStatusChange: self._checkPaymentContextStatusAndProcessResult.bind(self),\n cancelTokenization: self.cancelTokenization.bind(self),\n frameServiceInstance: self._frameServiceInstance,\n venmoUrl: url,\n debug: self._isDebug,\n checkPaymentContextStatus: self._checkPaymentContextStatus.bind(self)\n }).then(function (payload) {\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.web-login.success\");\n self._tokenizePromise.resolve({\n paymentMethodNonce: payload.paymentMethodId,\n username: payload.userName,\n payerInfo: payload.payerInfo,\n id: self._venmoPaymentContextId\n });\n }).catch(function (err) {\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.web-login.failure\");\n self._tokenizePromise.reject(err);\n });\n return self._tokenizePromise;\n });\n };\n Venmo.prototype._queryPaymentContextStatus = function (id) {\n var self = this;\n return this._createPromise.then(function (client) {\n var query = self._shouldUseLegacyFlow ? graphqlQueries.LEGACY_VENMO_PAYMENT_CONTEXT_STATUS_QUERY : graphqlQueries.VENMO_PAYMENT_CONTEXT_STATUS_QUERY;\n return client.request({\n api: \"graphQLApi\",\n data: {\n query: query,\n variables: {\n id: id\n }\n }\n });\n }).then(function (response) {\n return response.data.node;\n });\n };\n\n /**\n * Queries the GraphQL API to get the payment context and process the status. Retries until there is an update to the payment context status.\n * @name Venmo~checkPaymentContextStatusAndProcessResult\n * @ignore\n * @param {number} retryCount The counter for tracking number of retries made against the API.\n * @returns {Promise} Returns a promise\n */\n Venmo.prototype._checkPaymentContextStatusAndProcessResult = function (retryCount) {\n var self = this;\n return self._checkPaymentContextStatus().then(function (node) {\n var resultStatus = node.status;\n if (resultStatus !== self._venmoPaymentContextStatus) {\n self._venmoPaymentContextStatus = resultStatus;\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.web-login.status-change\");\n switch (resultStatus) {\n case \"APPROVED\":\n return Promise.resolve(node);\n case \"CANCELED\":\n return Promise.reject(new BraintreeError(errors.VENMO_CUSTOMER_CANCELED));\n case \"FAILED\":\n return Promise.reject(new BraintreeError(errors.VENMO_TOKENIZATION_FAILED));\n default:\n }\n }\n return new Promise(function (resolve, reject) {\n if (retryCount < self._maxRetryCount) {\n retryCount++;\n return self._checkPaymentContextStatusAndProcessResult(retryCount).then(resolve).catch(reject);\n }\n return reject(new BraintreeError(errors.VENMO_TOKENIZATION_FAILED));\n });\n });\n };\n Venmo.prototype._checkPaymentContextStatus = function () {\n var self = this;\n return self._queryPaymentContextStatus(self._venmoPaymentContextId).catch(function (networkError) {\n return Promise.reject(new BraintreeError({\n type: errors.VENMO_NETWORK_ERROR.type,\n code: errors.VENMO_NETWORK_ERROR.code,\n message: errors.VENMO_NETWORK_ERROR.message,\n details: networkError\n }));\n }).then(function (node) {\n return Promise.resolve(node);\n });\n };\n Venmo.prototype._pollForStatusChange = function () {\n var self = this;\n if (Date.now() > self._mobilePollingContextExpiresIn) {\n return Promise.reject(new BraintreeError(errors.VENMO_MOBILE_POLLING_TOKENIZATION_TIMEOUT));\n }\n return this._queryPaymentContextStatus(this._venmoPaymentContextId).catch(function (networkError) {\n return Promise.reject(new BraintreeError({\n type: errors.VENMO_MOBILE_POLLING_TOKENIZATION_NETWORK_ERROR.type,\n code: errors.VENMO_MOBILE_POLLING_TOKENIZATION_NETWORK_ERROR.code,\n message: errors.VENMO_MOBILE_POLLING_TOKENIZATION_NETWORK_ERROR.message,\n details: {\n originalError: networkError\n }\n }));\n }).then(function (node) {\n var newStatus = node.status;\n if (newStatus !== self._venmoPaymentContextStatus) {\n self._venmoPaymentContextStatus = newStatus;\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.manual-return.status-change.\" + newStatus.toLowerCase());\n switch (newStatus) {\n case \"EXPIRED\":\n case \"FAILED\":\n case \"CANCELED\":\n return Promise.reject(new BraintreeError(errors[\"VENMO_MOBILE_POLLING_TOKENIZATION_\" + newStatus]));\n case \"APPROVED\":\n return Promise.resolve(node);\n case \"CREATED\":\n case \"SCANNED\":\n default:\n // any other statuses are irrelevant to the polling\n // and can just be ignored\n }\n }\n return new Promise(function (resolve, reject) {\n setTimeout(function () {\n self._pollForStatusChange().then(resolve).catch(reject);\n }, self._mobilePollingInterval);\n });\n });\n };\n Venmo.prototype._tokenizeForMobileWithManualReturn = function () {\n var self = this;\n analytics.sendEvent(this._createPromise, \"venmo.tokenize.manual-return.start\");\n this._mobilePollingContextExpiresIn = Date.now() + this._mobilePollingExpiresThreshold;\n this._tokenizePromise = new ExtendedPromise();\n this._pollForStatusChange().then(function (payload) {\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.manual-return.success\");\n self._tokenizePromise.resolve({\n paymentMethodNonce: payload.paymentMethodId,\n username: payload.userName,\n payerInfo: payload.payerInfo,\n id: self._venmoPaymentContextId\n });\n }).catch(function (err) {\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.manual-return.failure\");\n self._tokenizePromise.reject(err);\n });\n return this.getUrl().then(function (url) {\n self.appSwitch(url);\n return self._tokenizePromise;\n });\n };\n Venmo.prototype._shouldUseRedirectStrategy = function () {\n if (!browserDetection.isIos()) {\n return false;\n }\n if (this._mobileWebFallBack === true) {\n return true;\n }\n return this._useRedirectForIOS;\n };\n Venmo.prototype._tokenizeForMobileWithHashChangeListeners = function (options) {\n var self = this;\n var resultProcessingInProgress, visibilityChangeListenerTimeout;\n if (this.hasTokenizationResult()) {\n return this.processHashChangeFlowResults();\n }\n analytics.sendEvent(this._createPromise, \"venmo.tokenize.mobile.start\");\n this._tokenizePromise = new ExtendedPromise();\n this._previousHash = window.location.hash;\n function completeFlow(hash) {\n var error;\n self.processHashChangeFlowResults(hash).catch(function (err) {\n error = err;\n }).then(function (res) {\n if (!self._ignoreHistoryChanges && window.location.hash !== self._previousHash) {\n window.location.hash = self._previousHash;\n }\n self._removeVisibilityEventListener();\n if (error) {\n self._tokenizePromise.reject(error);\n } else {\n self._tokenizePromise.resolve(res);\n }\n delete self._tokenizePromise;\n });\n }\n\n // The Venmo SDK app switches back with the results of the\n // tokenization encoded in the hash\n this._onHashChangeListener = function (e) {\n var hash = e.newURL.split(\"#\")[1];\n if (!self._hasTokenizationResult(hash)) {\n return;\n }\n resultProcessingInProgress = true;\n clearTimeout(visibilityChangeListenerTimeout);\n completeFlow(hash);\n };\n window.addEventListener(\"hashchange\", this._onHashChangeListener, false);\n\n // Subscribe to document visibility change events to detect when app switch\n // has returned. Acts as a fallback for the hashchange listener and catches\n // the cancel case via manual app switch back\n this._visibilityChangeListener = function () {\n var delay = options.processResultsDelay || constants.DEFAULT_PROCESS_RESULTS_DELAY;\n if (!window.document.hidden) {\n if (!resultProcessingInProgress) {\n visibilityChangeListenerTimeout = setTimeout(completeFlow, delay);\n }\n }\n };\n return this.getUrl().then(function (url) {\n self.appSwitch(url);\n\n // Add a brief delay to ignore visibility change events that occur right before app switch\n setTimeout(function () {\n window.document.addEventListener(documentVisibilityChangeEventName(), self._visibilityChangeListener);\n }, constants.DOCUMENT_VISIBILITY_CHANGE_EVENT_DELAY);\n return self._tokenizePromise;\n });\n };\n Venmo.prototype._tokenizeForDesktopQRFlow = function () {\n var self = this;\n analytics.sendEvent(this._createPromise, \"venmo.tokenize.desktop.start\");\n this._tokenizePromise = new ExtendedPromise();\n this._createPromise.then(function () {\n return self._venmoDesktopInstance.launchDesktopFlow();\n }).then(function (payload) {\n self._venmoDesktopInstance.hideDesktopFlow();\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.desktop.success\");\n self._tokenizePromise.resolve(payload);\n }).catch(function (err) {\n analytics.sendEvent(self._createPromise, \"venmo.tokenize.desktop.failure\");\n if (self._venmoDesktopInstance) {\n self._venmoDesktopInstance.hideDesktopFlow();\n }\n if (err && err.reason === \"CUSTOMER_CANCELED\") {\n self._tokenizePromise.reject(new BraintreeError(errors.VENMO_DESKTOP_CANCELED));\n return;\n }\n self._tokenizePromise.reject(new BraintreeError({\n type: errors.VENMO_DESKTOP_UNKNOWN_ERROR.type,\n code: errors.VENMO_DESKTOP_UNKNOWN_ERROR.code,\n message: errors.VENMO_DESKTOP_UNKNOWN_ERROR.message,\n details: {\n originalError: err\n }\n }));\n });\n return this._tokenizePromise;\n };\n Venmo.prototype._cancelMobilePaymentContext = function () {\n var self = this;\n return this._createPromise.then(function (client) {\n var query;\n if (self._venmoPaymentContextId) {\n query = self._shouldUseLegacyFlow ? graphqlQueries.LEGACY_UPDATE_PAYMENT_CONTEXT_QUERY : graphqlQueries.UPDATE_PAYMENT_CONTEXT_QUERY;\n return client.request({\n api: \"graphQLApi\",\n data: {\n query: query,\n variables: {\n input: {\n id: self._venmoPaymentContextId,\n status: \"CANCELED\"\n }\n }\n }\n });\n }\n return Promise.resolve();\n });\n };\n Venmo.prototype._cancelVenmoDesktopContext = function () {\n var self = this;\n return this._createPromise.then(function () {\n if (self._venmoDesktopInstance) {\n self._venmoDesktopInstance.updateVenmoDesktopPaymentContext(\"CANCELED\");\n }\n return Promise.resolve();\n });\n };\n\n /**\n * Cleanly tear down anything set up by {@link module:braintree-web/venmo.create|create}.\n * @public\n * @param {callback} [callback] Called once teardown is complete. No data is returned if teardown completes successfully.\n * @example\n * venmoInstance.teardown();\n * @example tokenizePayload
is a {@link VisaCheckout~tokenizePayload|tokenizePayload}. If no callback is provided, `tokenize` returns a promise that resolves with the {@link VisaCheckout~tokenizePayload|tokenizePayload}.\n * @returns {(Promise|void)} Returns a promise if no callback is provided.\n */\n VisaCheckout.prototype.tokenize = function (payment) {\n var self = this;\n if (!payment.callid || !payment.encKey || !payment.encPaymentData) {\n return Promise.reject(new BraintreeError(errors.VISA_CHECKOUT_PAYMENT_REQUIRED));\n }\n return this._client.request({\n method: \"post\",\n endpoint: \"payment_methods/visa_checkout_cards\",\n data: {\n _meta: {\n source: \"visa-checkout\"\n },\n visaCheckoutCard: {\n callId: payment.callid,\n encryptedPaymentData: payment.encPaymentData,\n encryptedKey: payment.encKey\n }\n }\n }).then(function (response) {\n analytics.sendEvent(self._client, \"visacheckout.tokenize.succeeded\");\n return response.visaCheckoutCards[0];\n }).catch(function (err) {\n analytics.sendEvent(self._client, \"visacheckout.tokenize.failed\");\n return Promise.reject(new BraintreeError({\n type: errors.VISA_CHECKOUT_TOKENIZATION.type,\n code: errors.VISA_CHECKOUT_TOKENIZATION.code,\n message: errors.VISA_CHECKOUT_TOKENIZATION.message,\n details: {\n originalError: err\n }\n }));\n });\n };\n\n /**\n * Cleanly tear down anything set up by {@link module:braintree-web/visa-checkout.create|create}.\n * @public\n * @param {callback} [callback] Called once teardown is complete. No data is returned if teardown completes successfully.\n * @example\n * visaCheckoutInstance.teardown();\n * @example \n {{\n (userDataService?.userData?.configParams?.pixBrInfo?.isSeamless\n ? 'PARTY.CASHIER.web.deposit.failure.descriptionNew'\n : 'PARTY.CASHIER.web.deposit.failure.description'\n ) | translate\n }}\n
\n\n {{ 'PARTY.CASHIER.web.deposit.bankregistration.failure.content1' | translate }}\n
\n\n {{ 'PARTY.CASHIER.web.deposit.bankregistration.failure.content2' | translate }}\n
\n{{ 'PARTY.CASHIER.web.deposit.ada.interaction.uk.msg' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.ada.interaction.uk.msg1' | translate }}
\n \n{{ 'PARTY.CASHIER.web.deposit.ada.interaction.uk.msg2' | translate }}
\n \n \n {{ 'PARTY.CASHIER.web.deposit.ada.interaction.cancel' | translate }} \n {{ 'PARTY.CASHIER.web.deposit.ada.interaction.continue' | translate }} \n \n \n{{ 'PARTY.CASHIER.web.ada.interaction.msg1' | translate }}
\n{{ 'PARTY.CASHIER.web.ada.interaction.msg2' | translate }}
\n{{ 'PARTY.CASHIER.web.ada.interaction.msg3' | translate }}
\n \n \n {{ 'PARTY.CASHIER.web.continue' | translate }} \n {{ 'PARTY.CASHIER.web.ada.interaction.adjust.amount' | translate }} \n \n{{ 'PARTY.CASHIER.web.arc.deposit.limits.intervention.declined.msg.quote' | translate }}
\n{{ 'PARTY.CASHIER.web.arc.deposit.limits.intervention.blocked.body.msg1' | translate }}
\n\n {{\n 'PARTY.CASHIER.web.arc.deposit.limits.intervention.blocked.body.msg2'\n | translate\n : {\n hhmm: arcDepositBlockStatus?.expiryTime,\n date: arcDepositBlockStatus?.expiryDate,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.kyc.verification.msg2' | translate }}
\n \n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.301.msg2'\n | translate\n : {\n accountbalanceInfo: userBalance | vnCurrency: currencyPLN,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.301.msg3'\n | translate\n : {\n amount: depositLimit | vnCurrency: currencyPLN,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.301.msg2'\n | translate\n : {\n accountbalanceInfo: userBalance | vnCurrency: currencyPLN,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.302.msg1'\n | translate\n : {\n amount: depositLimit | vnCurrency: currencyPLN,\n }\n }}\n
\n \n{{ 'PARTY.CASHIER.web.play.break.message' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.purchaselimits.message' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.rglimitsexceeded.daily.message' | translate }}
\n }\n @case ('117') {\n{{ 'PARTY.CASHIER.web.deposit.rglimitsexceeded.weekly.message' | translate }}
\n }\n @case ('118') {\n{{ 'PARTY.CASHIER.web.deposit.rglimitsexceeded.monthly.message' | translate }}
\n }\n }\n{{ 'PARTY.CASHIER.web.deposit.instrument.limit.exceeded.message' | translate }}
\n }\n @case ('INSTRUMENT_DEPOSIT_LIMIT_TO_BE_EXCEEDED') {\n{{ 'PARTY.CASHIER.web.deposit.instrument.limit.revised.amount.message' | translate }}
\n }\n }\n \n{{ 'PARTY.CASHIER.web.deposit.notavailble' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.decline.message1.v3.text' | translate }}
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.limit.exceededsweden'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.de.limit.exceeded.msg'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.de.sofort.msg'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n }\n }}\n
\n\n \n {{ 'PARTY.CASHIER.web.deposit.de.limit.another.option' | translate }}.\n
\n @if (isDepositAllowedOnOtherProduct) {\n\n {{\n 'PARTY.CASHIER.web.deposit.de.proposed.product.msg'\n | translate\n : {\n product: proposedProduct,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.limit.exce.gbr'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.limit.exce.irl'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.de.limit.tobe.exceededmsg'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.de.limit.tobe.exceeded1msg'\n | translate\n : {\n product: productToShow,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.de.limit.tobe.exceeded3' | translate }}
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.limit.tobe.exceeded'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n allowedDepLimit:\n kycDetails.kycRemainingLimit?.value\n | vnCurrency: kycDetails.kycRemainingLimit?.currencyCode,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.limit.tobe.exceed.sb'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n kycStandardLimit:\n kycDetails.additionalInfo?.kycStandardLimitAmount\n | vnCurrency: kycDetails.additionalInfo?.kycStandardLimitCurrency,\n allowedDepLimit:\n kycDetails.kycRemainingLimit?.value\n | vnCurrency: kycDetails.kycRemainingLimit?.currencyCode,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.kyc.limit.exce.gbr'\n | translate\n : {\n kycDepositLimit: kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.de.sofort.msg'\n | translate\n : {\n kycDepositLimit:\n kycDetails.kycLimit?.value | vnCurrency: kycDetails.kycLimit?.currencyCode,\n }\n }}\n
\n \n {{ 'PARTY.CASHIER.web.deposit.de.limit.another.option' | translate }}.\n\n {{\n 'PARTY.CASHIER.web.deposit.de.proposed.product.msg'\n | translate\n : {\n product: proposedProduct,\n }\n }}\n
\n\n {{ 'PARTY.CASHIER.web.deposit.kyc.graceperiod.completed' | translate }}\n
\n }\n\n {{\n 'PARTY.CASHIER.web.deposit.qd.centraldeplimit.exceeded.message'\n | translate\n : {\n remainingAmount:\n CentralDepLimitsErrorDetails?.errorResponse?.remainingAmount\n | vnCurrency: CentralDepLimitsErrorDetails?.amount?.currencyCode,\n }\n }}\n
\n }\n @if (!ExceededCase) {\n{{ 'PARTY.CASHIER.web.deposit.qd.centraldeplimit.exhausted.message' | translate }}
\n }\n\n {{\n 'PARTY.CASHIER.web.deposit.decline.message2.refund.cdr.message'\n | translate\n : {\n paymentMethod: paymentMethod,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.decline.message2.rejected.cdr.message' | translate }}
\n\n {{ 'PARTY.CASHIER.web.deposit.paypaldirect.2046.insufficientFunds.text' | translate }}\n
\n }\n @if (['2046 : TRANSACTION_REFUSED', '2046 : INSTRUMENT DECLINED'].includes(depositService.paypalDirectBadFunding?.errorMessage)) {\n\n {{ 'PARTY.CASHIER.web.deposit.paypaldirect.2046.instrumentDecline.text' | translate }}\n
\n }\n{{ 'PARTY.CASHIER.web.deposit.error.DepositDecline.DonotHonour' | translate }}
\n }\n @if (isUSLabel) {\n{{ 'PARTY.CASHIER.web.deposit.error.DepositDecline.DonotHonour.US' | translate }}
\n }\n{{ 'PARTY.CASHIER.web.deposit.insuffientfunds.text' | translate }}
\n }\n @if (isUSLabel) {\n{{ 'PARTY.CASHIER.web.deposit.insuffientfunds.text.US' | translate }}
\n }\n{{ 'PARTY.CASHIER.web.deposit.invalidCvv.text' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.internalErrorDetails.text' | translate }}
\n{{ 'PARTY.CASHIER.web.arc.deposit.limits.interaction.bmsg1' | translate }}
\n{{ 'PARTY.CASHIER.web.arc.deposit.limits.interaction.bmsg2' | translate }}
\n\n {{ 'PARTY.CASHIER.web.deposit.affordibility.limit.exceeded.msg' | translate }}\n {{\n amlNetDepLimitErrorDetails?.contactEmail\n }}\n
\n\n {{ 'PARTY.CASHIER.web.deposit.affordibility.limit.tobeexceeded.msg' | translate }}\n {{\n amlNetDepLimitErrorDetails?.contactEmail\n }}\n
\n\n @if (!isCountryUK) {\n \n {{\n 'PARTY.CASHIER.web.svoc.161.message1'\n | translate\n : {\n phoneNumber: amlNetDepLimitErrorDetails?.contactUsPhone,\n }\n }}\n \n }\n @if (isCountryUK) {\n \n {{\n 'PARTY.CASHIER.web.svoc.161.message1.uk'\n | translate\n : {\n phoneNumber: amlNetDepLimitErrorDetails?.contactUsPhone,\n }\n }}\n \n }\n chat\n {{ 'PARTY.CASHIER.web.svoc.161.message3' | translate }}\n {{\n amlNetDepLimitErrorDetails?.contactEmail\n }}\n {{ 'PARTY.CASHIER.web.svoc.161.message2' | translate }}\n
\n{{ 'PARTY.CASHIER.web.deposit.hardstop.limit.text1' | translate }}
\n \n\n {{\n 'PARTY.CASHIER.web.172.limit.to.be.reached.msg3'\n | translate\n : {\n remainingamount:\n prorgDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: prorgDepLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n\n {{ 'PARTY.CASHIER.web.deposit.hardstop.limit.text1' | translate }}\n
\n \n{{ 'PARTY.CASHIER.web.deposit.hardstop.limit.text1' | translate }}
\n \n\n {{\n 'PARTY.CASHIER.web.172.limit.to.be.reached.msg3'\n | translate\n : {\n remainingamount:\n prorgDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: prorgDepLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.hardstop.limit.text1' | translate }}
\n \n\n {{\n 'PARTY.CASHIER.web.monthly.hardstop.limit.exceeded'\n | translate\n : {\n phoneNumber: prorgDepLimitErrorDetails?.contactUsNumber,\n }\n }}\n
\n }\n @if (isCountryUK) {\n\n {{\n 'PARTY.CASHIER.web.monthly.hardstop.limit.exceeded.uk'\n | translate\n : {\n phoneNumber: prorgDepLimitErrorDetails?.contactUsNumber,\n }\n }}\n
\n }\n\n {{\n 'PARTY.CASHIER.web.svoc.harstop.monthly.limit.tobeexceeded'\n | translate\n : {\n limit:\n prorgDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: prorgDepLimitErrorDetails?.allowedAmt?.currencyCode,\n phoneNumber: prorgDepLimitErrorDetails?.contactUsNumber,\n }\n }}\n
\n }\n @if (isCountryUK) {\n\n {{\n 'PARTY.CASHIER.web.svoc.harstop.monthly.limit.tobeexceeded.uk'\n | translate\n : {\n limit:\n prorgDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: prorgDepLimitErrorDetails?.allowedAmt?.currencyCode,\n phoneNumber: prorgDepLimitErrorDetails?.contactUsNumber,\n }\n }}\n
\n }\n\n {{\n 'PARTY.CASHIER.web.svoc.chat.text' | translate\n }}.\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.belgium.aff.limits.description'\n | translate\n : {\n BelgiumLimit: maxPurchaseLimit | vnCurrency: currencyEUR,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.belgium.aff.limits.time'\n | translate\n : {\n availableBelgiumLimit: availableBelgiumLimit | vnCurrency: currencyEUR,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.belgium.aff.exceeded.limits.description'\n | translate\n : {\n BelgiumLimit: maxPurchaseLimit | vnCurrency: currencyEUR,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.belgium.aff.exceeded.limits.time'\n | translate\n : {\n nextDate: nextDate.substring(0, 10),\n time: nextDate.substring(nextDate.length - 5),\n }\n }}\n
\n\n {{ 'PARTY.CASHIER.web.deposit.sportslimitsexceeded.monthly.message4' | translate }}\n
\n }\n\n {{ 'PARTY.CASHIER.web.deposit.gaminglimitsexceeded.monthly.message4' | translate }}\n
\n }\n\n {{ 'PARTY.CASHIER.web.deposit.gaminglimit.casinoandpoker.message' | translate }}\n \n {{ 'PARTY.CASHIER.web.deposit.deposit.limits.set' | translate }}\n \n
\n }\n @if (!isCasinoAndPokerProductError && isCasinoProductError) {\n\n {{ 'PARTY.CASHIER.web.deposit.gaminglimit.casino.message' | translate }} \n {{ 'PARTY.CASHIER.web.deposit.deposit.limits.set' | translate }}\n \n
\n }\n @if (!isCasinoAndPokerProductError && isPokerProductError) {\n\n {{ 'PARTY.CASHIER.web.deposit.gaminglimit.poker.message' | translate }} \n {{ 'PARTY.CASHIER.web.deposit.deposit.limits.set' | translate }}\n \n
\n }\n{{ 'PARTY.CASHIER.web.deposit.card.blocked.msg1' | translate }}
\n }\n @case ('CC_DEPOSIT_BLOCK_COOLOFF') {\n{{ 'PARTY.CASHIER.web.deposit.card.blocked.msg1' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.card.blocked.coolOff' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.gamerscard.error.1000.message' | translate }}
\n }\n @case (1001) {\n{{ 'PARTY.CASHIER.web.deposit.gamerscard.error.1001.message' | translate }}
\n }\n @case (2000) {\n{{ 'PARTY.CASHIER.web.deposit.gamerscard.error.2000.message' | translate }}
\n }\n @case (2001) {\n{{ 'PARTY.CASHIER.web.deposit.gamerscard.error.2001.message' | translate }}
\n }\n @case (2003) {\n{{ 'PARTY.CASHIER.web.deposit.gamerscard.error.2003.message' | translate }}
\n }\n @case (2005) {\n{{ 'PARTY.CASHIER.web.deposit.gamerscard.error.2005.message' | translate }}
\n }\n }\n{{ 'PARTY.CASHIER.web.deposit.risk.player.message' | translate }}
\n {{ 'PARTY.CASHIER.web.arc.deposit.limits.intervention.liveChat' | translate }}\n\n {{ 'PARTY.CASHIER.web.monthly.affordibility.limit.exceeded.msg1' | translate }}\n
\n }\n @if (isCountryUK) {\n\n {{ 'PARTY.CASHIER.web.monthly.affordibility.limit.exceeded.msg1.uk' | translate }}\n \n {{ affordibilityMonthlyNetDepLimitErrorDetails?.contactEmail }}\n
\n }\n\n {{\n 'PARTY.CASHIER.web.affordibility.limit.tobeexceeded.msg1'\n | translate\n : {\n netDepLimit:\n affordibilityMonthlyNetDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: affordibilityMonthlyNetDepLimitErrorDetails?.accountCurrency,\n }\n }}\n
\n\n {{\n 'PARTY.CASHIER.web.bonus.redirect.page' | translate\n }}.\n
\n\n {{\n 'PARTY.CASHIER.web.183.deposit.affordibility.limit.to.be.exceeded.msg5'\n | translate\n : {\n remainingamount:\n affordibilityMonthlyGrossDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency\n : affordibilityMonthlyGrossDepLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n \n \n }\n\n {{\n 'PARTY.CASHIER.web.183.deposit.affordibility.limit.to.be.exceeded.msg5'\n | translate\n : {\n remainingamount:\n affordibilityMonthlyGrossDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency\n : affordibilityMonthlyGrossDepLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n \n }\n\n {{\n 'PARTY.CASHIER.web.178.deposit.affordibility.limit.to.be.exceeded.msg3'\n | translate\n : {\n remainingamount:\n affordibilityYearlyGrossDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency\n : affordibilityYearlyGrossDepLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n \n }\n\n {{\n 'PARTY.CASHIER.web.178.deposit.affordibility.limit.to.be.exceeded.msg3'\n | translate\n : {\n remainingamount:\n affordibilityYearlyGrossDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency\n : affordibilityYearlyGrossDepLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n \n }\n{{ 'PARTY.CASHIER.web.deposit.hardstop.limit.text3' | translate }}
\n \n\n {{\n 'PARTY.CASHIER.web.181.deposit.affordibility.limit.to.be.exceeded.msg4'\n | translate\n : {\n remainingamount:\n affordibilityLtmGrossLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: affordibilityLtmGrossLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.hardstop.limit.text3' | translate }}
\n \n{{ 'PARTY.CASHIER.web.deposit.hardstop.limit.text3' | translate }}
\n \n\n {{\n 'PARTY.CASHIER.web.181.deposit.affordibility.limit.to.be.exceeded.msg4'\n | translate\n : {\n remainingamount:\n affordibilityLtmGrossLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: affordibilityLtmGrossLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.hardstop.limit.text3' | translate }}
\n \n{{ 'PARTY.CASHIER.web.172.limit.to.be.reached.msg2' | translate }}
\n\n {{ 'PARTY.CASHIER.web.172.limit.to.be.reached.msg4' | translate }}\n {{ 'PARTY.CASHIER.web.172.limit.reached.msg2' | translate }}\n
\n\n {{ 'PARTY.CASHIER.web.172.limit.to.be.reached.msg2' | translate }}\n {{ 'PARTY.CASHIER.web.172.limit.to.be.reached.msg4' | translate }}\n
\n\n {{\n 'PARTY.CASHIER.web.172.limit.to.be.reached.msg3'\n | translate\n : {\n remainingamount:\n affordibilityTUDepLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: affordibilityTUDepLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n\n \n
\n
\n {{\n 'PARTY.CASHIER.web.hardstoplimit.174.limit.to.be.reached.msg2'\n | translate\n : {\n remainingamount:\n affordibilityHardStopLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: affordibilityHardStopLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n\n {{ 'PARTY.CASHIER.web.175.3k.milestone.limit.reached.msg1' | translate }}\n
\n \n{{ 'PARTY.CASHIER.web.175.3k.milestone.limit.reached.msg3' | translate }}
\n\n {{ 'PARTY.CASHIER.web.175.3k.milestone.limit.reached.msg1' | translate }}\n
\n\n {{\n 'PARTY.CASHIER.web.175.3k.milestone.limit.to.be.reached.msg1'\n | translate\n : {\n remainingamount:\n affordibility3kMilestoneLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: affordibility3kMilestoneLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n{{ 'PARTY.CASHIER.web.175.3k.milestone.limit.reached.msg3' | translate }}
\n\n {{ 'PARTY.CASHIER.web.180.limit.tobereached.msg3' | translate }}
\n
{{ 'PARTY.CASHIER.web.180.tobereached.msg6' | translate }}
\n @if (hideChat) {\n \n }\n\n {{\n 'PARTY.CASHIER.web.176.8k.milestone.to.be.limit.reached.msg2'\n | translate\n : {\n remainingamount:\n affordibility8kMilestoneLimitErrorDetails?.allowedAmt?.value\n | vnCurrency: affordibility8kMilestoneLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n \n{{ 'PARTY.CASHIER.web.179.milestone.limit.exceeded.msg3' | translate }}
\n \n }\n\n {{\n 'PARTY.CASHIER.web.179.milestone.limit.to.be.exceeded.msg1'\n | translate\n : {\n remainingamount:\n affordibilityMilestoneSgqGrossLimitErrorDetails?.allowedAmt?.value\n | vnCurrency\n : affordibilityMilestoneSgqGrossLimitErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n{{ 'PARTY.CASHIER.web.179.milestone.limit.to.be.exceeded.msg3' | translate }}
\n \n }\n\n {{\n 'PARTY.CASHIER.web.180.deposit.affordibility.limit.to.be.exceeded.msg4'\n | translate\n : {\n remainingamount:\n affordibilityMilestoneSelfCertGrossLimitErrorDetails?.allowedAmt?.value\n | vnCurrency\n : affordibilityMilestoneSelfCertGrossLimitErrorDetails?.allowedAmt\n ?.currencyCode,\n }\n }}\n
\n \n \n \n }\n\n {{\n 'PARTY.CASHIER.web.svoc.161.message1'\n | translate\n : {\n phoneNumber: svocAffordabilityErrorDetails?.contactUsPhone,\n }\n }}\n
\n }\n @if (isCountryUK) {\n\n {{\n 'PARTY.CASHIER.web.svoc.161.message1.uk'\n | translate\n : {\n phoneNumber: svocAffordabilityErrorDetails?.contactUsPhone,\n }\n }}\n
\n }\n chat\n {{ 'PARTY.CASHIER.web.svoc.161.message3' | translate }}\n {{\n svocAffordabilityErrorDetails?.contactEmail\n }}\n {{ 'PARTY.CASHIER.web.svoc.161.message2' | translate }}\n \n\n {{\n 'PARTY.CASHIER.web.svoc.161.message1'\n | translate\n : {\n phoneNumber: svocAffordabilityErrorDetails?.contactUsPhone,\n }\n }}\n
\n }\n @if (isCountryUK) {\n\n {{\n 'PARTY.CASHIER.web.svoc.161.message1.uk'\n | translate\n : {\n phoneNumber: svocAffordabilityErrorDetails?.contactUsPhone,\n }\n }}\n
\n }\n chat\n {{ 'PARTY.CASHIER.web.svoc.161.message3' | translate }}\n {{\n svocAffordabilityErrorDetails?.contactEmail\n }}\n {{ 'PARTY.CASHIER.web.svoc.161.message2' | translate }}\n \n{{ 'PARTY.CASHIER.web.svoc.160.message1' | translate }}
\n }\n @if (isCountryUK) {\n{{ 'PARTY.CASHIER.web.svoc.160.message1.uk' | translate }}
\n }\n\n {{\n 'PARTY.CASHIER.web.svoc.160.message2'\n | translate\n : {\n allowedAmt:\n svocAffordabilityErrorDetails?.allowedAmt?.value\n | vnCurrency: svocAffordabilityErrorDetails?.accountCurrency,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.179.milestone.limit.exceeded.msg3' | translate }}
\n{{ 'PARTY.CASHIER.web.191.deposit.affordibility.limit.exceeded.text3' | translate }}
\n\n {{\n 'PARTY.CASHIER.web.181.deposit.affordibility.limit.to.be.exceeded.msg4'\n | translate\n : {\n remainingamount:\n rolling30dayLossLimitDetails?.allowedAmt?.value\n | vnCurrency: rolling30dayLossLimitDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.191.deposit.affordibility.limit.exceeded.text3' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.maxlosslimit.reached.msg' | translate }}
\n\n {{\n 'PARTY.CASHIER.web.deposit.maxlosslimit.tobeReached.msg1'\n | translate\n : {\n remainingamount:\n maxLossLimitMonthlyExceededErrorDetails?.allowedAmt?.value\n | vnCurrency: maxLossLimitMonthlyExceededErrorDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n \n{{ 'PARTY.CASHIER.web.fra.deposit.affordibility.limit.exceeded.msg1' | translate }}
\n \n\n {{\n 'PARTY.CASHIER.web.181.deposit.affordibility.limit.to.be.exceeded.msg4'\n | translate\n : {\n remainingamount:\n frarolling90dayLossLimitDetails?.allowedAmt?.value\n | vnCurrency: frarolling90dayLossLimitDetails?.allowedAmt?.currencyCode,\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.svoc.purchaseLimit.txnExceeded.txt' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.error.description' | translate }}
\n\n {{ 'PARTY.CASHIER.web.deposit.bankregistration.qrcode.generator.processing.txt' | translate }}\n
\n\n {{\n 'PARTY.CASHIER.web.deposit.bankregistration.qrcode.generator.processing.amount'\n | translate\n : {\n processingamount: depositSubmitResponse?.amount?.value | vnCurrency: depositSubmitResponse?.amount?.currencyCode : '1.2',\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.bankregistration.qrcode.generator.processing.time' | translate }}
\n\n {{ 'PARTY.CASHIER.web.deposit.bankregistration.qrcode.generator.processing.sla' | translate: { time: processingTime } }}\n
\n \n{{ 'PARTY.CASHIER.web.deposit.qrcode.generator.instructions.header' | translate }}
\n }\n{{ 'PARTY.CASHIER.web.deposit.bankregistration.pixcode.deposit.amount.label' | translate }}
\n }\n\n {{ depositSubmitResponse?.amount?.value | vnCurrency: depositSubmitResponse?.amount?.currencyCode : '1.2' }}\n
\n @if (userDataService?.userData?.configParams?.isBrazilBankRegEnabled) {\n\n {{ 'PARTY.CASHIER.web.deposit.bankregistration.pixcode.expires.in.label' | translate }}\n {{ timerDurationDetails?.hours }}:{{ timerDurationDetails?.minutes }}:{{ timerDurationDetails?.seconds }}\n
\n } @else {\n\n {{ timerDurationDetails?.hours }}:{{ timerDurationDetails?.minutes }}:{{ timerDurationDetails?.seconds }}\n
\n }\n\n {{ 'PARTY.CASHIER.web.deposit.qrcode.generator.copy.pix.code' | translate }}\n
\n @if (QRCodeCopiedStatus['ICON_CLICKED']?.isActive) {\n{{ depositSubmitResponse?.postData?.textToQRcode }}
\n \n\n {{ depositSubmitResponse?.amount?.value | vnCurrency: depositSubmitResponse?.amount?.currencyCode : '1.2' }}\n
\n @if (providerName == 'OKTO') {\n\n {{\n 'PARTY.CASHIER.web.deposit.ada.intervention.uk.msg'\n | translate\n : {\n time: response?.adaDepositStatus?.expiryTime,\n date: response?.adaDepositStatus?.expiryDate,\n }\n }}\n
\n \n }\n @if (!isCountryUK) {\n\n {{\n 'PARTY.CASHIER.web.ada.intervention.msg1'\n | translate\n : {\n time: response?.adaDepositStatus?.expiryTime,\n date: response?.adaDepositStatus?.expiryDate,\n }\n }}\n
\n }\n @if (isCountryUK) {\n \n }\n @if (!isCountryUK) {\n \n }\n \n @if (showChatNotAvailable) {\n\n {{ 'PARTY.CASHIER.web.deposit.prorgdeplimits.exceeded.bea' | translate }}\n \n {{ response?.playerProtectionEmail }}.\n
\n\n {{ 'PARTY.CASHIER.web.svoc.harstop.deposit.more.info' | translate }}\n {{ response?.hardstopInfoLink }}. \n
\n } @else {\n \n \n{{ 'PARTY.CASHIER.web.svoc.harstop.limit.success.uk.msg2' | translate }}
\n }\n\n {{ 'PARTY.CASHIER.web.deposit.aff.high.velocity.msg1' | translate }}\n
\n\n {{ 'PARTY.CASHIER.web.deposit.aff.high.velocity.msg2' | translate }}\n
\n \n{{ 'PARTY.CASHIER.web.deposit.popupblock.message' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.redirected.message' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.cvv.tooltip' | translate }}
\n \n\n {{\n 'PARTY.CASHIER.web.deposit.ny.creditcard.deposit.limit.message2'\n | translate\n : {\n annualLimit: 100 | vnCurrency: currencyUSD,\n avlAmount: +ccCurrentDepositLimit | vnCurrency: currencyUSD,\n }\n }}\n
\n\n \n {{ 'PARTY.CASHIER.web.deposit.ny.creditcard.deposit.limits.update' | translate }}\n \n
\n{{ 'PARTY.CASHIER.web.limits.exceeded1.' + limitPeriod?.toLowerCase() | translate }}
\n }\n @if (minDepositLimitCheck) {\n\n {{\n 'PARTY.CASHIER.web.limits.exceeded2'\n | translate\n : {\n remainingLimit:\n maxDepositLimit | vnCurrency: selectedOption?.paymentMethodInfo?.maxDepositLimit?.currencyCode,\n }\n }}\n
\n }\n @if (minDepositLimitCheck) {\n {{\n 'PARTY.CASHIER.web.limits.exceeded3' | translate\n }}\n }\n }\n\n {{ 'PARTY.CASHIER.web.limits.rg.exceeded.' + limitPeriod?.toLowerCase() | translate }}\n @if (country == 'BE') {\n \n \n } @else {\n {{ 'PARTY.CASHIER.web.limits.rg.non_be.review' | translate }}\n }\n
\n }\n @if (selfLimits.type.includes('purchase_limit') || selfLimits.type.includes('overall_deposit_limit')) {\n @if (selfLimits.type.includes('purchase_limit')) {\n \n } @else {\n {{ 'PARTY.CASHIER.web.limits.purchaselimits.exceeded' | translate }} \n \n }\n }\n\n {{\n 'PARTY.CASHIER.web.deposit.rekyc.tobeExceeded.limit.' + spainRekycLimitTemplate + '.minAmount.header'\n | translate\n : {\n remainingLimit:\n userDataService?.userData?.configParams?.rekycRemainingLimit\n | vnCurrency: selectedOption?.paymentMethodInfo?.maxDepositLimit?.currencyCode : '1.0',\n }\n }}\n
\n{{ 'PARTY.CASHIER.web.deposit.rekyc.tobeExceeded.limit.' + spainRekycLimitTemplate + '.minAmount.text' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.occu.msg3' | translate }}
\n \n \n\n {{\n 'PARTY.CASHIER.web.deposit.prepaidCard.deposits.entered.exceeds.cumulativeAmount'\n | translate\n : {\n maxLimit: rollingWeekMaxAmount | vnCurrency: selectedOption?.paymentMethodInfo?.minDepositLimit?.currencyCode,\n remainingAmount:\n rollingWeekRemainingAmount | vnCurrency: selectedOption?.paymentMethodInfo?.minDepositLimit?.currencyCode,\n }\n }}\n
\n \n {{ 'PARTY.CASHIER.web.deposit.ny.creditcard.deposit.limits.update' | translate }}\n \n{{ 'PARTY.CASHIER.web.deposit.graceperiod.ended' | translate }}
\n{{ 'PARTY.CASHIER.web.deposit.choose.product.text' | translate }}
\n\n {{ 'PARTY.CASHIER.web.deposit.gaminglimit.casinoandpoker.message' | translate }}\n \n {{ 'PARTY.CASHIER.web.deposit.deposit.limits.set' | translate }}\n \n
\n }\n @if (!isBrandSupportBothCasinoAndPokerProduct && isBrandSupportOnlyCasinoProduct) {\n\n {{ 'PARTY.CASHIER.web.deposit.gaminglimit.casino.message' | translate }} \n {{ 'PARTY.CASHIER.web.deposit.deposit.limits.set' | translate }}\n \n
\n }\n @if (!isBrandSupportBothCasinoAndPokerProduct && isBrandSupportOnlyPokerProduct) {\n\n {{ 'PARTY.CASHIER.web.deposit.gaminglimit.poker.message' | translate }} \n {{ 'PARTY.CASHIER.web.deposit.deposit.limits.set' | translate }}\n \n
\n }\n{{ 'PARTY.CASHIER.web.deposit.occu.hdr' | translate }}
\n {{ 'PARTY.CASHIER.web.deposit.occu.link' | translate }}\n