@elliemae/pui-app-sdk 5.22.0 → 5.23.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/analytics/index.js +2 -1
- package/dist/cjs/index.js +3 -0
- package/dist/cjs/utils/micro-frontend/app-bridge.js +38 -0
- package/dist/cjs/utils/micro-frontend/guest.js +101 -14
- package/dist/cjs/utils/micro-frontend/host.js +36 -3
- package/dist/cjs/utils/micro-frontend/scripting-objects/analytics.js +8 -14
- 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/guest-microapp.js +113 -0
- 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/tests/__snapshots__/guest-microapp.test.tsx.snap +21 -0
- package/dist/cjs/view/tests/__snapshots__/micro-iframe-app.test.tsx.snap +208 -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 +81 -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 +200 -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/index.js +7 -1
- package/dist/esm/utils/micro-frontend/app-bridge.js +18 -0
- package/dist/esm/utils/micro-frontend/guest.js +101 -14
- package/dist/esm/utils/micro-frontend/host.js +36 -3
- package/dist/esm/utils/micro-frontend/scripting-objects/analytics.js +8 -4
- 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/guest-microapp.js +83 -0
- 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/tests/__snapshots__/guest-microapp.test.tsx.snap +21 -0
- package/dist/esm/view/tests/__snapshots__/micro-iframe-app.test.tsx.snap +208 -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 +63 -0
- package/dist/esm/view/tests/scriptingObjects/constant.js +4 -0
- package/dist/esm/view/tests/scriptingObjects/global.js +22 -0
- package/dist/esm/view/tests/scriptingObjects/loan.js +180 -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/index.d.ts +2 -1
- 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 +27 -10
- package/dist/types/lib/utils/micro-frontend/scripting-objects/analytics.d.ts +8 -5
- 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/guest-microapp.d.ts +13 -0
- package/dist/types/lib/view/micro-app/index.d.ts +5 -0
- package/dist/types/lib/view/micro-iframe-app/index.d.ts +5 -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/micro-iframe-app.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 +44 -44
- 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/guest-microapp.test.d.ts} +0 -0
|
@@ -0,0 +1,116 @@
|
|
|
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 utils_exports = {};
|
|
20
|
+
__export(utils_exports, {
|
|
21
|
+
applicationScriptingObject: () => applicationScriptingObject,
|
|
22
|
+
authScriptingObject: () => authScriptingObject,
|
|
23
|
+
postMessage: () => postMessage,
|
|
24
|
+
setupHost: () => setupHost
|
|
25
|
+
});
|
|
26
|
+
module.exports = __toCommonJS(utils_exports);
|
|
27
|
+
var import_microfe_common = require("@elliemae/microfe-common");
|
|
28
|
+
const applicationScriptingObject = {
|
|
29
|
+
object: {
|
|
30
|
+
events: [],
|
|
31
|
+
functions: [
|
|
32
|
+
"closeModal",
|
|
33
|
+
"extend",
|
|
34
|
+
"getApplicationContext",
|
|
35
|
+
"getCapabilities",
|
|
36
|
+
"getCompanySettings",
|
|
37
|
+
"getDescriptor",
|
|
38
|
+
"getPersonaAccess",
|
|
39
|
+
"getPoliciesDetails",
|
|
40
|
+
"getUserAccessRights",
|
|
41
|
+
"hideSpinner",
|
|
42
|
+
"keepSessionAlive",
|
|
43
|
+
"log",
|
|
44
|
+
"navigate",
|
|
45
|
+
"open",
|
|
46
|
+
"openModal",
|
|
47
|
+
"performAction",
|
|
48
|
+
"print",
|
|
49
|
+
"showError",
|
|
50
|
+
"showSpinner",
|
|
51
|
+
"supportsAction",
|
|
52
|
+
"supportsNavigateTo"
|
|
53
|
+
],
|
|
54
|
+
objectId: "application",
|
|
55
|
+
objectType: "Object"
|
|
56
|
+
},
|
|
57
|
+
type: "object"
|
|
58
|
+
};
|
|
59
|
+
const authScriptingObject = {
|
|
60
|
+
object: {
|
|
61
|
+
events: [],
|
|
62
|
+
functions: ["getAccessToken", "createAuthCode", "getUser"],
|
|
63
|
+
objectId: "auth",
|
|
64
|
+
objectType: "Object"
|
|
65
|
+
},
|
|
66
|
+
type: "object"
|
|
67
|
+
};
|
|
68
|
+
const hostObjects = {
|
|
69
|
+
application: applicationScriptingObject,
|
|
70
|
+
auth: authScriptingObject
|
|
71
|
+
};
|
|
72
|
+
const getOrigin = (url) => {
|
|
73
|
+
if (!url || url === "about:blank") return "*";
|
|
74
|
+
try {
|
|
75
|
+
const { origin } = new URL(url);
|
|
76
|
+
return origin === "null" || !origin ? url : origin;
|
|
77
|
+
} catch (e) {
|
|
78
|
+
const { origin } = new URL(url, document.baseURI);
|
|
79
|
+
return origin;
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
const postMessage = ({
|
|
83
|
+
srcWindow,
|
|
84
|
+
targetWindow,
|
|
85
|
+
message
|
|
86
|
+
}) => {
|
|
87
|
+
targetWindow.dispatchEvent(
|
|
88
|
+
new MessageEvent("message", {
|
|
89
|
+
source: srcWindow,
|
|
90
|
+
origin: getOrigin(srcWindow.location.href),
|
|
91
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
92
|
+
data: {
|
|
93
|
+
source: "elli:remoting",
|
|
94
|
+
...message
|
|
95
|
+
}
|
|
96
|
+
})
|
|
97
|
+
);
|
|
98
|
+
};
|
|
99
|
+
const setupHost = (hostWindow) => {
|
|
100
|
+
const onMessage = ({ data }) => {
|
|
101
|
+
if (data?.type !== import_microfe_common.MessageType.ObjectGet) return;
|
|
102
|
+
const scriptingObject = hostObjects[data?.body?.objectId ?? ""] ?? null;
|
|
103
|
+
if (scriptingObject)
|
|
104
|
+
postMessage({
|
|
105
|
+
srcWindow: hostWindow,
|
|
106
|
+
targetWindow: window,
|
|
107
|
+
message: {
|
|
108
|
+
body: scriptingObject,
|
|
109
|
+
type: "elli:remoting:response",
|
|
110
|
+
requestId: data.requestId
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
};
|
|
114
|
+
hostWindow?.addEventListener?.("message", onMessage);
|
|
115
|
+
return () => hostWindow?.removeEventListener?.("message", onMessage);
|
|
116
|
+
};
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
2
3
|
var __defProp = Object.defineProperty;
|
|
3
4
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
5
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
5
7
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
8
|
var __export = (target, all) => {
|
|
7
9
|
for (var name in all)
|
|
@@ -16,6 +18,14 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
18
|
return to;
|
|
17
19
|
};
|
|
18
20
|
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
21
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
22
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
23
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
24
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
25
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
26
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
27
|
+
mod
|
|
28
|
+
));
|
|
19
29
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
30
|
var testing_exports = {};
|
|
21
31
|
__export(testing_exports, {
|
|
@@ -24,6 +34,7 @@ __export(testing_exports, {
|
|
|
24
34
|
module.exports = __toCommonJS(testing_exports);
|
|
25
35
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
26
36
|
var import_react = require("@testing-library/react");
|
|
37
|
+
var import_user_event = __toESM(require("@testing-library/user-event"));
|
|
27
38
|
var import_pui_theme = require("@elliemae/pui-theme");
|
|
28
39
|
var import_store = require("../../data/store.js");
|
|
29
40
|
var import_app_root = require("../../view/app-root/index.js");
|
|
@@ -36,4 +47,7 @@ const AllTheProviders = ({
|
|
|
36
47
|
theme = defaultTheme,
|
|
37
48
|
children
|
|
38
49
|
}) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_app_root.AppRoot, { store, history: import_history.browserHistory, theme, children });
|
|
39
|
-
const customRender = (ui, options) => (
|
|
50
|
+
const customRender = (ui, options) => ({
|
|
51
|
+
user: import_user_event.default.setup(),
|
|
52
|
+
...(0, import_react.render)(ui, { wrapper: AllTheProviders, ...options })
|
|
53
|
+
});
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var guest_microapp_exports = {};
|
|
30
|
+
__export(guest_microapp_exports, {
|
|
31
|
+
GuestMicroApp: () => GuestMicroApp
|
|
32
|
+
});
|
|
33
|
+
module.exports = __toCommonJS(guest_microapp_exports);
|
|
34
|
+
var import_jsx_runtime = require("react/jsx-runtime");
|
|
35
|
+
var import_react = require("react");
|
|
36
|
+
var import_styled_components = __toESM(require("styled-components"));
|
|
37
|
+
var import_react_redux = require("react-redux");
|
|
38
|
+
var import_app_bridge = require("../utils/micro-frontend/app-bridge.js");
|
|
39
|
+
var import_actions = require("../data/wait-message/actions.js");
|
|
40
|
+
var import_micro_frontend = require("../utils/micro-frontend/index.js");
|
|
41
|
+
const Div = import_styled_components.default.div`
|
|
42
|
+
display: flex;
|
|
43
|
+
width: 100%;
|
|
44
|
+
height: 100%;
|
|
45
|
+
flex-direction: column;
|
|
46
|
+
overflow: hidden;
|
|
47
|
+
`;
|
|
48
|
+
const useAppRenderer = (props) => {
|
|
49
|
+
const { id, history, onLoadComplete, onUnloadComplete, containerId } = props;
|
|
50
|
+
const dispatch = (0, import_react_redux.useDispatch)();
|
|
51
|
+
(0, import_react.useLayoutEffect)(() => {
|
|
52
|
+
let isMounted = true;
|
|
53
|
+
let appBridge = null;
|
|
54
|
+
let unloadInProgress = Promise.resolve();
|
|
55
|
+
let instanceId = null;
|
|
56
|
+
(async () => {
|
|
57
|
+
await unloadInProgress;
|
|
58
|
+
dispatch(import_actions.waitMessage.open());
|
|
59
|
+
try {
|
|
60
|
+
appBridge = await (0, import_app_bridge.getAppBridge)();
|
|
61
|
+
if (!appBridge)
|
|
62
|
+
throw new Error(`Failed to load ${id}, AppBridge not initialized`);
|
|
63
|
+
if (isMounted) {
|
|
64
|
+
instanceId = await appBridge.openApp({
|
|
65
|
+
id,
|
|
66
|
+
frameOptions: { containerId },
|
|
67
|
+
history
|
|
68
|
+
});
|
|
69
|
+
setTimeout(() => {
|
|
70
|
+
try {
|
|
71
|
+
onLoadComplete?.(instanceId);
|
|
72
|
+
} catch (ex) {
|
|
73
|
+
}
|
|
74
|
+
}, 0);
|
|
75
|
+
}
|
|
76
|
+
} catch (ex) {
|
|
77
|
+
(0, import_micro_frontend.getLogger)().error({
|
|
78
|
+
message: `Failed to load ${id}`,
|
|
79
|
+
exception: ex
|
|
80
|
+
});
|
|
81
|
+
isMounted = false;
|
|
82
|
+
if (appBridge && instanceId)
|
|
83
|
+
unloadInProgress = appBridge.closeApp(instanceId);
|
|
84
|
+
throw ex;
|
|
85
|
+
} finally {
|
|
86
|
+
dispatch(import_actions.waitMessage.close());
|
|
87
|
+
}
|
|
88
|
+
})();
|
|
89
|
+
return () => {
|
|
90
|
+
isMounted = false;
|
|
91
|
+
if (appBridge) {
|
|
92
|
+
unloadInProgress = appBridge.closeApp(instanceId);
|
|
93
|
+
unloadInProgress.then(() => {
|
|
94
|
+
instanceId = null;
|
|
95
|
+
setTimeout(() => {
|
|
96
|
+
try {
|
|
97
|
+
onUnloadComplete?.();
|
|
98
|
+
} catch (ex) {
|
|
99
|
+
}
|
|
100
|
+
}, 0);
|
|
101
|
+
}).catch(() => {
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
}, [containerId, dispatch, history, id, onLoadComplete, onUnloadComplete]);
|
|
106
|
+
};
|
|
107
|
+
const GuestMicroApp = (0, import_react.memo)(
|
|
108
|
+
(props) => {
|
|
109
|
+
const containerId = (0, import_react.useRef)(crypto.randomUUID());
|
|
110
|
+
useAppRenderer({ ...props, containerId: containerId.current });
|
|
111
|
+
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(Div, { id: containerId.current });
|
|
112
|
+
}
|
|
113
|
+
);
|
|
@@ -61,7 +61,7 @@ const IFrame = (0, import_react.memo)(
|
|
|
61
61
|
ref: frameRef,
|
|
62
62
|
title,
|
|
63
63
|
src,
|
|
64
|
-
|
|
64
|
+
"data-testid": `${import_const.IFRAME_CONTAINER_ID_PREFIX}${id}`,
|
|
65
65
|
...sandboxProps,
|
|
66
66
|
onLoad: () => frameRef?.current?.contentDocument && onFrameReady(frameRef.current.contentDocument)
|
|
67
67
|
}
|
|
@@ -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,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,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
|
+
`;
|