@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.
- package/dist/umd/ams-checkout.min.js +1 -1
- package/esm/common/applepay/index.d.ts +48 -0
- package/esm/common/applepay/index.js +171 -0
- package/esm/common/applepay/interface.d.ts +102 -0
- package/esm/common/applepay/interface.js +1 -0
- package/esm/config/index.js +3 -3
- package/esm/config/request.js +3 -3
- package/esm/constant/index.d.ts +5 -0
- package/esm/constant/index.js +5 -0
- package/esm/core/applepay/index.d.ts +31 -0
- package/esm/core/applepay/index.js +369 -0
- package/esm/core/component/index.d.ts +3 -1
- package/esm/core/component/index.js +5 -2
- package/esm/index.d.ts +3 -0
- package/esm/index.js +18 -8
- package/esm/plugin/component/cashierApp.d.ts +1 -2
- package/esm/plugin/component/cashierApp.js +2 -2
- package/esm/plugin/component/component.popup.style.js +1 -1
- package/esm/plugin/component/index.d.ts +8 -1
- package/esm/plugin/component/index.js +148 -65
- package/esm/request/index.js +14 -8
- package/esm/service/index.d.ts +9 -1
- package/esm/service/index.js +31 -0
- package/esm/types/index.d.ts +61 -7
- package/esm/types/index.js +16 -0
- package/esm/util/logger.d.ts +1 -1
- package/esm/util/logger.js +3 -1
- package/esm/util/security.d.ts +1 -0
- package/esm/util/security.js +1 -1
- package/package.json +56 -1
@@ -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
|
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
|
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
|
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
|
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
|
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
|
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
|
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
|
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:
|
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
|