@alipay/ams-checkout 0.0.1693912790-dev.3 → 0.0.1694400497-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.
- package/dist/umd/ams-checkout.min.js +1 -1
- package/esm/constant/index.d.ts +53 -32
- package/esm/constant/index.js +53 -32
- package/esm/core/component/index.d.ts +23 -16
- package/esm/core/component/index.js +155 -44
- package/esm/core/drop-in/index.d.ts +4 -11
- package/esm/core/drop-in/index.js +19 -19
- package/esm/core/instance/index.d.ts +6 -15
- package/esm/core/instance/index.js +32 -53
- package/esm/image/skeleton.svg +18 -0
- package/esm/index.d.ts +4 -10
- package/esm/index.js +8 -30
- package/esm/plugin/component/cashierApp.d.ts +2 -2
- package/esm/plugin/component/cashierApp.js +16 -15
- package/esm/plugin/component/{component.style.d.ts → component.inline.style.d.ts} +4 -1
- package/esm/plugin/component/component.inline.style.js +38 -0
- package/esm/plugin/component/component.popup.style.d.ts +12 -0
- package/esm/plugin/component/component.popup.style.js +165 -0
- package/esm/plugin/component/index.d.ts +26 -33
- package/esm/plugin/component/index.js +243 -396
- package/esm/plugin/drop-in/index.d.ts +7 -9
- package/esm/plugin/drop-in/index.js +4 -3
- package/esm/request/index.d.ts +2 -9
- package/esm/request/index.js +15 -28
- package/esm/request/utils.d.ts +4 -4
- package/esm/request/utils.js +6 -4
- package/esm/service/index.d.ts +2 -2
- package/esm/types/index.d.ts +78 -51
- package/esm/types/index.js +85 -48
- package/esm/util/createIframeNode.d.ts +3 -3
- package/esm/util/createIframeNode.js +15 -8
- package/esm/util/get.js +7 -0
- package/esm/util/index.d.ts +8 -6
- package/esm/util/index.js +25 -11
- package/esm/util/mock.js +1 -2
- package/package.json +1 -1
- package/esm/plugin/component/component.style.js +0 -15
- package/esm/util/security.d.ts +0 -12
- package/esm/util/security.js +0 -107
@@ -0,0 +1,165 @@
|
|
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}\n\n.ams-component-container-desktop {\n display: block;\n width: 672px;\n position: fixed;\n top: 50%;\n left: 50%;\n z-index: 1001;\n border-radius: 8px;\n overflow: hidden;\n transform-origin: 50% 50%;\n}\n.ams-component-container-desktop-animation{\n animation: ams-component-container-zoom-in 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n\n@keyframes ams-component-container-zoom-out {\n 0% {\n transform: translate(-50%, -50%) scale(1);\n -webkit-transform: translate(-50%, -50%) scale(1);\n opacity: 1\n }\n \n 100% {\n opacity: 0;\n transform: translate(-50%, -50%) scale(0.4);\n -webkit-transform: translate(-50%, -50%) scale(0.4);\n }\n}\n\n@keyframes ams-component-container-zoom-in {\n 0% {\n transform: translate(-50%, -50%) scale(0.4);\n opacity: 0\n }\n\n 80% {\n opacity: 1\n }\n\n 100% {\n opacity: 1;\n transform: translate(-50%, -50%) scale(1);\n }\n}\n\n.ams-component-container-hidden-desktop {\n display: block;\n position: fixed;\n top: 50%;\n left: 50%;\n z-index: 1001;\n border-radius: 8px;\n overflow: hidden;\n animation: ams-component-container-zoom-out 0.3s ease-in-out;\n animation-fill-mode: forwards;\n transform-origin: 50% 50%;\n}\n\n.ams-component-loading {\n width: 0.8em;\n height:0.8em;\n background: rgba(0, 0, 0, 0.5);\n border-radius: 8px;\n position: fixed;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n z-index: 1001;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n}\n\n.ams-component-loading .line {\n width: 40px;\n height: 40px;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n}\n.ams-component-loading .line div {\n position: absolute;\n left: 17.67px;\n top: 0;\n width: 5.33px;\n height: 40px;\n}\n\n.ams-component-loading .line div:before,\n.ams-component-loading .line div:after {\n content: '';\n display: block;\n height: 13.33px;\n background: #fcfcfc;\n border-radius: 5.3px;\n}\n.ams-component-loading .line div:after {\n margin-top: 13.33px;\n}\n\n.ams-component-loading .line div:nth-child(2) {\n -webkit-transform: rotate(45deg);\n}\n\n.ams-component-loading .line div:nth-child(3) {\n -webkit-transform: rotate(90deg);\n}\n\n.ams-component-loading .line div:nth-child(4) {\n -webkit-transform: rotate(135deg);\n}\n\n/** \u52A0\u8F7D\u52A8\u753B **/\n@-webkit-keyframes load {\n 0% {\n opacity: 0;\n }\n\n 100% {\n opacity: 1;\n }\n}\n\n.ams-component-loading .line div:nth-child(1):before {\n -webkit-animation: load 1s linear 0s infinite;\n}\n\n.ams-component-loading .line div:nth-child(2):before {\n -webkit-animation: load 1s linear 0.125s infinite;\n}\n\n.ams-component-loading .line div:nth-child(3):before {\n -webkit-animation: load 1s linear 0.25s infinite;\n}\n\n.ams-component-loading .line div:nth-child(4):before {\n -webkit-animation: load 1s linear 0.375s infinite;\n}\n\n.ams-component-loading .line div:nth-child(1):after {\n -webkit-animation: load 1s linear 0.5s infinite;\n}\n\n.ams-component-loading .line div:nth-child(2):after {\n -webkit-animation: load 1s linear 0.675s infinite;\n}\n\n.ams-component-loading .line div:nth-child(3):after {\n -webkit-animation: load 1s linear 0.75s infinite;\n}\n\n.ams-component-loading .line div:nth-child(4):after {\n -webkit-animation: load 1s linear 0.875s infinite;\n}\n\n.ams-component-loading-logo {\n width: 0.44em;\n height: 0.44em;\n -webkit-transform:rotate(360deg);\n transform:rotate(360deg);\n -webkit-transition:-webkit-transform 1s linear;\n transition:transform 1s linear;\n animation: ams-component-loading-logo 1s linear infinite;\n}\n\n.asm-component-close-block-desktop {\n position: absolute;\n width: 40px;\n height: 40px;\n right: 0;\n top: 0;\n cursor: pointer;\n}\n.asm-component-close-block-btn-desktop {\n width: 11px;\n height: 11px;\n object-fit: fill;\n position: absolute;\n right: 18.7px;\n top: 26.7px;\n}\n.asm-component-close-block-hidden {\n width: 0px !important;\n height: 0px !important;\n visibility: hidden;\n}\n.asm-component-close-block-mobile {\n position: absolute;\n width: 0.4em;\n height: 0.4em;\n right: 0;\n top: 0;\n cursor: pointer;\n z-index: 1009;\n}\n\n.asm-component-close-block-btn-mobile {\n width: 0.11em;\n height: 0.11em;\n object-fit: fill;\n position: absolute;\n right: 0.147em;\n top: 0.167em;\n}\n\n\n.ams-component-container-opacity{\n opacity: 1;\n}\n\n.ams-component-container-opacity:after{\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n display: block;\n content: \"\";\n z-index: 1010;\n background-color: rgba(0, 0, 0, 0.35);\n}\n\n#ams-component-retention {\n position: fixed;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n transform-origin: 50%;\n height: auto;\n display: none;\n z-index: 1009;\n}\n\n.ams-component-retention-show {\n display: flex !important;\n animation: ams-component-container-zoom-in 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n\n.ams-component-retention-hidden {\n display: flex !important;\n animation: ams-component-container-zoom-out 0.3s ease-in-out;\n -webkit-animation: ams-component-container-zoom-out 0.3s ease-in-out;\n animation-fill-mode: forwards;\n -webkit-animation-fill-mode: forwards;\n}\n\n.ams-component-retention-mobile {\n width: 294px;\n border-radius: 12px;\n padding: 24px 0;\n background-color: #fff;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n box-sizing: border-box;\n}\n\n.ams-component-retention-desktop {\n width: 544px;\n border-radius: 12px;\n padding: 32px;\n background-color: #fff;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n box-sizing: border-box;\n}\n\n@media screen and (max-width: 300px) {\n .ams-component-retention-mobile {\n transform: translate(-50%, -50%) scale(0.8);\n }\n}\n\n.ams-component-retention-title-mobile {\n width: 100%;\n font-style: normal;\n font-weight: 500;\n font-size: 16px;\n line-height: 24px;\n color: #2A3A52;\n text-align: center;\n padding: 0 16px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-title-desktop {\n text-align: left;\n width: 100%;\n font-style: normal;\n font-weight: 500;\n font-size: 16px;\n line-height: 24px;\n color: #2A3A52;\n}\n\n.ams-component-retention-sub-title-mobile {\n width: 100%;\n font-weight: 400;\n font-size: 14px;\n line-height: 20px;\n color: #7C8CA3;\n margin-top: 8px;\n text-align: center;\n padding: 0 16px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-sub-title-desktop {\n text-align: left;\n font-style: normal;\n font-weight: 400;\n font-size: 14px;\n line-height: 20px;\n color: #7C8CA3;\n margin-top: 10px;\n}\n\n.ams-component-retention-btn-block-mobile {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: center;\n margin-top: 24px;\n padding: 0 24px;\n box-sizing: border-box;\n}\n\n.ams-component-retention-btn-block-desktop {\n width: 100%;\n margin-top: 24px;\n}\n\n#ams-component-retention-remain {\n background: #0079FF;\n border-radius: 100px;\n font-style: normal;\n font-weight: 500;\n text-align: center;\n box-sizing: border-box;\n color: #FFFFFF;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.ams-component-retention-remain-mobile {\n width: 100%;\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n padding: 0 6px;\n}\n\n.ams-component-retention-remain-desktop {\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n display: inline-block;\n padding: 0 24px;\n float: right;\n cursor: pointer;\n padding: 0 8px;\n max-width: 225px;\n}\n\n#ams-component-retention-leave {\n border-radius: 100px;\n border: 1px solid #0079FF;\n font-style: normal;\n font-weight: 500;\n text-align: center;\n box-sizing: border-box;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.ams-component-retention-leave-mobile {\n width: 100%;\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n color: #1677FF;\n margin-top: 12px;\n padding: 0 6px;\n}\n\n.ams-component-retention-leave-desktop {\n height: 44px;\n font-size: 16px;\n line-height: 44px;\n color: #1677FF;\n display: inline-block;\n padding: 0 24px;\n float: right;\n margin-right: 16px;\n cursor: pointer;\n padding: 0 8px;\n max-width: 225px;\n}\n.".concat(MOCKUP_ID, "-hidden{\nanimation: ").concat(MOCKUP_ID, "-opacity 0.3s ease-in-out;\n animation-fill-mode: forwards\n}\n/** \u52A0\u8F7D\u52A8\u753B **/\n@-webkit-keyframes ").concat(MOCKUP_ID, "-opacity {\n 0% {\n opacity: 1;\n }\n\n 100% {\n opacity: 0;\n }\n}\n");
|
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 ? 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 ? void 0 : _document$getElementB.remove();
|
91
|
+
};
|
92
|
+
export var createMockup = function createMockup() {
|
93
|
+
var body = document.getElementsByTagName('body')[0];
|
94
|
+
body.style.overflow = 'hidden';
|
95
|
+
var mockup = document.createElement('div');
|
96
|
+
mockup.style.width = '100vw';
|
97
|
+
mockup.style.height = '100vh';
|
98
|
+
mockup.style.position = 'fixed';
|
99
|
+
mockup.style.top = '0';
|
100
|
+
mockup.style.left = '0';
|
101
|
+
mockup.style.zIndex = '1000';
|
102
|
+
mockup.style.background = 'rgba(0,0,0,0.5)';
|
103
|
+
mockup.style.display = 'none';
|
104
|
+
mockup.id = MOCKUP_ID;
|
105
|
+
body.appendChild(mockup);
|
106
|
+
};
|
107
|
+
export var addPopupLoading = function addPopupLoading() {
|
108
|
+
var loading = document.createElement('div');
|
109
|
+
loading === null || loading === void 0 ? void 0 : loading.classList.add(LOADING_ID);
|
110
|
+
loading.id = LOADING_ID;
|
111
|
+
loading.innerHTML = '<div class="line"><div></div><div></div><div></div><div></div></div>';
|
112
|
+
loading.style.fontSize = "".concat(getDesignFontSize(), "px");
|
113
|
+
var body = document.getElementsByTagName('body')[0];
|
114
|
+
body === null || body === void 0 ? void 0 : body.appendChild(loading);
|
115
|
+
};
|
116
|
+
|
117
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
118
|
+
export var handleDeclareInfo = function handleDeclareInfo(_ref) {
|
119
|
+
var _ref$closeDialogData = _ref.closeDialogData,
|
120
|
+
closeDialogData = _ref$closeDialogData === void 0 ? {} : _ref$closeDialogData;
|
121
|
+
try {
|
122
|
+
if (closeDialogData) {
|
123
|
+
var retentionTitle = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-title"));
|
124
|
+
if (retentionTitle) {
|
125
|
+
var _closeDialogData$titl, _closeDialogData$titl2, _closeDialogData$titl3;
|
126
|
+
retentionTitle.style.fontSize = "".concat(closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$titl = closeDialogData.title) === null || _closeDialogData$titl === void 0 ? void 0 : _closeDialogData$titl.fontSize, "px");
|
127
|
+
retentionTitle.style.color = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$titl2 = closeDialogData.title) === null || _closeDialogData$titl2 === void 0 ? void 0 : _closeDialogData$titl2.fontColor;
|
128
|
+
retentionTitle.innerHTML = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$titl3 = closeDialogData.title) === null || _closeDialogData$titl3 === void 0 ? void 0 : _closeDialogData$titl3.text;
|
129
|
+
}
|
130
|
+
var retentionMessage = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-sub-title"));
|
131
|
+
if (retentionMessage) {
|
132
|
+
var _closeDialogData$mess, _closeDialogData$mess2, _closeDialogData$mess3;
|
133
|
+
retentionMessage.style.fontSize = "".concat(closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$mess = closeDialogData.message) === null || _closeDialogData$mess === void 0 ? void 0 : _closeDialogData$mess.fontSize, "px");
|
134
|
+
retentionMessage.style.color = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$mess2 = closeDialogData.message) === null || _closeDialogData$mess2 === void 0 ? void 0 : _closeDialogData$mess2.fontColor;
|
135
|
+
retentionMessage.innerHTML = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$mess3 = closeDialogData.message) === null || _closeDialogData$mess3 === void 0 ? void 0 : _closeDialogData$mess3.text;
|
136
|
+
}
|
137
|
+
var remainBtn = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-remain"));
|
138
|
+
if (remainBtn) {
|
139
|
+
var _closeDialogData$btnO, _closeDialogData$btnO2, _closeDialogData$btnO3, _closeDialogData$btnO4, _closeDialogData$btnO5, _closeDialogData$btnO7;
|
140
|
+
remainBtn.innerHTML = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnO = closeDialogData.btnOK) === null || _closeDialogData$btnO === void 0 ? void 0 : _closeDialogData$btnO.text;
|
141
|
+
remainBtn.style.fontSize = "".concat(closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnO2 = closeDialogData.btnOK) === null || _closeDialogData$btnO2 === void 0 ? void 0 : _closeDialogData$btnO2.fontSize, "px");
|
142
|
+
remainBtn.style.color = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnO3 = closeDialogData.btnOK) === null || _closeDialogData$btnO3 === void 0 ? void 0 : _closeDialogData$btnO3.fontColor;
|
143
|
+
remainBtn.style.borderRadius = "".concat(closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnO4 = closeDialogData.btnOK) === null || _closeDialogData$btnO4 === void 0 ? void 0 : _closeDialogData$btnO4.corner, "px");
|
144
|
+
if ((closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnO5 = closeDialogData.btnOK) === null || _closeDialogData$btnO5 === void 0 ? void 0 : _closeDialogData$btnO5.type) === 'stroke') {
|
145
|
+
var _closeDialogData$btnO6;
|
146
|
+
remainBtn.style.border = "1px solid ".concat(closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnO6 = closeDialogData.btnOK) === null || _closeDialogData$btnO6 === void 0 ? void 0 : _closeDialogData$btnO6.bg);
|
147
|
+
} else remainBtn.style.backgroundColor = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnO7 = closeDialogData.btnOK) === null || _closeDialogData$btnO7 === void 0 ? void 0 : _closeDialogData$btnO7.bg;
|
148
|
+
}
|
149
|
+
var leaveBrn = document.getElementById("".concat(COMPONENT_RETENTION_ID, "-leave"));
|
150
|
+
if (leaveBrn) {
|
151
|
+
var _closeDialogData$btnC, _closeDialogData$btnC2, _closeDialogData$btnC3, _closeDialogData$btnC4, _closeDialogData$btnC5, _closeDialogData$btnC7;
|
152
|
+
leaveBrn.innerHTML = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnC = closeDialogData.btnCancel) === null || _closeDialogData$btnC === void 0 ? void 0 : _closeDialogData$btnC.text;
|
153
|
+
leaveBrn.style.fontSize = "".concat(closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnC2 = closeDialogData.btnCancel) === null || _closeDialogData$btnC2 === void 0 ? void 0 : _closeDialogData$btnC2.fontSize, "px");
|
154
|
+
leaveBrn.style.color = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnC3 = closeDialogData.btnCancel) === null || _closeDialogData$btnC3 === void 0 ? void 0 : _closeDialogData$btnC3.fontColor;
|
155
|
+
leaveBrn.style.borderRadius = "".concat(closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnC4 = closeDialogData.btnCancel) === null || _closeDialogData$btnC4 === void 0 ? void 0 : _closeDialogData$btnC4.corner, "px");
|
156
|
+
if ((closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnC5 = closeDialogData.btnCancel) === null || _closeDialogData$btnC5 === void 0 ? void 0 : _closeDialogData$btnC5.type) === 'stroke') {
|
157
|
+
var _closeDialogData$btnC6;
|
158
|
+
leaveBrn.style.border = "1px solid ".concat(closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnC6 = closeDialogData.btnCancel) === null || _closeDialogData$btnC6 === void 0 ? void 0 : _closeDialogData$btnC6.bg);
|
159
|
+
} else leaveBrn.style.backgroundColor = closeDialogData === null || closeDialogData === void 0 ? void 0 : (_closeDialogData$btnC7 = closeDialogData.btnCancel) === null || _closeDialogData$btnC7 === void 0 ? void 0 : _closeDialogData$btnC7.bg;
|
160
|
+
}
|
161
|
+
}
|
162
|
+
} catch (error) {
|
163
|
+
console.error(error);
|
164
|
+
}
|
165
|
+
};
|
@@ -1,11 +1,15 @@
|
|
1
1
|
import type AMSCheckout from '../../core/instance';
|
2
|
-
import type { IappendIframeNodesParams,
|
3
|
-
import {
|
2
|
+
import type { eventPayload, eventPayloadContext, IappendIframeNodesParams, Iselector } from '../../types';
|
3
|
+
import { componentSignEnum, platformEnum, renderDisplayTypeEnum } from '../../types';
|
4
|
+
type IrenderFuncParams = (context: ComponentApp, selector: Iselector, renderDisplayType: renderDisplayTypeEnum) => Promise<void>;
|
4
5
|
export default class ComponentApp {
|
5
6
|
app: any;
|
6
|
-
appDomain: string;
|
7
7
|
AMSSDK: AMSCheckout;
|
8
|
-
platform:
|
8
|
+
platform: platformEnum;
|
9
|
+
_performanceData: any[];
|
10
|
+
_loadAppPromiseResolve: ((value: boolean) => void) | null;
|
11
|
+
_isInitComponent: boolean;
|
12
|
+
private appDomain;
|
9
13
|
private createIframeNode;
|
10
14
|
private _selector;
|
11
15
|
private _appVersion;
|
@@ -13,9 +17,8 @@ export default class ComponentApp {
|
|
13
17
|
private _actionQueryPromise;
|
14
18
|
private _renderParams;
|
15
19
|
private _componentSign;
|
16
|
-
private _performanceData;
|
17
|
-
private _isInitComponent;
|
18
20
|
private _clickEventName;
|
21
|
+
private _renderDisplayType;
|
19
22
|
constructor();
|
20
23
|
/**
|
21
24
|
* @description Cancel listening and destroy the dom
|
@@ -28,17 +31,19 @@ export default class ComponentApp {
|
|
28
31
|
/**
|
29
32
|
* @description Set the rendering capability of the cashier plug-in. Different technology stacks have some differences in the packaging and use of rendering functions
|
30
33
|
*/
|
31
|
-
setRender(
|
32
|
-
initAPSecurity(): void;
|
34
|
+
setRender(renderFunc: IrenderFuncParams): void;
|
33
35
|
/**
|
34
36
|
* @description render iframe content
|
35
37
|
*/
|
36
|
-
appendIframeNodes(componentSign: componentSignEnum, renderParams: IappendIframeNodesParams): Promise<void
|
38
|
+
appendIframeNodes(componentSign: componentSignEnum, renderParams: IappendIframeNodesParams): Promise<void>;
|
39
|
+
private renderInlineLoading;
|
40
|
+
private renderPopupLoading;
|
41
|
+
_createLoadAppPromise(): Promise<unknown>;
|
37
42
|
/**
|
38
43
|
* @description Interface request
|
39
44
|
*/
|
40
45
|
private createActionQueryPromise;
|
41
|
-
private
|
46
|
+
private cleanElement;
|
42
47
|
/**
|
43
48
|
* @description Create app
|
44
49
|
*/
|
@@ -48,12 +53,12 @@ export default class ComponentApp {
|
|
48
53
|
/**
|
49
54
|
* @description Initialize subscription iframe message
|
50
55
|
*/
|
51
|
-
private
|
52
|
-
private
|
56
|
+
private addEventListener;
|
57
|
+
private removeEventListener;
|
53
58
|
/**
|
54
59
|
* @description Processing messages from iframe
|
55
60
|
*/
|
56
|
-
|
61
|
+
_handleAppMessage(data: eventPayload): void;
|
57
62
|
private handleSizeChanged;
|
58
63
|
private handleRedirect;
|
59
64
|
private handleDeclareInfo;
|
@@ -61,11 +66,13 @@ export default class ComponentApp {
|
|
61
66
|
/**
|
62
67
|
* @description Send message to SDK
|
63
68
|
*/
|
64
|
-
|
69
|
+
dispatchToSDK(event: string, data: any, eventCallbackId?: string): void;
|
65
70
|
/**
|
66
71
|
* @description Send message to iframe
|
67
72
|
*/
|
68
|
-
|
73
|
+
dispatchToApp(payload: {
|
74
|
+
context: eventPayloadContext;
|
75
|
+
}): any;
|
69
76
|
/**
|
70
77
|
* @description Subscribe to messages from SDK
|
71
78
|
*/
|
@@ -74,30 +81,16 @@ export default class ComponentApp {
|
|
74
81
|
* @description Send rendering events to iframe
|
75
82
|
*/
|
76
83
|
private sendRenderEvent;
|
77
|
-
private showLoading;
|
78
|
-
/**
|
79
|
-
* @description show cashier
|
80
|
-
*/
|
81
|
-
private showCashier;
|
82
84
|
/**
|
83
85
|
* @description close cashier
|
84
86
|
*/
|
85
|
-
private
|
86
|
-
private
|
87
|
+
private cleanContainer;
|
88
|
+
private hideComponentAnimation;
|
87
89
|
private closeBtnFunc;
|
88
|
-
/**
|
89
|
-
* @description create mount node
|
90
|
-
*/
|
91
|
-
private createMountElement;
|
92
|
-
private createCloseBtn;
|
93
|
-
private createRetentionPopup;
|
94
90
|
private retentionPopupLeaveFunc;
|
95
91
|
private removeRetentionPopup;
|
96
92
|
private showRetentionPopup;
|
97
|
-
private
|
98
|
-
/**
|
99
|
-
* @description create mockup
|
100
|
-
*/
|
101
|
-
private createMockup;
|
93
|
+
private hideRetentionPopupFunc;
|
102
94
|
private submitForm;
|
103
95
|
}
|
96
|
+
export {};
|