@elliemae/pui-app-sdk 5.20.3 → 5.21.0-beta.2
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/cjs/analytics/index.js +2 -1
- package/dist/cjs/utils/decorators/functionDecorators.js +2 -2
- package/dist/cjs/utils/micro-frontend/app-bridge.js +36 -0
- package/dist/cjs/utils/micro-frontend/guest.js +99 -13
- package/dist/cjs/utils/micro-frontend/host.js +35 -2
- package/dist/cjs/utils/micro-frontend/tests/app.config.json +200 -0
- package/dist/cjs/utils/micro-frontend/tests/utils.js +116 -0
- package/dist/cjs/utils/testing/index.js +15 -1
- package/dist/cjs/view/micro-iframe-app/iframe/index.js +1 -1
- package/dist/cjs/view/micro-iframe-app/iframe.html +5 -1
- package/dist/cjs/view/micro-iframe-app/use-frame-loaded.js +3 -1
- package/dist/cjs/view/microapp-v2.js +91 -0
- package/dist/cjs/view/tests/__snapshots__/micro-iframe-app.test.tsx.snap +208 -0
- package/dist/cjs/view/tests/__snapshots__/microapp-v2.test.tsx.snap +21 -0
- package/dist/cjs/view/tests/app.config.json +200 -0
- package/dist/cjs/view/tests/constants.js +44 -0
- package/dist/cjs/view/tests/flights/23.1/app.checksum1.css +3 -0
- package/dist/cjs/view/tests/flights/23.1/app.checksum1.js +52 -0
- package/dist/cjs/view/tests/flights/23.1/manifest.json +4 -0
- package/dist/cjs/view/tests/flights/latest/app.checksum.css +3 -0
- package/dist/cjs/view/tests/flights/latest/app.checksum.js +52 -0
- package/dist/cjs/view/tests/flights/latest/manifest.json +4 -0
- package/dist/cjs/view/tests/hotels/23.1/app.checksum.css +3 -0
- package/dist/cjs/view/tests/hotels/23.1/app.checksum.js +52 -0
- package/dist/cjs/view/tests/hotels/23.1/manifest.json +4 -0
- package/dist/cjs/view/tests/hotels/latest/app.checksum.css +3 -0
- package/dist/cjs/view/tests/hotels/latest/app.checksum.js +52 -0
- package/dist/cjs/view/tests/hotels/latest/manifest.json +4 -0
- package/dist/cjs/view/tests/loan/latest/index.js +116 -0
- package/dist/cjs/view/tests/loan/latest/manifest.json +3 -0
- package/dist/cjs/view/tests/scriptingObjects/appraisalServiceModule.js +85 -0
- package/dist/cjs/{utils/micro-frontend/host-app.js → view/tests/scriptingObjects/constant.js} +5 -10
- package/dist/cjs/view/tests/scriptingObjects/global.js +40 -0
- package/dist/cjs/view/tests/scriptingObjects/loan.js +207 -0
- package/dist/cjs/view/tests/server.js +29 -0
- package/dist/cjs/view/tests/serverHandlers.js +210 -0
- package/dist/cjs/view/tests/task/latest/index.dev.js +67 -0
- package/dist/cjs/view/tests/task/latest/index.js +67 -0
- package/dist/cjs/view/tests/task/latest/manifest.json +4 -0
- package/dist/cjs/view/tests/travelhub/23.1/app.checksum.css +3 -0
- package/dist/cjs/view/tests/travelhub/23.1/app.checksum.js +25 -0
- package/dist/cjs/view/tests/travelhub/23.1/landing.checksum1.css +3 -0
- package/dist/cjs/view/tests/travelhub/23.1/landing.checksum1.js +6 -0
- package/dist/cjs/view/tests/travelhub/23.1/manifest.json +6 -0
- package/dist/cjs/view/tests/travelhub/latest/app.checksum.css +3 -0
- package/dist/cjs/view/tests/travelhub/latest/app.checksum.js +30 -0
- package/dist/cjs/view/tests/travelhub/latest/landing.checksum.css +3 -0
- package/dist/cjs/view/tests/travelhub/latest/landing.checksum.js +8 -0
- package/dist/cjs/view/tests/travelhub/latest/manifest.json +6 -0
- package/dist/cjs/{utils/micro-frontend/ssfguest-adapter.js → view/tests/utils.js} +34 -29
- package/dist/esm/analytics/index.js +2 -1
- package/dist/esm/utils/decorators/functionDecorators.js +2 -2
- package/dist/esm/utils/micro-frontend/app-bridge.js +16 -0
- package/dist/esm/utils/micro-frontend/guest.js +99 -13
- package/dist/esm/utils/micro-frontend/host.js +35 -2
- package/dist/esm/utils/micro-frontend/tests/app.config.json +200 -0
- package/dist/esm/utils/micro-frontend/tests/utils.js +96 -0
- package/dist/esm/utils/testing/index.js +5 -1
- package/dist/esm/view/micro-iframe-app/iframe/index.js +1 -1
- package/dist/esm/view/micro-iframe-app/iframe.html +5 -1
- package/dist/esm/view/micro-iframe-app/use-frame-loaded.js +3 -1
- package/dist/esm/view/microapp-v2.js +71 -0
- package/dist/esm/view/tests/__snapshots__/micro-iframe-app.test.tsx.snap +208 -0
- package/dist/esm/view/tests/__snapshots__/microapp-v2.test.tsx.snap +21 -0
- package/dist/esm/view/tests/app.config.json +200 -0
- package/dist/esm/view/tests/constants.js +24 -0
- package/dist/esm/view/tests/flights/23.1/app.checksum1.css +3 -0
- package/dist/esm/view/tests/flights/23.1/app.checksum1.js +51 -0
- package/dist/esm/view/tests/flights/23.1/manifest.json +4 -0
- package/dist/esm/view/tests/flights/latest/app.checksum.css +3 -0
- package/dist/esm/view/tests/flights/latest/app.checksum.js +51 -0
- package/dist/esm/view/tests/flights/latest/manifest.json +4 -0
- package/dist/esm/view/tests/hotels/23.1/app.checksum.css +3 -0
- package/dist/esm/view/tests/hotels/23.1/app.checksum.js +51 -0
- package/dist/esm/view/tests/hotels/23.1/manifest.json +4 -0
- package/dist/esm/view/tests/hotels/latest/app.checksum.css +3 -0
- package/dist/esm/view/tests/hotels/latest/app.checksum.js +51 -0
- package/dist/esm/view/tests/hotels/latest/manifest.json +4 -0
- package/dist/esm/view/tests/loan/latest/index.js +115 -0
- package/dist/esm/view/tests/loan/latest/manifest.json +3 -0
- package/dist/esm/view/tests/scriptingObjects/appraisalServiceModule.js +67 -0
- package/dist/esm/view/tests/scriptingObjects/constant.js +4 -0
- package/dist/esm/view/tests/scriptingObjects/global.js +20 -0
- package/dist/esm/view/tests/scriptingObjects/loan.js +187 -0
- package/dist/esm/view/tests/server.js +9 -0
- package/dist/esm/view/tests/serverHandlers.js +180 -0
- package/dist/esm/view/tests/task/latest/index.dev.js +66 -0
- package/dist/esm/view/tests/task/latest/index.js +66 -0
- package/dist/esm/view/tests/task/latest/manifest.json +4 -0
- package/dist/esm/view/tests/travelhub/23.1/app.checksum.css +3 -0
- package/dist/esm/view/tests/travelhub/23.1/app.checksum.js +24 -0
- package/dist/esm/view/tests/travelhub/23.1/landing.checksum1.css +3 -0
- package/dist/esm/view/tests/travelhub/23.1/landing.checksum1.js +5 -0
- package/dist/esm/view/tests/travelhub/23.1/manifest.json +6 -0
- package/dist/esm/view/tests/travelhub/latest/app.checksum.css +3 -0
- package/dist/esm/view/tests/travelhub/latest/app.checksum.js +29 -0
- package/dist/esm/view/tests/travelhub/latest/landing.checksum.css +3 -0
- package/dist/esm/view/tests/travelhub/latest/landing.checksum.js +7 -0
- package/dist/esm/view/tests/travelhub/latest/manifest.json +6 -0
- package/dist/esm/view/tests/utils.js +33 -0
- package/dist/types/lib/utils/micro-frontend/app-bridge.d.ts +4 -0
- package/dist/types/lib/utils/micro-frontend/guest.d.ts +46 -11
- package/dist/types/lib/utils/micro-frontend/host.d.ts +20 -3
- package/dist/types/lib/utils/micro-frontend/tests/utils.d.ts +39 -0
- package/dist/types/lib/utils/micro-frontend/types.d.ts +2 -1
- package/dist/types/lib/utils/testing/index.d.ts +57 -1
- package/dist/types/lib/utils/window.d.ts +13 -6
- package/dist/types/lib/view/microapp-v2.d.ts +16 -0
- package/dist/types/lib/view/tests/constants.d.ts +11 -0
- package/dist/types/lib/view/tests/flights/23.1/app.checksum1.d.ts +7 -0
- package/dist/types/lib/view/tests/flights/latest/app.checksum.d.ts +7 -0
- package/dist/types/lib/view/tests/hotels/23.1/app.checksum.d.ts +7 -0
- package/dist/types/lib/view/tests/hotels/latest/app.checksum.d.ts +7 -0
- package/dist/types/lib/view/tests/loan/latest/index.d.ts +11 -0
- package/dist/types/lib/view/tests/microapp-v2.test.d.ts +1 -0
- package/dist/types/lib/view/tests/scriptingObjects/appraisalServiceModule.d.ts +36 -0
- package/dist/types/lib/view/tests/scriptingObjects/constant.d.ts +1 -0
- package/dist/types/lib/view/tests/scriptingObjects/global.d.ts +9 -0
- package/dist/types/lib/view/tests/scriptingObjects/loan.d.ts +31 -0
- package/dist/types/lib/view/tests/server.d.ts +1 -0
- package/dist/types/lib/view/tests/serverHandlers.d.ts +5 -0
- package/dist/types/lib/view/tests/task/latest/index.d.ts +10 -0
- package/dist/types/lib/view/tests/task/latest/index.dev.d.ts +10 -0
- package/dist/types/lib/view/tests/travelhub/23.1/app.checksum.d.ts +7 -0
- package/dist/types/lib/view/tests/travelhub/23.1/landing.checksum1.d.ts +2 -0
- package/dist/types/lib/view/tests/travelhub/latest/app.checksum.d.ts +0 -0
- package/dist/types/lib/view/tests/travelhub/latest/landing.checksum.d.ts +0 -0
- package/dist/types/lib/view/tests/utils.d.ts +7 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +43 -39
- package/dist/esm/utils/micro-frontend/host-app.js +0 -9
- package/dist/esm/utils/micro-frontend/ssfguest-adapter.js +0 -28
- package/dist/types/lib/utils/micro-frontend/host-app.d.ts +0 -11
- package/dist/types/lib/utils/micro-frontend/ssfguest-adapter.d.ts +0 -7
- /package/dist/types/lib/{utils/micro-frontend/tests/guest-ssf-host.test.d.ts → view/tests/micro-iframe-app.test.d.ts} +0 -0
|
@@ -69,6 +69,10 @@
|
|
|
69
69
|
<strong>JavaScript has been disabled on your browser</strong>, please
|
|
70
70
|
<strong>enable JS</strong> to make this app work.</noscript
|
|
71
71
|
>
|
|
72
|
-
<div
|
|
72
|
+
<div
|
|
73
|
+
id="pui-app-container-"
|
|
74
|
+
data-testid="pui-app-container-"
|
|
75
|
+
class="full-width full-height"
|
|
76
|
+
></div>
|
|
73
77
|
</body>
|
|
74
78
|
</html>
|
|
@@ -25,6 +25,7 @@ var import_react = require("react");
|
|
|
25
25
|
var import_session = require("../../utils/session.js");
|
|
26
26
|
var import_host = require("../../utils/micro-frontend/host.js");
|
|
27
27
|
var import_micro_frontend = require("../../utils/micro-frontend/index.js");
|
|
28
|
+
var import_const = require("../micro-app/const.js");
|
|
28
29
|
const addBaseTag = (id, documentEle) => {
|
|
29
30
|
const { hostUrl, manifestPath } = (0, import_micro_frontend.getMicroFrontEndAppConfig)({
|
|
30
31
|
id
|
|
@@ -36,9 +37,10 @@ const addBaseTag = (id, documentEle) => {
|
|
|
36
37
|
documentEle.getElementsByTagName("head")[0].appendChild(base);
|
|
37
38
|
};
|
|
38
39
|
const updateContainerId = (id, documentEle) => {
|
|
39
|
-
const ele = documentEle.getElementById(
|
|
40
|
+
const ele = documentEle.getElementById(import_const.APP_CONTAINER_ID_PREFIX);
|
|
40
41
|
if (ele) {
|
|
41
42
|
ele.id = `${ele.id}${id}`;
|
|
43
|
+
ele.dataset.testid = ele.id;
|
|
42
44
|
}
|
|
43
45
|
};
|
|
44
46
|
const useFrameLoaded = ({ id, documentEle }) => {
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var microapp_v2_exports = {};
|
|
20
|
+
__export(microapp_v2_exports, {
|
|
21
|
+
MicroApp2: () => MicroApp2
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(microapp_v2_exports);
|
|
24
|
+
var import_react = require("react");
|
|
25
|
+
var import_react_redux = require("react-redux");
|
|
26
|
+
var import_app_bridge = require("../utils/micro-frontend/app-bridge.js");
|
|
27
|
+
var import_actions = require("../data/wait-message/actions.js");
|
|
28
|
+
var import_micro_frontend = require("../utils/micro-frontend/index.js");
|
|
29
|
+
const useAppRenderer = (props) => {
|
|
30
|
+
const { id, frameOptions, history, onLoadComplete, onUnloadComplete } = props;
|
|
31
|
+
const dispatch = (0, import_react_redux.useDispatch)();
|
|
32
|
+
(0, import_react.useLayoutEffect)(() => {
|
|
33
|
+
let isMounted = true;
|
|
34
|
+
let appBridge = null;
|
|
35
|
+
let unloadInProgress = Promise.resolve();
|
|
36
|
+
let instanceId = null;
|
|
37
|
+
(async () => {
|
|
38
|
+
await unloadInProgress;
|
|
39
|
+
dispatch(import_actions.waitMessage.open());
|
|
40
|
+
try {
|
|
41
|
+
appBridge = await (0, import_app_bridge.getAppBridge)();
|
|
42
|
+
if (!appBridge)
|
|
43
|
+
throw new Error(`Failed to load ${id}, AppBridge not initialized`);
|
|
44
|
+
if (isMounted) {
|
|
45
|
+
instanceId = await appBridge.openApp({
|
|
46
|
+
id,
|
|
47
|
+
frameOptions,
|
|
48
|
+
history
|
|
49
|
+
});
|
|
50
|
+
setTimeout(() => {
|
|
51
|
+
try {
|
|
52
|
+
onLoadComplete?.(instanceId);
|
|
53
|
+
} catch (ex) {
|
|
54
|
+
}
|
|
55
|
+
}, 0);
|
|
56
|
+
}
|
|
57
|
+
} catch (ex) {
|
|
58
|
+
(0, import_micro_frontend.getLogger)().error({
|
|
59
|
+
message: `Failed to load ${id}`,
|
|
60
|
+
exception: ex
|
|
61
|
+
});
|
|
62
|
+
isMounted = false;
|
|
63
|
+
if (appBridge && instanceId)
|
|
64
|
+
unloadInProgress = appBridge.closeApp(instanceId);
|
|
65
|
+
throw ex;
|
|
66
|
+
} finally {
|
|
67
|
+
dispatch(import_actions.waitMessage.close());
|
|
68
|
+
}
|
|
69
|
+
})();
|
|
70
|
+
return () => {
|
|
71
|
+
isMounted = false;
|
|
72
|
+
if (appBridge) {
|
|
73
|
+
unloadInProgress = appBridge.closeApp(instanceId);
|
|
74
|
+
unloadInProgress.then(() => {
|
|
75
|
+
instanceId = null;
|
|
76
|
+
setTimeout(() => {
|
|
77
|
+
try {
|
|
78
|
+
onUnloadComplete?.();
|
|
79
|
+
} catch (ex) {
|
|
80
|
+
}
|
|
81
|
+
}, 0);
|
|
82
|
+
}).catch(() => {
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
}, [dispatch, frameOptions, history, id, onLoadComplete, onUnloadComplete]);
|
|
87
|
+
};
|
|
88
|
+
const MicroApp2 = (0, import_react.memo)((props) => {
|
|
89
|
+
useAppRenderer(props);
|
|
90
|
+
return null;
|
|
91
|
+
});
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
2
|
+
|
|
3
|
+
exports[`MicroIFrameApp should close previous instance of app before loading new instance 2`] = `
|
|
4
|
+
<body
|
|
5
|
+
class="full-width full-height"
|
|
6
|
+
>
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
<!-- Display a message if JS has been disabled on the browser. -->
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
<noscript>
|
|
13
|
+
If you're seeing this message, that means
|
|
14
|
+
<strong>JavaScript has been disabled on your browser</strong>, please
|
|
15
|
+
<strong>enable JS</strong> to make this app work.
|
|
16
|
+
</noscript>
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
<div
|
|
20
|
+
class="full-width full-height"
|
|
21
|
+
data-testid="pui-app-container-loanapp"
|
|
22
|
+
id="pui-app-container-loanapp"
|
|
23
|
+
>
|
|
24
|
+
<main>
|
|
25
|
+
<h1>
|
|
26
|
+
Loan App
|
|
27
|
+
</h1>
|
|
28
|
+
<p>
|
|
29
|
+
Go to
|
|
30
|
+
<a
|
|
31
|
+
href="#"
|
|
32
|
+
>
|
|
33
|
+
Pipeline
|
|
34
|
+
</a>
|
|
35
|
+
</p>
|
|
36
|
+
</main>
|
|
37
|
+
</div>
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
<script
|
|
43
|
+
id="emui-script-Loan-1"
|
|
44
|
+
src="http://localhost:3111/loan/latest/index.js"
|
|
45
|
+
/>
|
|
46
|
+
</body>
|
|
47
|
+
`;
|
|
48
|
+
|
|
49
|
+
exports[`MicroIFrameApp should open loanapp and call init and mount methods 1`] = `
|
|
50
|
+
<head>
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
<!-- The first thing in any HTML file should be the charset -->
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
<meta
|
|
57
|
+
charset="utf-8"
|
|
58
|
+
/>
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
<!-- Make the page mobile compatible -->
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
<meta
|
|
65
|
+
content="width=device-width, initial-scale=1"
|
|
66
|
+
name="viewport"
|
|
67
|
+
/>
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
<!-- Allow installing the app to the homescreen -->
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
<meta
|
|
74
|
+
content="yes"
|
|
75
|
+
name="mobile-web-app-capable"
|
|
76
|
+
/>
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
<link
|
|
80
|
+
href="/favicon.ico"
|
|
81
|
+
rel="icon"
|
|
82
|
+
/>
|
|
83
|
+
|
|
84
|
+
|
|
85
|
+
<title>
|
|
86
|
+
Application
|
|
87
|
+
</title>
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
<!-- Google Tag Manager -->
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
<!-- <script nonce="__CSP_NONCE__">
|
|
94
|
+
(function (w, d, s, l, i) {
|
|
95
|
+
w[l] = w[l] || [];
|
|
96
|
+
w[l].push({ 'gtm.start': new Date().getTime(), event: 'gtm.js' });
|
|
97
|
+
var f = d.getElementsByTagName(s)[0],
|
|
98
|
+
j = d.createElement(s),
|
|
99
|
+
dl = l != 'dataLayer' ? '&l=' + l : '';
|
|
100
|
+
j.async = true;
|
|
101
|
+
j.src =
|
|
102
|
+
'https://www.googletagmanager.com/gtm.js?id=' +
|
|
103
|
+
i +
|
|
104
|
+
dl;
|
|
105
|
+
f.parentNode.insertBefore(j, f);
|
|
106
|
+
})(window, document, 'script', 'dataLayer', window.emui.gtm.id);
|
|
107
|
+
</script> -->
|
|
108
|
+
|
|
109
|
+
|
|
110
|
+
<!-- <script nonce="__CSP_NONCE__">
|
|
111
|
+
window.emuiUserMonitoring = window.parent.emuiUserMonitoring || {
|
|
112
|
+
setCustomVirtualPageName: function () {},
|
|
113
|
+
startVirtualPageMonitoringWithAutoEnd: function () {},
|
|
114
|
+
};
|
|
115
|
+
</script> -->
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
<script
|
|
119
|
+
src="https://www.google-analytics.com/analytics.js"
|
|
120
|
+
/>
|
|
121
|
+
<script>
|
|
122
|
+
|
|
123
|
+
(function (i, s, o, g, r, a, m) {
|
|
124
|
+
i['GoogleAnalyticsObject'] = r;
|
|
125
|
+
(i[r] =
|
|
126
|
+
i[r] ||
|
|
127
|
+
function () {
|
|
128
|
+
(i[r].q = i[r].q || []).push(arguments);
|
|
129
|
+
}),
|
|
130
|
+
(i[r].l = 1 * new Date());
|
|
131
|
+
(a = s.createElement(o)), (m = s.getElementsByTagName(o)[0]);
|
|
132
|
+
a.async = 1;
|
|
133
|
+
a.src = g;
|
|
134
|
+
m.parentNode.insertBefore(a, m);
|
|
135
|
+
})(
|
|
136
|
+
window,
|
|
137
|
+
document,
|
|
138
|
+
'script',
|
|
139
|
+
'https://www.google-analytics.com/analytics.js',
|
|
140
|
+
'ga',
|
|
141
|
+
);
|
|
142
|
+
|
|
143
|
+
</script>
|
|
144
|
+
|
|
145
|
+
|
|
146
|
+
<style>
|
|
147
|
+
|
|
148
|
+
.full-width {
|
|
149
|
+
width: 100%;
|
|
150
|
+
}
|
|
151
|
+
.full-height {
|
|
152
|
+
height: 100%;
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
</style>
|
|
156
|
+
|
|
157
|
+
|
|
158
|
+
<base
|
|
159
|
+
href="http://localhost:3111/loan/latest"
|
|
160
|
+
/>
|
|
161
|
+
</head>
|
|
162
|
+
`;
|
|
163
|
+
|
|
164
|
+
exports[`MicroIFrameApp should open loanapp and call init and mount methods 2`] = `
|
|
165
|
+
<body
|
|
166
|
+
class="full-width full-height"
|
|
167
|
+
>
|
|
168
|
+
|
|
169
|
+
|
|
170
|
+
<!-- Display a message if JS has been disabled on the browser. -->
|
|
171
|
+
|
|
172
|
+
|
|
173
|
+
<noscript>
|
|
174
|
+
If you're seeing this message, that means
|
|
175
|
+
<strong>JavaScript has been disabled on your browser</strong>, please
|
|
176
|
+
<strong>enable JS</strong> to make this app work.
|
|
177
|
+
</noscript>
|
|
178
|
+
|
|
179
|
+
|
|
180
|
+
<div
|
|
181
|
+
class="full-width full-height"
|
|
182
|
+
data-testid="pui-app-container-loanapp"
|
|
183
|
+
id="pui-app-container-loanapp"
|
|
184
|
+
>
|
|
185
|
+
<main>
|
|
186
|
+
<h1>
|
|
187
|
+
Loan App
|
|
188
|
+
</h1>
|
|
189
|
+
<p>
|
|
190
|
+
Go to
|
|
191
|
+
<a
|
|
192
|
+
href="#"
|
|
193
|
+
>
|
|
194
|
+
Pipeline
|
|
195
|
+
</a>
|
|
196
|
+
</p>
|
|
197
|
+
</main>
|
|
198
|
+
</div>
|
|
199
|
+
|
|
200
|
+
|
|
201
|
+
|
|
202
|
+
|
|
203
|
+
<script
|
|
204
|
+
id="emui-script-Loan-1"
|
|
205
|
+
src="http://localhost:3111/loan/latest/index.js"
|
|
206
|
+
/>
|
|
207
|
+
</body>
|
|
208
|
+
`;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
|
2
|
+
|
|
3
|
+
exports[`MicroAppV2 should open loanapp and call init and mount methods 1`] = `
|
|
4
|
+
Document {
|
|
5
|
+
"location": Location {
|
|
6
|
+
"assign": [Function],
|
|
7
|
+
"hash": "",
|
|
8
|
+
"host": "localhost:3111",
|
|
9
|
+
"hostname": "localhost",
|
|
10
|
+
"href": "http://localhost:3111/frame.html",
|
|
11
|
+
"origin": "http://localhost:3111",
|
|
12
|
+
"pathname": "/frame.html",
|
|
13
|
+
"port": "3111",
|
|
14
|
+
"protocol": "http:",
|
|
15
|
+
"reload": [Function],
|
|
16
|
+
"replace": [Function],
|
|
17
|
+
"search": "",
|
|
18
|
+
"toString": [Function],
|
|
19
|
+
},
|
|
20
|
+
}
|
|
21
|
+
`;
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
{
|
|
2
|
+
"appId": "microfe",
|
|
3
|
+
"activeEnv": "localhost",
|
|
4
|
+
"googleTagManager": true,
|
|
5
|
+
"sessionTimeoutWarnInterval": "7200000",
|
|
6
|
+
"sessionTimeoutInterval": "9000000",
|
|
7
|
+
"microFrontendApps": {
|
|
8
|
+
"loanapp": {
|
|
9
|
+
"name": "Loan",
|
|
10
|
+
"hostUrl": "./loan",
|
|
11
|
+
"development": {
|
|
12
|
+
"files": ["index.js"]
|
|
13
|
+
},
|
|
14
|
+
"production": {
|
|
15
|
+
"files": ["index.js"]
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
"taskapp": {
|
|
19
|
+
"name": "Task",
|
|
20
|
+
"hostUrl": "./task",
|
|
21
|
+
"mode": "development",
|
|
22
|
+
"development": {
|
|
23
|
+
"files": ["index.dev.js"]
|
|
24
|
+
},
|
|
25
|
+
"production": {
|
|
26
|
+
"files": ["index.js"]
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
"travelhub": {
|
|
30
|
+
"name": "TravelHub",
|
|
31
|
+
"hostUrl": "./travelhub",
|
|
32
|
+
"development": {
|
|
33
|
+
"files": ["app.js", "landing.js", "app.css", "landing.css"]
|
|
34
|
+
},
|
|
35
|
+
"production": {
|
|
36
|
+
"files": ["app.js", "landing.js", "app.css", "landing.css"]
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
"flights": {
|
|
40
|
+
"name": "Flights",
|
|
41
|
+
"hostUrl": "./flights",
|
|
42
|
+
"development": {
|
|
43
|
+
"files": ["app.js", "app.css"]
|
|
44
|
+
},
|
|
45
|
+
"production": {
|
|
46
|
+
"files": ["app.js", "app.css"]
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
"hotels": {
|
|
50
|
+
"name": "Hotels",
|
|
51
|
+
"hostUrl": "./hotels",
|
|
52
|
+
"development": {
|
|
53
|
+
"files": ["app.js", "app.css"]
|
|
54
|
+
},
|
|
55
|
+
"production": {
|
|
56
|
+
"files": ["app.js", "app.css"]
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
"serviceEndpoints": {
|
|
61
|
+
"api": "",
|
|
62
|
+
"idp": "https://int.idp.ellielabs.com",
|
|
63
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
64
|
+
},
|
|
65
|
+
"env": {
|
|
66
|
+
"localhost": {
|
|
67
|
+
"serviceEndpoints": {
|
|
68
|
+
"api": "",
|
|
69
|
+
"idp": "https://int.idp.ellielabs.com",
|
|
70
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
"dev": {
|
|
74
|
+
"serviceEndpoints": {
|
|
75
|
+
"api": "https://dev.api.puiservice.rd.elliemae.io",
|
|
76
|
+
"idp": "https://int.idp.ellielabs.com",
|
|
77
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
"dev2": {
|
|
81
|
+
"serviceEndpoints": {
|
|
82
|
+
"api": "https://int.api.ellielabs.com",
|
|
83
|
+
"idp": "https://int.idp.ellielabs.com",
|
|
84
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
85
|
+
}
|
|
86
|
+
},
|
|
87
|
+
"qa": {
|
|
88
|
+
"serviceEndpoints": {
|
|
89
|
+
"api": "https://dev.api.puiservice.rd.elliemae.io",
|
|
90
|
+
"idp": "https://int.idp.ellielabs.com",
|
|
91
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
92
|
+
}
|
|
93
|
+
},
|
|
94
|
+
"qa2": {
|
|
95
|
+
"serviceEndpoints": {
|
|
96
|
+
"api": "https://int.api.ellielabs.com",
|
|
97
|
+
"idp": "https://int.idp.ellielabs.com",
|
|
98
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
99
|
+
}
|
|
100
|
+
},
|
|
101
|
+
"qa3": {
|
|
102
|
+
"serviceEndpoints": {
|
|
103
|
+
"api": "https://int.api.ellielabs.com",
|
|
104
|
+
"idp": "https://int.idp.ellielabs.com",
|
|
105
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
106
|
+
}
|
|
107
|
+
},
|
|
108
|
+
"int": {
|
|
109
|
+
"serviceEndpoints": {
|
|
110
|
+
"api": "https://int.api.ellielabs.com",
|
|
111
|
+
"idp": "https://int.idp.ellielabs.com",
|
|
112
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
|
+
"peg-osb1": {
|
|
116
|
+
"serviceEndpoints": {
|
|
117
|
+
"api": "https://encompass-peg-api.elliemae.com",
|
|
118
|
+
"idp": "https://peg.idp.ellielabs.com/authorize",
|
|
119
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
120
|
+
}
|
|
121
|
+
},
|
|
122
|
+
"peg-osb2": {
|
|
123
|
+
"serviceEndpoints": {
|
|
124
|
+
"api": "https://encompass-peg2-api.elliemae.com",
|
|
125
|
+
"idp": "https://peg.idp.ellielabs.com/authorize",
|
|
126
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
127
|
+
}
|
|
128
|
+
},
|
|
129
|
+
"peg": {
|
|
130
|
+
"serviceEndpoints": {
|
|
131
|
+
"api": "https://peg2-west.api.ellielabs.com",
|
|
132
|
+
"idp": "https://peg.idp.ellielabs.com/authorize",
|
|
133
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
134
|
+
}
|
|
135
|
+
},
|
|
136
|
+
"peg-oapi-west": {
|
|
137
|
+
"serviceEndpoints": {
|
|
138
|
+
"api": "https://peg2-west.api.ellielabs.com",
|
|
139
|
+
"idp": "https://peg.idp.ellielabs.com/authorize",
|
|
140
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
141
|
+
}
|
|
142
|
+
},
|
|
143
|
+
"peg-oapi-east": {
|
|
144
|
+
"serviceEndpoints": {
|
|
145
|
+
"api": "https://peg2-east.api.ellielabs.com",
|
|
146
|
+
"idp": "https://peg.idp.ellielabs.com/authorize",
|
|
147
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
148
|
+
}
|
|
149
|
+
},
|
|
150
|
+
"peg2-oapi-east": {
|
|
151
|
+
"serviceEndpoints": {
|
|
152
|
+
"api": "https://peg2-east.api.ellielabs.com",
|
|
153
|
+
"idp": "https://peg.idp.ellielabs.com/authorize",
|
|
154
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
155
|
+
}
|
|
156
|
+
},
|
|
157
|
+
"peg3": {
|
|
158
|
+
"serviceEndpoints": {
|
|
159
|
+
"api": "https://pel1.api.ellielabs.com",
|
|
160
|
+
"idp": "https://peg3.idp.ellielabs.com/authorize",
|
|
161
|
+
"logger": "https://int.api.ellielabs.com/diagnostics/v2/logging"
|
|
162
|
+
}
|
|
163
|
+
},
|
|
164
|
+
"stage": {
|
|
165
|
+
"serviceEndpoints": {
|
|
166
|
+
"api": "https://stg.api.elliemae.com",
|
|
167
|
+
"idp": "https://stg.idp.elliemae.com/authorize",
|
|
168
|
+
"logger": "https://api.ellielabs.com/diagnostics/v2/logging"
|
|
169
|
+
}
|
|
170
|
+
},
|
|
171
|
+
"beta": {
|
|
172
|
+
"serviceEndpoints": {
|
|
173
|
+
"api": "https://concept.api.elliemae.com",
|
|
174
|
+
"idp": "https://concept.idp.elliemae.com/authorize",
|
|
175
|
+
"logger": "https://api.ellielabs.com/diagnostics/v2/logging"
|
|
176
|
+
}
|
|
177
|
+
},
|
|
178
|
+
"demo": {
|
|
179
|
+
"serviceEndpoints": {
|
|
180
|
+
"api": "https://concept.api.elliemae.com",
|
|
181
|
+
"idp": "https://concept.idp.elliemae.com/authorize",
|
|
182
|
+
"logger": "https://api.ellielabs.com/diagnostics/v2/logging"
|
|
183
|
+
}
|
|
184
|
+
},
|
|
185
|
+
"epc": {
|
|
186
|
+
"serviceEndpoints": {
|
|
187
|
+
"api": "https://concept.api.elliemae.com",
|
|
188
|
+
"idp": "https://concept.idp.elliemae.com/authorize",
|
|
189
|
+
"logger": "https://api.ellielabs.com/diagnostics/v2/logging"
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
"prod": {
|
|
193
|
+
"serviceEndpoints": {
|
|
194
|
+
"api": "https://api.elliemae.com",
|
|
195
|
+
"idp": "https://idp.elliemae.com/authorize",
|
|
196
|
+
"logger": "https://api.ellielabs.com/diagnostics/v2/logging"
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var constants_exports = {};
|
|
20
|
+
__export(constants_exports, {
|
|
21
|
+
APP_CONFIG_JSON_URL: () => APP_CONFIG_JSON_URL,
|
|
22
|
+
FLIGHTS_APP_ID: () => FLIGHTS_APP_ID,
|
|
23
|
+
FRAME_APP_CONTAINER_ID_PREFIX: () => FRAME_APP_CONTAINER_ID_PREFIX,
|
|
24
|
+
FRAME_CONTAINER_ID_PREFIX: () => FRAME_CONTAINER_ID_PREFIX,
|
|
25
|
+
HOTELS_APP_ID: () => HOTELS_APP_ID,
|
|
26
|
+
LATEST_VERSION: () => LATEST_VERSION,
|
|
27
|
+
LOAN_APP_ID: () => LOAN_APP_ID,
|
|
28
|
+
LOAN_SAVED_EVENT: () => LOAN_SAVED_EVENT,
|
|
29
|
+
PRE_COMMIT_EVENT: () => PRE_COMMIT_EVENT,
|
|
30
|
+
RELEASE_VERSION: () => RELEASE_VERSION,
|
|
31
|
+
TASK_APP_ID: () => TASK_APP_ID
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(constants_exports);
|
|
34
|
+
const LATEST_VERSION = "latest";
|
|
35
|
+
const RELEASE_VERSION = "23.1.0";
|
|
36
|
+
const LOAN_APP_ID = "loanapp";
|
|
37
|
+
const TASK_APP_ID = "taskapp";
|
|
38
|
+
const FLIGHTS_APP_ID = "flights";
|
|
39
|
+
const HOTELS_APP_ID = "hotels";
|
|
40
|
+
const APP_CONFIG_JSON_URL = "/latest/app.config.json";
|
|
41
|
+
const LOAN_SAVED_EVENT = "loanSaved";
|
|
42
|
+
const PRE_COMMIT_EVENT = "preCommit";
|
|
43
|
+
const FRAME_CONTAINER_ID_PREFIX = "pui-iframe-container-";
|
|
44
|
+
const FRAME_APP_CONTAINER_ID_PREFIX = "pui-app-container-";
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
const appId = "flights";
|
|
3
|
+
const appName = "Flights App";
|
|
4
|
+
const getWindow = () => {
|
|
5
|
+
try {
|
|
6
|
+
window.parent.document;
|
|
7
|
+
return window.parent;
|
|
8
|
+
} catch (err) {
|
|
9
|
+
return window;
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
let host = null;
|
|
13
|
+
let parentHistory = null;
|
|
14
|
+
let logger = null;
|
|
15
|
+
const browserWindow = getWindow();
|
|
16
|
+
browserWindow.__TEST__ = browserWindow.__TEST__ ?? {
|
|
17
|
+
logs: []
|
|
18
|
+
};
|
|
19
|
+
window.emui = window.emui || { uuid: crypto.randomUUID() };
|
|
20
|
+
window.emui.app = {
|
|
21
|
+
uuid: window.emui.uuid,
|
|
22
|
+
init: async (options) => {
|
|
23
|
+
browserWindow.__TEST__.logs.push(`${appId} initializing`);
|
|
24
|
+
host = options.host;
|
|
25
|
+
parentHistory = options.history;
|
|
26
|
+
logger = options.logger;
|
|
27
|
+
return Promise.resolve();
|
|
28
|
+
},
|
|
29
|
+
mount: async () => {
|
|
30
|
+
browserWindow.__TEST__.logs.push(`${appId} mounting`);
|
|
31
|
+
const mainElement = document.createElement("main");
|
|
32
|
+
const pageHeaderEle = document.createElement("h1");
|
|
33
|
+
pageHeaderEle.textContent = appName;
|
|
34
|
+
pageHeaderEle.id = "header";
|
|
35
|
+
mainElement.appendChild(pageHeaderEle);
|
|
36
|
+
const versionEle = document.createElement("p");
|
|
37
|
+
versionEle.textContent = "Version: 23.1";
|
|
38
|
+
versionEle.id = "version";
|
|
39
|
+
mainElement.appendChild(versionEle);
|
|
40
|
+
document.body.appendChild(mainElement);
|
|
41
|
+
browserWindow.__TEST__.logs.push(`${appId} mounted`);
|
|
42
|
+
return Promise.resolve();
|
|
43
|
+
},
|
|
44
|
+
unmount: () => {
|
|
45
|
+
browserWindow.__TEST__.logs.push(`${appId} unmounting`);
|
|
46
|
+
const mainEle = document.getElementsByTagName("main")[0];
|
|
47
|
+
if (mainEle) mainEle.remove();
|
|
48
|
+
browserWindow.__TEST__.logs.push(`${appId} unmounted`);
|
|
49
|
+
return Promise.resolve();
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
browserWindow.emui?.registerApp?.({ appId, app: window.emui.app });
|