@getflip/bridge 0.1.0-alpha.3 → 0.1.0-alpha.5

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 (37) hide show
  1. package/README.md +44 -3
  2. package/dist/i18n/i18n.spec.d.ts +1 -0
  3. package/dist/i18n/i18n.spec.js +27 -0
  4. package/dist/i18n/i18n.spec.js.map +1 -0
  5. package/dist/index.cjs.js +38 -17
  6. package/dist/index.cjs.js.map +1 -1
  7. package/dist/index.d.ts +7 -0
  8. package/dist/index.js +7 -0
  9. package/dist/index.js.map +1 -1
  10. package/dist/index.mjs +38 -18
  11. package/dist/index.mjs.map +1 -1
  12. package/dist/index.spec.d.ts +1 -0
  13. package/dist/index.spec.js +20 -0
  14. package/dist/index.spec.js.map +1 -0
  15. package/dist/logging/logging.js +2 -2
  16. package/dist/logging/logging.js.map +1 -1
  17. package/dist/logging/logging.spec.d.ts +1 -0
  18. package/dist/logging/logging.spec.js +19 -0
  19. package/dist/logging/logging.spec.js.map +1 -0
  20. package/dist/messaging/messaging.d.ts +2 -1
  21. package/dist/messaging/messaging.js +21 -14
  22. package/dist/messaging/messaging.js.map +1 -1
  23. package/dist/messaging/messaging.spec.d.ts +1 -0
  24. package/dist/messaging/messaging.spec.js +57 -0
  25. package/dist/messaging/messaging.spec.js.map +1 -0
  26. package/dist/navigation/navigation.js.map +1 -1
  27. package/dist/navigation/navigation.spec.d.ts +1 -0
  28. package/dist/navigation/navigation.spec.js +22 -0
  29. package/dist/navigation/navigation.spec.js.map +1 -0
  30. package/dist/navigation/navigation.types.d.ts +1 -1
  31. package/dist/theming/theming.spec.d.ts +1 -0
  32. package/dist/theming/theming.spec.js +19 -0
  33. package/dist/theming/theming.spec.js.map +1 -0
  34. package/dist/theming/theming.types.d.ts +1 -1
  35. package/dist/types.d.ts +6 -2
  36. package/dist/types.js.map +1 -1
  37. package/package.json +10 -2
package/README.md CHANGED
@@ -10,6 +10,7 @@ App or Flip Admin Console.
10
10
  - [Internationalization](#internationalization)
11
11
  - [Navigation](#navigation)
12
12
  - [Theming](#theming)
13
+ - [Error Handling](#error-handling)
13
14
  - [Development](#development)
14
15
 
15
16
  ## Installation
@@ -25,6 +26,18 @@ yarn add @getflip/bridge
25
26
  The library exposes a set of functions and listeners you can use to communicate
26
27
  with the Flip App and Flip Admin Console (host app for short).
27
28
 
29
+ **Before using the provided functions, you have to call the `initFlipBridge`
30
+ function to set up the Flip Bridge.**
31
+
32
+ ```js
33
+ import { initFlipBridge } from "@getflip/bridge";
34
+
35
+ initFlipBridge({
36
+ debug: true,
37
+ hostAppOrigin: "http://localhost:4200", // has to be the origin of the targeted host app
38
+ });
39
+ ```
40
+
28
41
  ### Internationalization
29
42
 
30
43
  #### `getAvailableLangs`
@@ -77,22 +90,50 @@ await navigate("/my-app/settings");
77
90
 
78
91
  Get the current theme.
79
92
 
80
- **Returns** `'light' | 'dark'`
93
+ **Returns**
94
+
95
+ ```js
96
+ {
97
+ activeTheme: "light" | "dark";
98
+ preferredTheme: "light" | "dark" | undefined;
99
+ }
100
+ ```
81
101
 
82
102
  **Example**
83
103
 
84
104
  ```js
85
105
  import { getTheme } from "@getflip/bridge";
86
106
 
87
- const currentTheme = await getTheme(); // e.g. 'light'
107
+ const theme = await getTheme();
88
108
  ```
89
109
 
110
+ ## Error Handling
111
+
112
+ All provided functions return promises that throw an error if the execution
113
+ failed. The errors have the following format.
114
+
115
+ ```js
116
+ {
117
+ code: BridgeErrorCode; // e.g. 'FORBIDDEN_ORIGIN'
118
+ }
119
+ ```
120
+
121
+ ### `FORBIDDEN_ORIGIN`
122
+
123
+ Thrown when the origin of the requesting app is not allowed by the host app.
124
+ Please check if your app is correctly registered in the Flip Partner Dashboard
125
+ and the `hostAppOrigin` option is set (see [Usage](#usage)).
126
+
127
+ ### `INVALID_REQUEST`
128
+
129
+ The host app identified the request as invalid. This typically occurs when the
130
+ provided parameters are invalid.
131
+
90
132
  ## Development
91
133
 
92
134
  Start the compiler in watch mode for local development:
93
135
 
94
136
  ```
95
- yarn
96
137
  yarn dev
97
138
  ```
98
139
 
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,27 @@
1
+ import { makeRequest } from "../messaging";
2
+ import { getAvailableLangs, getLang } from "./i18n";
3
+ jest.mock("../messaging", () => ({
4
+ makeRequest: jest.fn(),
5
+ }));
6
+ describe("i18n", () => {
7
+ beforeAll(() => {
8
+ global.flipBridgeOptions = { hostAppOrigin: "http://localhost" };
9
+ });
10
+ test("'getAvailableLangs' sends correct request", async () => {
11
+ await getAvailableLangs();
12
+ const makeRequestMock = makeRequest;
13
+ expect(makeRequestMock).toHaveBeenCalledWith({
14
+ id: makeRequestMock.mock.calls[0][0].id,
15
+ method: "GET_AVAILABLE_LANGS",
16
+ });
17
+ });
18
+ test("'getLang' sends correct request", async () => {
19
+ await getLang();
20
+ const makeRequestMock = makeRequest;
21
+ expect(makeRequestMock).toHaveBeenCalledWith({
22
+ id: makeRequestMock.mock.calls[0][0].id,
23
+ method: "GET_LANG",
24
+ });
25
+ });
26
+ });
27
+ //# sourceMappingURL=i18n.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i18n.spec.js","sourceRoot":"","sources":["../../src/i18n/i18n.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAEpD,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC;IAC/B,WAAW,EAAE,IAAI,CAAC,EAAE,EAAE;CACvB,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,MAAM,EAAE,GAAG,EAAE;IACpB,SAAS,CAAC,GAAG,EAAE;QACZ,MAAc,CAAC,iBAAiB,GAAG,EAAE,aAAa,EAAE,kBAAkB,EAAE,CAAC;IAC5E,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,iBAAiB,EAAE,CAAC;QAE1B,MAAM,eAAe,GAAG,WAEvB,CAAC;QAEF,MAAM,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC;YAC3C,EAAE,EAAE,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;YACvC,MAAM,EAAE,qBAAqB;SAC9B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,OAAO,EAAE,CAAC;QAEhB,MAAM,eAAe,GAAG,WAEvB,CAAC;QAEF,MAAM,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC;YAC3C,EAAE,EAAE,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;YACvC,MAAM,EAAE,UAAU;SACnB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
package/dist/index.cjs.js CHANGED
@@ -15,20 +15,23 @@ exports.BridgeMethod = void 0;
15
15
  BridgeMethod["NAVIGATE"] = "NAVIGATE";
16
16
  })(exports.BridgeMethod || (exports.BridgeMethod = {}));
17
17
 
18
- var _a$1;
19
- const debug = ((_a$1 = process === null || process === void 0 ? void 0 : process.env) === null || _a$1 === void 0 ? void 0 : _a$1.NODE_ENV) === "development";
20
18
  function log(message, details) {
19
+ var _a;
20
+ const debug = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.debug;
21
21
  if (debug) {
22
22
  console.log(`${message} – `, details);
23
23
  }
24
24
  }
25
25
 
26
- var _a;
27
- const hostAppOrigin = ((_a = process === null || process === void 0 ? void 0 : process.env) === null || _a === void 0 ? void 0 : _a.HOST_APP_ORIGIN) || "http://localhost:4200";
28
26
  function postMessage(message) {
27
+ var _a;
29
28
  if (!window.top) {
30
29
  return;
31
30
  }
31
+ const hostAppOrigin = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.hostAppOrigin;
32
+ if (!hostAppOrigin) {
33
+ throw Error(`Please call 'initFlipBridge'.`);
34
+ }
32
35
  window.top.postMessage(message, hostAppOrigin);
33
36
  log("postMessage", {
34
37
  message,
@@ -38,26 +41,35 @@ function postMessage(message) {
38
41
  function makeRequest(request) {
39
42
  return new Promise((resolve, reject) => {
40
43
  const handler = (event) => {
41
- if (!isAllowedOrigin(event.origin)) ;
42
- if (event.data.id === request.id) {
43
- log("handleResponse", event.data);
44
- window.removeEventListener("message", handler);
45
- if (event.data.error) {
46
- reject(event.data.error);
47
- }
48
- else {
49
- resolve(event.data.result);
50
- }
44
+ if (!isResponse(event.data) || event.data.id !== request.id) {
45
+ return;
46
+ }
47
+ if (!isAllowedOrigin(event.origin)) {
48
+ reject({
49
+ code: exports.BridgeErrorCode.FORBIDDEN_ORIGIN,
50
+ });
51
+ return;
52
+ }
53
+ log("handleResponse", event.data);
54
+ window.removeEventListener("message", handler);
55
+ if (event.data.error) {
56
+ reject(event.data.error);
57
+ }
58
+ else {
59
+ resolve(event.data.result);
51
60
  }
52
61
  };
53
62
  window.addEventListener("message", handler);
54
63
  postMessage(request);
55
64
  });
56
65
  }
66
+ function isResponse(message) {
67
+ return "id" in message && ("result" in message || "error" in message);
68
+ }
57
69
  function isAllowedOrigin(origin) {
58
- // TODO: check origin
59
- console.log(origin);
60
- return true;
70
+ var _a;
71
+ const hostAppOrigin = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.hostAppOrigin;
72
+ return origin === hostAppOrigin;
61
73
  }
62
74
 
63
75
  function getAvailableLangs() {
@@ -92,8 +104,17 @@ function getTheme() {
92
104
  return makeRequest(request);
93
105
  }
94
106
 
107
+ function initFlipBridge(options) {
108
+ if (window.flipBridgeOptions) {
109
+ console.warn(`'initFlipBridge' has already been called.`);
110
+ return;
111
+ }
112
+ window.flipBridgeOptions = options;
113
+ }
114
+
95
115
  exports.getAvailableLangs = getAvailableLangs;
96
116
  exports.getLang = getLang;
97
117
  exports.getTheme = getTheme;
118
+ exports.initFlipBridge = initFlipBridge;
98
119
  exports.navigate = navigate;
99
120
  //# sourceMappingURL=index.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../src/types.ts","../src/logging/logging.ts","../src/messaging/messaging.ts","../src/i18n/i18n.ts","../src/navigation/navigation.ts","../src/theming/theming.ts"],"sourcesContent":[null,null,null,null,null,null],"names":["BridgeErrorCode","BridgeMethod","_a","uuidv4"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../src/types.ts","../src/logging/logging.ts","../src/messaging/messaging.ts","../src/i18n/i18n.ts","../src/navigation/navigation.ts","../src/theming/theming.ts","../src/index.ts"],"sourcesContent":[null,null,null,null,null,null,null],"names":["BridgeErrorCode","BridgeMethod","uuidv4"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,4 +1,11 @@
1
+ import { BridgeOptions } from "./types";
1
2
  export * from "./types";
2
3
  export * from "./i18n";
3
4
  export * from "./navigation";
4
5
  export * from "./theming";
6
+ declare global {
7
+ interface Window {
8
+ flipBridgeOptions: BridgeOptions;
9
+ }
10
+ }
11
+ export declare function initFlipBridge(options: BridgeOptions): void;
package/dist/index.js CHANGED
@@ -2,4 +2,11 @@ export * from "./types";
2
2
  export * from "./i18n";
3
3
  export * from "./navigation";
4
4
  export * from "./theming";
5
+ export function initFlipBridge(options) {
6
+ if (window.flipBridgeOptions) {
7
+ console.warn(`'initFlipBridge' has already been called.`);
8
+ return;
9
+ }
10
+ window.flipBridgeOptions = options;
11
+ }
5
12
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AAExB,cAAc,QAAQ,CAAC;AACvB,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,cAAc,SAAS,CAAC;AAExB,cAAc,QAAQ,CAAC;AACvB,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAQ1B,MAAM,UAAU,cAAc,CAAC,OAAsB;IACnD,IAAI,MAAM,CAAC,iBAAiB,EAAE;QAC5B,OAAO,CAAC,IAAI,CAAC,2CAA2C,CAAC,CAAC;QAC1D,OAAO;KACR;IAED,MAAM,CAAC,iBAAiB,GAAG,OAAO,CAAC;AACrC,CAAC"}
package/dist/index.mjs CHANGED
@@ -13,20 +13,23 @@ var BridgeMethod;
13
13
  BridgeMethod["NAVIGATE"] = "NAVIGATE";
14
14
  })(BridgeMethod || (BridgeMethod = {}));
15
15
 
16
- var _a$1;
17
- const debug = ((_a$1 = process === null || process === void 0 ? void 0 : process.env) === null || _a$1 === void 0 ? void 0 : _a$1.NODE_ENV) === "development";
18
16
  function log(message, details) {
17
+ var _a;
18
+ const debug = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.debug;
19
19
  if (debug) {
20
20
  console.log(`${message} – `, details);
21
21
  }
22
22
  }
23
23
 
24
- var _a;
25
- const hostAppOrigin = ((_a = process === null || process === void 0 ? void 0 : process.env) === null || _a === void 0 ? void 0 : _a.HOST_APP_ORIGIN) || "http://localhost:4200";
26
24
  function postMessage(message) {
25
+ var _a;
27
26
  if (!window.top) {
28
27
  return;
29
28
  }
29
+ const hostAppOrigin = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.hostAppOrigin;
30
+ if (!hostAppOrigin) {
31
+ throw Error(`Please call 'initFlipBridge'.`);
32
+ }
30
33
  window.top.postMessage(message, hostAppOrigin);
31
34
  log("postMessage", {
32
35
  message,
@@ -36,26 +39,35 @@ function postMessage(message) {
36
39
  function makeRequest(request) {
37
40
  return new Promise((resolve, reject) => {
38
41
  const handler = (event) => {
39
- if (!isAllowedOrigin(event.origin)) ;
40
- if (event.data.id === request.id) {
41
- log("handleResponse", event.data);
42
- window.removeEventListener("message", handler);
43
- if (event.data.error) {
44
- reject(event.data.error);
45
- }
46
- else {
47
- resolve(event.data.result);
48
- }
42
+ if (!isResponse(event.data) || event.data.id !== request.id) {
43
+ return;
44
+ }
45
+ if (!isAllowedOrigin(event.origin)) {
46
+ reject({
47
+ code: BridgeErrorCode.FORBIDDEN_ORIGIN,
48
+ });
49
+ return;
50
+ }
51
+ log("handleResponse", event.data);
52
+ window.removeEventListener("message", handler);
53
+ if (event.data.error) {
54
+ reject(event.data.error);
55
+ }
56
+ else {
57
+ resolve(event.data.result);
49
58
  }
50
59
  };
51
60
  window.addEventListener("message", handler);
52
61
  postMessage(request);
53
62
  });
54
63
  }
64
+ function isResponse(message) {
65
+ return "id" in message && ("result" in message || "error" in message);
66
+ }
55
67
  function isAllowedOrigin(origin) {
56
- // TODO: check origin
57
- console.log(origin);
58
- return true;
68
+ var _a;
69
+ const hostAppOrigin = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.hostAppOrigin;
70
+ return origin === hostAppOrigin;
59
71
  }
60
72
 
61
73
  function getAvailableLangs() {
@@ -90,5 +102,13 @@ function getTheme() {
90
102
  return makeRequest(request);
91
103
  }
92
104
 
93
- export { BridgeErrorCode, BridgeMethod, getAvailableLangs, getLang, getTheme, navigate };
105
+ function initFlipBridge(options) {
106
+ if (window.flipBridgeOptions) {
107
+ console.warn(`'initFlipBridge' has already been called.`);
108
+ return;
109
+ }
110
+ window.flipBridgeOptions = options;
111
+ }
112
+
113
+ export { BridgeErrorCode, BridgeMethod, getAvailableLangs, getLang, getTheme, initFlipBridge, navigate };
94
114
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../src/types.ts","../src/logging/logging.ts","../src/messaging/messaging.ts","../src/i18n/i18n.ts","../src/navigation/navigation.ts","../src/theming/theming.ts"],"sourcesContent":[null,null,null,null,null,null],"names":["_a","uuidv4"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../src/types.ts","../src/logging/logging.ts","../src/messaging/messaging.ts","../src/i18n/i18n.ts","../src/navigation/navigation.ts","../src/theming/theming.ts","../src/index.ts"],"sourcesContent":[null,null,null,null,null,null,null],"names":["uuidv4"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,20 @@
1
+ import { initFlipBridge } from ".";
2
+ describe("index", () => {
3
+ test("'initFlipBridge' sets global options once", async () => {
4
+ const options = {
5
+ hostAppOrigin: "http://localhost",
6
+ debug: true,
7
+ };
8
+ initFlipBridge(options);
9
+ expect(global.flipBridgeOptions).toEqual(options);
10
+ const newOptions = {
11
+ hostAppOrigin: "http://localhost:3000",
12
+ debug: false,
13
+ };
14
+ const spy = jest.spyOn(global.console, "warn").mockImplementation();
15
+ initFlipBridge(newOptions);
16
+ expect(spy).toHaveBeenCalledWith("'initFlipBridge' has already been called.");
17
+ expect(global.flipBridgeOptions).not.toEqual(newOptions);
18
+ });
19
+ });
20
+ //# sourceMappingURL=index.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.spec.js","sourceRoot":"","sources":["../src/index.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,GAAG,CAAC;AAGnC,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE;IACrB,IAAI,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,OAAO,GAAkB;YAC7B,aAAa,EAAE,kBAAkB;YACjC,KAAK,EAAE,IAAI;SACZ,CAAC;QAEF,cAAc,CAAC,OAAO,CAAC,CAAC;QAExB,MAAM,CAAE,MAAc,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAE3D,MAAM,UAAU,GAAkB;YAChC,aAAa,EAAE,uBAAuB;YACtC,KAAK,EAAE,KAAK;SACb,CAAC;QAEF,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,kBAAkB,EAAE,CAAC;QAEpE,cAAc,CAAC,UAAU,CAAC,CAAC;QAE3B,MAAM,CAAC,GAAG,CAAC,CAAC,oBAAoB,CAC9B,2CAA2C,CAC5C,CAAC;QAEF,MAAM,CAAE,MAAc,CAAC,iBAAiB,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,6 +1,6 @@
1
- var _a;
2
- const debug = ((_a = process === null || process === void 0 ? void 0 : process.env) === null || _a === void 0 ? void 0 : _a.NODE_ENV) === "development";
3
1
  export function log(message, details) {
2
+ var _a;
3
+ const debug = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.debug;
4
4
  if (debug) {
5
5
  console.log(`${message} – `, details);
6
6
  }
@@ -1 +1 @@
1
- {"version":3,"file":"logging.js","sourceRoot":"","sources":["../../src/logging/logging.ts"],"names":[],"mappings":";AAAA,MAAM,KAAK,GAAG,CAAA,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,GAAG,0CAAE,QAAQ,MAAK,aAAa,CAAC;AAEvD,MAAM,UAAU,GAAG,CAAC,OAAe,EAAE,OAAgB;IACnD,IAAI,KAAK,EAAE;QACT,OAAO,CAAC,GAAG,CAAC,GAAG,OAAO,KAAK,EAAE,OAAO,CAAC,CAAC;KACvC;AACH,CAAC"}
1
+ {"version":3,"file":"logging.js","sourceRoot":"","sources":["../../src/logging/logging.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,GAAG,CAAC,OAAe,EAAE,OAAgB;;IACnD,MAAM,KAAK,GAAG,MAAA,MAAM,CAAC,iBAAiB,0CAAE,KAAK,CAAC;IAE9C,IAAI,KAAK,EAAE;QACT,OAAO,CAAC,GAAG,CAAC,GAAG,OAAO,KAAK,EAAE,OAAO,CAAC,CAAC;KACvC;AACH,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,19 @@
1
+ import { log } from "./logging";
2
+ describe("logging", () => {
3
+ test("'log' logs to console if in debug mode", async () => {
4
+ global.flipBridgeOptions = {
5
+ debug: true,
6
+ };
7
+ const spy = jest.spyOn(global.console, "log").mockImplementation();
8
+ log("Message 1", { details: "details" });
9
+ expect(spy).toHaveBeenCalledWith("Message 1 – ", { details: "details" });
10
+ global.flipBridgeOptions = {
11
+ debug: false,
12
+ };
13
+ log("Message 2", { details: "details" });
14
+ expect(spy).not.toHaveBeenCalledWith("Message 2 – ", {
15
+ details: "details",
16
+ });
17
+ });
18
+ });
19
+ //# sourceMappingURL=logging.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging.spec.js","sourceRoot":"","sources":["../../src/logging/logging.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAEhC,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACvB,IAAI,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACvD,MAAc,CAAC,iBAAiB,GAAG;YAClC,KAAK,EAAE,IAAI;SACZ,CAAC;QAEF,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,kBAAkB,EAAE,CAAC;QAEnE,GAAG,CAAC,WAAW,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;QACzC,MAAM,CAAC,GAAG,CAAC,CAAC,oBAAoB,CAAC,cAAc,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;QAExE,MAAc,CAAC,iBAAiB,GAAG;YAClC,KAAK,EAAE,KAAK;SACb,CAAC;QAEF,GAAG,CAAC,WAAW,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;QACzC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAC,cAAc,EAAE;YACnD,OAAO,EAAE,SAAS;SACnB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,4 +1,5 @@
1
- import { BridgeError, BridgeRequest } from "../types";
1
+ import { BridgeError, BridgeRequest, BridgeResponse } from "../types";
2
2
  export declare function postMessage(message: BridgeRequest): void;
3
3
  export declare function makeRequest<Result>(request: BridgeRequest): Promise<Result | BridgeError>;
4
+ export declare function isResponse(message: Object): message is BridgeResponse;
4
5
  export declare function isAllowedOrigin(origin: string): boolean;
@@ -1,11 +1,14 @@
1
- var _a;
2
1
  import { log } from "../logging";
3
2
  import { BridgeErrorCode, } from "../types";
4
- const hostAppOrigin = ((_a = process === null || process === void 0 ? void 0 : process.env) === null || _a === void 0 ? void 0 : _a.HOST_APP_ORIGIN) || "http://localhost:4200";
5
3
  export function postMessage(message) {
4
+ var _a;
6
5
  if (!window.top) {
7
6
  return;
8
7
  }
8
+ const hostAppOrigin = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.hostAppOrigin;
9
+ if (!hostAppOrigin) {
10
+ throw Error(`Please call 'initFlipBridge'.`);
11
+ }
9
12
  window.top.postMessage(message, hostAppOrigin);
10
13
  log("postMessage", {
11
14
  message,
@@ -15,30 +18,34 @@ export function postMessage(message) {
15
18
  export function makeRequest(request) {
16
19
  return new Promise((resolve, reject) => {
17
20
  const handler = (event) => {
21
+ if (!isResponse(event.data) || event.data.id !== request.id) {
22
+ return;
23
+ }
18
24
  if (!isAllowedOrigin(event.origin)) {
19
25
  reject({
20
26
  code: BridgeErrorCode.FORBIDDEN_ORIGIN,
21
27
  });
22
28
  return;
23
29
  }
24
- if (event.data.id === request.id) {
25
- log("handleResponse", event.data);
26
- window.removeEventListener("message", handler);
27
- if (event.data.error) {
28
- reject(event.data.error);
29
- }
30
- else {
31
- resolve(event.data.result);
32
- }
30
+ log("handleResponse", event.data);
31
+ window.removeEventListener("message", handler);
32
+ if (event.data.error) {
33
+ reject(event.data.error);
34
+ }
35
+ else {
36
+ resolve(event.data.result);
33
37
  }
34
38
  };
35
39
  window.addEventListener("message", handler);
36
40
  postMessage(request);
37
41
  });
38
42
  }
43
+ export function isResponse(message) {
44
+ return "id" in message && ("result" in message || "error" in message);
45
+ }
39
46
  export function isAllowedOrigin(origin) {
40
- // TODO: check origin
41
- console.log(origin);
42
- return true;
47
+ var _a;
48
+ const hostAppOrigin = (_a = window.flipBridgeOptions) === null || _a === void 0 ? void 0 : _a.hostAppOrigin;
49
+ return origin === hostAppOrigin;
43
50
  }
44
51
  //# sourceMappingURL=messaging.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"messaging.js","sourceRoot":"","sources":["../../src/messaging/messaging.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,YAAY,CAAC;AACjC,OAAO,EAEL,eAAe,GAGhB,MAAM,UAAU,CAAC;AAElB,MAAM,aAAa,GAAG,CAAA,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,GAAG,0CAAE,eAAe,KAAI,uBAAuB,CAAC;AAE/E,MAAM,UAAU,WAAW,CAAC,OAAsB;IAChD,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;QACf,OAAO;KACR;IAED,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IAE/C,GAAG,CAAC,aAAa,EAAE;QACjB,OAAO;QACP,YAAY,EAAE,aAAa;KAC5B,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,WAAW,CACzB,OAAsB;IAEtB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,OAAO,GAAG,CAAC,KAAmC,EAAE,EAAE;YACtD,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;gBAClC,MAAM,CAAC;oBACL,IAAI,EAAE,eAAe,CAAC,gBAAgB;iBACxB,CAAC,CAAC;gBAElB,OAAO;aACR;YAED,IAAI,KAAK,CAAC,IAAI,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,EAAE;gBAChC,GAAG,CAAC,gBAAgB,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;gBAElC,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;gBAE/C,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE;oBACpB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,KAAoB,CAAC,CAAC;iBACzC;qBAAM;oBACL,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAgB,CAAC,CAAC;iBACtC;aACF;QACH,CAAC,CAAC;QAEF,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAC5C,WAAW,CAAC,OAAO,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,MAAc;IAC5C,qBAAqB;IACrB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAEpB,OAAO,IAAI,CAAC;AACd,CAAC"}
1
+ {"version":3,"file":"messaging.js","sourceRoot":"","sources":["../../src/messaging/messaging.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,YAAY,CAAC;AACjC,OAAO,EAEL,eAAe,GAGhB,MAAM,UAAU,CAAC;AAElB,MAAM,UAAU,WAAW,CAAC,OAAsB;;IAChD,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE;QACf,OAAO;KACR;IAED,MAAM,aAAa,GAAG,MAAA,MAAM,CAAC,iBAAiB,0CAAE,aAAa,CAAC;IAE9D,IAAI,CAAC,aAAa,EAAE;QAClB,MAAM,KAAK,CAAC,+BAA+B,CAAC,CAAC;KAC9C;IAED,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;IAE/C,GAAG,CAAC,aAAa,EAAE;QACjB,OAAO;QACP,YAAY,EAAE,aAAa;KAC5B,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,WAAW,CACzB,OAAsB;IAEtB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,OAAO,GAAG,CAAC,KAAmC,EAAE,EAAE;YACtD,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,EAAE;gBAC3D,OAAO;aACR;YAED,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;gBAClC,MAAM,CAAC;oBACL,IAAI,EAAE,eAAe,CAAC,gBAAgB;iBACxB,CAAC,CAAC;gBAElB,OAAO;aACR;YAED,GAAG,CAAC,gBAAgB,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;YAElC,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;YAE/C,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE;gBACpB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,KAAoB,CAAC,CAAC;aACzC;iBAAM;gBACL,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAgB,CAAC,CAAC;aACtC;QACH,CAAC,CAAC;QAEF,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAC5C,WAAW,CAAC,OAAO,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,OAAe;IACxC,OAAO,IAAI,IAAI,OAAO,IAAI,CAAC,QAAQ,IAAI,OAAO,IAAI,OAAO,IAAI,OAAO,CAAC,CAAC;AACxE,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,MAAc;;IAC5C,MAAM,aAAa,GAAG,MAAA,MAAM,CAAC,iBAAiB,0CAAE,aAAa,CAAC;IAE9D,OAAO,MAAM,KAAK,aAAa,CAAC;AAClC,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,57 @@
1
+ import { BridgeErrorCode, BridgeMethod } from "../types";
2
+ import { isAllowedOrigin, isResponse, postMessage } from "./messaging";
3
+ describe("messaging", () => {
4
+ const request = {
5
+ id: "ID",
6
+ method: BridgeMethod.NAVIGATE,
7
+ params: { path: "/" },
8
+ };
9
+ beforeEach(() => {
10
+ global.flipBridgeOptions = { hostAppOrigin: "http://localhost" };
11
+ });
12
+ test("'postMessage' fails without init call", async () => {
13
+ global.flipBridgeOptions = undefined;
14
+ const postMessageWrapper = () => postMessage(request);
15
+ expect(postMessageWrapper).toThrowError("Please call 'initFlipBridge'.");
16
+ });
17
+ test("'postMessage' posts a request", async () => {
18
+ const spy = jest.fn();
19
+ window.top.postMessage = spy;
20
+ postMessage(request);
21
+ expect(spy).toHaveBeenCalledWith({
22
+ id: "ID",
23
+ method: "NAVIGATE",
24
+ params: {
25
+ path: "/",
26
+ },
27
+ }, "http://localhost");
28
+ });
29
+ test("'isResponse' checks response type", async () => {
30
+ expect(isResponse({})).toBe(false);
31
+ expect(isResponse({
32
+ id: "test",
33
+ })).toBe(false);
34
+ expect(isResponse({
35
+ id: "test",
36
+ error: {
37
+ code: BridgeErrorCode.FORBIDDEN_ORIGIN,
38
+ },
39
+ })).toBe(true);
40
+ expect(isResponse({
41
+ id: "test",
42
+ result: true,
43
+ })).toBe(true);
44
+ expect(isResponse({
45
+ error: {
46
+ code: BridgeErrorCode.FORBIDDEN_ORIGIN,
47
+ },
48
+ })).toBe(false);
49
+ });
50
+ test("'isAllowedOrigin' validates origins", async () => {
51
+ expect(isAllowedOrigin("http://")).toBe(false);
52
+ expect(isAllowedOrigin("")).toBe(false);
53
+ expect(isAllowedOrigin("http://localhost:3000")).toBe(false);
54
+ expect(isAllowedOrigin("http://localhost")).toBe(true);
55
+ });
56
+ });
57
+ //# sourceMappingURL=messaging.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"messaging.spec.js","sourceRoot":"","sources":["../../src/messaging/messaging.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,YAAY,EAAiB,MAAM,UAAU,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAEvE,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,MAAM,OAAO,GAAkB;QAC7B,EAAE,EAAE,IAAI;QACR,MAAM,EAAE,YAAY,CAAC,QAAQ;QAC7B,MAAM,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE;KACtB,CAAC;IAEF,UAAU,CAAC,GAAG,EAAE;QACb,MAAc,CAAC,iBAAiB,GAAG,EAAE,aAAa,EAAE,kBAAkB,EAAE,CAAC;IAC5E,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAc,CAAC,iBAAiB,GAAG,SAAS,CAAC;QAE9C,MAAM,kBAAkB,GAAG,GAAG,EAAE,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAEtD,MAAM,CAAC,kBAAkB,CAAC,CAAC,YAAY,CAAC,+BAA+B,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,+BAA+B,EAAE,KAAK,IAAI,EAAE;QAC/C,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;QAErB,MAAM,CAAC,GAAW,CAAC,WAAW,GAAG,GAAG,CAAC;QAEtC,WAAW,CAAC,OAAO,CAAC,CAAC;QACrB,MAAM,CAAC,GAAG,CAAC,CAAC,oBAAoB,CAC9B;YACE,EAAE,EAAE,IAAI;YACR,MAAM,EAAE,UAAU;YAClB,MAAM,EAAE;gBACN,IAAI,EAAE,GAAG;aACV;SACF,EACD,kBAAkB,CACnB,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mCAAmC,EAAE,KAAK,IAAI,EAAE;QACnD,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEnC,MAAM,CACJ,UAAU,CAAC;YACT,EAAE,EAAE,MAAM;SACX,CAAC,CACH,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEd,MAAM,CACJ,UAAU,CAAC;YACT,EAAE,EAAE,MAAM;YACV,KAAK,EAAE;gBACL,IAAI,EAAE,eAAe,CAAC,gBAAgB;aACvC;SACF,CAAC,CACH,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEb,MAAM,CACJ,UAAU,CAAC;YACT,EAAE,EAAE,MAAM;YACV,MAAM,EAAE,IAAI;SACb,CAAC,CACH,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEb,MAAM,CACJ,UAAU,CAAC;YACT,KAAK,EAAE;gBACL,IAAI,EAAE,eAAe,CAAC,gBAAgB;aACvC;SACF,CAAC,CACH,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/C,MAAM,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,CAAC,eAAe,CAAC,uBAAuB,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7D,MAAM,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"navigation.js","sourceRoot":"","sources":["../../src/navigation/navigation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAGxC,MAAM,UAAU,QAAQ,CAAC,IAAY;IACnC,MAAM,OAAO,GAAoB;QAC/B,EAAE,EAAE,MAAM,EAAE;QACZ,MAAM,EAAE,YAAY,CAAC,QAAQ;QAC7B,MAAM,EAAE,EAAE,IAAI,EAAE;KACjB,CAAC;IAEF,OAAO,WAAW,CAAoB,OAAO,CAAC,CAAC;AACjD,CAAC"}
1
+ {"version":3,"file":"navigation.js","sourceRoot":"","sources":["../../src/navigation/navigation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAGxC,MAAM,UAAU,QAAQ,CAAC,IAAY;IACnC,MAAM,OAAO,GAAoB;QAC/B,EAAE,EAAE,MAAM,EAAE;QACZ,MAAM,EAAE,YAAY,CAAC,QAAQ;QAC7B,MAAM,EAAE,EAAE,IAAI,EAAE;KACjB,CAAC;IAEF,OAAO,WAAW,CAAiB,OAAO,CAAC,CAAC;AAC9C,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,22 @@
1
+ import { makeRequest } from "../messaging";
2
+ import { navigate } from "./navigation";
3
+ jest.mock("../messaging", () => ({
4
+ makeRequest: jest.fn(),
5
+ }));
6
+ describe("navigation", () => {
7
+ beforeAll(() => {
8
+ global.flipBridgeOptions = { hostAppOrigin: "http://localhost" };
9
+ });
10
+ test("'navigate' sends correct request", async () => {
11
+ await navigate("/route");
12
+ const makeRequestMock = makeRequest;
13
+ expect(makeRequestMock).toHaveBeenCalledWith({
14
+ id: makeRequestMock.mock.calls[0][0].id,
15
+ method: "NAVIGATE",
16
+ params: {
17
+ path: "/route",
18
+ },
19
+ });
20
+ });
21
+ });
22
+ //# sourceMappingURL=navigation.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"navigation.spec.js","sourceRoot":"","sources":["../../src/navigation/navigation.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAExC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC;IAC/B,WAAW,EAAE,IAAI,CAAC,EAAE,EAAE;CACvB,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,SAAS,CAAC,GAAG,EAAE;QACZ,MAAc,CAAC,iBAAiB,GAAG,EAAE,aAAa,EAAE,kBAAkB,EAAE,CAAC;IAC5E,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kCAAkC,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAEzB,MAAM,eAAe,GAAG,WAEvB,CAAC;QAEF,MAAM,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC;YAC3C,EAAE,EAAE,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;YACvC,MAAM,EAAE,UAAU;YAClB,MAAM,EAAE;gBACN,IAAI,EAAE,QAAQ;aACf;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -2,4 +2,4 @@ import { BridgeMethod, BridgeRequest } from "../types";
2
2
  export type NavigateRequest = BridgeRequest<BridgeMethod.NAVIGATE, {
3
3
  path: string;
4
4
  }>;
5
- export type GetNavigateResult = boolean;
5
+ export type NavigateResult = boolean;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,19 @@
1
+ import { makeRequest } from "../messaging";
2
+ import { getTheme } from "./theming";
3
+ jest.mock("../messaging", () => ({
4
+ makeRequest: jest.fn(),
5
+ }));
6
+ describe("theming", () => {
7
+ beforeAll(() => {
8
+ global.flipBridgeOptions = { hostAppOrigin: "http://localhost" };
9
+ });
10
+ test("'getTheme' sends correct request", async () => {
11
+ await getTheme();
12
+ const makeRequestMock = makeRequest;
13
+ expect(makeRequestMock).toHaveBeenCalledWith({
14
+ id: makeRequestMock.mock.calls[0][0].id,
15
+ method: "GET_THEME",
16
+ });
17
+ });
18
+ });
19
+ //# sourceMappingURL=theming.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theming.spec.js","sourceRoot":"","sources":["../../src/theming/theming.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAErC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,GAAG,EAAE,CAAC,CAAC;IAC/B,WAAW,EAAE,IAAI,CAAC,EAAE,EAAE;CACvB,CAAC,CAAC,CAAC;AAEJ,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACvB,SAAS,CAAC,GAAG,EAAE;QACZ,MAAc,CAAC,iBAAiB,GAAG,EAAE,aAAa,EAAE,kBAAkB,EAAE,CAAC;IAC5E,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kCAAkC,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,QAAQ,EAAE,CAAC;QAEjB,MAAM,eAAe,GAAG,WAEvB,CAAC;QAEF,MAAM,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC;YAC3C,EAAE,EAAE,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE;YACvC,MAAM,EAAE,WAAW;SACpB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -3,5 +3,5 @@ import { BridgeMethod, BridgeRequest } from "../types";
3
3
  export type GetThemeRequest = BridgeRequest<BridgeMethod.GET_THEME, undefined>;
4
4
  export type GetThemeResult = {
5
5
  activeTheme: FlipTheme;
6
- preferredTheme: FlipTheme;
6
+ preferredTheme: FlipTheme | undefined;
7
7
  };
package/dist/types.d.ts CHANGED
@@ -1,6 +1,10 @@
1
1
  import { GetAvailableLangsResult, GetLangResult } from "./i18n";
2
- import { GetNavigateResult } from "./navigation";
2
+ import { NavigateResult } from "./navigation";
3
3
  import { GetThemeResult } from "./theming";
4
+ export type BridgeOptions = {
5
+ debug?: boolean;
6
+ hostAppOrigin: string;
7
+ };
4
8
  export type BridgeRequest<WithMethod extends BridgeMethod | unknown = unknown, WithParams = Record<string, unknown> | Array<unknown>> = {
5
9
  id: string;
6
10
  method: WithMethod;
@@ -28,5 +32,5 @@ export type BridgeMethodResultMapping = {
28
32
  [BridgeMethod.GET_AVAILABLE_LANGS]: GetAvailableLangsResult;
29
33
  [BridgeMethod.GET_LANG]: GetLangResult;
30
34
  [BridgeMethod.GET_THEME]: GetThemeResult;
31
- [BridgeMethod.NAVIGATE]: GetNavigateResult;
35
+ [BridgeMethod.NAVIGATE]: NavigateResult;
32
36
  };
package/dist/types.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AA0BA,MAAM,CAAN,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,wDAAqC,CAAA;IACrC,sDAAmC,CAAA;AACrC,CAAC,EAHW,eAAe,KAAf,eAAe,QAG1B;AAED,MAAM,CAAN,IAAY,YAKX;AALD,WAAY,YAAY;IACtB,2DAA2C,CAAA;IAC3C,qCAAqB,CAAA;IACrB,uCAAuB,CAAA;IACvB,qCAAqB,CAAA;AACvB,CAAC,EALW,YAAY,KAAZ,YAAY,QAKvB"}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AA+BA,MAAM,CAAN,IAAY,eAGX;AAHD,WAAY,eAAe;IACzB,wDAAqC,CAAA;IACrC,sDAAmC,CAAA;AACrC,CAAC,EAHW,eAAe,KAAf,eAAe,QAG1B;AAED,MAAM,CAAN,IAAY,YAKX;AALD,WAAY,YAAY;IACtB,2DAA2C,CAAA;IAC3C,qCAAqB,CAAA;IACrB,uCAAuB,CAAA;IACvB,qCAAqB,CAAA;AACvB,CAAC,EALW,YAAY,KAAZ,YAAY,QAKvB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@getflip/bridge",
3
- "version": "0.1.0-alpha.3",
3
+ "version": "0.1.0-alpha.5",
4
4
  "description": "Flip JavaScript Bridge for external integrations.",
5
5
  "main": "dist/index.cjs.js",
6
6
  "module": "dist/index.mjs",
@@ -13,15 +13,23 @@
13
13
  "scripts": {
14
14
  "build": "rimraf dist && tsc && rollup -c rollup.config.mjs",
15
15
  "dev": "tsc -w",
16
- "start": "yarn dev"
16
+ "start": "yarn dev",
17
+ "test": "jest",
18
+ "test:watch": "jest --watchAll"
17
19
  },
18
20
  "dependencies": {
19
21
  "@getflip/swirl-components": "^0.8.4",
20
22
  "uuid": "^9.0.0"
21
23
  },
22
24
  "devDependencies": {
25
+ "@babel/core": "^7.20.5",
26
+ "@babel/preset-env": "^7.20.2",
27
+ "@babel/preset-typescript": "^7.18.6",
23
28
  "@rollup/plugin-typescript": "^10.0.1",
29
+ "@types/jest": "^27.0.3",
24
30
  "@types/uuid": "^8.3.4",
31
+ "babel-jest": "^29.3.1",
32
+ "jest": "^27.4.5",
25
33
  "rimraf": "^3.0.2",
26
34
  "rollup": "^3.5.1",
27
35
  "typescript": "^4.9.3"