@alipay/ams-checkout 0.0.1720509876-dev.2 → 0.0.1723203704-dev.1

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.
Files changed (42) hide show
  1. package/dist/umd/ams-checkout.min.js +1 -1
  2. package/esm/config/request.js +3 -3
  3. package/esm/constant/index.d.ts +10 -1
  4. package/esm/constant/index.js +9 -0
  5. package/esm/core/component/address.d.ts +34 -0
  6. package/esm/core/component/address.js +298 -0
  7. package/esm/core/component/appPreloadProcessing.d.ts +1 -0
  8. package/esm/core/component/appPreloadProcessing.js +89 -0
  9. package/esm/core/component/index.d.ts +1 -1
  10. package/esm/core/component/index.js +39 -14
  11. package/esm/core/instance/address.d.ts +76 -0
  12. package/esm/core/instance/address.js +283 -0
  13. package/esm/index.d.ts +12 -1
  14. package/esm/index.js +57 -19
  15. package/esm/plugin/address/cashierApp.d.ts +34 -0
  16. package/esm/plugin/address/cashierApp.js +218 -0
  17. package/esm/plugin/address/channel.d.ts +20 -0
  18. package/esm/plugin/address/channel.js +52 -0
  19. package/esm/plugin/address/component.inline.style.d.ts +11 -0
  20. package/esm/plugin/address/component.inline.style.js +38 -0
  21. package/esm/plugin/address/component.popup.style.d.ts +16 -0
  22. package/esm/plugin/address/component.popup.style.js +174 -0
  23. package/esm/plugin/address/index.d.ts +108 -0
  24. package/esm/plugin/address/index.js +860 -0
  25. package/esm/plugin/address/popupWindow.style.d.ts +8 -0
  26. package/esm/plugin/address/popupWindow.style.js +65 -0
  27. package/esm/plugin/component/cashierApp.js +9 -5
  28. package/esm/plugin/component/component.inline.style.d.ts +8 -9
  29. package/esm/plugin/component/component.inline.style.js +87 -6
  30. package/esm/plugin/component/index.js +49 -25
  31. package/esm/plugin/component/popupWindow.style.d.ts +5 -2
  32. package/esm/plugin/component/popupWindow.style.js +55 -7
  33. package/esm/plugin/type.d.ts +1 -0
  34. package/esm/types/address.d.ts +92 -0
  35. package/esm/types/address.js +7 -0
  36. package/esm/types/index.d.ts +13 -3
  37. package/esm/types/index.js +5 -0
  38. package/esm/util/index.d.ts +7 -1
  39. package/esm/util/index.js +67 -1
  40. package/esm/util/upgrade.d.ts +4 -4
  41. package/esm/util/upgrade.js +6 -6
  42. package/package.json +1 -1
@@ -0,0 +1,218 @@
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 _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
3
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread 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 _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
6
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
7
+ 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; }
8
+ 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; }
9
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
10
+ 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); }
11
+ /**
12
+ * Copyright (c) 2022 International Business Group, Ant Group. All rights reserved.
13
+ *
14
+ * 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:
15
+ * 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
16
+ * 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.
17
+ */
18
+ import { marmotMap, sdkVersion, elementAppMarmotMap } from "../../config/index";
19
+ import { componentSignEnum, ComponentSignEnumV2 } from "../../types";
20
+ import { isDebugLog } from "../../util/debug";
21
+ import { queryParse, serialize } from "../../util/index";
22
+ import { Logger } from "../../util/logger";
23
+ import { getLastAppVersion, getMatchAppVersion, setLastAppVersion } from "../../util/upgrade";
24
+ var getAppVersion = function getAppVersion(_extendInfo, productScene, mid) {
25
+ var sendLog = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
26
+ try {
27
+ var appVersion = getMatchAppVersion(_extendInfo, {
28
+ sdkVersion: sdkVersion,
29
+ productScene: productScene,
30
+ mid: mid
31
+ });
32
+ if (sendLog) {
33
+ var _Logger$getInstance;
34
+ (_Logger$getInstance = Logger.getInstance()) === null || _Logger$getInstance === void 0 || _Logger$getInstance.logInfo({
35
+ title: 'sdk_event_appUpgradeInfo'
36
+ }, {
37
+ appUpgradeVersion: appVersion,
38
+ appUpgraded: appVersion ? true : false,
39
+ isPreload: _extendInfo ? false : true,
40
+ extendInfo: _extendInfo,
41
+ productScene: productScene,
42
+ mid: mid
43
+ });
44
+ }
45
+
46
+ // 没有匹配到版本,查询上次的加载版本
47
+ if (!appVersion) {
48
+ appVersion = getLastAppVersion(productScene);
49
+ return appVersion;
50
+ }
51
+ // 不为空时代表是有sessionData,因此要保存当前版本
52
+ if (_extendInfo) {
53
+ setLastAppVersion(productScene, appVersion);
54
+ }
55
+ return appVersion;
56
+ } catch (error) {
57
+ return '';
58
+ }
59
+ };
60
+ var getFinalProductSceneVersion = function getFinalProductSceneVersion(componentSign, productSceneVersion) {
61
+ var _signSupportMap;
62
+ var signSupportMap = (_signSupportMap = {}, _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_signSupportMap, componentSignEnum.NONE, ['']), componentSignEnum.AUTO_DEBIT_WALLET, ['1.0']), componentSignEnum.AUTO_DEBIT_PAY_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.EASY_PAY_APM, ['2.0']), componentSignEnum.VAULTING_CARD, ['1.0']), componentSignEnum.ELEMENT_PAYMENT, ['1.0']), _defineProperty(_signSupportMap, componentSignEnum.ELEMENT_ADDRESS, ['1.0']));
63
+ var supportProductSceneVersion = signSupportMap[componentSign];
64
+ // 从左到右,从旧到新
65
+ var isSupport = supportProductSceneVersion.find(function (it) {
66
+ return it === productSceneVersion;
67
+ });
68
+ var finalProductSceneVersion = supportProductSceneVersion[supportProductSceneVersion.length - 1];
69
+ return isSupport ? productSceneVersion : finalProductSceneVersion;
70
+ };
71
+ export var getAppPath = function getAppPath() {
72
+ var environment = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'prod';
73
+ var appVersion = arguments.length > 1 ? arguments[1] : undefined;
74
+ var componentSign = arguments.length > 2 ? arguments[2] : undefined;
75
+ var productScene = arguments.length > 3 ? arguments[3] : undefined;
76
+ var productSceneVersion = arguments.length > 4 ? arguments[4] : undefined;
77
+ var extendInfo = arguments.length > 5 ? arguments[5] : undefined;
78
+ var mid = arguments.length > 6 ? arguments[6] : undefined;
79
+ var sendLog = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : false;
80
+ var _ref = queryParse() || {},
81
+ urlTestHost = _ref.host;
82
+ var upgradeAppVersion = getAppVersion(extendInfo, productScene, mid, sendLog);
83
+ var finalAppVersion = upgradeAppVersion || appVersion;
84
+ // 当有升级版本时,更新到全局字段
85
+ if (upgradeAppVersion) {
86
+ var _Logger$getInstance2;
87
+ (_Logger$getInstance2 = Logger.getInstance()) === null || _Logger$getInstance2 === void 0 || _Logger$getInstance2.setMedta({
88
+ webAppVersion: finalAppVersion
89
+ });
90
+ }
91
+ if (isDebugLog()) {
92
+ console.log('appUpgrade#getAppPath#finalAppVersion', finalAppVersion);
93
+ console.log('appUpgrade#getAppPath#extendInfo', extendInfo, mid);
94
+ }
95
+ var finalProductSceneVersion = getFinalProductSceneVersion(componentSign, productSceneVersion);
96
+ // only for test while testurl?host=https://xxxxx.test.html
97
+ if (urlTestHost && !['sandbox', 'light_sandbox', 'prod'].includes(environment)) {
98
+ return urlTestHost;
99
+ }
100
+ // element应用特殊处理
101
+ if (_toConsumableArray(Object.values(ComponentSignEnumV2)).includes(componentSign)) {
102
+ return "".concat(elementAppMarmotMap[environment], "/").concat(productScene, "/").concat(finalAppVersion, "/pages/").concat(productScene, "/index.html");
103
+ }
104
+ return "".concat(marmotMap[environment], "/").concat(componentSign, "/").concat(finalProductSceneVersion, "/index.").concat(finalAppVersion, ".html");
105
+ };
106
+ export var getAppDomain = function getAppDomain(domainParams) {
107
+ var environment = domainParams.environment,
108
+ appVersion = domainParams.appVersion,
109
+ componentSign = domainParams.componentSign,
110
+ productScene = domainParams.productScene,
111
+ productSceneVersion = domainParams.productSceneVersion,
112
+ extendInfo = domainParams.extendInfo,
113
+ mid = domainParams.mid;
114
+ var reg = /^https?:\/\/([^/<>\s]+\.?)*/;
115
+ var macth = reg.exec(getAppPath(environment, appVersion, componentSign, productScene, productSceneVersion, extendInfo, mid));
116
+ return macth && macth[0] || '';
117
+ };
118
+ export var getIframeUrl = function getIframeUrl(iframeParams) {
119
+ var componentSign = iframeParams.componentSign,
120
+ _iframeParams$analyti = iframeParams.analytics,
121
+ analytics = _iframeParams$analyti === void 0 ? {
122
+ enabled: true
123
+ } : _iframeParams$analyti,
124
+ productScene = iframeParams.productScene,
125
+ productSceneVersion = iframeParams.productSceneVersion,
126
+ environment = iframeParams.environment,
127
+ appVersion = iframeParams.appVersion,
128
+ extendInfo = iframeParams.extendInfo,
129
+ locale = iframeParams.locale,
130
+ instanceId = iframeParams.instanceId,
131
+ renderDisplayType = iframeParams.renderDisplayType,
132
+ _iframeParams$isPrelo = iframeParams.isPreload,
133
+ isPreload = _iframeParams$isPrelo === void 0 ? '' : _iframeParams$isPrelo,
134
+ _iframeParams$hostSig = iframeParams.hostSign,
135
+ hostSign = _iframeParams$hostSig === void 0 ? '' : _iframeParams$hostSig,
136
+ _iframeParams$mid = iframeParams.mid,
137
+ mid = _iframeParams$mid === void 0 ? '' : _iframeParams$mid;
138
+ var path = getAppPath(environment, appVersion, componentSign, productScene, productSceneVersion, extendInfo || '', mid, true);
139
+ var appMatched = getMatchAppVersion(extendInfo, {
140
+ sdkVersion: sdkVersion,
141
+ productScene: productScene,
142
+ mid: mid
143
+ }) ? 'true' : 'false';
144
+ var _queryParse = queryParse(),
145
+ _sandbox = _queryParse._sandbox,
146
+ _light_sandbox = _queryParse._light_sandbox,
147
+ _queryParse$requestHo = _queryParse.requestHost,
148
+ requestHost = _queryParse$requestHo === void 0 ? '' : _queryParse$requestHo,
149
+ _queryParse$groupId = _queryParse.groupId,
150
+ groupId = _queryParse$groupId === void 0 ? '' : _queryParse$groupId,
151
+ LOCAL_MOCK = _queryParse.LOCAL_MOCK,
152
+ _displayType = _queryParse._displayType;
153
+ var urlParams = Object.assign({}, {
154
+ displayType: renderDisplayType,
155
+ locale: locale,
156
+ instanceId: instanceId,
157
+ appMatched: appMatched,
158
+ analyticsEnabled: (analytics === null || analytics === void 0 ? void 0 : analytics.enabled) === false ? 'false' : 'true',
159
+ sdkVersion: sdkVersion,
160
+ refUrl: window.location.href,
161
+ _componentStartTime: "".concat(Date.now()),
162
+ isPreload: isPreload || '',
163
+ hostSign: hostSign || ''
164
+ });
165
+ if (LOCAL_MOCK) urlParams.LOCAL_MOCK = LOCAL_MOCK;
166
+ if (requestHost) urlParams.requestHost = requestHost;
167
+ if (groupId) urlParams.groupId = groupId;
168
+ if (environment === 'light_sandbox' || _light_sandbox === 'true') urlParams.sandbox = 'true';
169
+ if (environment === 'sandbox' || _sandbox === 'true') urlParams.shadow = 'true';
170
+ if (_displayType) urlParams.displayType = _displayType;
171
+ var locationSearch = serialize(urlParams);
172
+ if (isDebugLog()) {
173
+ console.log('appUpgrade#getIframeUrl#appMatched', appMatched);
174
+ console.log('appUpgrade#getIframeUrl#url', path, locationSearch);
175
+ }
176
+ return {
177
+ path: path,
178
+ locationSearch: locationSearch
179
+ };
180
+ };
181
+
182
+ /**
183
+ * @description Create iframe
184
+ */
185
+ export var createIframe = function createIframe(mode, platform) {
186
+ var getIframeId = function getIframeId() {
187
+ var IdMap = {
188
+ dropin: "ams-checkout-dropin-".concat(platform),
189
+ component: "ams-checkout-component-".concat(platform)
190
+ };
191
+ return IdMap[mode] || 'ams-checkout-component';
192
+ };
193
+ var iframe = document.createElement('iframe');
194
+ var iframeId = getIframeId();
195
+ var none = '0';
196
+ var width = '100%';
197
+ iframe.id = iframeId;
198
+ iframe.style.height = none;
199
+ iframe.style.width = width;
200
+ iframe.style.border = none;
201
+ iframe.style.opacity = none;
202
+ iframe.style.overflow = 'hidden';
203
+ return iframe;
204
+ };
205
+ export var createPreloadIframe = function createPreloadIframe(channelType, version) {
206
+ var id = "ams-checkout-component-".concat(channelType, "-").concat(version);
207
+ var iframe = document.createElement('iframe');
208
+ var iframeId = id;
209
+ var none = '1px';
210
+ var width = '1px';
211
+ iframe.id = iframeId;
212
+ iframe.style.height = none;
213
+ iframe.style.width = width;
214
+ iframe.style.border = none;
215
+ iframe.style.opacity = '0';
216
+ iframe.style.overflow = 'hidden';
217
+ return iframe;
218
+ };
@@ -0,0 +1,20 @@
1
+ import type { IpaymentSessionMetaData } from "src/types";
2
+ type IChannelBehavior = {
3
+ usePaymentSessionAsQueryResult: boolean;
4
+ submitPayInSdk: boolean;
5
+ createIframeNode: boolean;
6
+ loadApp: boolean;
7
+ buildSubmitPayExtParams?: (params: GetDoubleFaParams) => any;
8
+ allowClickOutsideClose?: boolean;
9
+ };
10
+ type GetDoubleFaParams = {
11
+ instanceId: string;
12
+ paymentSessionData: string;
13
+ locale: string;
14
+ paymentMethodType: string;
15
+ env: string;
16
+ sdkVersion: string;
17
+ };
18
+ export declare function getChannelBehavior(paymentSessionMetaData?: IpaymentSessionMetaData): IChannelBehavior | undefined;
19
+ export declare function getDoubleFaUrl(params: GetDoubleFaParams): string;
20
+ export {};
@@ -0,0 +1,52 @@
1
+ export function getChannelBehavior(paymentSessionMetaData) {
2
+ var _paymentSessionMetaDa, _paymentSessionMetaDa2, _paymentSessionMetaDa3, _paymentSessionMetaDa4, _paymentSessionMetaDa5, _paymentSessionMetaDa6, _paymentSessionMetaDa7, _paymentSessionMetaDa8;
3
+ // TOSS EASYPAY 2.0
4
+ if ('BANKTRANSFER_QUICKPAY' === (paymentSessionMetaData === null || paymentSessionMetaData === void 0 || (_paymentSessionMetaDa = paymentSessionMetaData.paymentMethodInfoView) === null || _paymentSessionMetaDa === void 0 ? void 0 : _paymentSessionMetaDa.paymentMethodType) && (paymentSessionMetaData === null || paymentSessionMetaData === void 0 || (_paymentSessionMetaDa2 = paymentSessionMetaData.paymentSessionConfig) === null || _paymentSessionMetaDa2 === void 0 ? void 0 : _paymentSessionMetaDa2.productScene) === 'EASY_PAY' && (paymentSessionMetaData === null || paymentSessionMetaData === void 0 || (_paymentSessionMetaDa3 = paymentSessionMetaData.paymentSessionConfig) === null || _paymentSessionMetaDa3 === void 0 ? void 0 : _paymentSessionMetaDa3.paymentMethodCategoryType) === 'APM' && (paymentSessionMetaData === null || paymentSessionMetaData === void 0 || (_paymentSessionMetaDa4 = paymentSessionMetaData.paymentSessionConfig) === null || _paymentSessionMetaDa4 === void 0 ? void 0 : _paymentSessionMetaDa4.productSceneVersion) === '2.0') {
5
+ return {
6
+ usePaymentSessionAsQueryResult: true,
7
+ submitPayInSdk: true,
8
+ createIframeNode: true,
9
+ loadApp: true,
10
+ allowClickOutsideClose: true,
11
+ buildSubmitPayExtParams: function buildSubmitPayExtParams(params) {
12
+ var callBackUrl = getDoubleFaUrl(params);
13
+ return {
14
+ callBackUrl: callBackUrl
15
+ };
16
+ }
17
+ };
18
+ }
19
+ // TNG EASYPAY 2.0
20
+ if ('TNG' === (paymentSessionMetaData === null || paymentSessionMetaData === void 0 || (_paymentSessionMetaDa5 = paymentSessionMetaData.paymentMethodInfoView) === null || _paymentSessionMetaDa5 === void 0 ? void 0 : _paymentSessionMetaDa5.paymentMethodType) && (paymentSessionMetaData === null || paymentSessionMetaData === void 0 || (_paymentSessionMetaDa6 = paymentSessionMetaData.paymentSessionConfig) === null || _paymentSessionMetaDa6 === void 0 ? void 0 : _paymentSessionMetaDa6.productScene) === 'EASY_PAY' && (paymentSessionMetaData === null || paymentSessionMetaData === void 0 || (_paymentSessionMetaDa7 = paymentSessionMetaData.paymentSessionConfig) === null || _paymentSessionMetaDa7 === void 0 ? void 0 : _paymentSessionMetaDa7.paymentMethodCategoryType) === 'WALLET' && (paymentSessionMetaData === null || paymentSessionMetaData === void 0 || (_paymentSessionMetaDa8 = paymentSessionMetaData.paymentSessionConfig) === null || _paymentSessionMetaDa8 === void 0 ? void 0 : _paymentSessionMetaDa8.productSceneVersion) === '2.0') {
21
+ return {
22
+ usePaymentSessionAsQueryResult: false,
23
+ submitPayInSdk: false,
24
+ createIframeNode: true,
25
+ loadApp: true,
26
+ allowClickOutsideClose: false,
27
+ buildSubmitPayExtParams: function buildSubmitPayExtParams(params) {
28
+ return {};
29
+ }
30
+ };
31
+ }
32
+ return undefined;
33
+ }
34
+ export function getDoubleFaUrl(params) {
35
+ var instanceId = params.instanceId,
36
+ paymentMethodType = params.paymentMethodType,
37
+ paymentSessionData = params.paymentSessionData,
38
+ locale = params.locale,
39
+ env = params.env,
40
+ sdkVersion = params.sdkVersion;
41
+ var isLandscapeOrientation = false; // Web 不含横屏
42
+
43
+ var DOUBLE_FA_URL_MAPPING = {
44
+ local: "http://page.alipay.net/page/antom-web-checkout/src/component-app/doubleFA/index.".concat(sdkVersion, ".html"),
45
+ dev: "http://page.alipay.net/page/antom-web-checkout/src/component-app/doubleFA/index.".concat(sdkVersion, ".html"),
46
+ sit: "http://page.test.alipay.net/page/antom-web-checkout/src/component-app/doubleFA/index.".concat(sdkVersion, ".html"),
47
+ pre: "https://pre.ac.alipay.com/page/antom-web-checkout/src/component-app/doubleFA/index.".concat(sdkVersion, ".html"),
48
+ prod: "https://ac.alipay.com/page/antom-web-checkout/src/component-app/doubleFA/index.".concat(sdkVersion, ".html")
49
+ };
50
+ var doubleFaBaseUrl = DOUBLE_FA_URL_MAPPING[env] || DOUBLE_FA_URL_MAPPING.prod;
51
+ return "".concat(doubleFaBaseUrl, "?scene=cashierResultPage&instanceId=").concat(instanceId, "&paymentSessionData=").concat(encodeURIComponent(paymentSessionData), "&isLandscape=").concat(isLandscapeOrientation ? 'true' : '', "&pmt=").concat(paymentMethodType, "&locale=").concat(locale, "&sdkVersion=").concat(sdkVersion);
52
+ }
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Copyright (c) 2022 International Business Group, Ant Group. All rights reserved.
3
+ *
4
+ * 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:
5
+ * 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
6
+ * 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.
7
+ */
8
+ import { platformEnum } from '../../types';
9
+ export declare const inlineComponentAddCss: () => void;
10
+ export declare const addInlineLoading: (_selector: HTMLDivElement, platform: platformEnum) => void;
11
+ export declare const createInlineBaseElement: (selector: string) => HTMLDivElement;
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Copyright (c) 2022 International Business Group, Ant Group. All rights reserved.
3
+ *
4
+ * 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:
5
+ * 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
6
+ * 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.
7
+ */
8
+ import { platformEnum } from "../../types";
9
+ import { INLINE_BASE_STYLE_ID, LOADING_ID, INLINE_IMG_CLASSNAME, COMPONENT_CONTAINER_ID, COMPONENT_IFRAME_TAG_ID } from "../../constant";
10
+ import { amsSetSize } from "../../util";
11
+ var inlineComponentCss = "#".concat(COMPONENT_IFRAME_TAG_ID, "-desktop{\n border-radius: 8px;\n position: absolute;\n top: 0;\n left: 0;\n}\n#").concat(COMPONENT_IFRAME_TAG_ID, "-mobile{\n position: absolute;\n top: 0;\n left: 0;\n}\n.").concat(COMPONENT_CONTAINER_ID, "-inline{\n width: 100%;\n height: auto;\n position: relative;\n line-height: 0;\n display: flex;\n}\n#").concat(LOADING_ID, "{\n width: 100%;\n flex: 1;\n}\n.").concat(INLINE_IMG_CLASSNAME, "{\n width: 100%;\n height: auto;\n object-fit: contain;\n box-sizing: border-box;\n}\n.").concat(INLINE_IMG_CLASSNAME, "-mobile{\n padding: 0 0.16em;\n}\n.").concat(INLINE_IMG_CLASSNAME, "-desktop{}\n");
12
+ export var inlineComponentAddCss = function inlineComponentAddCss() {
13
+ var style = document.createElement('style');
14
+ style.id = 'ams-inline-component-style';
15
+ style.type = 'text/css';
16
+ style.innerHTML = inlineComponentCss;
17
+ document.head.appendChild(style);
18
+ };
19
+ export var addInlineLoading = function addInlineLoading(_selector, platform) {
20
+ var loading = document.createElement('div');
21
+ loading.id = LOADING_ID;
22
+ if (platform === platformEnum.desktop) loading.innerHTML = "<svg class=\"".concat(INLINE_IMG_CLASSNAME, " ").concat(INLINE_IMG_CLASSNAME, "-").concat(platform, "\" width=\"740\" height=\"360\" viewBox=\"0 0 740 360\" fill=\"none\" xmlns=\"\">\n <rect width=\"740\" height=\"360\" rx=\"12\" fill=\"#F6F6F6\"/>\n <rect opacity=\"0.7\" x=\"44\" y=\"44\" width=\"32\" height=\"32\" rx=\"4\" fill=\"#E1E6ED\"/>\n <rect opacity=\"0.7\" x=\"94\" y=\"44\" width=\"32\" height=\"32\" rx=\"4\" fill=\"#E1E6ED\"/>\n <rect opacity=\"0.7\" x=\"144\" y=\"44\" width=\"32\" height=\"32\" rx=\"4\" fill=\"#E1E6ED\"/>\n <g style=\"mix-blend-mode:multiply\" opacity=\"0.336007\">\n <path d=\"M136 100H48C43.5817 100 40 103.582 40 108C40 112.418 43.5817 116 48 116H136C140.418 116 144 112.418 144 108C144 103.582 140.418 100 136 100Z\" fill=\"#E1E6ED\"/>\n </g>\n <g style=\"mix-blend-mode:multiply\" opacity=\"0.336007\">\n <path d=\"M682 126H58C48.0589 126 40 134.059 40 144C40 153.941 48.0589 162 58 162H682C691.941 162 700 153.941 700 144C700 134.059 691.941 126 682 126Z\" fill=\"#E1E6ED\"/>\n </g>\n <g style=\"mix-blend-mode:multiply\" opacity=\"0.336007\">\n <path d=\"M682 182H58C48.0589 182 40 190.059 40 200C40 209.941 48.0589 218 58 218H682C691.941 218 700 209.941 700 200C700 190.059 691.941 182 682 182Z\" fill=\"#E1E6ED\"/>\n </g>\n <g style=\"mix-blend-mode:multiply\" opacity=\"0.336007\">\n <path d=\"M504 274H64C52.9543 274 44 282.954 44 294C44 305.046 52.9543 314 64 314H504C515.046 314 524 305.046 524 294C524 282.954 515.046 274 504 274Z\" fill=\"#E1E6ED\"/>\n </g>\n </svg>");
23
+ if (platform === platformEnum.mobile) loading.innerHTML = "<svg class=\"".concat(INLINE_IMG_CLASSNAME, " ").concat(INLINE_IMG_CLASSNAME, "-").concat(platform, "\" width=\"358\" height=\"186\" viewBox=\"0 0 358 186\" fill=\"none\" xmlns=\"\">\n <g clip-path=\"url(#clip0_2543_91192)\">\n <rect width=\"358\" height=\"186\" fill=\"white\"/>\n <g clip-path=\"url(#clip1_2543_91192)\">\n <rect width=\"358\" height=\"186\" fill=\"white\"/>\n <rect width=\"358\" height=\"40\" fill=\"white\"/>\n <rect opacity=\"0.7\" x=\"4\" y=\"4\" width=\"32\" height=\"32\" rx=\"4\" fill=\"#E1E6ED\"/>\n <rect opacity=\"0.7\" x=\"54\" y=\"4\" width=\"32\" height=\"32\" rx=\"4\" fill=\"#E1E6ED\"/>\n <rect opacity=\"0.7\" x=\"104\" y=\"4\" width=\"32\" height=\"32\" rx=\"4\" fill=\"#E1E6ED\"/>\n <g clip-path=\"url(#clip2_2543_91192)\">\n <rect width=\"358\" height=\"120\" transform=\"translate(0 66)\" fill=\"white\"/>\n <g style=\"mix-blend-mode:multiply\" opacity=\"0.336007\">\n <path d=\"M95 66H9C4.02944 66 0 70.0294 0 75C0 79.9706 4.02943 84 9 84H95C99.9706 84 104 79.9706 104 75C104 70.0294 99.9706 66 95 66Z\" fill=\"#E1E6ED\"/>\n </g>\n <g clip-path=\"url(#clip3_2543_91192)\">\n <g style=\"mix-blend-mode:multiply\" opacity=\"0.336007\">\n <path d=\"M340 94H18C8.05888 94 0 102.059 0 112C0 121.941 8.05887 130 18 130H340C349.941 130 358 121.941 358 112C358 102.059 349.941 94 340 94Z\" fill=\"#E1E6ED\"/>\n </g>\n <g style=\"mix-blend-mode:multiply\" opacity=\"0.336007\">\n <path d=\"M340 150H18C8.05888 150 0 158.059 0 168C0 177.941 8.05887 186 18 186H340C349.941 186 358 177.941 358 168C358 158.059 349.941 150 340 150Z\" fill=\"#E1E6ED\"/>\n </g>\n </g>\n </g>\n </g>\n </g>\n <defs>\n <clipPath id=\"clip0_2543_91192\">\n <rect width=\"358\" height=\"186\" fill=\"white\"/>\n </clipPath>\n <clipPath id=\"clip1_2543_91192\">\n <rect width=\"358\" height=\"186\" fill=\"white\"/>\n </clipPath>\n <clipPath id=\"clip2_2543_91192\">\n <rect width=\"358\" height=\"120\" fill=\"white\" transform=\"translate(0 66)\"/>\n </clipPath>\n <clipPath id=\"clip3_2543_91192\">\n <rect width=\"358\" height=\"92\" fill=\"white\" transform=\"translate(0 94)\"/>\n </clipPath>\n </defs>\n </svg>\n ");
24
+ if (_selector) _selector.appendChild(loading);
25
+ var loadingDom = document.getElementById(LOADING_ID);
26
+ amsSetSize(null, loadingDom);
27
+ };
28
+ export var createInlineBaseElement = function createInlineBaseElement(selector) {
29
+ var inlineBaseStyle = document.getElementById(INLINE_BASE_STYLE_ID);
30
+ if (!inlineBaseStyle) inlineComponentAddCss();
31
+ if (document.getElementById(COMPONENT_CONTAINER_ID)) return;
32
+ var amsComponentContainer = document.createElement('div');
33
+ amsComponentContainer.className = "".concat(COMPONENT_CONTAINER_ID, "-inline");
34
+ amsComponentContainer.id = COMPONENT_CONTAINER_ID;
35
+ var selectorDom = document.querySelector(selector);
36
+ if (selectorDom) selectorDom.appendChild(amsComponentContainer);
37
+ return amsComponentContainer;
38
+ };
@@ -0,0 +1,16 @@
1
+ import { platformEnum } from '../../types';
2
+ export declare const componentAddCSS: () => void;
3
+ export declare const createBaseElement: (platform: platformEnum, closeBtnFunc: () => void) => HTMLDivElement;
4
+ export declare const createCloseBtn: (platform: platformEnum, closeBtnFunc: () => void) => void;
5
+ export declare const createRetentionPopup: (platform: platformEnum, remainBtnFunc: () => void, leaveBtnFunc: () => void) => void;
6
+ export declare const hideRetentionPopup: () => void;
7
+ export declare const removeRetentionPopup: (platform: platformEnum, remainBtnFunc: () => void, leaveBtnFunc: () => void) => void;
8
+ export declare const createMockup: (options: {
9
+ platform: platformEnum;
10
+ onClickOutside: () => void;
11
+ }) => void;
12
+ export declare const addPopupLoading: () => void;
13
+ export declare const handleDeclareInfo: ({ closeDialogData }: {
14
+ closeDialogData: any;
15
+ }) => void;
16
+ export declare const slideInAndOutKeyframes: (id: any, height: any) => string;
@@ -0,0 +1,174 @@
1
+ /**
2
+ * Copyright (c) 2022 International Business Group, Ant Group. All rights reserved.
3
+ *
4
+ * 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:
5
+ * 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
6
+ * 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.
7
+ */
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
+ import { platformEnum } from "../../types";
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 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 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
+ export var componentAddCSS = function componentAddCSS() {
13
+ var style = document.createElement('style');
14
+ style.type = 'text/css';
15
+ style.innerHTML = componentCss;
16
+ document.head.appendChild(style);
17
+ };
18
+ export var createBaseElement = function createBaseElement(platform, closeBtnFunc) {
19
+ if (document.getElementById(COMPONENT_CONTAINER_ID)) return;
20
+ componentAddCSS();
21
+ addSetFontSizeEvent();
22
+ var amsComponentContainer = document.createElement('div');
23
+ amsComponentContainer.className = "".concat(COMPONENT_CONTAINER_ID, "-hidden-").concat(platform);
24
+ amsComponentContainer.id = COMPONENT_CONTAINER_ID;
25
+ amsSetSize(null, amsComponentContainer);
26
+ document.body.appendChild(amsComponentContainer);
27
+ var amsComponentSection = document.createElement('div');
28
+ amsComponentSection.className = "ams-component-section-".concat(platform);
29
+ amsComponentSection.id = COMPONENT_SECTION_ID;
30
+ amsComponentContainer.appendChild(amsComponentSection);
31
+ amsComponentContainer.classList.remove("".concat(COMPONENT_CONTAINER_ID, "-hidden-").concat(platform));
32
+ amsComponentContainer.classList.add("".concat(COMPONENT_CONTAINER_ID, "-").concat(platform));
33
+ createCloseBtn(platform, closeBtnFunc);
34
+ return amsComponentContainer;
35
+ };
36
+ export var createCloseBtn = function createCloseBtn(platform, closeBtnFunc) {
37
+ var clickEventName = platform === platformEnum.mobile ? 'touchend' : 'click';
38
+ var container = document.getElementById(COMPONENT_CONTAINER_ID);
39
+ // close btn
40
+ var closeBtnHTML = "<img class='".concat(COMPONENT_CLOSE_BLOCK_ID, "-btn-").concat(platform, "' src=\"").concat(closeImg, "\"/>");
41
+ var closeBlock = document.createElement('div');
42
+ closeBlock.classList.add("".concat(COMPONENT_CLOSE_BLOCK_ID, "-").concat(platform), "".concat(COMPONENT_CLOSE_BLOCK_ID, "-hidden"));
43
+ closeBlock.id = COMPONENT_CLOSE_BLOCK_ID;
44
+ closeBlock.innerHTML = closeBtnHTML;
45
+ closeBlock.addEventListener(clickEventName, function () {
46
+ closeBtnFunc();
47
+ });
48
+ if (container) container.appendChild(closeBlock);
49
+ };
50
+ export var createRetentionPopup = function createRetentionPopup(platform, remainBtnFunc, leaveBtnFunc) {
51
+ var clickEventName = platform === platformEnum.mobile ? 'touchend' : 'click';
52
+ // retention popup
53
+ var retentionPopup = document.createElement('div');
54
+ retentionPopup.id = COMPONENT_RETENTION_ID;
55
+ retentionPopup.classList.add("".concat(COMPONENT_RETENTION_ID, "-").concat(platform));
56
+ retentionPopup.innerHTML = "\n <span id=\"".concat(COMPONENT_RETENTION_ID, "-title\" class=\"").concat(COMPONENT_RETENTION_ID, "-title-").concat(platform, "\">\n Are you sure you want to leave?\n </span>\n <span\n id=\"").concat(COMPONENT_RETENTION_ID, "-sub-title\"\n class=\"").concat(COMPONENT_RETENTION_ID, "-sub-title-").concat(platform, "\"\n >\n If you leave this page, you'll have to start over again.\n </span>\n <div class=\"").concat(COMPONENT_RETENTION_ID, "-btn-block-").concat(platform, "\">\n <div id=\"").concat(COMPONENT_RETENTION_ID, "-remain\" class=\"").concat(COMPONENT_RETENTION_ID, "-remain-").concat(platform, "\">\n Continue Payment\n </div>\n <div id=\"").concat(COMPONENT_RETENTION_ID, "-leave\" class=\"").concat(COMPONENT_RETENTION_ID, "-leave-").concat(platform, "\">\n Leave\n </div>\n </div>");
57
+ document.body.appendChild(retentionPopup);
58
+ var remainBtn = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-remain"));
59
+ if (remainBtn) {
60
+ remainBtn.addEventListener(clickEventName, remainBtnFunc);
61
+ }
62
+ var leaveBtn = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-leave"));
63
+ if (leaveBtn) {
64
+ leaveBtn.addEventListener(clickEventName, leaveBtnFunc);
65
+ }
66
+ };
67
+ export var hideRetentionPopup = function hideRetentionPopup() {
68
+ var retentionPopup = document.getElementById(COMPONENT_RETENTION_ID);
69
+ var container = document.getElementById(COMPONENT_CONTAINER_ID);
70
+ if (retentionPopup) {
71
+ retentionPopup.classList.remove("".concat(COMPONENT_RETENTION_ID, "-show"));
72
+ retentionPopup.classList.add("".concat(COMPONENT_RETENTION_ID, "-hidden"));
73
+ setTimeout(function () {
74
+ retentionPopup.classList.remove("".concat(COMPONENT_RETENTION_ID, "-hidden"));
75
+ container === null || container === void 0 || container.classList.remove("".concat(COMPONENT_CONTAINER_ID, "-opacity"));
76
+ }, ANIMATION_TIME);
77
+ }
78
+ };
79
+ export var removeRetentionPopup = function removeRetentionPopup(platform, remainBtnFunc, leaveBtnFunc) {
80
+ var _document$getElementB;
81
+ var clickEventName = platform === platformEnum.mobile ? 'touchend' : 'click';
82
+ var remainBtn = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-remain"));
83
+ if (remainBtn) {
84
+ remainBtn.removeEventListener(clickEventName, remainBtnFunc);
85
+ }
86
+ var leaveBtn = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-leave"));
87
+ if (leaveBtn) {
88
+ leaveBtn.removeEventListener(clickEventName, leaveBtnFunc);
89
+ }
90
+ (_document$getElementB = document.getElementById(COMPONENT_RETENTION_ID)) === null || _document$getElementB === void 0 || _document$getElementB.remove();
91
+ };
92
+ export var createMockup = function createMockup(options) {
93
+ var clickEventName = (options === null || options === void 0 ? void 0 : options.platform) === platformEnum.mobile ? 'touchend' : 'click';
94
+ var body = document.getElementsByTagName('body')[0];
95
+ body.style.overflow = 'hidden';
96
+ var mockup = document.createElement('div');
97
+ mockup.style.width = '100vw';
98
+ mockup.style.height = '100vh';
99
+ mockup.style.position = 'fixed';
100
+ mockup.style.top = '0';
101
+ mockup.style.left = '0';
102
+ mockup.style.zIndex = '1000';
103
+ mockup.style.background = 'rgba(0,0,0,0.5)';
104
+ mockup.style.display = 'none';
105
+ mockup.id = MOCKUP_ID;
106
+ // let click to close
107
+ mockup.addEventListener(clickEventName, function () {
108
+ var _options$onClickOutsi;
109
+ options === null || options === void 0 || (_options$onClickOutsi = options.onClickOutside) === null || _options$onClickOutsi === void 0 || _options$onClickOutsi.call(options);
110
+ });
111
+ body.appendChild(mockup);
112
+ };
113
+ export var addPopupLoading = function addPopupLoading() {
114
+ var loading = document.createElement('div');
115
+ loading === null || loading === void 0 || loading.classList.add(LOADING_ID);
116
+ loading.id = LOADING_ID;
117
+ loading.innerHTML = '<div class="line"><div></div><div></div><div></div><div></div></div>';
118
+ loading.style.fontSize = "".concat(getDesignFontSize(), "px");
119
+ var body = document.getElementsByTagName('body')[0];
120
+ body === null || body === void 0 || body.appendChild(loading);
121
+ };
122
+
123
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
124
+ export var handleDeclareInfo = function handleDeclareInfo(_ref) {
125
+ var _ref$closeDialogData = _ref.closeDialogData,
126
+ closeDialogData = _ref$closeDialogData === void 0 ? {} : _ref$closeDialogData;
127
+ try {
128
+ if (closeDialogData) {
129
+ var retentionTitle = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-title"));
130
+ if (retentionTitle) {
131
+ var _closeDialogData$titl, _closeDialogData$titl2, _closeDialogData$titl3;
132
+ retentionTitle.style.fontSize = "".concat(closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$titl = closeDialogData.title) === null || _closeDialogData$titl === void 0 ? void 0 : _closeDialogData$titl.fontSize, "px");
133
+ retentionTitle.style.color = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$titl2 = closeDialogData.title) === null || _closeDialogData$titl2 === void 0 ? void 0 : _closeDialogData$titl2.fontColor;
134
+ retentionTitle.innerHTML = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$titl3 = closeDialogData.title) === null || _closeDialogData$titl3 === void 0 ? void 0 : _closeDialogData$titl3.text;
135
+ }
136
+ var retentionMessage = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-sub-title"));
137
+ if (retentionMessage) {
138
+ var _closeDialogData$mess, _closeDialogData$mess2, _closeDialogData$mess3;
139
+ retentionMessage.style.fontSize = "".concat(closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$mess = closeDialogData.message) === null || _closeDialogData$mess === void 0 ? void 0 : _closeDialogData$mess.fontSize, "px");
140
+ retentionMessage.style.color = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$mess2 = closeDialogData.message) === null || _closeDialogData$mess2 === void 0 ? void 0 : _closeDialogData$mess2.fontColor;
141
+ retentionMessage.innerHTML = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$mess3 = closeDialogData.message) === null || _closeDialogData$mess3 === void 0 ? void 0 : _closeDialogData$mess3.text;
142
+ }
143
+ var remainBtn = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-remain"));
144
+ if (remainBtn) {
145
+ var _closeDialogData$btnO, _closeDialogData$btnO2, _closeDialogData$btnO3, _closeDialogData$btnO4, _closeDialogData$btnO5, _closeDialogData$btnO7;
146
+ remainBtn.innerHTML = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnO = closeDialogData.btnOK) === null || _closeDialogData$btnO === void 0 ? void 0 : _closeDialogData$btnO.text;
147
+ remainBtn.style.fontSize = "".concat(closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnO2 = closeDialogData.btnOK) === null || _closeDialogData$btnO2 === void 0 ? void 0 : _closeDialogData$btnO2.fontSize, "px");
148
+ remainBtn.style.color = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnO3 = closeDialogData.btnOK) === null || _closeDialogData$btnO3 === void 0 ? void 0 : _closeDialogData$btnO3.fontColor;
149
+ remainBtn.style.borderRadius = "".concat(closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnO4 = closeDialogData.btnOK) === null || _closeDialogData$btnO4 === void 0 ? void 0 : _closeDialogData$btnO4.corner, "px");
150
+ if ((closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnO5 = closeDialogData.btnOK) === null || _closeDialogData$btnO5 === void 0 ? void 0 : _closeDialogData$btnO5.type) === 'stroke') {
151
+ var _closeDialogData$btnO6;
152
+ remainBtn.style.border = "1px solid ".concat(closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnO6 = closeDialogData.btnOK) === null || _closeDialogData$btnO6 === void 0 ? void 0 : _closeDialogData$btnO6.bg);
153
+ } else remainBtn.style.backgroundColor = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnO7 = closeDialogData.btnOK) === null || _closeDialogData$btnO7 === void 0 ? void 0 : _closeDialogData$btnO7.bg;
154
+ }
155
+ var leaveBrn = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-leave"));
156
+ if (leaveBrn) {
157
+ var _closeDialogData$btnC, _closeDialogData$btnC2, _closeDialogData$btnC3, _closeDialogData$btnC4, _closeDialogData$btnC5, _closeDialogData$btnC7;
158
+ leaveBrn.innerHTML = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnC = closeDialogData.btnCancel) === null || _closeDialogData$btnC === void 0 ? void 0 : _closeDialogData$btnC.text;
159
+ leaveBrn.style.fontSize = "".concat(closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnC2 = closeDialogData.btnCancel) === null || _closeDialogData$btnC2 === void 0 ? void 0 : _closeDialogData$btnC2.fontSize, "px");
160
+ leaveBrn.style.color = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnC3 = closeDialogData.btnCancel) === null || _closeDialogData$btnC3 === void 0 ? void 0 : _closeDialogData$btnC3.fontColor;
161
+ leaveBrn.style.borderRadius = "".concat(closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnC4 = closeDialogData.btnCancel) === null || _closeDialogData$btnC4 === void 0 ? void 0 : _closeDialogData$btnC4.corner, "px");
162
+ if ((closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnC5 = closeDialogData.btnCancel) === null || _closeDialogData$btnC5 === void 0 ? void 0 : _closeDialogData$btnC5.type) === 'stroke') {
163
+ var _closeDialogData$btnC6;
164
+ leaveBrn.style.border = "1px solid ".concat(closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnC6 = closeDialogData.btnCancel) === null || _closeDialogData$btnC6 === void 0 ? void 0 : _closeDialogData$btnC6.bg);
165
+ } else leaveBrn.style.backgroundColor = closeDialogData === null || closeDialogData === void 0 || (_closeDialogData$btnC7 = closeDialogData.btnCancel) === null || _closeDialogData$btnC7 === void 0 ? void 0 : _closeDialogData$btnC7.bg;
166
+ }
167
+ }
168
+ } catch (error) {
169
+ console.error(error);
170
+ }
171
+ };
172
+ export var slideInAndOutKeyframes = function slideInAndOutKeyframes(id, height) {
173
+ return "@keyframes ".concat(id, "-slide-in {\n 0% {\n height: 1px;\n }\n 100% {\n height: ").concat(height, "px;\n }\n }\n @keyframes ").concat(id, "-slide-out {\n 0% {\n height: ").concat(height, "px;\n opacity: 1;\n }\n 50% {\n opacity: 1;\n }\n 100% {\n height: 1px;\n opacity: 0;\n }\n }");
174
+ };