@elliemae/pui-app-sdk 2.12.3 → 2.13.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.
Files changed (231) hide show
  1. package/dist/cjs/analytics/appdynamics.js +36 -0
  2. package/dist/cjs/analytics/index.js +15 -13
  3. package/dist/cjs/analytics/page-view-event.js +16 -19
  4. package/dist/cjs/analytics/user-session-event.js +13 -14
  5. package/dist/cjs/analytics/user-wait-event.js +4 -4
  6. package/dist/cjs/analytics/{ba-event-parameters.js → web-analytics.js} +2 -2
  7. package/dist/cjs/api/auth/index.js +13 -20
  8. package/dist/cjs/api/helpers.js +4 -16
  9. package/dist/cjs/api/users/index.js +4 -5
  10. package/dist/cjs/communication/http-client/index.js +16 -21
  11. package/dist/cjs/communication/http-client/retry-axios.js +0 -2
  12. package/dist/cjs/communication/http-client/tests/index.test-disable.js +5 -6
  13. package/dist/cjs/data/auth/actions.js +22 -28
  14. package/dist/cjs/data/breakpoint/index.js +1 -3
  15. package/dist/cjs/data/live-message/index.js +8 -11
  16. package/dist/cjs/data/reducers.js +1 -2
  17. package/dist/cjs/data/store.js +4 -8
  18. package/dist/cjs/data/wait-message/actions.js +6 -9
  19. package/dist/cjs/data/wait-message/reducer.js +13 -17
  20. package/dist/cjs/index.js +21 -15
  21. package/dist/cjs/route/index.js +23 -12
  22. package/dist/cjs/route/{usePageView.js → page-view.js} +12 -22
  23. package/dist/cjs/route/private-route/index.js +9 -10
  24. package/dist/cjs/sideeffect/auth/index.js +6 -10
  25. package/dist/cjs/utils/app-config/config.js +3 -14
  26. package/dist/cjs/utils/app-config/index.js +11 -15
  27. package/dist/cjs/utils/app-host-integration/react.js +7 -10
  28. package/dist/cjs/utils/auth/index.js +40 -44
  29. package/dist/cjs/utils/font-size.js +1 -1
  30. package/dist/cjs/utils/helpers.js +0 -6
  31. package/dist/cjs/utils/log-records.js +7 -7
  32. package/dist/cjs/utils/micro-frontend/guest.js +31 -8
  33. package/dist/cjs/utils/micro-frontend/host.js +14 -7
  34. package/dist/cjs/utils/micro-frontend/index.js +2 -4
  35. package/dist/cjs/utils/redact-pii.js +39 -0
  36. package/dist/cjs/utils/service-worker.js +2 -5
  37. package/dist/cjs/utils/session.js +2 -8
  38. package/dist/cjs/utils/storybook/theme.js +9 -12
  39. package/dist/cjs/utils/testing/index.js +9 -18
  40. package/dist/cjs/utils/testing/render-with-redux.js +11 -14
  41. package/dist/cjs/utils/testing/render-with-router-redux.js +17 -20
  42. package/dist/cjs/utils/testing/render-with-router.js +13 -16
  43. package/dist/cjs/utils/testing/render-with-state-addons.js +7 -16
  44. package/dist/cjs/utils/url.js +0 -8
  45. package/dist/cjs/utils/web-storage.js +1 -7
  46. package/dist/cjs/utils/window.js +0 -2
  47. package/dist/cjs/view/app-root/hosted-app.js +5 -8
  48. package/dist/cjs/view/app-root/index.js +20 -23
  49. package/dist/cjs/view/app-root/stand-alone-app.js +5 -8
  50. package/dist/cjs/view/app-root/style.js +5 -12
  51. package/dist/cjs/view/error-toast/index.stories.js +22 -31
  52. package/dist/cjs/view/fetch-host-app-data/store.js +1 -5
  53. package/dist/cjs/view/fields/check-box/index.js +20 -32
  54. package/dist/cjs/view/fields/check-box/index.stories.js +20 -24
  55. package/dist/cjs/view/fields/check-box/set-value.stories.js +17 -21
  56. package/dist/cjs/view/fields/combo-box/index.js +22 -28
  57. package/dist/cjs/view/fields/connect-form.js +3 -4
  58. package/dist/cjs/view/fields/date-input/index.js +15 -21
  59. package/dist/cjs/view/fields/date-picker/index.js +15 -21
  60. package/dist/cjs/view/fields/form-item-layout/index.js +16 -20
  61. package/dist/cjs/view/fields/input-mask/index.js +16 -28
  62. package/dist/cjs/view/fields/large-text-box/index.js +15 -21
  63. package/dist/cjs/view/fields/radio/index.js +20 -26
  64. package/dist/cjs/view/fields/radio/index.stories.js +17 -21
  65. package/dist/cjs/view/fields/radio/set-value.stories.js +15 -19
  66. package/dist/cjs/view/fields/radio-group/index.js +16 -22
  67. package/dist/cjs/view/fields/radio-group/index.stories.js +37 -44
  68. package/dist/cjs/view/fields/text-box/index.js +15 -21
  69. package/dist/cjs/view/fields/watch-value.js +4 -5
  70. package/dist/cjs/view/form/index.js +9 -10
  71. package/dist/cjs/view/form/index.stories.js +3 -6
  72. package/dist/cjs/view/form/submit-button/index.js +2 -3
  73. package/dist/cjs/view/form/usecases.stories.js +3 -6
  74. package/dist/cjs/view/guest-unload-handlers/index.js +1 -2
  75. package/dist/cjs/view/header/center-region/index.js +8 -20
  76. package/dist/cjs/view/header/index.js +8 -11
  77. package/dist/cjs/view/host-binding-events/index.js +2 -2
  78. package/dist/cjs/view/live-message/index.stories.js +0 -6
  79. package/dist/cjs/view/loadable/index.js +1 -2
  80. package/dist/cjs/view/login/index.js +5 -6
  81. package/dist/cjs/view/media-breakpoint/index.js +1 -1
  82. package/dist/cjs/view/message-to-host-app/index.js +1 -2
  83. package/dist/cjs/view/micro-app/app-factory/index.js +30 -48
  84. package/dist/cjs/view/micro-app/index.js +1 -1
  85. package/dist/cjs/view/micro-app/resources/manifest.js +27 -39
  86. package/dist/cjs/view/micro-app/resources/script.js +22 -35
  87. package/dist/cjs/view/micro-app/resources/style.js +20 -33
  88. package/dist/cjs/view/micro-app/use-app-will-render.js +12 -12
  89. package/dist/cjs/view/micro-app/utils.js +0 -6
  90. package/dist/cjs/view/micro-iframe-app/app.js +6 -9
  91. package/dist/cjs/view/micro-iframe-app/iframe/index.js +8 -9
  92. package/dist/cjs/view/micro-iframe-app/index.js +4 -7
  93. package/dist/cjs/view/micro-iframe-app/use-frame-loaded.js +5 -12
  94. package/dist/cjs/view/modals/error/index.js +6 -13
  95. package/dist/cjs/view/modals/navigation-prompt/index.js +4 -11
  96. package/dist/cjs/view/modals/session-expiry/customHooks.js +3 -5
  97. package/dist/cjs/view/modals/session-expiry/index.js +6 -13
  98. package/dist/cjs/view/modals/wait-message/html-wait-message.js +3 -4
  99. package/dist/cjs/view/modals/wait-message/index.js +8 -9
  100. package/dist/cjs/view/modals/wait-message/index.stories.js +4 -5
  101. package/dist/cjs/view/render-with-delay/index.js +3 -6
  102. package/dist/cjs/view/render-with-host-data/index.js +0 -2
  103. package/dist/cjs/view/session-timeout/index.js +0 -2
  104. package/dist/cjs/view/useMediaBreakpoints/index.js +0 -12
  105. package/dist/es/analytics/appdynamics.js +18 -0
  106. package/dist/es/analytics/index.js +14 -13
  107. package/dist/es/analytics/page-view-event.js +16 -19
  108. package/dist/es/analytics/user-session-event.js +12 -13
  109. package/dist/es/analytics/user-wait-event.js +4 -4
  110. package/dist/es/analytics/{ba-event-parameters.js → web-analytics.js} +2 -2
  111. package/dist/es/api/auth/index.js +13 -18
  112. package/dist/es/api/helpers.js +4 -14
  113. package/dist/es/api/users/index.js +4 -5
  114. package/dist/es/communication/http-client/index.js +16 -20
  115. package/dist/es/communication/http-client/retry-axios.js +0 -2
  116. package/dist/es/communication/http-client/tests/index.test-disable.js +5 -6
  117. package/dist/es/data/auth/actions.js +22 -28
  118. package/dist/es/data/breakpoint/index.js +1 -3
  119. package/dist/es/data/live-message/index.js +8 -11
  120. package/dist/es/data/reducers.js +1 -2
  121. package/dist/es/data/store.js +4 -8
  122. package/dist/es/data/wait-message/actions.js +6 -9
  123. package/dist/es/data/wait-message/reducer.js +12 -16
  124. package/dist/es/index.js +4 -1
  125. package/dist/es/route/index.js +23 -13
  126. package/dist/es/route/page-view.js +15 -0
  127. package/dist/es/route/private-route/index.js +9 -10
  128. package/dist/es/sideeffect/auth/index.js +6 -10
  129. package/dist/es/utils/app-config/config.js +3 -14
  130. package/dist/es/utils/app-config/index.js +11 -15
  131. package/dist/es/utils/app-host-integration/react.js +7 -10
  132. package/dist/es/utils/auth/index.js +39 -41
  133. package/dist/es/utils/font-size.js +1 -1
  134. package/dist/es/utils/helpers.js +0 -3
  135. package/dist/es/utils/log-records.js +7 -7
  136. package/dist/es/utils/micro-frontend/guest.js +29 -6
  137. package/dist/es/utils/micro-frontend/host.js +13 -7
  138. package/dist/es/utils/micro-frontend/index.js +2 -3
  139. package/dist/es/utils/redact-pii.js +31 -0
  140. package/dist/es/utils/service-worker.js +2 -4
  141. package/dist/es/utils/session.js +2 -8
  142. package/dist/es/utils/storybook/theme.js +9 -12
  143. package/dist/es/utils/testing/index.js +9 -12
  144. package/dist/es/utils/testing/render-with-redux.js +11 -14
  145. package/dist/es/utils/testing/render-with-router-redux.js +17 -20
  146. package/dist/es/utils/testing/render-with-router.js +13 -16
  147. package/dist/es/utils/testing/render-with-state-addons.js +7 -12
  148. package/dist/es/utils/url.js +0 -4
  149. package/dist/es/utils/web-storage.js +1 -4
  150. package/dist/es/utils/window.js +0 -1
  151. package/dist/es/view/app-root/hosted-app.js +5 -8
  152. package/dist/es/view/app-root/index.js +20 -23
  153. package/dist/es/view/app-root/stand-alone-app.js +5 -8
  154. package/dist/es/view/app-root/style.js +5 -10
  155. package/dist/es/view/error-toast/index.stories.js +22 -30
  156. package/dist/es/view/fetch-host-app-data/store.js +1 -5
  157. package/dist/es/view/fields/check-box/index.js +20 -26
  158. package/dist/es/view/fields/check-box/index.stories.js +20 -24
  159. package/dist/es/view/fields/check-box/set-value.stories.js +17 -21
  160. package/dist/es/view/fields/combo-box/index.js +22 -28
  161. package/dist/es/view/fields/connect-form.js +3 -4
  162. package/dist/es/view/fields/date-input/index.js +15 -21
  163. package/dist/es/view/fields/date-picker/index.js +15 -21
  164. package/dist/es/view/fields/form-item-layout/index.js +16 -20
  165. package/dist/es/view/fields/input-mask/index.js +16 -22
  166. package/dist/es/view/fields/large-text-box/index.js +15 -21
  167. package/dist/es/view/fields/radio/index.js +20 -26
  168. package/dist/es/view/fields/radio/index.stories.js +17 -21
  169. package/dist/es/view/fields/radio/set-value.stories.js +15 -19
  170. package/dist/es/view/fields/radio-group/index.js +16 -22
  171. package/dist/es/view/fields/radio-group/index.stories.js +37 -44
  172. package/dist/es/view/fields/text-box/index.js +15 -21
  173. package/dist/es/view/fields/watch-value.js +4 -5
  174. package/dist/es/view/form/index.js +9 -10
  175. package/dist/es/view/form/index.stories.js +3 -6
  176. package/dist/es/view/form/submit-button/index.js +2 -3
  177. package/dist/es/view/form/usecases.stories.js +3 -6
  178. package/dist/es/view/guest-unload-handlers/index.js +1 -2
  179. package/dist/es/view/header/center-region/index.js +8 -17
  180. package/dist/es/view/header/index.js +8 -11
  181. package/dist/es/view/host-binding-events/index.js +2 -2
  182. package/dist/es/view/live-message/index.stories.js +0 -1
  183. package/dist/es/view/loadable/index.js +1 -2
  184. package/dist/es/view/login/index.js +5 -6
  185. package/dist/es/view/media-breakpoint/index.js +1 -1
  186. package/dist/es/view/message-to-host-app/index.js +1 -2
  187. package/dist/es/view/micro-app/app-factory/index.js +30 -42
  188. package/dist/es/view/micro-app/index.js +1 -1
  189. package/dist/es/view/micro-app/resources/manifest.js +26 -31
  190. package/dist/es/view/micro-app/resources/script.js +21 -31
  191. package/dist/es/view/micro-app/resources/style.js +20 -30
  192. package/dist/es/view/micro-app/use-app-will-render.js +12 -12
  193. package/dist/es/view/micro-app/utils.js +0 -3
  194. package/dist/es/view/micro-iframe-app/app.js +6 -8
  195. package/dist/es/view/micro-iframe-app/iframe/index.js +8 -9
  196. package/dist/es/view/micro-iframe-app/index.js +4 -6
  197. package/dist/es/view/micro-iframe-app/use-frame-loaded.js +5 -9
  198. package/dist/es/view/modals/error/index.js +6 -8
  199. package/dist/es/view/modals/navigation-prompt/index.js +4 -5
  200. package/dist/es/view/modals/session-expiry/customHooks.js +3 -4
  201. package/dist/es/view/modals/session-expiry/index.js +6 -8
  202. package/dist/es/view/modals/wait-message/html-wait-message.js +3 -4
  203. package/dist/es/view/modals/wait-message/index.js +8 -9
  204. package/dist/es/view/modals/wait-message/index.stories.js +4 -5
  205. package/dist/es/view/render-with-delay/index.js +3 -5
  206. package/dist/es/view/render-with-host-data/index.js +0 -1
  207. package/dist/es/view/session-timeout/index.js +0 -1
  208. package/dist/es/view/useMediaBreakpoints/index.js +0 -6
  209. package/dist/types/analytics/appdynamics.d.ts +9 -0
  210. package/dist/types/analytics/index.d.ts +2 -2
  211. package/dist/types/analytics/web-analytics.d.ts +8 -0
  212. package/dist/types/index.d.ts +3 -1
  213. package/dist/types/route/page-view.d.ts +1 -0
  214. package/dist/types/utils/micro-frontend/guest.d.ts +1 -0
  215. package/dist/types/utils/micro-frontend/host.d.ts +1 -1
  216. package/dist/types/utils/redact-pii.d.ts +1 -0
  217. package/dist/types/view/visually-hidden/index.d.ts +1 -1
  218. package/package.json +7 -3
  219. package/dist/es/route/usePageView.js +0 -18
  220. package/dist/public/app.config.json +0 -129
  221. package/dist/public/assets/index.ad459dcebaa616bff55e77d860405729.svg +0 -1
  222. package/dist/public/assets/index.dae17c8817fd9c5ab29e7c3a8925a1f4.svg +0 -1
  223. package/dist/public/assets/logo.0cbd33c5006f8ea6d106f8ab13f6e6dc.svg +0 -1
  224. package/dist/public/iframe.b3911eaf1a99a53ef7b10a1e1f0bdfc4.html +0 -8
  225. package/dist/public/index.html +0 -5
  226. package/dist/public/js/emuiAppSdk.e28a62497e211b4c6132.js +0 -3
  227. package/dist/public/js/emuiAppSdk.e28a62497e211b4c6132.js.LICENSE.txt +0 -95
  228. package/dist/public/js/emuiAppSdk.e28a62497e211b4c6132.js.gz +0 -0
  229. package/dist/public/js/emuiAppSdk.e28a62497e211b4c6132.js.map +0 -1
  230. package/dist/types/analytics/ba-event-parameters.d.ts +0 -8
  231. package/dist/types/route/usePageView.d.ts +0 -1
@@ -1,33 +1,30 @@
1
1
  import { sendBAEvent } from "./index.js";
2
- export const pageViewEvent = _ref => {
3
- let {
4
- pageTitle
5
- } = _ref;
2
+ export const pageViewEvent = ({
3
+ pageTitle
4
+ }) => {
6
5
  const {
7
6
  pathname,
8
7
  href
9
8
  } = (window.top || window.self).location;
10
9
  const {
11
10
  title
12
- } = (window.top || window.self).document; // eslint-disable-next-line @typescript-eslint/naming-convention
13
-
11
+ } = (window.top || window.self).document;
14
12
  const {
15
- pathname: framed_page_path,
16
- href: framed_page_url
17
- } = window.location; // eslint-disable-next-line @typescript-eslint/naming-convention
18
-
13
+ pathname: guestPagePath,
14
+ href: guestPageUrl
15
+ } = window.location;
19
16
  const {
20
- title: framed_page_title
17
+ title: guestPageTitle
21
18
  } = document;
22
19
  sendBAEvent({
23
- event: {
24
- event: 'page_view',
25
- page_url: href,
26
- page_path: pathname,
27
- page_title: title,
28
- framed_page_url,
29
- framed_page_path,
30
- framed_page_title: pageTitle || framed_page_title
20
+ data: {
21
+ event: 'pageView',
22
+ pageUrl: href,
23
+ pagePath: pathname,
24
+ pageTitle: title,
25
+ guestPageUrl,
26
+ guestPagePath,
27
+ guestPageTitle: pageTitle || guestPageTitle
31
28
  }
32
29
  });
33
30
  };
@@ -1,28 +1,27 @@
1
1
  import { sendBAEvent } from "./index.js";
2
- import { updateBAEventParameters } from "./ba-event-parameters.js";
3
- export const loginEvent = _ref => {
4
- let {
2
+ import { updateBAEventParameters } from "./web-analytics.js";
3
+ export const loginEvent = ({
4
+ instanceId,
5
+ userId
6
+ }) => {
7
+ updateBAEventParameters({
5
8
  instanceId,
6
9
  userId
7
- } = _ref;
8
- updateBAEventParameters({
9
- instance_id: instanceId,
10
- user_id: userId
11
10
  });
12
11
  sendBAEvent({
13
- event: {
14
- event: 'user_login'
12
+ data: {
13
+ event: 'login'
15
14
  }
16
15
  });
17
16
  };
18
17
  export const logoutEvent = () => {
19
18
  sendBAEvent({
20
- event: {
21
- event: 'user_logout'
19
+ data: {
20
+ event: 'logout'
22
21
  }
23
22
  });
24
23
  updateBAEventParameters({
25
- instance_id: '',
26
- user_id: ''
24
+ instanceId: '',
25
+ userId: ''
27
26
  });
28
27
  };
@@ -1,11 +1,11 @@
1
1
  import { sendBAEvent } from "./index.js";
2
2
  export const waitStartEvent = () => sendBAEvent({
3
- event: {
4
- event: 'page_interaction_enabled'
3
+ data: {
4
+ event: 'pageInteractionEnabled'
5
5
  }
6
6
  });
7
7
  export const waitEndEvent = () => sendBAEvent({
8
- event: {
9
- event: 'page_interaction_disabled'
8
+ data: {
9
+ event: 'pageInteractionDisabled'
10
10
  }
11
11
  });
@@ -1,6 +1,6 @@
1
1
  let baEventParameters = {
2
- instance_id: '',
3
- user_id: ''
2
+ instanceId: '',
3
+ userId: ''
4
4
  };
5
5
  export const getBAEventParameters = () => baEventParameters;
6
6
  export const updateBAEventParameters = params => {
@@ -1,12 +1,9 @@
1
- import "core-js/modules/web.dom-collections.iterator.js";
2
- import "core-js/modules/web.url-search-params.js";
3
1
  import { getHTTPClient } from "../../communication/http-client/index.js";
4
- export const getToken = async _ref => {
5
- let {
6
- clientId,
7
- redirectUri,
8
- idpCode
9
- } = _ref;
2
+ export const getToken = async ({
3
+ clientId,
4
+ redirectUri,
5
+ idpCode
6
+ }) => {
10
7
  const params = new URLSearchParams();
11
8
  params.append('grant_type', 'authorization_code');
12
9
  params.append('client_id', clientId);
@@ -20,21 +17,19 @@ export const getToken = async _ref => {
20
17
  accessToken: data.access_token
21
18
  };
22
19
  };
23
- export const revokeToken = async _ref2 => {
24
- let {
25
- clientId,
26
- token
27
- } = _ref2;
20
+ export const revokeToken = async ({
21
+ clientId,
22
+ token
23
+ }) => {
28
24
  const params = new URLSearchParams();
29
25
  params.append('token', token);
30
26
  params.append('client_id', clientId);
31
27
  await getHTTPClient().post('/oauth2/v1/token/revocation', params);
32
28
  };
33
- export const introspectToken = async _ref3 => {
34
- let {
35
- clientId,
36
- accessToken
37
- } = _ref3;
29
+ export const introspectToken = async ({
30
+ clientId,
31
+ accessToken
32
+ }) => {
38
33
  const params = new URLSearchParams();
39
34
  params.append('token', accessToken);
40
35
  params.append('client_id', clientId);
@@ -1,6 +1,4 @@
1
1
  import _get from "lodash/get";
2
- import "core-js/modules/esnext.async-iterator.map.js";
3
- import "core-js/modules/esnext.iterator.map.js";
4
2
  import { createAction } from '@reduxjs/toolkit';
5
3
 
6
4
  /**
@@ -34,9 +32,9 @@ import { createAction } from '@reduxjs/toolkit';
34
32
  * @returns {Function} Redux Action Creators util function
35
33
  */
36
34
  export const getApiActionCreator = api => operation => ({
37
- [operation]: createAction("".concat(api, "/").concat(operation)),
38
- ["".concat(operation, "Success")]: createAction("".concat(api, "/").concat(operation, "Success")),
39
- ["".concat(operation, "Error")]: createAction("".concat(api, "/").concat(operation, "Error"))
35
+ [operation]: createAction(`${api}/${operation}`),
36
+ [`${operation}Success`]: createAction(`${api}/${operation}Success`),
37
+ [`${operation}Error`]: createAction(`${api}/${operation}Error`)
40
38
  });
41
39
  /**
42
40
  * Why use this? It will prevent unnecessary rerenders hence improving performance, it also reduces the amount of code needed to select data from the store
@@ -83,13 +81,5 @@ export const getApiActionCreator = api => operation => ({
83
81
 
84
82
  /* eslint-disable prettier/prettier */
85
83
 
86
- export const getSelectField = stateName => function () {
87
- let fieldName = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
88
- let defaultValue = arguments.length > 1 ? arguments[1] : undefined;
89
- return function () {
90
- let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
91
- let stateValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _get(state, stateName);
92
- return Array.isArray(fieldName) ? fieldName.map((field, i) => _get(stateValue, field, Array.isArray(defaultValue) ? defaultValue[i] : defaultValue)) : _get(stateValue, fieldName, defaultValue);
93
- };
94
- };
84
+ export const getSelectField = stateName => (fieldName = '', defaultValue) => (state = {}, stateValue = _get(state, stateName)) => Array.isArray(fieldName) ? fieldName.map((field, i) => _get(stateValue, field, Array.isArray(defaultValue) ? defaultValue[i] : defaultValue)) : _get(stateValue, fieldName, defaultValue);
95
85
  /* eslint-enable prettier/prettier */
@@ -1,10 +1,9 @@
1
1
  import { getAuthHTTPClient } from "../../communication/http-client/index.js";
2
- export const getUser = async _ref => {
3
- let {
4
- userName
5
- } = _ref;
2
+ export const getUser = async ({
3
+ userName
4
+ }) => {
6
5
  const {
7
6
  data
8
- } = await getAuthHTTPClient().get("/encompass/v1/users/".concat(userName));
7
+ } = await getAuthHTTPClient().get(`/encompass/v1/users/${userName}`);
9
8
  return data;
10
9
  };
@@ -6,13 +6,12 @@ import { requestInterceptor } from "./request-interceptor.js";
6
6
  import { handleSuccess, handleFailure } from "./response-interceptor.js";
7
7
  const REQUEST_TIMEOUT = 2 * 60 * 1000; // 2 mins
8
8
 
9
- export const getHTTPClient = function () {
9
+ export const getHTTPClient = ({
10
+ baseURL = getAppConfigValue('serviceEndpoints.api', ''),
11
+ headers = {}
12
+ } = {}) => {
10
13
  var _client$defaults;
11
14
 
12
- let {
13
- baseURL = getAppConfigValue('serviceEndpoints.api', ''),
14
- headers = {}
15
- } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
16
15
  // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
17
16
  const client = axios.create({
18
17
  baseURL,
@@ -28,18 +27,15 @@ export const getHTTPClient = function () {
28
27
  if (response) response.use(handleSuccess, handleFailure);
29
28
  return client;
30
29
  };
31
- export const getAuthHTTPClient = function () {
32
- let {
33
- baseURL,
34
- headers = {},
35
- ...rest
36
- } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
37
- return getHTTPClient({
38
- baseURL,
39
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
40
- headers: { ...headers,
41
- Authorization: getAuthorizationHeader()
42
- },
43
- ...rest
44
- });
45
- };
30
+ export const getAuthHTTPClient = ({
31
+ baseURL,
32
+ headers = {},
33
+ ...rest
34
+ } = {}) => getHTTPClient({
35
+ baseURL,
36
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
37
+ headers: { ...headers,
38
+ Authorization: getAuthorizationHeader()
39
+ },
40
+ ...rest
41
+ });
@@ -1,5 +1,3 @@
1
- import "core-js/modules/web.dom-collections.iterator.js";
2
-
3
1
  /* eslint-disable no-param-reassign,jsdoc/require-returns,jsdoc/require-param-type,jsdoc/require-returns-type,max-lines,@typescript-eslint/no-non-null-assertion */
4
2
  import axios from 'axios';
5
3
 
@@ -3,12 +3,11 @@ import enums from "../../../utils/constants.js";
3
3
  import { getAuthHTTPClient } from "../index.js";
4
4
  import { onAuthorizationFailure } from "../response-interceptor.js";
5
5
  describe('http client test cases', () => {
6
- const callApi = _ref => {
7
- let {
8
- apiUrl,
9
- options = {},
10
- baseURL = 'http://localhost:3001'
11
- } = _ref;
6
+ const callApi = ({
7
+ apiUrl,
8
+ options = {},
9
+ baseURL = 'http://localhost:3001'
10
+ }) => {
12
11
  const httpClient = getAuthHTTPClient({
13
12
  baseURL
14
13
  });
@@ -2,42 +2,36 @@ export const LOGIN = 'auth/LOGIN';
2
2
  export const LOGIN_SUCCESS = 'auth/LOGIN_SUCCESS';
3
3
  export const LOGOUT = 'auth/LOGOUT';
4
4
  export const auth = {
5
- login: _ref => {
6
- let {
5
+ login: ({
6
+ idpCode,
7
+ redirectUri,
8
+ clientId,
9
+ responseType,
10
+ scope
11
+ }) => ({
12
+ type: LOGIN,
13
+ payload: {
7
14
  idpCode,
8
15
  redirectUri,
9
16
  clientId,
10
17
  responseType,
11
18
  scope
12
- } = _ref;
13
- return {
14
- type: LOGIN,
15
- payload: {
16
- idpCode,
17
- redirectUri,
18
- clientId,
19
- responseType,
20
- scope
21
- }
22
- };
23
- },
24
- logout: _ref2 => {
25
- let {
19
+ }
20
+ }),
21
+ logout: ({
22
+ clientId,
23
+ redirectUri,
24
+ responseType,
25
+ scope,
26
+ code
27
+ }) => ({
28
+ type: LOGOUT,
29
+ payload: {
26
30
  clientId,
27
31
  redirectUri,
28
32
  responseType,
29
33
  scope,
30
34
  code
31
- } = _ref2;
32
- return {
33
- type: LOGOUT,
34
- payload: {
35
- clientId,
36
- redirectUri,
37
- responseType,
38
- scope,
39
- code
40
- }
41
- };
42
- }
35
+ }
36
+ })
43
37
  };
@@ -14,9 +14,7 @@ export let Breakpoints;
14
14
  const initialState = {
15
15
  value: Breakpoints.LARGE
16
16
  };
17
- export const breakpointReducer = function () {
18
- let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
19
- let action = arguments.length > 1 ? arguments[1] : undefined;
17
+ export const breakpointReducer = (state = initialState, action) => {
20
18
  const {
21
19
  type,
22
20
  payload
@@ -8,20 +8,17 @@ const liveMessage = createSlice({
8
8
  name: 'liveMessage',
9
9
  initialState,
10
10
  reducers: {
11
- announce: (state, _ref) => {
12
- let {
13
- payload: {
14
- message,
15
- ariaLive,
16
- id
17
- }
18
- } = _ref;
19
- return {
11
+ announce: (state, {
12
+ payload: {
20
13
  message,
21
14
  ariaLive,
22
15
  id
23
- };
24
- }
16
+ }
17
+ }) => ({
18
+ message,
19
+ ariaLive,
20
+ id
21
+ })
25
22
  }
26
23
  });
27
24
  export const {
@@ -3,8 +3,7 @@ import { waitMessageReducer } from "./wait-message/reducer.js";
3
3
  import { errorReducer } from "./error/index.js";
4
4
  import { breakpointReducer } from "./breakpoint/index.js";
5
5
  import { liveMessageReducer } from "./live-message/index.js";
6
- export const createReducer = function () {
7
- let injectedReducers = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
6
+ export const createReducer = (injectedReducers = {}) => {
8
7
  const rootReducer = combineReducers({
9
8
  waitMessage: waitMessageReducer,
10
9
  error: errorReducer,
@@ -14,10 +14,9 @@ export const setStore = store => {
14
14
  export const getStore = () => appStore;
15
15
 
16
16
  // ToDo: middlewareConfig is a temporary parameter and will be removed in the future
17
- const createStore = function (initialState, sagaMiddleware, history) {
18
- let middlewareConfig = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {
19
- thunk: false
20
- };
17
+ const createStore = (initialState, sagaMiddleware, history, middlewareConfig = {
18
+ thunk: false
19
+ }) => {
21
20
  // eslint-disable-next-line @typescript-eslint/unbound-method
22
21
  const {
23
22
  run: runSaga
@@ -61,10 +60,7 @@ const createStore = function (initialState, sagaMiddleware, history) {
61
60
  return baseStore;
62
61
  };
63
62
 
64
- export const createAppStore = function () {
65
- let initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
66
- let history = arguments.length > 1 ? arguments[1] : undefined;
67
- let middlewareConfig = arguments.length > 2 ? arguments[2] : undefined;
63
+ export const createAppStore = (initialState = {}, history, middlewareConfig) => {
68
64
  const sagaMiddleware = createSagaMiddleware({});
69
65
  const store = createStore(initialState, sagaMiddleware, history, middlewareConfig);
70
66
  setStore(store);
@@ -3,15 +3,12 @@ export const ACTIONS = {
3
3
  CLOSE: 'wait-message/CLOSE'
4
4
  };
5
5
  export const waitMessage = {
6
- open: function () {
7
- let message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'loading...';
8
- return {
9
- type: ACTIONS.OPEN,
10
- payload: {
11
- message
12
- }
13
- };
14
- },
6
+ open: (message = 'loading...') => ({
7
+ type: ACTIONS.OPEN,
8
+ payload: {
9
+ message
10
+ }
11
+ }),
15
12
  close: () => ({
16
13
  type: ACTIONS.CLOSE,
17
14
  payload: null
@@ -6,20 +6,16 @@ export const initialState = {
6
6
  isOpen: null,
7
7
  message: 'loading...'
8
8
  };
9
- export const waitMessageReducer = function () {
10
- let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
11
- let action = arguments.length > 1 ? arguments[1] : undefined;
12
- return produce(state, draft => {
13
- // eslint-disable-next-line default-case
14
- switch (action.type) {
15
- case ACTIONS.OPEN:
16
- draft.isOpen = true;
17
- draft.message = action.payload.message;
18
- break;
9
+ export const waitMessageReducer = (state = initialState, action) => produce(state, draft => {
10
+ // eslint-disable-next-line default-case
11
+ switch (action.type) {
12
+ case ACTIONS.OPEN:
13
+ draft.isOpen = true;
14
+ draft.message = action.payload.message;
15
+ break;
19
16
 
20
- case ACTIONS.CLOSE:
21
- draft.isOpen = false;
22
- break;
23
- }
24
- });
25
- };
17
+ case ACTIONS.CLOSE:
18
+ draft.isOpen = false;
19
+ break;
20
+ }
21
+ });
package/dist/es/index.js CHANGED
@@ -76,5 +76,8 @@ export { getNavigationLinks } from "./view/micro-app/utils.js"; // app host
76
76
  export { getStore } from "./data/store.js";
77
77
  export { RegisterService } from "./utils/guest-with-service.js"; // analytics
78
78
 
79
+ export { setAppDynamicsUserData } from "./analytics/appdynamics.js";
79
80
  export { sendBAEvent } from "./analytics/index.js";
80
- export { updateBAEventParameters } from "./analytics/ba-event-parameters.js"; // Type utils
81
+ export { updateBAEventParameters } from "./analytics/web-analytics.js"; // security utils
82
+
83
+ export { redactPii } from "./utils/redact-pii.js"; // Type utils
@@ -1,18 +1,28 @@
1
- import _jsx from "@babel/runtime/helpers/jsx";
2
- import { Route } from 'react-router-dom';
1
+ import _jsx2 from "@babel/runtime/helpers/jsx";
3
2
  import { Helmet } from 'react-helmet';
4
- import { usePageView } from "./usePageView.js";
5
- import { jsx as _jsx2 } from "react/jsx-runtime";
3
+ import { useCallback } from 'react';
4
+ import { Route } from 'react-router-dom';
5
+ import { onPageView } from "./page-view.js";
6
+ import { jsx as _jsx } from "react/jsx-runtime";
6
7
  import { Fragment as _Fragment } from "react/jsx-runtime";
7
8
  import { jsxs as _jsxs } from "react/jsx-runtime";
8
- export const AppRoute = _ref => {
9
- let {
10
- pageTitle = 'ICE Mortgage Technology',
11
- ...rest
12
- } = _ref;
13
- usePageView(pageTitle);
14
- return /*#__PURE__*/_jsxs(_Fragment, {
15
- children: [/*#__PURE__*/_jsx(Helmet, {}, void 0, /*#__PURE__*/_jsx("title", {}, void 0, pageTitle)), /*#__PURE__*/_jsx2(Route, { ...rest
16
- })]
9
+ export const AppRoute = ({
10
+ component: Component,
11
+ render,
12
+ children,
13
+ pageTitle = 'ICE',
14
+ ...rest
15
+ }) => {
16
+ var _Helmet;
17
+
18
+ const memoizedRender = useCallback(routeProps => render && typeof render === 'function' ? render(routeProps) : Component && /*#__PURE__*/_jsx(Component, { ...routeProps
19
+ }), [Component, render]);
20
+ return /*#__PURE__*/_jsx(Route, { ...rest,
21
+ render: routeProps => {
22
+ onPageView(pageTitle);
23
+ return /*#__PURE__*/_jsxs(_Fragment, {
24
+ children: [_Helmet || (_Helmet = /*#__PURE__*/_jsx2(Helmet, {}, void 0, /*#__PURE__*/_jsx2("title", {}, void 0, pageTitle))), children || memoizedRender(routeProps)]
25
+ });
26
+ }
17
27
  });
18
28
  };
@@ -0,0 +1,15 @@
1
+ import * as brum from '@elliemae/pui-user-monitoring';
2
+ import { pageViewEvent } from "../analytics/page-view-event.js";
3
+ export const onPageView = pageTitle => {
4
+ try {
5
+ if (brum && pageTitle) {
6
+ brum.setCustomVirtualPageName(pageTitle);
7
+ brum.startVirtualPageMonitoringWithAutoEnd(pageTitle);
8
+ }
9
+ } catch {// eslint-disable-next-line no-empty
10
+ }
11
+
12
+ pageViewEvent({
13
+ pageTitle
14
+ });
15
+ };
@@ -10,18 +10,17 @@ import { isUserAuthorized } from "../../utils/auth/index.js";
10
10
  import { AppRoute } from "../index.js";
11
11
  import { jsx as _jsx } from "react/jsx-runtime";
12
12
  const key = 'auth';
13
- export const PrivateRoute = _ref => {
13
+ export const PrivateRoute = ({
14
+ component: Component,
15
+ render,
16
+ children,
17
+ clientId = enums.CLIENT_ID,
18
+ scope = 'loc',
19
+ responseType = 'code',
20
+ ...rest
21
+ }) => {
14
22
  var _Login;
15
23
 
16
- let {
17
- component: Component,
18
- render,
19
- children,
20
- clientId = enums.CLIENT_ID,
21
- scope = 'loc',
22
- responseType = 'code',
23
- ...rest
24
- } = _ref;
25
24
  useInjectReducer({
26
25
  key,
27
26
  reducer: authReducer
@@ -3,11 +3,9 @@ import { LOGIN, LOGOUT, LOGIN_SUCCESS } from "../../data/auth/actions.js";
3
3
  import { authorize, endSession } from "../../utils/auth/index.js";
4
4
  import { getLogger } from "../../utils/micro-frontend/index.js";
5
5
  import { logRecords } from "../../utils/log-records.js";
6
- export function* login(_ref) {
7
- let {
8
- payload
9
- } = _ref;
10
-
6
+ export function* login({
7
+ payload
8
+ }) {
11
9
  try {
12
10
  yield call(authorize, payload);
13
11
  yield put({
@@ -19,11 +17,9 @@ export function* login(_ref) {
19
17
  });
20
18
  }
21
19
  }
22
- export function* logout(_ref2) {
23
- let {
24
- payload
25
- } = _ref2;
26
-
20
+ export function* logout({
21
+ payload
22
+ }) {
27
23
  try {
28
24
  yield call(endSession, payload);
29
25
  } catch (err) {
@@ -7,17 +7,6 @@ let gAppConfig = APP_CONFIG;
7
7
  export const setAppConfig = config => {
8
8
  gAppConfig = config;
9
9
  };
10
- export const getAppConfigValue = function () {
11
- let key = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
12
- let defaultValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
13
- return _clone(_get(gAppConfig, key, defaultValue));
14
- };
15
- export const setAppConfigValue = function () {
16
- let key = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
17
- let value = arguments.length > 1 ? arguments[1] : undefined;
18
- return _set(gAppConfig, key, value);
19
- };
20
- export const hasItem = function () {
21
- let key = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
22
- return _has(gAppConfig, key);
23
- };
10
+ export const getAppConfigValue = (key = '', defaultValue = null) => _clone(_get(gAppConfig, key, defaultValue));
11
+ export const setAppConfigValue = (key = '', value) => _set(gAppConfig, key, value);
12
+ export const hasItem = (key = '') => _has(gAppConfig, key);