@alipay/ams-checkout 1.7.1 → 1.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,369 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
3
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
4
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
5
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
6
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
7
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
8
+ function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
9
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
10
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
11
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
12
+ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
13
+ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
14
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
15
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
16
+ function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
17
+ function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
18
+ function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
19
+ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
20
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
21
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
22
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
23
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
24
+ /**
25
+ * Copyright (c) 2022 International Business Group, Ant Group. All rights reserved.
26
+ *
27
+ * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), the rights to use, copy, modify, merge, and/or distribute the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
28
+ * 1. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE; and
29
+ * 2. If applicable, the use of the Software is also subject to the terms and conditions of any non-disclosure agreement signed by you and the relevant Ant Group entity.
30
+ */
31
+ import { componentSignEnum, environmentEnum, eventCodeEnum, productSceneEnum } from "../../types";
32
+ import ApplePayService from "../../common/applepay";
33
+ import { getComponentSign, parseSessionData } from "../component";
34
+ import { getApplePayPaymentSession, submitPayInfo } from "../../service";
35
+ import CoreInstance from "../instance";
36
+ import { EVENT } from "../../constant";
37
+
38
+ /**
39
+ * Apple pay Component
40
+ */
41
+ var ApplePayComponent = /*#__PURE__*/function (_CoreInstance) {
42
+ _inherits(ApplePayComponent, _CoreInstance);
43
+ var _super = _createSuper(ApplePayComponent);
44
+ function ApplePayComponent(options) {
45
+ var _this;
46
+ _classCallCheck(this, ApplePayComponent);
47
+ var _options = Object.assign({
48
+ environment: environmentEnum.prod
49
+ }, options, {
50
+ product: productSceneEnum.CARD_APPLE_PAY
51
+ });
52
+ _this = _super.call(this, _options);
53
+ _defineProperty(_assertThisInitialized(_this), "_applePayService", void 0);
54
+ _defineProperty(_assertThisInitialized(_this), "_parseData", void 0);
55
+ _defineProperty(_assertThisInitialized(_this), "_sessionData", void 0);
56
+ _defineProperty(_assertThisInitialized(_this), "_isFinish", false);
57
+ _this._applePayService = new ApplePayService();
58
+ return _this;
59
+ }
60
+ _createClass(ApplePayComponent, [{
61
+ key: "getDeviceIdAndLog",
62
+ value: function getDeviceIdAndLog() {
63
+ var _this2 = this;
64
+ var deviceIdParameter = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
65
+ var isPolling = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
66
+ return new Promise(function (resolve) {
67
+ // To avoid rendering being blocked, move the logic to the next event loop for processing
68
+ setTimeout( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
69
+ var _this2$_parseData;
70
+ var productScene, getDeviceIdStartTime, securitySDK, deviceId;
71
+ return _regeneratorRuntime().wrap(function _callee$(_context) {
72
+ while (1) switch (_context.prev = _context.next) {
73
+ case 0:
74
+ productScene = (_this2$_parseData = _this2._parseData) === null || _this2$_parseData === void 0 || (_this2$_parseData = _this2$_parseData.paymentSessionConfig) === null || _this2$_parseData === void 0 ? void 0 : _this2$_parseData.productScene;
75
+ getDeviceIdStartTime = Date.now();
76
+ securitySDK = _this2._getSecuritySDKByProductScene({
77
+ product: (deviceIdParameter === null || deviceIdParameter === void 0 ? void 0 : deviceIdParameter.productScene) || productScene
78
+ });
79
+ deviceId = '';
80
+ if (!securitySDK) {
81
+ _context.next = 16;
82
+ break;
83
+ }
84
+ if (!(isPolling && parseInt(deviceIdParameter === null || deviceIdParameter === void 0 ? void 0 : deviceIdParameter.tokenCollectTime) > 0)) {
85
+ _context.next = 11;
86
+ break;
87
+ }
88
+ _context.next = 8;
89
+ return securitySDK.pollingGetApdidToken(deviceIdParameter);
90
+ case 8:
91
+ _context.t0 = _context.sent;
92
+ _context.next = 14;
93
+ break;
94
+ case 11:
95
+ _context.next = 13;
96
+ return securitySDK.getApdidToken();
97
+ case 13:
98
+ _context.t0 = _context.sent;
99
+ case 14:
100
+ deviceId = _context.t0;
101
+ _this2.logDeviceId(deviceId, getDeviceIdStartTime);
102
+ case 16:
103
+ resolve(deviceId);
104
+ case 17:
105
+ case "end":
106
+ return _context.stop();
107
+ }
108
+ }, _callee);
109
+ })), 0);
110
+ });
111
+ }
112
+ }, {
113
+ key: "logDeviceId",
114
+ value: function logDeviceId(deviceId, getDeviceIdStartTime) {
115
+ var time = "".concat(Date.now() - getDeviceIdStartTime);
116
+ if (deviceId) {
117
+ this.logger.logInfo({
118
+ title: 'sdk_event_securitySdkGetTokenSuccess'
119
+ }, {
120
+ deviceId: deviceId,
121
+ time: time
122
+ }).send();
123
+ } else {
124
+ this.logger.logInfo({
125
+ title: 'sdk_error_securitySdkGetTokenFailed'
126
+ }, {
127
+ deviceId: deviceId,
128
+ time: time
129
+ }).send();
130
+ }
131
+ }
132
+
133
+ /**
134
+ * Is Apple Pay Enabled
135
+ */
136
+ }, {
137
+ key: "isAppPayEnabled",
138
+ value: function isAppPayEnabled() {
139
+ return this._applePayService.isEnabled();
140
+ }
141
+
142
+ /**
143
+ * Submit Pay
144
+ * @param paymentSessionData
145
+ */
146
+ }, {
147
+ key: "submitPay",
148
+ value: function submitPay(paymentSessionData) {
149
+ var _this3 = this;
150
+ this._isFinish = false;
151
+ // parse session Data
152
+ var _parseSessionData = parseSessionData(paymentSessionData),
153
+ _parseSessionData2 = _slicedToArray(_parseSessionData, 2),
154
+ parseData = _parseSessionData2[0],
155
+ sessionData = _parseSessionData2[1];
156
+ this._parseData = parseData;
157
+ this._sessionData = sessionData;
158
+ // parse data is null
159
+ if (Object.keys(parseData).length === 0) {
160
+ this._eventCenter.emit(EVENT.eventCallback.name, {
161
+ code: eventCodeEnum.SDK_PAYMENT_FAIL,
162
+ result: {
163
+ errorMsg: 'Abnormal response data is null'
164
+ }
165
+ });
166
+ this.logger.logError({
167
+ name: 'APPLE_PAY',
168
+ title: 'sessionDataNull',
169
+ msg: 'Abnormal response data is null'
170
+ }, {
171
+ type: 'error',
172
+ biz: 'sdk'
173
+ }).send();
174
+ return;
175
+ }
176
+ // validate parse data
177
+ var componentSign = getComponentSign(parseData);
178
+ if (componentSign === componentSignEnum.NONE) {
179
+ // eslint-disable-next-line prefer-promise-reject-errors
180
+ this._eventCenter.emit(EVENT.eventCallback.name, {
181
+ code: eventCodeEnum.SDK_PAYMENT_FAIL,
182
+ result: {
183
+ errorMsg: "Abnormal response data, interface failure, or unsupported payment method"
184
+ }
185
+ });
186
+ this.logger.logError({
187
+ name: 'APPLE_PAY',
188
+ title: 'paymentMethodUnknown',
189
+ msg: 'Abnormal response data, interface failure, or unsupported payment method'
190
+ }, {
191
+ type: 'error',
192
+ biz: 'sdk'
193
+ }).send();
194
+ return;
195
+ }
196
+ /**
197
+ * Get MerchantSession spi
198
+ * @param event
199
+ */
200
+ var getMerchantSession = /*#__PURE__*/function () {
201
+ var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(_ref2) {
202
+ var validationUrl, requestParams;
203
+ return _regeneratorRuntime().wrap(function _callee2$(_context2) {
204
+ while (1) switch (_context2.prev = _context2.next) {
205
+ case 0:
206
+ validationUrl = _ref2.validationUrl;
207
+ // get validateUrl
208
+ requestParams = {
209
+ validateUrl: validationUrl,
210
+ paymentSessionData: _this3._sessionData
211
+ }; // get deviceId
212
+ _context2.t0 = getApplePayPaymentSession;
213
+ _context2.t1 = _this3._sessionData;
214
+ _context2.t2 = requestParams;
215
+ _context2.t3 = _this3.options.env.environment;
216
+ _context2.next = 8;
217
+ return _this3.getDeviceIdAndLog();
218
+ case 8:
219
+ _context2.t4 = _context2.sent;
220
+ _context2.t5 = {
221
+ deviceId: _context2.t4
222
+ };
223
+ _context2.t6 = {
224
+ env: _context2.t3,
225
+ envInfo: _context2.t5
226
+ };
227
+ _context2.t7 = _this3.logger;
228
+ return _context2.abrupt("return", (0, _context2.t0)(_context2.t1, _context2.t2, _context2.t6, _context2.t7).then(function (res) {
229
+ if (res !== null && res !== void 0 && res.success && res.merchantSessionObject) {
230
+ return Promise.resolve(res.merchantSessionObject);
231
+ }
232
+ return Promise.reject({
233
+ errorCode: res.errorCode,
234
+ errorMessage: res.errorMessage
235
+ });
236
+ }).catch(function (error) {
237
+ return Promise.reject(error);
238
+ }));
239
+ case 13:
240
+ case "end":
241
+ return _context2.stop();
242
+ }
243
+ }, _callee2);
244
+ }));
245
+ return function getMerchantSession(_x) {
246
+ return _ref3.apply(this, arguments);
247
+ };
248
+ }();
249
+
250
+ /**
251
+ * Complete Payment Authorized spi
252
+ * @param tokens
253
+ */
254
+ var completePaymentAuthorized = /*#__PURE__*/function () {
255
+ var _ref5 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(_ref4) {
256
+ var paymentToken, params;
257
+ return _regeneratorRuntime().wrap(function _callee3$(_context3) {
258
+ while (1) switch (_context3.prev = _context3.next) {
259
+ case 0:
260
+ paymentToken = _ref4.paymentToken;
261
+ params = {
262
+ paymentFactors: {
263
+ instPaymentToken: paymentToken
264
+ },
265
+ paymentSessionData: _this3._sessionData
266
+ };
267
+ _context3.t0 = submitPayInfo;
268
+ _context3.t1 = params;
269
+ _context3.t2 = _this3.options.env.environment;
270
+ _context3.next = 7;
271
+ return _this3.getDeviceIdAndLog();
272
+ case 7:
273
+ _context3.t3 = _context3.sent;
274
+ _context3.t4 = {
275
+ deviceId: _context3.t3
276
+ };
277
+ _context3.t5 = {
278
+ env: _context3.t2,
279
+ envInfo: _context3.t4
280
+ };
281
+ _context3.t6 = _this3.logger;
282
+ return _context3.abrupt("return", (0, _context3.t0)(_context3.t1, _context3.t5, _context3.t6).then(function (res) {
283
+ _this3.logger.logInfo({
284
+ name: 'APPLE_PAY',
285
+ title: 'submitPayStatus',
286
+ msg: res === null || res === void 0 ? void 0 : res.errorStatus
287
+ }, {
288
+ biz: 'sdk'
289
+ }).send();
290
+ if (res !== null && res !== void 0 && res.success || (res === null || res === void 0 ? void 0 : res.errorStatus) === 'U') {
291
+ return Promise.resolve(res);
292
+ }
293
+ return Promise.reject({
294
+ errorCode: res.errorCode,
295
+ errorMessage: res.errorMessage
296
+ });
297
+ }).catch(function (error) {
298
+ return Promise.reject(error);
299
+ }));
300
+ case 12:
301
+ case "end":
302
+ return _context3.stop();
303
+ }
304
+ }, _callee3);
305
+ }));
306
+ return function completePaymentAuthorized(_x2) {
307
+ return _ref5.apply(this, arguments);
308
+ };
309
+ }();
310
+ var completeApplePay = function completeApplePay(data) {
311
+ var _data$actionForm;
312
+ _this3._isFinish = true;
313
+ _this3._eventCenter.emit(EVENT.eventCallback.name, {
314
+ code: eventCodeEnum.SDK_PAYMENT_FINISH,
315
+ result: {
316
+ redirectUrl: (data === null || data === void 0 || (_data$actionForm = data.actionForm) === null || _data$actionForm === void 0 ? void 0 : _data$actionForm.redirectUrl) || ''
317
+ }
318
+ });
319
+ };
320
+ var logError = function logError(msg, error) {
321
+ // log error
322
+ _this3.logger.logError({
323
+ name: 'APPLE_PAY',
324
+ title: msg,
325
+ label: msg,
326
+ msg: error
327
+ }, {
328
+ type: 'error',
329
+ biz: 'sdk'
330
+ }).send();
331
+ if (_this3._isFinish) {
332
+ return;
333
+ }
334
+ _this3._isFinish = true;
335
+ if (msg === 'UserCancel') {
336
+ _this3._eventCenter.emit(EVENT.eventCallback.name, {
337
+ code: eventCodeEnum.SDK_PAYMENT_CANCEL
338
+ });
339
+ } else {
340
+ _this3._eventCenter.emit(EVENT.eventCallback.name, {
341
+ code: eventCodeEnum.SDK_PAYMENT_FAIL,
342
+ result: {
343
+ errorMsg: msg
344
+ }
345
+ });
346
+ }
347
+ };
348
+ var applePayTrace = function applePayTrace(msg) {
349
+ // set log funnel
350
+ _this3.logger.logInfo({
351
+ name: 'APPLE_PAY',
352
+ title: msg,
353
+ label: msg
354
+ }, {
355
+ type: 'funnel',
356
+ biz: 'sdk'
357
+ }).send();
358
+ };
359
+
360
+ // set Apple Pay params
361
+ this._applePayService.setApplePayParams(getMerchantSession, completePaymentAuthorized, completeApplePay, logError, applePayTrace);
362
+
363
+ // init Apple Pay service
364
+ this._applePayService.startPay(this._parseData);
365
+ }
366
+ }]);
367
+ return ApplePayComponent;
368
+ }(CoreInstance);
369
+ export default ApplePayComponent;
@@ -1,6 +1,8 @@
1
1
  import ComponentApp from '../../plugin/component';
2
- import { IcreateComponent, IoptionsParams, Iselector, Isubmit } from '../../types';
2
+ import { componentSignEnum, IcreateComponent, IoptionsParams, IpaymentSessionMetaData, Iselector, Isubmit } from '../../types';
3
3
  import CoreInstance from '../instance/index';
4
+ export declare const getComponentSign: (params: IpaymentSessionMetaData) => componentSignEnum;
5
+ export declare const parseSessionData: (sessionData: string) => [IpaymentSessionMetaData, string];
4
6
  export declare class AMSComponent extends CoreInstance {
5
7
  _componentApp: ComponentApp;
6
8
  constructor(options: IoptionsParams);
@@ -33,7 +33,7 @@ import { getOrSetStorageId, isPC } from "../../util";
33
33
  import { createIframeNode } from "../../util/createIframeNode";
34
34
  import { getSecurityConfigStorageKey } from "../../util/security";
35
35
  import CoreInstance from "../instance/index";
36
- var getComponentSign = function getComponentSign(params) {
36
+ export var getComponentSign = function getComponentSign(params) {
37
37
  var _params$paymentSessio = params.paymentSessionConfig,
38
38
  _params$paymentSessio2 = _params$paymentSessio === void 0 ? {} : _params$paymentSessio,
39
39
  _params$paymentSessio3 = _params$paymentSessio2.productScene,
@@ -42,7 +42,7 @@ var getComponentSign = function getComponentSign(params) {
42
42
  paymentMethodCategoryType = _params$paymentSessio4 === void 0 ? '' : _params$paymentSessio4;
43
43
  return productScene && paymentMethodCategoryType ? "".concat(productScene, "_").concat(paymentMethodCategoryType) : componentSignEnum.NONE;
44
44
  };
45
- var parseSessionData = function parseSessionData(sessionData) {
45
+ export var parseSessionData = function parseSessionData(sessionData) {
46
46
  try {
47
47
  return [JSON.parse(atob(sessionData.split('&&')[3])), sessionData.split('&&').slice(0, 3).join('&&')];
48
48
  } catch (error) {
@@ -221,6 +221,9 @@ export var AMSComponent = /*#__PURE__*/function (_CoreInstance) {
221
221
  data: data
222
222
  }
223
223
  });
224
+ _this4.logger.logInfo({
225
+ title: 'sdk_event_apiSubmit'
226
+ });
224
227
  } catch (error) {
225
228
  reject(error);
226
229
  }
package/esm/index.d.ts CHANGED
@@ -1,8 +1,11 @@
1
1
  import { AMSComponent } from './core/component/index';
2
2
  import { IoptionsParams } from './types';
3
+ import ApplePayComponent from './core/applepay';
3
4
  export * from './types';
4
5
  export declare class AMSCheckout extends AMSComponent {
5
6
  }
7
+ export declare class AMSApplePay extends ApplePayComponent {
8
+ }
6
9
  export declare class AMSAutoDebit extends AMSCheckout {
7
10
  constructor(options: IoptionsParams);
8
11
  }
package/esm/index.js CHANGED
@@ -20,6 +20,7 @@ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.g
20
20
  */
21
21
  import { productSceneEnum } from "./types/index";
22
22
  import { AMSComponent } from "./core/component/index";
23
+ import ApplePayComponent from "./core/applepay";
23
24
  export * from "./types";
24
25
  export var AMSCheckout = /*#__PURE__*/function (_AMSComponent) {
25
26
  _inherits(AMSCheckout, _AMSComponent);
@@ -30,51 +31,60 @@ export var AMSCheckout = /*#__PURE__*/function (_AMSComponent) {
30
31
  }
31
32
  return _createClass(AMSCheckout);
32
33
  }(AMSComponent);
34
+ export var AMSApplePay = /*#__PURE__*/function (_ApplePayComponent) {
35
+ _inherits(AMSApplePay, _ApplePayComponent);
36
+ var _super2 = _createSuper(AMSApplePay);
37
+ function AMSApplePay() {
38
+ _classCallCheck(this, AMSApplePay);
39
+ return _super2.apply(this, arguments);
40
+ }
41
+ return _createClass(AMSApplePay);
42
+ }(ApplePayComponent);
33
43
  export var AMSAutoDebit = /*#__PURE__*/function (_AMSCheckout) {
34
44
  _inherits(AMSAutoDebit, _AMSCheckout);
35
- var _super2 = _createSuper(AMSAutoDebit);
45
+ var _super3 = _createSuper(AMSAutoDebit);
36
46
  function AMSAutoDebit(options) {
37
47
  _classCallCheck(this, AMSAutoDebit);
38
48
  var _options = Object.assign({}, options, {
39
49
  product: productSceneEnum.AUTO_DEBIT
40
50
  });
41
- return _super2.call(this, _options);
51
+ return _super3.call(this, _options);
42
52
  }
43
53
  return _createClass(AMSAutoDebit);
44
54
  }(AMSCheckout);
45
55
  export var AMSEasyPay = /*#__PURE__*/function (_AMSCheckout2) {
46
56
  _inherits(AMSEasyPay, _AMSCheckout2);
47
- var _super3 = _createSuper(AMSEasyPay);
57
+ var _super4 = _createSuper(AMSEasyPay);
48
58
  function AMSEasyPay(options) {
49
59
  _classCallCheck(this, AMSEasyPay);
50
60
  var _options = Object.assign({}, options, {
51
61
  product: productSceneEnum.EASY_PAY
52
62
  });
53
- return _super3.call(this, _options);
63
+ return _super4.call(this, _options);
54
64
  }
55
65
  return _createClass(AMSEasyPay);
56
66
  }(AMSCheckout);
57
67
  export var AMSCashierPayment = /*#__PURE__*/function (_AMSCheckout3) {
58
68
  _inherits(AMSCashierPayment, _AMSCheckout3);
59
- var _super4 = _createSuper(AMSCashierPayment);
69
+ var _super5 = _createSuper(AMSCashierPayment);
60
70
  function AMSCashierPayment(options) {
61
71
  _classCallCheck(this, AMSCashierPayment);
62
72
  var _options = Object.assign({}, options, {
63
73
  product: productSceneEnum.CASHIER_PAYMENT
64
74
  });
65
- return _super4.call(this, _options);
75
+ return _super5.call(this, _options);
66
76
  }
67
77
  return _createClass(AMSCashierPayment);
68
78
  }(AMSCheckout);
69
79
  export var AMSVaulting = /*#__PURE__*/function (_AMSCheckout4) {
70
80
  _inherits(AMSVaulting, _AMSCheckout4);
71
- var _super5 = _createSuper(AMSVaulting);
81
+ var _super6 = _createSuper(AMSVaulting);
72
82
  function AMSVaulting(options) {
73
83
  _classCallCheck(this, AMSVaulting);
74
84
  var _options = Object.assign({}, options, {
75
85
  product: productSceneEnum.VAULTING
76
86
  });
77
- return _super5.call(this, _options);
87
+ return _super6.call(this, _options);
78
88
  }
79
89
  return _createClass(AMSVaulting);
80
90
  }(AMSCheckout);
@@ -1,5 +1,4 @@
1
- import { componentSignEnum, Ianalytics } from '../../types';
2
- import { renderDisplayTypeEnum } from '../../types/index';
1
+ import { renderDisplayTypeEnum, componentSignEnum, Ianalytics } from '../../types';
3
2
  export declare const getAppPath: (environment: string, appVersion: string, componentSign: componentSignEnum, productSceneVersion: string, extendInfo: string) => any;
4
3
  export declare const getAppDomain: (domainParams: {
5
4
  environment: string;
@@ -10,8 +10,8 @@ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e
10
10
  * 2. If applicable, the use of the Software is also subject to the terms and conditions of any non-disclosure agreement signed by you and the relevant Ant Group entity.
11
11
  */
12
12
  import { marmotMap, sdkVersion } from "../../config/index";
13
- import { componentSignEnum } from "../../types";
14
13
  import { getViewPort, queryParse, serialize } from "../../util/index";
14
+ import { componentSignEnum } from "../../types";
15
15
  var getAppVersion = function getAppVersion(_extendInfo) {
16
16
  try {
17
17
  var info = JSON.parse(_extendInfo);
@@ -21,7 +21,7 @@ var getAppVersion = function getAppVersion(_extendInfo) {
21
21
  }
22
22
  };
23
23
  var getFinalProductSceneVersion = function getFinalProductSceneVersion(componentSign, productSceneVersion) {
24
- var signSupportMap = _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, componentSignEnum.NONE, ['']), componentSignEnum.AUTO_DEBIT_WALLET, ['1.0']), componentSignEnum.CASHIER_PAYMENT_BANK, ['1.0']), componentSignEnum.CASHIER_PAYMENT_CARD, ['1.0']), componentSignEnum.EASY_PAY_WALLET, ['1.0', '2.0']), componentSignEnum.VAULTING_CARD, ['1.0']);
24
+ var signSupportMap = _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, componentSignEnum.NONE, ['']), componentSignEnum.AUTO_DEBIT_WALLET, ['1.0']), componentSignEnum.CASHIER_PAYMENT_BANK, ['1.0']), componentSignEnum.CASHIER_PAYMENT_CARD, ['1.0']), componentSignEnum.CASHIER_PAYMENT_APM, ['1.0']), componentSignEnum.EASY_PAY_WALLET, ['1.0', '2.0']), componentSignEnum.VAULTING_CARD, ['1.0']);
25
25
  var supportProductSceneVersion = signSupportMap[componentSign];
26
26
  // 从左到右,从旧到新
27
27
  var isSupport = supportProductSceneVersion.find(function (it) {
@@ -8,7 +8,7 @@
8
8
  import { ANIMATION_TIME, closeImg, COMPONENT_CLOSE_BLOCK_ID, COMPONENT_CONTAINER_ID, COMPONENT_RETENTION_ID, COMPONENT_SECTION_ID, LOADING_ID, MOCKUP_ID } from "../../constant";
9
9
  import { platformEnum } from "../../types";
10
10
  import { addSetFontSizeEvent, amsSetSize, getDesignFontSize } from "../../util";
11
- var componentCss = ".ams-component-container-mobile {\n width: 100%;\n height: 1px;\n position: fixed;\n bottom: -1px;\n left: 0;\n z-index: 1001;\n border-radius: 12px 12px 0 0;\n overflow: hidden;\n}\n.ams-component-container-mobile-animation{\n animation: ams-component-container-slide-in 0.3s ease-in-out;\n}\n\n.ams-component-section-desktop {\n font-size: 0;\n}\n\n.ams-component-container-hidden-mobile {\n width: 100%;\n height: 0px;\n position: fixed;\n bottom: -1px;\n left: 0;\n z-index: 1001;\n background-color: transparent;\n border-radius: 12px 12px 0 0;\n animation: ams-component-container-slide-out 0.26s ease-in forwards;\n overflow: hidden;\n}\n\n.ams-component-section-mobile {\n border-radius: 12px 12px 0 0;\n overflow: hidden;\n font-size: 0;\n}\n\n.ams-component-container-desktop {\n display: block;\n width: 672px;\n position: fixed;\n top: 50%;\n left: 50%;\n z-index: 1001;\n border-radius: 8px;\n overflow: hidden;\n transform-origin: 50% 50%;\n}\n.ams-component-container-desktop-animation{\n animation: ams-component-container-zoom-in 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n\n@keyframes ams-component-container-zoom-out {\n 0% {\n transform: translate(-50%, -50%) scale(1);\n -webkit-transform: translate(-50%, -50%) scale(1);\n opacity: 1\n }\n \n 100% {\n opacity: 0;\n transform: translate(-50%, -50%) scale(0.4);\n -webkit-transform: translate(-50%, -50%) scale(0.4);\n }\n}\n\n@keyframes ams-component-container-zoom-in {\n 0% {\n transform: translate(-50%, -50%) scale(0.4);\n opacity: 0\n }\n\n 80% {\n opacity: 1\n }\n\n 100% {\n opacity: 1;\n transform: translate(-50%, -50%) scale(1);\n }\n}\n\n.ams-component-container-hidden-desktop {\n display: block;\n position: fixed;\n top: 50%;\n left: 50%;\n z-index: 1001;\n border-radius: 8px;\n overflow: hidden;\n animation: ams-component-container-zoom-out 0.3s ease-in-out;\n animation-fill-mode: forwards;\n transform-origin: 50% 50%;\n}\n\n.ams-component-loading {\n width: 0.8em;\n height:0.8em;\n background: rgba(0, 0, 0, 0.5);\n border-radius: 8px;\n position: fixed;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n z-index: 1001;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n}\n\n.ams-component-loading .line {\n width: 40px;\n height: 40px;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n}\n.ams-component-loading .line div {\n position: absolute;\n left: 17.67px;\n top: 0;\n width: 5.33px;\n height: 40px;\n}\n\n.ams-component-loading .line div:before,\n.ams-component-loading .line div:after {\n content: '';\n display: block;\n height: 13.33px;\n background: #fcfcfc;\n border-radius: 5.3px;\n}\n.ams-component-loading .line div:after {\n margin-top: 13.33px;\n}\n\n.ams-component-loading .line div:nth-child(2) {\n -webkit-transform: rotate(45deg);\n}\n\n.ams-component-loading .line div:nth-child(3) {\n -webkit-transform: rotate(90deg);\n}\n\n.ams-component-loading .line div:nth-child(4) {\n -webkit-transform: rotate(135deg);\n}\n\n/** \u52A0\u8F7D\u52A8\u753B **/\n@-webkit-keyframes load {\n 0% {\n opacity: 0;\n }\n\n 100% {\n opacity: 1;\n }\n}\n\n.ams-component-loading .line div:nth-child(1):before {\n -webkit-animation: load 1s linear 0s infinite;\n}\n\n.ams-component-loading .line div:nth-child(2):before {\n -webkit-animation: load 1s linear 0.125s infinite;\n}\n\n.ams-component-loading .line div:nth-child(3):before {\n -webkit-animation: load 1s linear 0.25s infinite;\n}\n\n.ams-component-loading .line div:nth-child(4):before {\n -webkit-animation: load 1s linear 0.375s infinite;\n}\n\n.ams-component-loading .line div:nth-child(1):after {\n -webkit-animation: load 1s linear 0.5s infinite;\n}\n\n.ams-component-loading .line div:nth-child(2):after {\n -webkit-animation: load 1s linear 0.675s infinite;\n}\n\n.ams-component-loading .line div:nth-child(3):after {\n -webkit-animation: load 1s linear 0.75s infinite;\n}\n\n.ams-component-loading .line div:nth-child(4):after {\n -webkit-animation: load 1s linear 0.875s infinite;\n}\n\n.ams-component-loading-logo {\n width: 0.44em;\n height: 0.44em;\n -webkit-transform:rotate(360deg);\n transform:rotate(360deg);\n -webkit-transition:-webkit-transform 1s linear;\n transition:transform 1s linear;\n animation: ams-component-loading-logo 1s linear infinite;\n}\n\n.asm-component-close-block-desktop {\n position: absolute;\n width: 40px;\n height: 40px;\n right: 0;\n top: 0;\n cursor: pointer;\n}\n.asm-component-close-block-btn-desktop {\n width: 11px;\n height: 11px;\n object-fit: fill;\n position: absolute;\n right: 18.7px;\n top: 26.7px;\n}\n.asm-component-close-block-hidden {\n width: 0px !important;\n height: 0px !important;\n visibility: hidden;\n}\n.asm-component-close-block-mobile {\n position: absolute;\n width: 0.4em;\n height: 0.4em;\n right: 0;\n top: 0;\n cursor: pointer;\n z-index: 1009;\n}\n\n.asm-component-close-block-btn-mobile {\n width: 0.11em;\n height: 0.11em;\n object-fit: fill;\n position: absolute;\n right: 0.147em;\n top: 0.167em;\n}\n\n\n.ams-component-container-opacity{\n opacity: 1;\n}\n\n.ams-component-container-opacity:after{\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n display: block;\n content: \"\";\n z-index: 1010;\n background-color: rgba(0, 0, 0, 0.35);\n}\n\n#ams-component-retention {\n position: fixed;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n transform-origin: 50%;\n height: auto;\n display: none;\n z-index: 1009;\n}\n\n.ams-component-retention-show {\n display: flex !important;\n animation: ams-component-container-zoom-in 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n\n.ams-component-retention-hidden {\n display: flex !important;\n animation: ams-component-container-zoom-out 0.3s ease-in-out;\n -webkit-animation: ams-component-container-zoom-out 0.3s ease-in-out;\n animation-fill-mode: forwards;\n -webkit-animation-fill-mode: forwards;\n}\n\n.ams-component-retention-mobile {\n width: 294px;\n border-radius: 12px;\n padding: 24px 0;\n background-color: #fff;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n box-sizing: border-box;\n}\n\n.ams-component-retention-desktop {\n width: 544px;\n border-radius: 12px;\n padding: 32px;\n background-color: #fff;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n box-sizing: border-box;\n}\n\n@media screen and (max-width: 300px) {\n .ams-component-retention-mobile {\n transform: translate(-50%, -50%) scale(0.8);\n }\n}\n\n.ams-component-retention-title-mobile {\n width: 100%;\n font-style: normal;\n font-weight: 500;\n font-size: 16px;\n line-height: 24px;\n color: #2A3A52;\n text-align: center;\n padding: 0 16px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-title-desktop {\n text-align: left;\n width: 100%;\n font-style: normal;\n font-weight: 500;\n font-size: 16px;\n line-height: 24px;\n color: #2A3A52;\n}\n\n.ams-component-retention-sub-title-mobile {\n width: 100%;\n font-weight: 400;\n font-size: 14px;\n line-height: 20px;\n color: #7C8CA3;\n margin-top: 8px;\n text-align: center;\n padding: 0 16px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-sub-title-desktop {\n text-align: left;\n font-style: normal;\n font-weight: 400;\n font-size: 14px;\n line-height: 20px;\n color: #7C8CA3;\n margin-top: 10px;\n}\n\n.ams-component-retention-btn-block-mobile {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n margin-top: 24px;\n padding: 0 24px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-btn-block-desktop {\n width: 100%;\n margin-top: 24px;\n}\n\n#ams-component-retention-remain {\n background: #0079FF;\n border-radius: 100px;\n font-style: normal;\n font-weight: 500;\n text-align: center;\n box-sizing: border-box;\n color: #FFFFFF;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.ams-component-retention-remain-mobile {\n width: 100%;\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n padding: 0 6px;\n}\n\n.ams-component-retention-remain-desktop {\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n display: inline-block;\n padding: 0 24px;\n float: right;\n cursor: pointer;\n padding: 0 8px;\n max-width: 225px;\n}\n\n#ams-component-retention-leave {\n border-radius: 100px;\n border: 1px solid #0079FF;\n font-style: normal;\n font-weight: 500;\n text-align: center;\n box-sizing: border-box;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.ams-component-retention-leave-mobile {\n width: 100%;\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n color: #1677FF;\n margin-top: 12px;\n padding: 0 6px;\n}\n\n.ams-component-retention-leave-desktop {\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n color: #1677FF;\n display: inline-block;\n padding: 0 24px;\n float: right;\n margin-right: 16px;\n cursor: pointer;\n padding: 0 8px;\n max-width: 225px;\n}\n.".concat(MOCKUP_ID, "-hidden{\nanimation: ").concat(MOCKUP_ID, "-opacity 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n/** \u52A0\u8F7D\u52A8\u753B **/\n@-webkit-keyframes ").concat(MOCKUP_ID, "-opacity {\n 0% {\n opacity: 1;\n }\n\n 100% {\n opacity: 0;\n }\n}\n");
11
+ var componentCss = ".ams-component-container-mobile {\n width: 100%;\n height: 1px;\n position: fixed;\n bottom: -1px;\n left: 0;\n z-index: 1001;\n border-radius: 12px 12px 0 0;\n overflow: hidden;\n}\n.ams-component-container-mobile-animation{\n animation: ams-component-container-slide-in 0.3s ease-in-out;\n}\n\n.ams-component-section-desktop {\n font-size: 0;\n}\n\n.ams-component-container-hidden-mobile {\n width: 100%;\n height: 0px;\n position: fixed;\n bottom: -1px;\n left: 0;\n z-index: 1001;\n background-color: transparent;\n border-radius: 12px 12px 0 0;\n animation: ams-component-container-slide-out 0.26s ease-in forwards;\n overflow: hidden;\n}\n\n.ams-component-section-mobile {\n border-radius: 12px 12px 0 0;\n overflow: hidden;\n font-size: 0;\n height: 100%;\n}\n\n.ams-component-container-desktop {\n display: block;\n width: 672px;\n position: fixed;\n top: 50%;\n left: 50%;\n z-index: 1001;\n border-radius: 12px;\n overflow: hidden;\n transform-origin: 50% 50%;\n transform: translate(-50%, -50%);\n}\n.ams-component-container-desktop-animation{\n animation: ams-component-container-zoom-in 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n\n@keyframes ams-component-container-zoom-out {\n 0% {\n transform: translate(-50%, -50%) scale(1);\n -webkit-transform: translate(-50%, -50%) scale(1);\n opacity: 1\n }\n \n 100% {\n opacity: 0;\n transform: translate(-50%, -50%) scale(0.4);\n -webkit-transform: translate(-50%, -50%) scale(0.4);\n }\n}\n\n@keyframes ams-component-container-zoom-in {\n 0% {\n transform: translate(-50%, -50%) scale(0.4);\n opacity: 0\n }\n\n 80% {\n opacity: 1\n }\n\n 100% {\n opacity: 1;\n transform: translate(-50%, -50%) scale(1);\n }\n}\n\n.ams-component-container-hidden-desktop {\n display: block;\n position: fixed;\n top: 50%;\n left: 50%;\n z-index: 1001;\n border-radius: 8px;\n overflow: hidden;\n animation: ams-component-container-zoom-out 0.3s ease-in-out;\n animation-fill-mode: forwards;\n transform-origin: 50% 50%;\n}\n\n.ams-component-loading {\n width: 0.8em;\n height:0.8em;\n background: rgba(0, 0, 0, 0.5);\n border-radius: 8px;\n position: fixed;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n z-index: 1001;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n}\n\n.ams-component-loading .line {\n width: 40px;\n height: 40px;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n}\n.ams-component-loading .line div {\n position: absolute;\n left: 17.67px;\n top: 0;\n width: 5.33px;\n height: 40px;\n}\n\n.ams-component-loading .line div:before,\n.ams-component-loading .line div:after {\n content: '';\n display: block;\n height: 13.33px;\n background: #fcfcfc;\n border-radius: 5.3px;\n}\n.ams-component-loading .line div:after {\n margin-top: 13.33px;\n}\n\n.ams-component-loading .line div:nth-child(2) {\n -webkit-transform: rotate(45deg);\n}\n\n.ams-component-loading .line div:nth-child(3) {\n -webkit-transform: rotate(90deg);\n}\n\n.ams-component-loading .line div:nth-child(4) {\n -webkit-transform: rotate(135deg);\n}\n\n/** \u52A0\u8F7D\u52A8\u753B **/\n@-webkit-keyframes load {\n 0% {\n opacity: 0;\n }\n\n 100% {\n opacity: 1;\n }\n}\n\n.ams-component-loading .line div:nth-child(1):before {\n -webkit-animation: load 1s linear 0s infinite;\n}\n\n.ams-component-loading .line div:nth-child(2):before {\n -webkit-animation: load 1s linear 0.125s infinite;\n}\n\n.ams-component-loading .line div:nth-child(3):before {\n -webkit-animation: load 1s linear 0.25s infinite;\n}\n\n.ams-component-loading .line div:nth-child(4):before {\n -webkit-animation: load 1s linear 0.375s infinite;\n}\n\n.ams-component-loading .line div:nth-child(1):after {\n -webkit-animation: load 1s linear 0.5s infinite;\n}\n\n.ams-component-loading .line div:nth-child(2):after {\n -webkit-animation: load 1s linear 0.675s infinite;\n}\n\n.ams-component-loading .line div:nth-child(3):after {\n -webkit-animation: load 1s linear 0.75s infinite;\n}\n\n.ams-component-loading .line div:nth-child(4):after {\n -webkit-animation: load 1s linear 0.875s infinite;\n}\n\n.ams-component-loading-logo {\n width: 0.44em;\n height: 0.44em;\n -webkit-transform:rotate(360deg);\n transform:rotate(360deg);\n -webkit-transition:-webkit-transform 1s linear;\n transition:transform 1s linear;\n animation: ams-component-loading-logo 1s linear infinite;\n}\n\n.asm-component-close-block-desktop {\n position: absolute;\n width: 40px;\n height: 40px;\n right: 0;\n top: 0;\n cursor: pointer;\n}\n.asm-component-close-block-btn-desktop {\n width: 11px;\n height: 11px;\n object-fit: fill;\n position: absolute;\n right: 18.7px;\n top: 26.7px;\n}\n.asm-component-close-block-hidden {\n width: 0px !important;\n height: 0px !important;\n visibility: hidden;\n}\n.asm-component-close-block-mobile {\n position: absolute;\n width: 0.4em;\n height: 0.4em;\n right: 0;\n top: 0;\n cursor: pointer;\n z-index: 1009;\n}\n\n.asm-component-close-block-btn-mobile {\n width: 0.11em;\n height: 0.11em;\n object-fit: fill;\n position: absolute;\n right: 0.147em;\n top: 0.167em;\n}\n\n\n.ams-component-container-opacity{\n opacity: 1;\n}\n\n.ams-component-container-opacity:after{\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n display: block;\n content: \"\";\n z-index: 1010;\n background-color: rgba(0, 0, 0, 0.35);\n border-radius: 12px 12px 0 0;\n}\n\n#ams-component-retention {\n position: fixed;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n transform-origin: 50%;\n height: auto;\n display: none;\n z-index: 1009;\n}\n\n.ams-component-retention-show {\n display: flex !important;\n animation: ams-component-container-zoom-in 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n\n.ams-component-retention-hidden {\n display: flex !important;\n animation: ams-component-container-zoom-out 0.3s ease-in-out;\n -webkit-animation: ams-component-container-zoom-out 0.3s ease-in-out;\n animation-fill-mode: forwards;\n -webkit-animation-fill-mode: forwards;\n}\n\n.ams-component-retention-mobile {\n width: 294px;\n border-radius: 12px;\n padding: 24px 0;\n background-color: #fff;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n box-sizing: border-box;\n}\n\n.ams-component-retention-desktop {\n width: 544px;\n border-radius: 12px;\n padding: 32px;\n background-color: #fff;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n box-sizing: border-box;\n}\n\n@media screen and (max-width: 300px) {\n .ams-component-retention-mobile {\n transform: translate(-50%, -50%) scale(0.8);\n }\n}\n\n.ams-component-retention-title-mobile {\n width: 100%;\n font-style: normal;\n font-weight: 500;\n font-size: 16px;\n line-height: 24px;\n color: #2A3A52;\n text-align: center;\n padding: 0 16px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-title-desktop {\n text-align: left;\n width: 100%;\n font-style: normal;\n font-weight: 500;\n font-size: 16px;\n line-height: 24px;\n color: #2A3A52;\n}\n\n.ams-component-retention-sub-title-mobile {\n width: 100%;\n font-weight: 400;\n font-size: 14px;\n line-height: 20px;\n color: #7C8CA3;\n margin-top: 8px;\n text-align: center;\n padding: 0 16px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-sub-title-desktop {\n text-align: left;\n font-style: normal;\n font-weight: 400;\n font-size: 14px;\n line-height: 20px;\n color: #7C8CA3;\n margin-top: 10px;\n}\n\n.ams-component-retention-btn-block-mobile {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n margin-top: 24px;\n padding: 0 24px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-btn-block-desktop {\n width: 100%;\n margin-top: 24px;\n}\n\n#ams-component-retention-remain {\n background: #0079FF;\n border-radius: 100px;\n font-style: normal;\n font-weight: 500;\n text-align: center;\n box-sizing: border-box;\n color: #FFFFFF;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.ams-component-retention-remain-mobile {\n width: 100%;\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n padding: 0 6px;\n}\n\n.ams-component-retention-remain-desktop {\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n display: inline-block;\n padding: 0 24px;\n float: right;\n cursor: pointer;\n padding: 0 16px;\n max-width: 225px;\n min-width: 159px;\n}\n\n#ams-component-retention-leave {\n border-radius: 100px;\n border: 1px solid #0079FF;\n font-style: normal;\n font-weight: 500;\n text-align: center;\n box-sizing: border-box;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.ams-component-retention-leave-mobile {\n width: 100%;\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n color: #1677FF;\n margin-top: 12px;\n padding: 0 6px;\n}\n\n.ams-component-retention-leave-desktop {\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n color: #1677FF;\n display: inline-block;\n padding: 0 24px;\n float: right;\n margin-right: 16px;\n cursor: pointer;\n padding: 0 16px;\n max-width: 225px;\n min-width: 144px;\n}\n.".concat(MOCKUP_ID, "-hidden{\nanimation: ").concat(MOCKUP_ID, "-opacity 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n/** \u52A0\u8F7D\u52A8\u753B **/\n@-webkit-keyframes ").concat(MOCKUP_ID, "-opacity {\n 0% {\n opacity: 1;\n }\n\n 100% {\n opacity: 0;\n }\n}\n");
12
12
  export var componentAddCSS = function componentAddCSS() {
13
13
  var style = document.createElement('style');
14
14
  style.type = 'text/css';
@@ -1,5 +1,5 @@
1
1
  import type AMSCheckout from '../../core/instance';
2
- import type { eventPayload, eventPayloadContext, IappendIframeNodesParams, Iselector } from '../../types';
2
+ import type { eventPayload, eventPayloadContext, IappendIframeNodesParams, IMerchantAppointParam, Iselector } from '../../types';
3
3
  import { componentSignEnum, platformEnum, renderDisplayTypeEnum } from '../../types';
4
4
  type IrenderFuncParams = (context: ComponentApp, selector: Iselector, renderDisplayType: renderDisplayTypeEnum) => Promise<void>;
5
5
  export default class ComponentApp {
@@ -23,6 +23,9 @@ export default class ComponentApp {
23
23
  private _appLocationSearch;
24
24
  private _renderDisplayType;
25
25
  private _multipleCallbackEvents;
26
+ _merchantAppointParam: IMerchantAppointParam;
27
+ private _webAppHeartBeatTimeoutId;
28
+ private _webAppHeartBeatTimeoutFn;
26
29
  constructor();
27
30
  /**
28
31
  * @description Cancel listening and destroy the dom
@@ -73,10 +76,14 @@ export default class ComponentApp {
73
76
  * @description Processing messages from iframe
74
77
  */
75
78
  _handleAppMessage(data: eventPayload): void;
79
+ private dismissLoadingFunc;
76
80
  private handleSizeChanged;
77
81
  private handleRedirect;
78
82
  private handleDeclareInfo;
79
83
  private handleDeclarePopWindowCallback;
84
+ private handleAppHeartBeat;
85
+ private isAppAttached;
86
+ private isWindowVisible;
80
87
  private handleCloseBtnShow;
81
88
  /**
82
89
  * @description Send message to SDK