@commercetools-frontend/application-shell 24.11.0 → 24.12.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.
Files changed (73) hide show
  1. package/dist/{application-entry-point-c87294b0.cjs.dev.js → application-entry-point-18d8fba0.cjs.dev.js} +7 -4
  2. package/dist/{application-entry-point-10a5e1a5.esm.js → application-entry-point-1b23fb6b.esm.js} +6 -4
  3. package/dist/{application-entry-point-8c4b8e53.cjs.prod.js → application-entry-point-74a06151.cjs.prod.js} +4 -3
  4. package/dist/commercetools-frontend-application-shell.cjs.dev.js +12 -11
  5. package/dist/commercetools-frontend-application-shell.cjs.prod.js +12 -11
  6. package/dist/commercetools-frontend-application-shell.esm.js +12 -11
  7. package/dist/{custom-view-dev-host-6091b78a.esm.js → custom-view-dev-host-091163ea.esm.js} +20 -16
  8. package/dist/{custom-view-dev-host-40b33836.cjs.dev.js → custom-view-dev-host-17daf42a.cjs.dev.js} +21 -16
  9. package/dist/{custom-view-dev-host-3a171a01.cjs.prod.js → custom-view-dev-host-a682a499.cjs.prod.js} +21 -16
  10. package/dist/{index-a57c8458.cjs.dev.js → index-1d1cc31f.cjs.dev.js} +212 -363
  11. package/dist/{index-67a5d8e8.esm.js → index-1dadca21.esm.js} +213 -362
  12. package/dist/{index-614accc4.cjs.dev.js → index-25183095.cjs.dev.js} +2 -2
  13. package/dist/{index-7bdde97c.cjs.prod.js → index-3cfc1f1e.cjs.prod.js} +200 -343
  14. package/dist/{index-245e2980.cjs.prod.js → index-52c724ed.cjs.prod.js} +2 -2
  15. package/dist/{index-86039df7.esm.js → index-5aaa33bb.esm.js} +2 -2
  16. package/dist/{navbar-022383bd.cjs.dev.js → navbar-586f7774.cjs.dev.js} +111 -92
  17. package/dist/{navbar-844d350d.esm.js → navbar-88e0fd1f.esm.js} +110 -92
  18. package/dist/{navbar-acc2cd1b.cjs.prod.js → navbar-93183a2d.cjs.prod.js} +111 -92
  19. package/dist/oidc-258fc018.cjs.prod.js +115 -0
  20. package/dist/oidc-35e8e62a.esm.js +100 -0
  21. package/dist/oidc-87d116c1.cjs.dev.js +115 -0
  22. package/dist/{oidc-callback-5f3d5280.esm.js → oidc-callback-019d623d.esm.js} +16 -14
  23. package/dist/{oidc-callback-e07f0c20.cjs.dev.js → oidc-callback-47743232.cjs.dev.js} +16 -14
  24. package/dist/{oidc-callback-ce8cbdfe.cjs.prod.js → oidc-callback-6bdb3c6f.cjs.prod.js} +16 -14
  25. package/dist/{project-container-a11a31ca.cjs.dev.js → project-container-2245f020.cjs.dev.js} +53 -19
  26. package/dist/{project-container-fba09841.esm.js → project-container-7fce9e66.esm.js} +52 -19
  27. package/dist/{project-container-2d3d027a.cjs.prod.js → project-container-954dbf0f.cjs.prod.js} +53 -19
  28. package/dist/{project-expired-ede4d485.esm.js → project-expired-1b0845c5.esm.js} +12 -11
  29. package/dist/{project-expired-9620dee4.cjs.dev.js → project-expired-c941b592.cjs.dev.js} +12 -11
  30. package/dist/{project-expired-f38a712a.cjs.prod.js → project-expired-ee8b232c.cjs.prod.js} +12 -11
  31. package/dist/{project-not-found-093ab795.esm.js → project-not-found-340217f6.esm.js} +11 -10
  32. package/dist/{project-not-found-05683f8e.cjs.dev.js → project-not-found-9b7cfe88.cjs.dev.js} +11 -10
  33. package/dist/{project-not-found-cfa934da.cjs.prod.js → project-not-found-9cee9625.cjs.prod.js} +11 -10
  34. package/dist/{project-not-initialized-1d934ae7.esm.js → project-not-initialized-55fd8df4.esm.js} +12 -11
  35. package/dist/{project-not-initialized-b5a1400f.cjs.prod.js → project-not-initialized-7a058b68.cjs.prod.js} +12 -11
  36. package/dist/{project-not-initialized-1ed56a00.cjs.dev.js → project-not-initialized-7b3843a3.cjs.dev.js} +12 -11
  37. package/dist/{project-suspended-8e15a452.cjs.prod.js → project-suspended-12618898.cjs.prod.js} +11 -10
  38. package/dist/{project-suspended-e0722654.esm.js → project-suspended-529b09d6.esm.js} +11 -10
  39. package/dist/{project-suspended-68e80299.cjs.dev.js → project-suspended-78e94b85.cjs.dev.js} +11 -10
  40. package/dist/{redirect-to-login-12f467b8.cjs.prod.js → redirect-to-login-3e4a6434.cjs.prod.js} +13 -10
  41. package/dist/{redirect-to-login-3bee13ba.cjs.dev.js → redirect-to-login-66ea895a.cjs.dev.js} +13 -10
  42. package/dist/{redirect-to-login-2944c890.esm.js → redirect-to-login-edbfacbc.esm.js} +13 -10
  43. package/dist/{redirect-to-logout-2802852c.cjs.prod.js → redirect-to-logout-52a7810f.cjs.prod.js} +14 -12
  44. package/dist/{redirect-to-logout-5db48f16.esm.js → redirect-to-logout-5d5fc361.esm.js} +14 -12
  45. package/dist/{redirect-to-logout-74b72fe8.cjs.dev.js → redirect-to-logout-b331b037.cjs.dev.js} +14 -12
  46. package/dist/{redirector-72ccfbc2.cjs.dev.js → redirector-0efdd994.cjs.dev.js} +4 -3
  47. package/dist/{redirector-d856975f.esm.js → redirector-656c6ee7.esm.js} +4 -3
  48. package/dist/{redirector-0c72d0a4.cjs.prod.js → redirector-c858d578.cjs.prod.js} +4 -3
  49. package/dist/{requests-in-flight-loader-e25f4c31.esm.js → requests-in-flight-loader-20021ccc.esm.js} +11 -10
  50. package/dist/{requests-in-flight-loader-877c1541.cjs.prod.js → requests-in-flight-loader-64d2e12d.cjs.prod.js} +11 -10
  51. package/dist/{requests-in-flight-loader-bc904171.cjs.dev.js → requests-in-flight-loader-83cab813.cjs.dev.js} +11 -10
  52. package/dist/{service-page-project-switcher-af044ac6.cjs.dev.js → service-page-project-switcher-49dabe13.cjs.dev.js} +1 -1
  53. package/dist/{service-page-project-switcher-f3eac18a.esm.js → service-page-project-switcher-6cdd506b.esm.js} +1 -1
  54. package/dist/{service-page-project-switcher-1dad9871.cjs.prod.js → service-page-project-switcher-f1b43eb7.cjs.prod.js} +1 -1
  55. package/dist/{use-applications-menu-14a5a1f4.cjs.prod.js → use-applications-menu-48d924bd.cjs.prod.js} +47 -39
  56. package/dist/{use-applications-menu-823a2492.cjs.dev.js → use-applications-menu-7f548a7a.cjs.dev.js} +47 -39
  57. package/dist/{use-applications-menu-1514af11.esm.js → use-applications-menu-b871849c.esm.js} +44 -37
  58. package/dist/{user-settings-menu-d75f4958.cjs.prod.js → user-settings-menu-6660f508.cjs.prod.js} +29 -22
  59. package/dist/{user-settings-menu-f98bea89.esm.js → user-settings-menu-afa82f2a.esm.js} +29 -22
  60. package/dist/{user-settings-menu-6113cdd3.cjs.dev.js → user-settings-menu-f5c74042.cjs.dev.js} +29 -22
  61. package/package.json +16 -16
  62. package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.dev.js +2 -1
  63. package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.prod.js +2 -1
  64. package/ssr/dist/commercetools-frontend-application-shell-ssr.esm.js +2 -1
  65. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.dev.js +26 -22
  66. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.prod.js +26 -22
  67. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.esm.js +20 -17
  68. package/dist/oidc-8827f9fe.cjs.dev.js +0 -98
  69. package/dist/oidc-b2520905.esm.js +0 -84
  70. package/dist/oidc-d74e6aa2.cjs.prod.js +0 -98
  71. package/dist/quick-access-9dd197bb.cjs.prod.js +0 -1875
  72. package/dist/quick-access-a665bbb7.cjs.dev.js +0 -1893
  73. package/dist/quick-access-dfc1f8a9.esm.js +0 -1865
@@ -1,6 +1,6 @@
1
- import { lazy, useEffect, useState, useCallback, Component, Suspense, useMemo, useRef, useLayoutEffect, StrictMode } from 'react';
2
- import { useLocation, Route, Switch, Redirect, Router, useRouteMatch, useHistory, generatePath } from 'react-router-dom';
3
- import { R as RouteCatchAll, i as internalReduxStore } from './index-86039df7.esm.js';
1
+ import { lazy, useEffect, useMemo, useRef, useLayoutEffect, Suspense, Component, StrictMode, useState, useCallback } from 'react';
2
+ import { useLocation, Switch, Route, Redirect, Router, useRouteMatch, useHistory, generatePath } from 'react-router-dom';
3
+ import { R as RouteCatchAll, i as internalReduxStore } from './index-5aaa33bb.esm.js';
4
4
  import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
5
5
  import _styled from '@emotion/styled/base';
6
6
  import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
@@ -21,8 +21,9 @@ import { STORAGE_KEYS, GRAPHQL_TARGETS, featureFlags, LOGOUT_REASONS, DOMAINS, C
21
21
  import { AsyncLocaleData } from '@commercetools-frontend/i18n';
22
22
  import { NotificationsList } from '@commercetools-frontend/react-notifications';
23
23
  import { reportErrorToSentry, SentryUserTracker, boot } from '@commercetools-frontend/sentry';
24
- import { D as DIMENSIONS, C as CONTAINERS, N as NAVBAR, b as buildOidcScope, O as OIDC_CLAIMS } from './oidc-b2520905.esm.js';
24
+ import { D as DIMENSIONS, C as CONTAINERS, N as NAVBAR, b as buildOidcScope, O as OIDC_CLAIMS } from './oidc-35e8e62a.esm.js';
25
25
  import '@babel/runtime-corejs3/core-js-stable/url';
26
+ import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
26
27
  import { customProperties, designTokens, ThemeProvider } from '@commercetools-uikit/design-system';
27
28
  import Spacings from '@commercetools-uikit/spacings';
28
29
  import { defineMessages, useIntl, FormattedMessage, IntlProvider } from 'react-intl';
@@ -30,6 +31,7 @@ import FlatButton from '@commercetools-uikit/flat-button';
30
31
  import { AngleLeftIcon } from '@commercetools-uikit/icons';
31
32
  import { l as location } from './location-f21dbc25.esm.js';
32
33
  import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
34
+ import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
33
35
  import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
34
36
  import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
35
37
  import memoize from 'memoize-one';
@@ -41,13 +43,6 @@ import CTLogoSVG from '@commercetools-frontend/assets/images/ct-logo.svg';
41
43
  import LoadingSpinner from '@commercetools-uikit/loading-spinner';
42
44
  import history from '@commercetools-frontend/browser-history';
43
45
  import { getSupportedLocale } from '@commercetools-frontend/l10n';
44
- import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
45
- import _Reflect$construct from '@babel/runtime-corejs3/core-js-stable/reflect/construct';
46
- import _classCallCheck from '@babel/runtime-corejs3/helpers/esm/classCallCheck';
47
- import _createClass from '@babel/runtime-corejs3/helpers/esm/createClass';
48
- import _possibleConstructorReturn from '@babel/runtime-corejs3/helpers/esm/possibleConstructorReturn';
49
- import _getPrototypeOf from '@babel/runtime-corejs3/helpers/esm/getPrototypeOf';
50
- import _inherits from '@babel/runtime-corejs3/helpers/esm/inherits';
51
46
  import '@babel/runtime-corejs3/core-js-stable/instance/index-of';
52
47
  import _sliceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/slice';
53
48
  import _Object$fromEntries from '@babel/runtime-corejs3/core-js-stable/object/from-entries';
@@ -59,7 +54,14 @@ import { adapter as adapter$1 } from '@flopflip/launchdarkly-adapter';
59
54
  import { ConfigureFlopFlip } from '@flopflip/react-broadcast';
60
55
  import { cacheIdentifiers, adapterIdentifiers, cacheModes } from '@flopflip/types';
61
56
  import { Provider, useStore } from 'react-redux';
57
+ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
62
58
  import _startsWithInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/starts-with';
59
+ import _Reflect$construct from '@babel/runtime-corejs3/core-js-stable/reflect/construct';
60
+ import _classCallCheck from '@babel/runtime-corejs3/helpers/esm/classCallCheck';
61
+ import _createClass from '@babel/runtime-corejs3/helpers/esm/createClass';
62
+ import _possibleConstructorReturn from '@babel/runtime-corejs3/helpers/esm/possibleConstructorReturn';
63
+ import _getPrototypeOf from '@babel/runtime-corejs3/helpers/esm/getPrototypeOf';
64
+ import _inherits from '@babel/runtime-corejs3/helpers/esm/inherits';
63
65
  import _reduceInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/reduce';
64
66
  import '@commercetools-uikit/design-system/materials/resets.css';
65
67
  import { entryPointUriPathToPermissionKeys } from '@commercetools-frontend/application-config/ssr';
@@ -70,9 +72,9 @@ import _someInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instanc
70
72
  import { showUnexpectedErrorNotification } from '@commercetools-frontend/actions-global';
71
73
 
72
74
  // NOTE: This string will be replaced on build time with the package version.
73
- var version = "24.11.0";
75
+ var version = "24.12.0";
74
76
 
75
- const RequestsInFlightLoader = /*#__PURE__*/lazy(() => import('./requests-in-flight-loader-e25f4c31.esm.js' /* webpackChunkName: "requests-in-flight-loader" */));
77
+ const RequestsInFlightLoader = /*#__PURE__*/lazy(() => import('./requests-in-flight-loader-20021ccc.esm.js' /* webpackChunkName: "requests-in-flight-loader" */));
76
78
 
77
79
  // Attempt to load the `projectKey` from localStorage
78
80
  function selectProjectKeyFromLocalStorage() {
@@ -98,7 +100,7 @@ var messages$1 = defineMessages({
98
100
  * A full page reload is needed as the user's project may have changed (deletions and/or additions).
99
101
  * As a result the project and user queries need refetching.
100
102
  */
101
- const redirectToProject = key => location.replace(`/${key}`);
103
+ const redirectToProject = key => location.replace("/".concat(key));
102
104
  const BackToProject = props => {
103
105
  const intl = useIntl();
104
106
  return jsx(FlatButton, {
@@ -109,14 +111,8 @@ const BackToProject = props => {
109
111
  };
110
112
  BackToProject.displayName = 'BackToProject';
111
113
 
112
- const animationPulse = keyframes`
113
- 0% {
114
- background-color: ${customProperties.colorNeutral};
115
- }
116
- 100% {
117
- background-color: ${customProperties.colorNeutral95};
118
- }
119
- `;
114
+ var _templateObject;
115
+ const animationPulse = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n 0% {\n background-color: ", ";\n }\n 100% {\n background-color: ", ";\n }\n"])), customProperties.colorNeutral, customProperties.colorNeutral95);
120
116
  const getWidthBySize = props => {
121
117
  switch (props.shape) {
122
118
  case 'dot':
@@ -219,7 +215,7 @@ var messages = defineMessages({
219
215
  const _excluded$3 = ["children"];
220
216
  function ownKeys$a(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
221
217
  function _objectSpread$a(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$a(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$a(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
222
- function _EMOTION_STRINGIFIED_CSS_ERROR__$4() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
218
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$3() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
223
219
  var ProjectsQuery = { kind: "Document", definitions: [{ kind: "OperationDefinition", operation: "query", name: { kind: "Name", value: "FetchUserProjects" }, variableDefinitions: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", alias: { kind: "Name", value: "user" }, name: { kind: "Name", value: "me" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "id" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "projects" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "total" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "results" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "key" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "suspension" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "isActive" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "expiry" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "isActive" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "isProductionProject" }, arguments: [], directives: [] }] } }] } }] } }] } }], loc: { start: 0, end: 258, source: { body: "query FetchUserProjects {\n user: me {\n id\n projects {\n total\n results {\n name\n key\n suspension {\n isActive\n }\n expiry {\n isActive\n }\n isProductionProject\n }\n }\n }\n}\n", name: "GraphQL request", locationOffset: { line: 1, column: 1 } } } };
224
220
  const PROJECT_SWITCHER_LABEL_ID = 'project-switcher-label';
225
221
  const ValueContainer = _ref2 => {
@@ -246,7 +242,7 @@ var _ref$2 = process.env.NODE_ENV === "production" ? {
246
242
  } : {
247
243
  name: "1wvu9ea-ProjectSwitcherOption",
248
244
  styles: "flex:1;word-wrap:break-word;label:ProjectSwitcherOption;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["project-switcher.tsx"],"names":[],"mappings":"AAiFkB","file":"project-switcher.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport memoize from 'memoize-one';\nimport { FormattedMessage, useIntl } from 'react-intl';\nimport type {\n  OptionProps,\n  ValueContainerProps,\n  MenuListProps,\n  ControlProps,\n} from 'react-select';\nimport { components } from 'react-select';\nimport { ProjectStamp } from '@commercetools-frontend/application-components';\nimport {\n  useMcQuery,\n  oidcStorage,\n} from '@commercetools-frontend/application-shell-connectors';\nimport type { ApplicationWindow } from '@commercetools-frontend/constants';\nimport { GRAPHQL_TARGETS } from '@commercetools-frontend/constants';\nimport AccessibleHidden from '@commercetools-uikit/accessible-hidden';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport SelectInput, { TOption } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport Text from '@commercetools-uikit/text';\nimport type {\n  TProject,\n  TFetchUserProjectsQuery,\n  TFetchUserProjectsQueryVariables,\n} from '../../types/generated/mc';\nimport { location } from '../../utils/location';\nimport messages from './messages';\nimport ProjectsQuery from './project-switcher.mc.graphql';\n\ndeclare let window: ApplicationWindow;\n\ntype Props = {\n  projectKey?: string;\n};\ntype OptionType = Pick<\n  TProject,\n  'key' | 'name' | 'suspension' | 'expiry' | 'isProductionProject'\n> &\n  TOption;\n\nconst PROJECT_SWITCHER_LABEL_ID = 'project-switcher-label';\n\nexport const ValueContainer = ({\n  children,\n  ...restProps\n}: ValueContainerProps<TOption>) => {\n  return (\n    <Text.Body fontWeight=\"medium\" as=\"span\">\n      <SelectInput.ValueContainer {...restProps}>\n        {children}\n      </SelectInput.ValueContainer>\n    </Text.Body>\n  );\n};\n\ntype TProjectStampsListProps = Pick<\n  TProject,\n  'isProductionProject' | 'suspension' | 'expiry'\n>;\nconst ProjectStampsList = (props: TProjectStampsListProps) => (\n  <Spacings.Stack scale=\"xs\" alignItems=\"flex-end\">\n    {props.isProductionProject && <ProjectStamp.IsProduction />}\n    {props.suspension && props.suspension.isActive && (\n      <ProjectStamp.IsSuspended />\n    )}\n    {props.expiry && props.expiry.isActive && <ProjectStamp.IsExpired />}\n    {props.expiry && Boolean(props.expiry.daysLeft) && (\n      <ProjectStamp.WillExpire daysLeft={props.expiry.daysLeft!} />\n    )}\n  </Spacings.Stack>\n);\n\nexport const ProjectSwitcherOption = (props: OptionProps<TOption>) => {\n  const project = props.data as OptionType;\n\n  return (\n    <SelectInput.Option {...props}>\n      <Spacings.Inline scale=\"xs\" justifyContent=\"space-between\">\n        <div\n          css={css`\n            flex: 1;\n            word-wrap: break-word;\n          `}\n        >\n          <Text.Body\n            fontWeight=\"medium\"\n            tone={props.isDisabled ? 'tertiary' : 'inherit'}\n          >\n            {project.name}\n          </Text.Body>\n          <Text.Caption tone={props.isDisabled ? 'tertiary' : 'secondary'}>\n            {project.key}\n          </Text.Caption>\n        </div>\n\n        <ProjectStampsList\n          isProductionProject={project.isProductionProject}\n          suspension={project.suspension}\n          expiry={project.expiry}\n        />\n      </Spacings.Inline>\n    </SelectInput.Option>\n  );\n};\n\nconst mapProjectsToOptions = memoize((projects) => {\n  return [\n    {\n      label: <FormattedMessage {...messages.projectsLabel} />,\n      options: projects.map((project: TProject) => ({\n        key: project.key,\n        name: project.name,\n        label: project.name,\n        value: project.key,\n        suspension: project.suspension,\n        expiry: project.expiry,\n        isProductionProject: project.isProductionProject,\n      })),\n    },\n  ];\n});\n\nconst CustomMenuList = (props: MenuListProps<TOption>) => {\n  return (\n    <div>\n      <components.MenuList {...props}>{props.children}</components.MenuList>\n    </div>\n  );\n};\n\nconst Control = (props: ControlProps<TOption>) => (\n  <components.Control\n    {...props}\n    css={css`\n      min-width: ${designTokens.constraint3};\n    `}\n  >\n    {props.children}\n  </components.Control>\n);\n\nconst redirectTo = (targetUrl: string) => location.replace(targetUrl);\n\nconst ProjectSwitcher = (props: Props) => {\n  const intl = useIntl();\n  const { loading, data } = useMcQuery<\n    TFetchUserProjectsQuery,\n    TFetchUserProjectsQueryVariables\n  >(ProjectsQuery, {\n    context: {\n      target: GRAPHQL_TARGETS.MERCHANT_CENTER_BACKEND,\n    },\n  });\n\n  if (loading) return null;\n\n  return (\n    <div>\n      <AccessibleHidden>\n        <span id={PROJECT_SWITCHER_LABEL_ID}>\n          <FormattedMessage {...messages.projectsLabel} />\n        </span>\n      </AccessibleHidden>\n      <SelectInput\n        value={props.projectKey || ''}\n        name=\"project-switcher\"\n        aria-labelledby={PROJECT_SWITCHER_LABEL_ID}\n        onChange={(event) => {\n          const selectedProjectKey = event.target.value as string;\n          if (selectedProjectKey !== props.projectKey) {\n            if (window.app.__DEVELOPMENT__?.oidc?.authorizeUrl) {\n              oidcStorage.setActiveProjectKey(selectedProjectKey);\n            }\n\n            // We simply redirect to a \"new\" browser page, instead of using the\n            // history router. This will simplify a lot of things and avoid possible\n            // problems like e.g. resetting the store/state.\n            redirectTo(`/${selectedProjectKey}`);\n          }\n        }}\n        options={\n          (data &&\n            data.user &&\n            mapProjectsToOptions(data.user.projects.results)) ||\n          []\n        }\n        isOptionDisabled={(option) => {\n          const project = option as OptionType;\n          return project.suspension.isActive || project.expiry.isActive;\n        }}\n        components={{\n          Option: ProjectSwitcherOption,\n          ValueContainer,\n          MenuList: CustomMenuList,\n          Control,\n        }}\n        isClearable={false}\n        backspaceRemovesValue={false}\n        placeholder={intl.formatMessage(messages.searchPlaceholder)}\n        noOptionsMessage={() => intl.formatMessage(messages.noResults)}\n        horizontalConstraint={'auto'}\n        appearance=\"quiet\"\n        maxMenuHeight={380}\n        maxMenuWidth={8}\n        minMenuWidth={8}\n      />\n    </div>\n  );\n};\nProjectSwitcher.displayName = 'ProjectSwitcher';\n\nexport default ProjectSwitcher;\n"]} */",
249
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$4
245
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
250
246
  };
251
247
  const ProjectSwitcherOption = props => {
252
248
  const project = props.data;
@@ -321,14 +317,15 @@ const ProjectSwitcher = props => {
321
317
  onChange: event => {
322
318
  const selectedProjectKey = event.target.value;
323
319
  if (selectedProjectKey !== props.projectKey) {
324
- if (window.app.__DEVELOPMENT__?.oidc?.authorizeUrl) {
320
+ var _window$app$__DEVELOP;
321
+ if ((_window$app$__DEVELOP = window.app.__DEVELOPMENT__) !== null && _window$app$__DEVELOP !== void 0 && (_window$app$__DEVELOP = _window$app$__DEVELOP.oidc) !== null && _window$app$__DEVELOP !== void 0 && _window$app$__DEVELOP.authorizeUrl) {
325
322
  oidcStorage.setActiveProjectKey(selectedProjectKey);
326
323
  }
327
324
 
328
325
  // We simply redirect to a "new" browser page, instead of using the
329
326
  // history router. This will simplify a lot of things and avoid possible
330
327
  // problems like e.g. resetting the store/state.
331
- redirectTo(`/${selectedProjectKey}`);
328
+ redirectTo("/".concat(selectedProjectKey));
332
329
  }
333
330
  },
334
331
  options: data && data.user && mapProjectsToOptions(data.user.projects.results) || [],
@@ -359,16 +356,16 @@ ProjectSwitcher.displayName = 'ProjectSwitcher';
359
356
  // eslint-disable-next-line import/prefer-default-export
360
357
  const REQUESTS_IN_FLIGHT_LOADER_DOM_ID = 'loader-for-requests-in-flight';
361
358
 
362
- const UserSettingsMenu = /*#__PURE__*/lazy(() => import('./user-settings-menu-f98bea89.esm.js' /* webpackChunkName: "user-settings-menu" */));
359
+ const UserSettingsMenu = /*#__PURE__*/lazy(() => import('./user-settings-menu-afa82f2a.esm.js' /* webpackChunkName: "user-settings-menu" */));
363
360
 
364
- function _EMOTION_STRINGIFIED_CSS_ERROR__$3() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
361
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
365
362
  var _ref$1 = process.env.NODE_ENV === "production" ? {
366
363
  name: "zjik7",
367
364
  styles: "display:flex"
368
365
  } : {
369
366
  name: "183miex-AppBar",
370
367
  styles: "display:flex;label:AppBar;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFwcC1iYXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlIZ0IiLCJmaWxlIjoiYXBwLWJhci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBQcm9qZWN0U3RhbXAgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJztcbmltcG9ydCB7IGRlc2lnblRva2VucyBhcyB1aWtpdERlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCB7IENPTlRBSU5FUlMsIERJTUVOU0lPTlMgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHR5cGUgeyBURmV0Y2hMb2dnZWRJblVzZXJRdWVyeSB9IGZyb20gJy4uLy4uL3R5cGVzL2dlbmVyYXRlZC9tYyc7XG5pbXBvcnQgeyBnZXRQcmV2aW91c1Byb2plY3RLZXkgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgQmFja1RvUHJvamVjdCBmcm9tICcuLi9iYWNrLXRvLXByb2plY3QnO1xuaW1wb3J0IExvYWRpbmdQbGFjZWhvbGRlciBmcm9tICcuLi9sb2FkaW5nLXBsYWNlaG9sZGVyJztcbmltcG9ydCBQcm9qZWN0U3dpdGNoZXIgZnJvbSAnLi4vcHJvamVjdC1zd2l0Y2hlcic7XG5pbXBvcnQgeyBSRVFVRVNUU19JTl9GTElHSFRfTE9BREVSX0RPTV9JRCB9IGZyb20gJy4uL3JlcXVlc3RzLWluLWZsaWdodC1sb2FkZXIvY29uc3RhbnRzJztcbmltcG9ydCBVc2VyU2V0dGluZ3NNZW51IGZyb20gJy4uL3VzZXItc2V0dGluZ3MtbWVudSc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIHVzZXI6IFRGZXRjaExvZ2dlZEluVXNlclF1ZXJ5Wyd1c2VyJ107XG4gIHByb2plY3RLZXlGcm9tVXJsPzogc3RyaW5nO1xufTtcblxuY29uc3QgQXBwQmFyID0gKHByb3BzOiBQcm9wcykgPT4ge1xuICBjb25zdCBwcmV2aW91c1Byb2plY3RLZXkgPSBnZXRQcmV2aW91c1Byb2plY3RLZXkoXG4gICAgcHJvcHMudXNlcj8uZGVmYXVsdFByb2plY3RLZXkgPz8gdW5kZWZpbmVkXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHt1aWtpdERlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICAgICAgICBib3gtc2hhZG93OiAwcHggMnB4IDVweCAwcHggcmdiYSgwLCAwLCAwLCAwLjE1KTtcbiAgICAgICAgcGFkZGluZzogMCA0MHB4O1xuICAgICAgICBtaW4taGVpZ2h0OiAke0RJTUVOU0lPTlMuaGVhZGVyfTtcbiAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgei1pbmRleDogMjAwMDA7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgIGB9XG4gICAgICBkYXRhLXRlc3Q9XCJ0b3AtbmF2aWdhdGlvblwiXG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBmbG9hdDogcmlnaHQ7XG4gICAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgICBmb250LXNpemU6IDFyZW07XG4gICAgICAgICAgbWFyZ2luLXJpZ2h0OiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmc1NX07XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwibVwiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICAgICAgZ2FwOiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmczMH07XG4gICAgICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHsoKCkgPT4ge1xuICAgICAgICAgICAgICBpZiAoIXByb3BzLnVzZXIpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gPExvYWRpbmdQbGFjZWhvbGRlciBzaGFwZT1cInJlY3RcIiBzaXplPVwic1wiIC8+O1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIC8vIFRoZSBgPFByb2plY3RTd2l0Y2hlcj5gIHNob3VsZCBiZSByZW5kZXJlZCBvbmx5IGlmIHRoZVxuICAgICAgICAgICAgICAvLyB1c2VyIGlzIGZldGNoZWQgYW5kIHRoZSB1c2VyIGhhcyBwcm9qZWN0cyB3aGlsZSB0aGUgYXBwIHJ1bnMgaW4gYW4gcHJvamVjdCBjb250ZXh0LlxuICAgICAgICAgICAgICBpZiAocHJvcHMudXNlci5wcm9qZWN0cy50b3RhbCA+IDAgJiYgcHJvcHMucHJvamVjdEtleUZyb21VcmwpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBzZWxlY3RlZFByb2plY3QgPSBwcm9wcy51c2VyLnByb2plY3RzLnJlc3VsdHMuZmluZChcbiAgICAgICAgICAgICAgICAgIChwcm9qZWN0KSA9PiBwcm9qZWN0LmtleSA9PT0gcHJvcHMucHJvamVjdEtleUZyb21VcmxcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgICAgICAgICAgICAgZ2FwOiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgICAgICAgICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICAgICAgICAgICAgYH1cbiAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAge3NlbGVjdGVkUHJvamVjdD8uaXNQcm9kdWN0aW9uUHJvamVjdCAmJiAoXG4gICAgICAgICAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGhlaWdodDogMjJweDtcbiAgICAgICAgICAgICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgPFByb2plY3RTdGFtcC5Jc1Byb2R1Y3Rpb24gLz5cbiAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgICAgICAgPFByb2plY3RTd2l0Y2hlclxuICAgICAgICAgICAgICAgICAgICAgIC8vIEluIHRoaXMgY2FzZSBpdCdzIG5vdCBuZWNlc3NhcnkgdG8gY2hlY2sgaWYgdGhlIGBwcm9qZWN0S2V5YCBwYXJhbVxuICAgICAgICAgICAgICAgICAgICAgIC8vIGlzIGluY2x1ZGVkIGluIHRoZSBsaXN0IG9mIHByb2plY3RzLiBJbiBzdWNoIGNhc2VcbiAgICAgICAgICAgICAgICAgICAgICAvLyB0aGUgZHJvcGRvd24gd2lsbCBzdGlsbCBiZSByZW5kZXJlZCBidXQgbm8gcHJvamVjdCB3aWxsIGJlIHNlbGVjdGVkLlxuICAgICAgICAgICAgICAgICAgICAgIC8vIFRoaXMgaXMgZmluZSBiZWNhc2UgdGhlIHVzZXIgaGFzIHN0aWxsIHRoZSBwb3NzaWJpbGl0eSB0byBcInN3aXRjaFwiXG4gICAgICAgICAgICAgICAgICAgICAgLy8gdG8gYSBwcm9qZWN0LlxuICAgICAgICAgICAgICAgICAgICAgIHByb2plY3RLZXk9e3Byb3BzLnByb2plY3RLZXlGcm9tVXJsIHx8IHByZXZpb3VzUHJvamVjdEtleX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgaWYgKCFwcm9wcy51c2VyLmRlZmF1bHRQcm9qZWN0S2V5KSByZXR1cm4gbnVsbDtcbiAgICAgICAgICAgICAgcmV0dXJuIDxCYWNrVG9Qcm9qZWN0IHByb2plY3RLZXk9e3ByZXZpb3VzUHJvamVjdEtleX0gLz47XG4gICAgICAgICAgICB9KSgpfVxuICAgICAgICAgICAgey8qIFRoaXMgbm9kZSBpcyB1c2VkIGJ5IGEgcmVhY3QgcG9ydGFsICovfVxuICAgICAgICAgICAgPGRpdiBpZD17Q09OVEFJTkVSUy5MT0NBTEVfU1dJVENIRVJ9IC8+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPFNwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgaWQ9e1JFUVVFU1RTX0lOX0ZMSUdIVF9MT0FERVJfRE9NX0lEfVxuICAgICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgICAgICAgIGZsZXg6IDE7XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2IGlkPXtDT05UQUlORVJTLkxFRlRfT0ZfUFJPRklMRX0+PC9kaXY+XG4gICAgICAgIHtwcm9wcy51c2VyID8gKFxuICAgICAgICAgIDxVc2VyU2V0dGluZ3NNZW51XG4gICAgICAgICAgICBsYW5ndWFnZT17cHJvcHMudXNlci5sYW5ndWFnZX1cbiAgICAgICAgICAgIGZpcnN0TmFtZT17cHJvcHMudXNlci5maXJzdE5hbWV9XG4gICAgICAgICAgICBsYXN0TmFtZT17cHJvcHMudXNlci5sYXN0TmFtZX1cbiAgICAgICAgICAgIGdyYXZhdGFySGFzaD17cHJvcHMudXNlci5ncmF2YXRhckhhc2h9XG4gICAgICAgICAgICBlbWFpbD17cHJvcHMudXNlci5lbWFpbH1cbiAgICAgICAgICAvPlxuICAgICAgICApIDogKFxuICAgICAgICAgIDxMb2FkaW5nUGxhY2Vob2xkZXIgc2hhcGU9XCJkb3RcIiBzaXplPVwibFwiIC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5BcHBCYXIuZGlzcGxheU5hbWUgPSAnQXBwQmFyJztcblxuZXhwb3J0IGRlZmF1bHQgQXBwQmFyO1xuIl19 */",
371
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
368
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
372
369
  };
373
370
  var _ref2$1 = process.env.NODE_ENV === "production" ? {
374
371
  name: "36bnqj",
@@ -376,7 +373,7 @@ var _ref2$1 = process.env.NODE_ENV === "production" ? {
376
373
  } : {
377
374
  name: "p3e2aw-AppBar",
378
375
  styles: "display:flex;flex:1;label:AppBar;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFwcC1iYXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXdHc0IiLCJmaWxlIjoiYXBwLWJhci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBQcm9qZWN0U3RhbXAgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJztcbmltcG9ydCB7IGRlc2lnblRva2VucyBhcyB1aWtpdERlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCB7IENPTlRBSU5FUlMsIERJTUVOU0lPTlMgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHR5cGUgeyBURmV0Y2hMb2dnZWRJblVzZXJRdWVyeSB9IGZyb20gJy4uLy4uL3R5cGVzL2dlbmVyYXRlZC9tYyc7XG5pbXBvcnQgeyBnZXRQcmV2aW91c1Byb2plY3RLZXkgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgQmFja1RvUHJvamVjdCBmcm9tICcuLi9iYWNrLXRvLXByb2plY3QnO1xuaW1wb3J0IExvYWRpbmdQbGFjZWhvbGRlciBmcm9tICcuLi9sb2FkaW5nLXBsYWNlaG9sZGVyJztcbmltcG9ydCBQcm9qZWN0U3dpdGNoZXIgZnJvbSAnLi4vcHJvamVjdC1zd2l0Y2hlcic7XG5pbXBvcnQgeyBSRVFVRVNUU19JTl9GTElHSFRfTE9BREVSX0RPTV9JRCB9IGZyb20gJy4uL3JlcXVlc3RzLWluLWZsaWdodC1sb2FkZXIvY29uc3RhbnRzJztcbmltcG9ydCBVc2VyU2V0dGluZ3NNZW51IGZyb20gJy4uL3VzZXItc2V0dGluZ3MtbWVudSc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIHVzZXI6IFRGZXRjaExvZ2dlZEluVXNlclF1ZXJ5Wyd1c2VyJ107XG4gIHByb2plY3RLZXlGcm9tVXJsPzogc3RyaW5nO1xufTtcblxuY29uc3QgQXBwQmFyID0gKHByb3BzOiBQcm9wcykgPT4ge1xuICBjb25zdCBwcmV2aW91c1Byb2plY3RLZXkgPSBnZXRQcmV2aW91c1Byb2plY3RLZXkoXG4gICAgcHJvcHMudXNlcj8uZGVmYXVsdFByb2plY3RLZXkgPz8gdW5kZWZpbmVkXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHt1aWtpdERlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICAgICAgICBib3gtc2hhZG93OiAwcHggMnB4IDVweCAwcHggcmdiYSgwLCAwLCAwLCAwLjE1KTtcbiAgICAgICAgcGFkZGluZzogMCA0MHB4O1xuICAgICAgICBtaW4taGVpZ2h0OiAke0RJTUVOU0lPTlMuaGVhZGVyfTtcbiAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgei1pbmRleDogMjAwMDA7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgIGB9XG4gICAgICBkYXRhLXRlc3Q9XCJ0b3AtbmF2aWdhdGlvblwiXG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBmbG9hdDogcmlnaHQ7XG4gICAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgICBmb250LXNpemU6IDFyZW07XG4gICAgICAgICAgbWFyZ2luLXJpZ2h0OiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmc1NX07XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwibVwiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICAgICAgZ2FwOiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmczMH07XG4gICAgICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHsoKCkgPT4ge1xuICAgICAgICAgICAgICBpZiAoIXByb3BzLnVzZXIpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gPExvYWRpbmdQbGFjZWhvbGRlciBzaGFwZT1cInJlY3RcIiBzaXplPVwic1wiIC8+O1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIC8vIFRoZSBgPFByb2plY3RTd2l0Y2hlcj5gIHNob3VsZCBiZSByZW5kZXJlZCBvbmx5IGlmIHRoZVxuICAgICAgICAgICAgICAvLyB1c2VyIGlzIGZldGNoZWQgYW5kIHRoZSB1c2VyIGhhcyBwcm9qZWN0cyB3aGlsZSB0aGUgYXBwIHJ1bnMgaW4gYW4gcHJvamVjdCBjb250ZXh0LlxuICAgICAgICAgICAgICBpZiAocHJvcHMudXNlci5wcm9qZWN0cy50b3RhbCA+IDAgJiYgcHJvcHMucHJvamVjdEtleUZyb21VcmwpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBzZWxlY3RlZFByb2plY3QgPSBwcm9wcy51c2VyLnByb2plY3RzLnJlc3VsdHMuZmluZChcbiAgICAgICAgICAgICAgICAgIChwcm9qZWN0KSA9PiBwcm9qZWN0LmtleSA9PT0gcHJvcHMucHJvamVjdEtleUZyb21VcmxcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgICAgICAgICAgICAgZ2FwOiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgICAgICAgICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICAgICAgICAgICAgYH1cbiAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAge3NlbGVjdGVkUHJvamVjdD8uaXNQcm9kdWN0aW9uUHJvamVjdCAmJiAoXG4gICAgICAgICAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGhlaWdodDogMjJweDtcbiAgICAgICAgICAgICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgPFByb2plY3RTdGFtcC5Jc1Byb2R1Y3Rpb24gLz5cbiAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgICAgICAgPFByb2plY3RTd2l0Y2hlclxuICAgICAgICAgICAgICAgICAgICAgIC8vIEluIHRoaXMgY2FzZSBpdCdzIG5vdCBuZWNlc3NhcnkgdG8gY2hlY2sgaWYgdGhlIGBwcm9qZWN0S2V5YCBwYXJhbVxuICAgICAgICAgICAgICAgICAgICAgIC8vIGlzIGluY2x1ZGVkIGluIHRoZSBsaXN0IG9mIHByb2plY3RzLiBJbiBzdWNoIGNhc2VcbiAgICAgICAgICAgICAgICAgICAgICAvLyB0aGUgZHJvcGRvd24gd2lsbCBzdGlsbCBiZSByZW5kZXJlZCBidXQgbm8gcHJvamVjdCB3aWxsIGJlIHNlbGVjdGVkLlxuICAgICAgICAgICAgICAgICAgICAgIC8vIFRoaXMgaXMgZmluZSBiZWNhc2UgdGhlIHVzZXIgaGFzIHN0aWxsIHRoZSBwb3NzaWJpbGl0eSB0byBcInN3aXRjaFwiXG4gICAgICAgICAgICAgICAgICAgICAgLy8gdG8gYSBwcm9qZWN0LlxuICAgICAgICAgICAgICAgICAgICAgIHByb2plY3RLZXk9e3Byb3BzLnByb2plY3RLZXlGcm9tVXJsIHx8IHByZXZpb3VzUHJvamVjdEtleX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgaWYgKCFwcm9wcy51c2VyLmRlZmF1bHRQcm9qZWN0S2V5KSByZXR1cm4gbnVsbDtcbiAgICAgICAgICAgICAgcmV0dXJuIDxCYWNrVG9Qcm9qZWN0IHByb2plY3RLZXk9e3ByZXZpb3VzUHJvamVjdEtleX0gLz47XG4gICAgICAgICAgICB9KSgpfVxuICAgICAgICAgICAgey8qIFRoaXMgbm9kZSBpcyB1c2VkIGJ5IGEgcmVhY3QgcG9ydGFsICovfVxuICAgICAgICAgICAgPGRpdiBpZD17Q09OVEFJTkVSUy5MT0NBTEVfU1dJVENIRVJ9IC8+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPFNwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgaWQ9e1JFUVVFU1RTX0lOX0ZMSUdIVF9MT0FERVJfRE9NX0lEfVxuICAgICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgICAgICAgIGZsZXg6IDE7XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2IGlkPXtDT05UQUlORVJTLkxFRlRfT0ZfUFJPRklMRX0+PC9kaXY+XG4gICAgICAgIHtwcm9wcy51c2VyID8gKFxuICAgICAgICAgIDxVc2VyU2V0dGluZ3NNZW51XG4gICAgICAgICAgICBsYW5ndWFnZT17cHJvcHMudXNlci5sYW5ndWFnZX1cbiAgICAgICAgICAgIGZpcnN0TmFtZT17cHJvcHMudXNlci5maXJzdE5hbWV9XG4gICAgICAgICAgICBsYXN0TmFtZT17cHJvcHMudXNlci5sYXN0TmFtZX1cbiAgICAgICAgICAgIGdyYXZhdGFySGFzaD17cHJvcHMudXNlci5ncmF2YXRhckhhc2h9XG4gICAgICAgICAgICBlbWFpbD17cHJvcHMudXNlci5lbWFpbH1cbiAgICAgICAgICAvPlxuICAgICAgICApIDogKFxuICAgICAgICAgIDxMb2FkaW5nUGxhY2Vob2xkZXIgc2hhcGU9XCJkb3RcIiBzaXplPVwibFwiIC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5BcHBCYXIuZGlzcGxheU5hbWUgPSAnQXBwQmFyJztcblxuZXhwb3J0IGRlZmF1bHQgQXBwQmFyO1xuIl19 */",
379
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
376
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
380
377
  };
381
378
  var _ref3$1 = process.env.NODE_ENV === "production" ? {
382
379
  name: "w3f7al",
@@ -384,10 +381,11 @@ var _ref3$1 = process.env.NODE_ENV === "production" ? {
384
381
  } : {
385
382
  name: "1ebvy0g-AppBar",
386
383
  styles: "height:22px;label:AppBar;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFwcC1iYXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZFZ0MiLCJmaWxlIjoiYXBwLWJhci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBQcm9qZWN0U3RhbXAgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJztcbmltcG9ydCB7IGRlc2lnblRva2VucyBhcyB1aWtpdERlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCB7IENPTlRBSU5FUlMsIERJTUVOU0lPTlMgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHR5cGUgeyBURmV0Y2hMb2dnZWRJblVzZXJRdWVyeSB9IGZyb20gJy4uLy4uL3R5cGVzL2dlbmVyYXRlZC9tYyc7XG5pbXBvcnQgeyBnZXRQcmV2aW91c1Byb2plY3RLZXkgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgQmFja1RvUHJvamVjdCBmcm9tICcuLi9iYWNrLXRvLXByb2plY3QnO1xuaW1wb3J0IExvYWRpbmdQbGFjZWhvbGRlciBmcm9tICcuLi9sb2FkaW5nLXBsYWNlaG9sZGVyJztcbmltcG9ydCBQcm9qZWN0U3dpdGNoZXIgZnJvbSAnLi4vcHJvamVjdC1zd2l0Y2hlcic7XG5pbXBvcnQgeyBSRVFVRVNUU19JTl9GTElHSFRfTE9BREVSX0RPTV9JRCB9IGZyb20gJy4uL3JlcXVlc3RzLWluLWZsaWdodC1sb2FkZXIvY29uc3RhbnRzJztcbmltcG9ydCBVc2VyU2V0dGluZ3NNZW51IGZyb20gJy4uL3VzZXItc2V0dGluZ3MtbWVudSc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIHVzZXI6IFRGZXRjaExvZ2dlZEluVXNlclF1ZXJ5Wyd1c2VyJ107XG4gIHByb2plY3RLZXlGcm9tVXJsPzogc3RyaW5nO1xufTtcblxuY29uc3QgQXBwQmFyID0gKHByb3BzOiBQcm9wcykgPT4ge1xuICBjb25zdCBwcmV2aW91c1Byb2plY3RLZXkgPSBnZXRQcmV2aW91c1Byb2plY3RLZXkoXG4gICAgcHJvcHMudXNlcj8uZGVmYXVsdFByb2plY3RLZXkgPz8gdW5kZWZpbmVkXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHt1aWtpdERlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICAgICAgICBib3gtc2hhZG93OiAwcHggMnB4IDVweCAwcHggcmdiYSgwLCAwLCAwLCAwLjE1KTtcbiAgICAgICAgcGFkZGluZzogMCA0MHB4O1xuICAgICAgICBtaW4taGVpZ2h0OiAke0RJTUVOU0lPTlMuaGVhZGVyfTtcbiAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgei1pbmRleDogMjAwMDA7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgIGB9XG4gICAgICBkYXRhLXRlc3Q9XCJ0b3AtbmF2aWdhdGlvblwiXG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBmbG9hdDogcmlnaHQ7XG4gICAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgICBmb250LXNpemU6IDFyZW07XG4gICAgICAgICAgbWFyZ2luLXJpZ2h0OiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmc1NX07XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwibVwiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICAgICAgZ2FwOiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmczMH07XG4gICAgICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHsoKCkgPT4ge1xuICAgICAgICAgICAgICBpZiAoIXByb3BzLnVzZXIpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gPExvYWRpbmdQbGFjZWhvbGRlciBzaGFwZT1cInJlY3RcIiBzaXplPVwic1wiIC8+O1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIC8vIFRoZSBgPFByb2plY3RTd2l0Y2hlcj5gIHNob3VsZCBiZSByZW5kZXJlZCBvbmx5IGlmIHRoZVxuICAgICAgICAgICAgICAvLyB1c2VyIGlzIGZldGNoZWQgYW5kIHRoZSB1c2VyIGhhcyBwcm9qZWN0cyB3aGlsZSB0aGUgYXBwIHJ1bnMgaW4gYW4gcHJvamVjdCBjb250ZXh0LlxuICAgICAgICAgICAgICBpZiAocHJvcHMudXNlci5wcm9qZWN0cy50b3RhbCA+IDAgJiYgcHJvcHMucHJvamVjdEtleUZyb21VcmwpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBzZWxlY3RlZFByb2plY3QgPSBwcm9wcy51c2VyLnByb2plY3RzLnJlc3VsdHMuZmluZChcbiAgICAgICAgICAgICAgICAgIChwcm9qZWN0KSA9PiBwcm9qZWN0LmtleSA9PT0gcHJvcHMucHJvamVjdEtleUZyb21VcmxcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgICAgICAgICAgICAgZ2FwOiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgICAgICAgICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICAgICAgICAgICAgYH1cbiAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAge3NlbGVjdGVkUHJvamVjdD8uaXNQcm9kdWN0aW9uUHJvamVjdCAmJiAoXG4gICAgICAgICAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGhlaWdodDogMjJweDtcbiAgICAgICAgICAgICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgPFByb2plY3RTdGFtcC5Jc1Byb2R1Y3Rpb24gLz5cbiAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgICAgICAgPFByb2plY3RTd2l0Y2hlclxuICAgICAgICAgICAgICAgICAgICAgIC8vIEluIHRoaXMgY2FzZSBpdCdzIG5vdCBuZWNlc3NhcnkgdG8gY2hlY2sgaWYgdGhlIGBwcm9qZWN0S2V5YCBwYXJhbVxuICAgICAgICAgICAgICAgICAgICAgIC8vIGlzIGluY2x1ZGVkIGluIHRoZSBsaXN0IG9mIHByb2plY3RzLiBJbiBzdWNoIGNhc2VcbiAgICAgICAgICAgICAgICAgICAgICAvLyB0aGUgZHJvcGRvd24gd2lsbCBzdGlsbCBiZSByZW5kZXJlZCBidXQgbm8gcHJvamVjdCB3aWxsIGJlIHNlbGVjdGVkLlxuICAgICAgICAgICAgICAgICAgICAgIC8vIFRoaXMgaXMgZmluZSBiZWNhc2UgdGhlIHVzZXIgaGFzIHN0aWxsIHRoZSBwb3NzaWJpbGl0eSB0byBcInN3aXRjaFwiXG4gICAgICAgICAgICAgICAgICAgICAgLy8gdG8gYSBwcm9qZWN0LlxuICAgICAgICAgICAgICAgICAgICAgIHByb2plY3RLZXk9e3Byb3BzLnByb2plY3RLZXlGcm9tVXJsIHx8IHByZXZpb3VzUHJvamVjdEtleX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgaWYgKCFwcm9wcy51c2VyLmRlZmF1bHRQcm9qZWN0S2V5KSByZXR1cm4gbnVsbDtcbiAgICAgICAgICAgICAgcmV0dXJuIDxCYWNrVG9Qcm9qZWN0IHByb2plY3RLZXk9e3ByZXZpb3VzUHJvamVjdEtleX0gLz47XG4gICAgICAgICAgICB9KSgpfVxuICAgICAgICAgICAgey8qIFRoaXMgbm9kZSBpcyB1c2VkIGJ5IGEgcmVhY3QgcG9ydGFsICovfVxuICAgICAgICAgICAgPGRpdiBpZD17Q09OVEFJTkVSUy5MT0NBTEVfU1dJVENIRVJ9IC8+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPFNwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgaWQ9e1JFUVVFU1RTX0lOX0ZMSUdIVF9MT0FERVJfRE9NX0lEfVxuICAgICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgICAgICAgIGZsZXg6IDE7XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2IGlkPXtDT05UQUlORVJTLkxFRlRfT0ZfUFJPRklMRX0+PC9kaXY+XG4gICAgICAgIHtwcm9wcy51c2VyID8gKFxuICAgICAgICAgIDxVc2VyU2V0dGluZ3NNZW51XG4gICAgICAgICAgICBsYW5ndWFnZT17cHJvcHMudXNlci5sYW5ndWFnZX1cbiAgICAgICAgICAgIGZpcnN0TmFtZT17cHJvcHMudXNlci5maXJzdE5hbWV9XG4gICAgICAgICAgICBsYXN0TmFtZT17cHJvcHMudXNlci5sYXN0TmFtZX1cbiAgICAgICAgICAgIGdyYXZhdGFySGFzaD17cHJvcHMudXNlci5ncmF2YXRhckhhc2h9XG4gICAgICAgICAgICBlbWFpbD17cHJvcHMudXNlci5lbWFpbH1cbiAgICAgICAgICAvPlxuICAgICAgICApIDogKFxuICAgICAgICAgIDxMb2FkaW5nUGxhY2Vob2xkZXIgc2hhcGU9XCJkb3RcIiBzaXplPVwibFwiIC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5BcHBCYXIuZGlzcGxheU5hbWUgPSAnQXBwQmFyJztcblxuZXhwb3J0IGRlZmF1bHQgQXBwQmFyO1xuIl19 */",
387
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
384
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
388
385
  };
389
386
  const AppBar = props => {
390
- const previousProjectKey = getPreviousProjectKey(props.user?.defaultProjectKey ?? undefined);
387
+ var _props$user$defaultPr, _props$user;
388
+ const previousProjectKey = getPreviousProjectKey((_props$user$defaultPr = (_props$user = props.user) === null || _props$user === void 0 ? void 0 : _props$user.defaultProjectKey) !== null && _props$user$defaultPr !== void 0 ? _props$user$defaultPr : undefined);
391
389
  return jsxs("div", {
392
390
  css: /*#__PURE__*/css("background-color:", designTokens.colorSurface, ";box-shadow:0px 2px 5px 0px rgba(0, 0, 0, 0.15);padding:0 40px;min-height:", DIMENSIONS.header, ";position:relative;width:100%;z-index:20000;display:flex;align-items:center;justify-content:space-between;" + (process.env.NODE_ENV === "production" ? "" : ";label:AppBar;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFwcC1iYXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCYyIsImZpbGUiOiJhcHAtYmFyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IFByb2plY3RTdGFtcCB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLWZyb250ZW5kL2FwcGxpY2F0aW9uLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIGFzIHVpa2l0RGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgU3BhY2luZ3MgZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvc3BhY2luZ3MnO1xuaW1wb3J0IHsgQ09OVEFJTkVSUywgRElNRU5TSU9OUyB9IGZyb20gJy4uLy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgdHlwZSB7IFRGZXRjaExvZ2dlZEluVXNlclF1ZXJ5IH0gZnJvbSAnLi4vLi4vdHlwZXMvZ2VuZXJhdGVkL21jJztcbmltcG9ydCB7IGdldFByZXZpb3VzUHJvamVjdEtleSB9IGZyb20gJy4uLy4uL3V0aWxzJztcbmltcG9ydCBCYWNrVG9Qcm9qZWN0IGZyb20gJy4uL2JhY2stdG8tcHJvamVjdCc7XG5pbXBvcnQgTG9hZGluZ1BsYWNlaG9sZGVyIGZyb20gJy4uL2xvYWRpbmctcGxhY2Vob2xkZXInO1xuaW1wb3J0IFByb2plY3RTd2l0Y2hlciBmcm9tICcuLi9wcm9qZWN0LXN3aXRjaGVyJztcbmltcG9ydCB7IFJFUVVFU1RTX0lOX0ZMSUdIVF9MT0FERVJfRE9NX0lEIH0gZnJvbSAnLi4vcmVxdWVzdHMtaW4tZmxpZ2h0LWxvYWRlci9jb25zdGFudHMnO1xuaW1wb3J0IFVzZXJTZXR0aW5nc01lbnUgZnJvbSAnLi4vdXNlci1zZXR0aW5ncy1tZW51JztcblxudHlwZSBQcm9wcyA9IHtcbiAgdXNlcjogVEZldGNoTG9nZ2VkSW5Vc2VyUXVlcnlbJ3VzZXInXTtcbiAgcHJvamVjdEtleUZyb21Vcmw/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBBcHBCYXIgPSAocHJvcHM6IFByb3BzKSA9PiB7XG4gIGNvbnN0IHByZXZpb3VzUHJvamVjdEtleSA9IGdldFByZXZpb3VzUHJvamVjdEtleShcbiAgICBwcm9wcy51c2VyPy5kZWZhdWx0UHJvamVjdEtleSA/PyB1bmRlZmluZWRcbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxkaXZcbiAgICAgIGNzcz17Y3NzYFxuICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke3Vpa2l0RGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gICAgICAgIGJveC1zaGFkb3c6IDBweCAycHggNXB4IDBweCByZ2JhKDAsIDAsIDAsIDAuMTUpO1xuICAgICAgICBwYWRkaW5nOiAwIDQwcHg7XG4gICAgICAgIG1pbi1oZWlnaHQ6ICR7RElNRU5TSU9OUy5oZWFkZXJ9O1xuICAgICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gICAgICAgIHdpZHRoOiAxMDAlO1xuICAgICAgICB6LWluZGV4OiAyMDAwMDtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICAgICAgYH1cbiAgICAgIGRhdGEtdGVzdD1cInRvcC1uYXZpZ2F0aW9uXCJcbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIGZsb2F0OiByaWdodDtcbiAgICAgICAgICBmb250LXdlaWdodDogbm9ybWFsO1xuICAgICAgICAgIGZvbnQtc2l6ZTogMXJlbTtcbiAgICAgICAgICBtYXJnaW4tcmlnaHQ6ICR7dWlraXREZXNpZ25Ub2tlbnMuc3BhY2luZzU1fTtcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxTcGFjaW5ncy5JbmxpbmUgc2NhbGU9XCJtXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgICAgICBnYXA6ICR7dWlraXREZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgICAgICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICAgIGB9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgeygoKSA9PiB7XG4gICAgICAgICAgICAgIGlmICghcHJvcHMudXNlcikge1xuICAgICAgICAgICAgICAgIHJldHVybiA8TG9hZGluZ1BsYWNlaG9sZGVyIHNoYXBlPVwicmVjdFwiIHNpemU9XCJzXCIgLz47XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgLy8gVGhlIGA8UHJvamVjdFN3aXRjaGVyPmAgc2hvdWxkIGJlIHJlbmRlcmVkIG9ubHkgaWYgdGhlXG4gICAgICAgICAgICAgIC8vIHVzZXIgaXMgZmV0Y2hlZCBhbmQgdGhlIHVzZXIgaGFzIHByb2plY3RzIHdoaWxlIHRoZSBhcHAgcnVucyBpbiBhbiBwcm9qZWN0IGNvbnRleHQuXG4gICAgICAgICAgICAgIGlmIChwcm9wcy51c2VyLnByb2plY3RzLnRvdGFsID4gMCAmJiBwcm9wcy5wcm9qZWN0S2V5RnJvbVVybCkge1xuICAgICAgICAgICAgICAgIGNvbnN0IHNlbGVjdGVkUHJvamVjdCA9IHByb3BzLnVzZXIucHJvamVjdHMucmVzdWx0cy5maW5kKFxuICAgICAgICAgICAgICAgICAgKHByb2plY3QpID0+IHByb2plY3Qua2V5ID09PSBwcm9wcy5wcm9qZWN0S2V5RnJvbVVybFxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICAgICAgICAgICAgICBnYXA6ICR7dWlraXREZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcbiAgICAgICAgICAgICAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICAgICAgICAgICAgICBgfVxuICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICB7c2VsZWN0ZWRQcm9qZWN0Py5pc1Byb2R1Y3Rpb25Qcm9qZWN0ICYmIChcbiAgICAgICAgICAgICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgICAgICAgICAgICAgaGVpZ2h0OiAyMnB4O1xuICAgICAgICAgICAgICAgICAgICAgICAgYH1cbiAgICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICA8UHJvamVjdFN0YW1wLklzUHJvZHVjdGlvbiAvPlxuICAgICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgICAgICAgICA8UHJvamVjdFN3aXRjaGVyXG4gICAgICAgICAgICAgICAgICAgICAgLy8gSW4gdGhpcyBjYXNlIGl0J3Mgbm90IG5lY2Vzc2FyeSB0byBjaGVjayBpZiB0aGUgYHByb2plY3RLZXlgIHBhcmFtXG4gICAgICAgICAgICAgICAgICAgICAgLy8gaXMgaW5jbHVkZWQgaW4gdGhlIGxpc3Qgb2YgcHJvamVjdHMuIEluIHN1Y2ggY2FzZVxuICAgICAgICAgICAgICAgICAgICAgIC8vIHRoZSBkcm9wZG93biB3aWxsIHN0aWxsIGJlIHJlbmRlcmVkIGJ1dCBubyBwcm9qZWN0IHdpbGwgYmUgc2VsZWN0ZWQuXG4gICAgICAgICAgICAgICAgICAgICAgLy8gVGhpcyBpcyBmaW5lIGJlY2FzZSB0aGUgdXNlciBoYXMgc3RpbGwgdGhlIHBvc3NpYmlsaXR5IHRvIFwic3dpdGNoXCJcbiAgICAgICAgICAgICAgICAgICAgICAvLyB0byBhIHByb2plY3QuXG4gICAgICAgICAgICAgICAgICAgICAgcHJvamVjdEtleT17cHJvcHMucHJvamVjdEtleUZyb21VcmwgfHwgcHJldmlvdXNQcm9qZWN0S2V5fVxuICAgICAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICBpZiAoIXByb3BzLnVzZXIuZGVmYXVsdFByb2plY3RLZXkpIHJldHVybiBudWxsO1xuICAgICAgICAgICAgICByZXR1cm4gPEJhY2tUb1Byb2plY3QgcHJvamVjdEtleT17cHJldmlvdXNQcm9qZWN0S2V5fSAvPjtcbiAgICAgICAgICAgIH0pKCl9XG4gICAgICAgICAgICB7LyogVGhpcyBub2RlIGlzIHVzZWQgYnkgYSByZWFjdCBwb3J0YWwgKi99XG4gICAgICAgICAgICA8ZGl2IGlkPXtDT05UQUlORVJTLkxPQ0FMRV9TV0lUQ0hFUn0gLz5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8U3BhY2luZ3MuSW5saW5lPlxuICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICBpZD17UkVRVUVTVFNfSU5fRkxJR0hUX0xPQURFUl9ET01fSUR9XG4gICAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgICAgICAgZmxleDogMTtcbiAgICAgICAgICAgICAgYH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9TcGFjaW5ncy5JbmxpbmU+XG4gICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGB9XG4gICAgICA+XG4gICAgICAgIDxkaXYgaWQ9e0NPTlRBSU5FUlMuTEVGVF9PRl9QUk9GSUxFfT48L2Rpdj5cbiAgICAgICAge3Byb3BzLnVzZXIgPyAoXG4gICAgICAgICAgPFVzZXJTZXR0aW5nc01lbnVcbiAgICAgICAgICAgIGxhbmd1YWdlPXtwcm9wcy51c2VyLmxhbmd1YWdlfVxuICAgICAgICAgICAgZmlyc3ROYW1lPXtwcm9wcy51c2VyLmZpcnN0TmFtZX1cbiAgICAgICAgICAgIGxhc3ROYW1lPXtwcm9wcy51c2VyLmxhc3ROYW1lfVxuICAgICAgICAgICAgZ3JhdmF0YXJIYXNoPXtwcm9wcy51c2VyLmdyYXZhdGFySGFzaH1cbiAgICAgICAgICAgIGVtYWlsPXtwcm9wcy51c2VyLmVtYWlsfVxuICAgICAgICAgIC8+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPExvYWRpbmdQbGFjZWhvbGRlciBzaGFwZT1cImRvdFwiIHNpemU9XCJsXCIgLz5cbiAgICAgICAgKX1cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICApO1xufTtcbkFwcEJhci5kaXNwbGF5TmFtZSA9ICdBcHBCYXInO1xuXG5leHBvcnQgZGVmYXVsdCBBcHBCYXI7XG4iXX0= */"),
393
391
  "data-test": "top-navigation",
@@ -412,7 +410,7 @@ const AppBar = props => {
412
410
  const selectedProject = _findInstanceProperty(_context = props.user.projects.results).call(_context, project => project.key === props.projectKeyFromUrl);
413
411
  return jsxs("div", {
414
412
  css: /*#__PURE__*/css("display:flex;gap:", designTokens.spacing20, ";align-items:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:AppBar;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFwcC1iYXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFFNEIiLCJmaWxlIjoiYXBwLWJhci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyBQcm9qZWN0U3RhbXAgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC9hcHBsaWNhdGlvbi1jb21wb25lbnRzJztcbmltcG9ydCB7IGRlc2lnblRva2VucyBhcyB1aWtpdERlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IFNwYWNpbmdzIGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3NwYWNpbmdzJztcbmltcG9ydCB7IENPTlRBSU5FUlMsIERJTUVOU0lPTlMgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHR5cGUgeyBURmV0Y2hMb2dnZWRJblVzZXJRdWVyeSB9IGZyb20gJy4uLy4uL3R5cGVzL2dlbmVyYXRlZC9tYyc7XG5pbXBvcnQgeyBnZXRQcmV2aW91c1Byb2plY3RLZXkgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgQmFja1RvUHJvamVjdCBmcm9tICcuLi9iYWNrLXRvLXByb2plY3QnO1xuaW1wb3J0IExvYWRpbmdQbGFjZWhvbGRlciBmcm9tICcuLi9sb2FkaW5nLXBsYWNlaG9sZGVyJztcbmltcG9ydCBQcm9qZWN0U3dpdGNoZXIgZnJvbSAnLi4vcHJvamVjdC1zd2l0Y2hlcic7XG5pbXBvcnQgeyBSRVFVRVNUU19JTl9GTElHSFRfTE9BREVSX0RPTV9JRCB9IGZyb20gJy4uL3JlcXVlc3RzLWluLWZsaWdodC1sb2FkZXIvY29uc3RhbnRzJztcbmltcG9ydCBVc2VyU2V0dGluZ3NNZW51IGZyb20gJy4uL3VzZXItc2V0dGluZ3MtbWVudSc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIHVzZXI6IFRGZXRjaExvZ2dlZEluVXNlclF1ZXJ5Wyd1c2VyJ107XG4gIHByb2plY3RLZXlGcm9tVXJsPzogc3RyaW5nO1xufTtcblxuY29uc3QgQXBwQmFyID0gKHByb3BzOiBQcm9wcykgPT4ge1xuICBjb25zdCBwcmV2aW91c1Byb2plY3RLZXkgPSBnZXRQcmV2aW91c1Byb2plY3RLZXkoXG4gICAgcHJvcHMudXNlcj8uZGVmYXVsdFByb2plY3RLZXkgPz8gdW5kZWZpbmVkXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2XG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHt1aWtpdERlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICAgICAgICBib3gtc2hhZG93OiAwcHggMnB4IDVweCAwcHggcmdiYSgwLCAwLCAwLCAwLjE1KTtcbiAgICAgICAgcGFkZGluZzogMCA0MHB4O1xuICAgICAgICBtaW4taGVpZ2h0OiAke0RJTUVOU0lPTlMuaGVhZGVyfTtcbiAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgICAgei1pbmRleDogMjAwMDA7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgIGB9XG4gICAgICBkYXRhLXRlc3Q9XCJ0b3AtbmF2aWdhdGlvblwiXG4gICAgPlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBmbG9hdDogcmlnaHQ7XG4gICAgICAgICAgZm9udC13ZWlnaHQ6IG5vcm1hbDtcbiAgICAgICAgICBmb250LXNpemU6IDFyZW07XG4gICAgICAgICAgbWFyZ2luLXJpZ2h0OiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmc1NX07XG4gICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8U3BhY2luZ3MuSW5saW5lIHNjYWxlPVwibVwiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgICAgICAgZ2FwOiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmczMH07XG4gICAgICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICAgICAgICBgfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHsoKCkgPT4ge1xuICAgICAgICAgICAgICBpZiAoIXByb3BzLnVzZXIpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gPExvYWRpbmdQbGFjZWhvbGRlciBzaGFwZT1cInJlY3RcIiBzaXplPVwic1wiIC8+O1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIC8vIFRoZSBgPFByb2plY3RTd2l0Y2hlcj5gIHNob3VsZCBiZSByZW5kZXJlZCBvbmx5IGlmIHRoZVxuICAgICAgICAgICAgICAvLyB1c2VyIGlzIGZldGNoZWQgYW5kIHRoZSB1c2VyIGhhcyBwcm9qZWN0cyB3aGlsZSB0aGUgYXBwIHJ1bnMgaW4gYW4gcHJvamVjdCBjb250ZXh0LlxuICAgICAgICAgICAgICBpZiAocHJvcHMudXNlci5wcm9qZWN0cy50b3RhbCA+IDAgJiYgcHJvcHMucHJvamVjdEtleUZyb21VcmwpIHtcbiAgICAgICAgICAgICAgICBjb25zdCBzZWxlY3RlZFByb2plY3QgPSBwcm9wcy51c2VyLnByb2plY3RzLnJlc3VsdHMuZmluZChcbiAgICAgICAgICAgICAgICAgIChwcm9qZWN0KSA9PiBwcm9qZWN0LmtleSA9PT0gcHJvcHMucHJvamVjdEtleUZyb21VcmxcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgICAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgICAgICAgICAgICAgICAgZ2FwOiAke3Vpa2l0RGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gICAgICAgICAgICAgICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAgICAgICAgICAgICAgYH1cbiAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAge3NlbGVjdGVkUHJvamVjdD8uaXNQcm9kdWN0aW9uUHJvamVjdCAmJiAoXG4gICAgICAgICAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICAgICAgICAgY3NzPXtjc3NgXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGhlaWdodDogMjJweDtcbiAgICAgICAgICAgICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgPFByb2plY3RTdGFtcC5Jc1Byb2R1Y3Rpb24gLz5cbiAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgICAgICAgPFByb2plY3RTd2l0Y2hlclxuICAgICAgICAgICAgICAgICAgICAgIC8vIEluIHRoaXMgY2FzZSBpdCdzIG5vdCBuZWNlc3NhcnkgdG8gY2hlY2sgaWYgdGhlIGBwcm9qZWN0S2V5YCBwYXJhbVxuICAgICAgICAgICAgICAgICAgICAgIC8vIGlzIGluY2x1ZGVkIGluIHRoZSBsaXN0IG9mIHByb2plY3RzLiBJbiBzdWNoIGNhc2VcbiAgICAgICAgICAgICAgICAgICAgICAvLyB0aGUgZHJvcGRvd24gd2lsbCBzdGlsbCBiZSByZW5kZXJlZCBidXQgbm8gcHJvamVjdCB3aWxsIGJlIHNlbGVjdGVkLlxuICAgICAgICAgICAgICAgICAgICAgIC8vIFRoaXMgaXMgZmluZSBiZWNhc2UgdGhlIHVzZXIgaGFzIHN0aWxsIHRoZSBwb3NzaWJpbGl0eSB0byBcInN3aXRjaFwiXG4gICAgICAgICAgICAgICAgICAgICAgLy8gdG8gYSBwcm9qZWN0LlxuICAgICAgICAgICAgICAgICAgICAgIHByb2plY3RLZXk9e3Byb3BzLnByb2plY3RLZXlGcm9tVXJsIHx8IHByZXZpb3VzUHJvamVjdEtleX1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgaWYgKCFwcm9wcy51c2VyLmRlZmF1bHRQcm9qZWN0S2V5KSByZXR1cm4gbnVsbDtcbiAgICAgICAgICAgICAgcmV0dXJuIDxCYWNrVG9Qcm9qZWN0IHByb2plY3RLZXk9e3ByZXZpb3VzUHJvamVjdEtleX0gLz47XG4gICAgICAgICAgICB9KSgpfVxuICAgICAgICAgICAgey8qIFRoaXMgbm9kZSBpcyB1c2VkIGJ5IGEgcmVhY3QgcG9ydGFsICovfVxuICAgICAgICAgICAgPGRpdiBpZD17Q09OVEFJTkVSUy5MT0NBTEVfU1dJVENIRVJ9IC8+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPFNwYWNpbmdzLklubGluZT5cbiAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgaWQ9e1JFUVVFU1RTX0lOX0ZMSUdIVF9MT0FERVJfRE9NX0lEfVxuICAgICAgICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgICAgICAgIGZsZXg6IDE7XG4gICAgICAgICAgICAgIGB9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvU3BhY2luZ3MuSW5saW5lPlxuICAgICAgICA8L1NwYWNpbmdzLklubGluZT5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdlxuICAgICAgICBjc3M9e2Nzc2BcbiAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBgfVxuICAgICAgPlxuICAgICAgICA8ZGl2IGlkPXtDT05UQUlORVJTLkxFRlRfT0ZfUFJPRklMRX0+PC9kaXY+XG4gICAgICAgIHtwcm9wcy51c2VyID8gKFxuICAgICAgICAgIDxVc2VyU2V0dGluZ3NNZW51XG4gICAgICAgICAgICBsYW5ndWFnZT17cHJvcHMudXNlci5sYW5ndWFnZX1cbiAgICAgICAgICAgIGZpcnN0TmFtZT17cHJvcHMudXNlci5maXJzdE5hbWV9XG4gICAgICAgICAgICBsYXN0TmFtZT17cHJvcHMudXNlci5sYXN0TmFtZX1cbiAgICAgICAgICAgIGdyYXZhdGFySGFzaD17cHJvcHMudXNlci5ncmF2YXRhckhhc2h9XG4gICAgICAgICAgICBlbWFpbD17cHJvcHMudXNlci5lbWFpbH1cbiAgICAgICAgICAvPlxuICAgICAgICApIDogKFxuICAgICAgICAgIDxMb2FkaW5nUGxhY2Vob2xkZXIgc2hhcGU9XCJkb3RcIiBzaXplPVwibFwiIC8+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5BcHBCYXIuZGlzcGxheU5hbWUgPSAnQXBwQmFyJztcblxuZXhwb3J0IGRlZmF1bHQgQXBwQmFyO1xuIl19 */"),
415
- children: [selectedProject?.isProductionProject && jsx("div", {
413
+ children: [(selectedProject === null || selectedProject === void 0 ? void 0 : selectedProject.isProductionProject) && jsx("div", {
416
414
  css: _ref3$1,
417
415
  children: jsx(ProjectStamp.IsProduction, {})
418
416
  }), jsx(ProjectSwitcher
@@ -555,207 +553,11 @@ const FetchUser = props => {
555
553
  };
556
554
  FetchUser.displayName = 'FetchUser';
557
555
 
558
- const Navbar = /*#__PURE__*/lazy(() => import('./navbar-844d350d.esm.js' /* webpackChunkName: "navbar" */));
559
-
560
- const ProjectContainer = /*#__PURE__*/lazy(() => import('./project-container-fba09841.esm.js' /* webpackChunkName: "project-container" */));
561
-
562
- const getSelectedDataLocaleForProject = projectLocales => {
563
- const cachedDataLocale = window.localStorage.getItem(STORAGE_KEYS.SELECTED_DATA_LOCALE);
564
- // Make sure the cached locale is listed in the selected project
565
- const isCachedDataLocaleIncludedInProjectLanguages = _includesInstanceProperty(projectLocales).call(projectLocales, cachedDataLocale || '');
566
- if (cachedDataLocale && isCachedDataLocaleIncludedInProjectLanguages) return cachedDataLocale;
567
- // Pick the first locale from the list
568
- const defaultDataLocaleForProject = projectLocales[0];
569
- // Cache it
570
- window.localStorage.setItem(STORAGE_KEYS.SELECTED_DATA_LOCALE, defaultDataLocaleForProject);
571
- return defaultDataLocaleForProject;
572
- };
573
- const ProjectDataLocale = props => {
574
- const _useState = useState(getSelectedDataLocaleForProject(props.locales)),
575
- _useState2 = _slicedToArray(_useState, 2),
576
- locale = _useState2[0],
577
- setLocale = _useState2[1];
578
- const handleSetProjectDataLocale = useCallback(locale => {
579
- setLocale(locale);
580
- // Cache it
581
- window.localStorage.setItem(STORAGE_KEYS.SELECTED_DATA_LOCALE, locale);
582
- }, []);
583
- return jsx(Fragment, {
584
- children: props.children({
585
- locale,
586
- setProjectDataLocale: handleSetProjectDataLocale
587
- })
588
- });
589
- };
590
- ProjectDataLocale.displayName = 'ProjectDataLocale';
591
-
592
- function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? _Reflect$construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
593
- function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
594
- let ErrorBoundary = /*#__PURE__*/function (_Component) {
595
- function ErrorBoundary() {
596
- var _this;
597
- _classCallCheck(this, ErrorBoundary);
598
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
599
- args[_key] = arguments[_key];
600
- }
601
- _this = _callSuper(this, ErrorBoundary, [...args]);
602
- _this.state = {
603
- hasError: false
604
- };
605
- return _this;
606
- }
607
- _inherits(ErrorBoundary, _Component);
608
- return _createClass(ErrorBoundary, [{
609
- key: "componentDidUpdate",
610
- value: function componentDidUpdate(prevProps) {
611
- const hasRouteChanged = prevProps.pathname !== this.props.pathname;
612
- this.setState(prevState => hasRouteChanged && prevState.hasError ? {
613
- hasError: false
614
- } : null);
615
- }
616
- }, {
617
- key: "componentDidCatch",
618
- value: function componentDidCatch(error, errorInfo) {
619
- // Note: In development mode componentDidCatch is not based on try-catch
620
- // to catch exceptions. Thus exceptions caught here will also be caught in
621
- // the global `error` event listener (setup-global-error-listener.js).
622
- // see: https://github.com/facebook/react/issues/10474
623
- reportErrorToSentry(error, {
624
- extra: errorInfo
625
- });
626
- }
627
- }, {
628
- key: "render",
629
- value: function render() {
630
- if (this.state.hasError) {
631
- return jsx(ErrorApologizer, {});
632
- }
633
- return jsx(Fragment, {
634
- children: this.props.children
635
- });
636
- }
637
- }], [{
638
- key: "getDerivedStateFromError",
639
- value: function getDerivedStateFromError(/* error */
640
- ) {
641
- // Update state so the next render will show the fallback UI.
642
- return {
643
- hasError: true
644
- };
645
- }
646
- }]);
647
- }(Component);
556
+ const Navbar = /*#__PURE__*/lazy(() => import('./navbar-88e0fd1f.esm.js' /* webpackChunkName: "navbar" */));
648
557
 
649
- function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
650
- const ButlerContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
651
- target: "e1fuwyk10"
652
- } : {
653
- target: "e1fuwyk10",
654
- label: "ButlerContainer"
655
- })(process.env.NODE_ENV === "production" ? {
656
- name: "xvk698",
657
- styles: "position:absolute;left:0;bottom:0;top:0;right:0;background-color:rgba(0, 0, 0, 0.35);z-index:20001"
658
- } : {
659
- name: "xvk698",
660
- styles: "position:absolute;left:0;bottom:0;top:0;right:0;background-color:rgba(0, 0, 0, 0.35);z-index:20001/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJ1dGxlci1jb250YWluZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVrQyIsImZpbGUiOiJidXRsZXItY29udGFpbmVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgQnV0bGVyQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAwO1xuICBib3R0b206IDA7XG4gIHRvcDogMDtcbiAgcmlnaHQ6IDA7XG4gIGJhY2tncm91bmQtY29sb3I6IHJnYmEoMCwgMCwgMCwgMC4zNSk7XG4gIHotaW5kZXg6IDIwMDAxO1xuYDtcblxuZXhwb3J0IGRlZmF1bHQgQnV0bGVyQ29udGFpbmVyO1xuIl19 */",
661
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
662
- });
558
+ const ProjectContainer = /*#__PURE__*/lazy(() => import('./project-container-7fce9e66.esm.js' /* webpackChunkName: "project-container" */));
663
559
 
664
- var pimIndexerStates = {
665
- // we did not check yet
666
- UNCHECKED: 'UNCHECKED',
667
- // the project is indexed by pim-indexer
668
- INDEXED: 'INDEXED',
669
- // the project is not indexed by pim-indexer
670
- NOT_INDEXED: 'NOT_INDEXED'
671
- };
672
-
673
- const QuickAccess = /*#__PURE__*/lazy(() => import('./quick-access-dfc1f8a9.esm.js' /* webpackChunkName: "quick-access" */));
674
- const QuickAccessTrigger = props => {
675
- const _useState = useState(false),
676
- _useState2 = _slicedToArray(_useState, 2),
677
- isVisible = _useState2[0],
678
- setIsVisible = _useState2[1];
679
- const open = useCallback(() => {
680
- setIsVisible(true);
681
- }, []);
682
- const close = useCallback(() => {
683
- setIsVisible(false);
684
- }, []);
685
- // We store the information of whether a project is indexed by pim-indexer,
686
- // to avoid having to refetch that information every time Quick Access is
687
- // opened. We can't move the information to the quick-access.js component
688
- // as that component unmounts and would lose its state.
689
- //
690
- // We need to know whether a project is indexed by pim-indexer to know
691
- // whether we should query pim-search or whether we can skip that request.
692
- //
693
- // We don't need to update this information when the project key changes,
694
- // as changing a project always results in a full page reload anyways.
695
- const _useState3 = useState(pimIndexerStates.UNCHECKED),
696
- _useState4 = _slicedToArray(_useState3, 2),
697
- pimIndexerState = _useState4[0],
698
- setPimIndexerState = _useState4[1];
699
- const handlePimIndexerStateChange = useCallback(nextPimIndexerState => {
700
- setPimIndexerState(nextPimIndexerState);
701
- }, []);
702
- const keyHandler = useCallback(event => {
703
- const hotKey = 'f';
704
- // avoid interfering with any key combinations using modifier keys
705
- if (event.ctrlKey || event.altKey || event.shiftKey || event.metaKey) return;
706
-
707
- // Let users close QuickAccess by pressing Escape
708
- if (event.key === 'Escape' && event.target.id === 'quick-access-search-input') {
709
- close();
710
- return;
711
- }
712
-
713
- // Avoid interfering with any other elements. We only
714
- // open the QuickAccess when nothing was focused, so target is document.body
715
- if (event.target !== document.body &&
716
- // tabIndex="-1" has a special meaning
717
- // It will make the element focusable, while hiding it from the
718
- // navigation. It is typically used for modals and overlays.
719
- // react-modal uses it for example. We want to treat those elements
720
- // similar to document.body.
721
- // See https://stackoverflow.com/a/32912224
722
- event.target.getAttribute('tabindex') !== '-1' &&
723
- // Do not prevent Quick Access from opening when a link has focus
724
- event.target.nodeName !== 'A') return;
725
- if (event.key === hotKey) {
726
- if (!isVisible) {
727
- // prevent the letter from appearing in the search input when
728
- // it is the key press that lead to opening Quick Access
729
- event.preventDefault();
730
- }
731
- open();
732
- }
733
- return;
734
- }, [close, isVisible, open]);
735
- useEffect(() => {
736
- document.addEventListener('keydown', keyHandler);
737
- return () => {
738
- document.removeEventListener('keydown', keyHandler);
739
- };
740
- }, [keyHandler]);
741
- if (!isVisible) return null;
742
- return jsx(ErrorBoundary, {
743
- children: jsx(Suspense, {
744
- fallback: jsx(ButlerContainer, {
745
- tabIndex: -1
746
- }),
747
- children: jsx(QuickAccess, {
748
- pimIndexerState: pimIndexerState,
749
- onPimIndexerStateChange: handlePimIndexerStateChange,
750
- onClose: close,
751
- onChangeProjectDataLocale: props.onChangeProjectDataLocale
752
- })
753
- })
754
- });
755
- };
756
- QuickAccessTrigger.displayName = 'QuickAccessTrigger';
757
-
758
- const RedirectToLogout = /*#__PURE__*/lazy(() => import('./redirect-to-logout-5db48f16.esm.js' /* webpackChunkName: "redirect-to-logout" */));
560
+ const RedirectToLogout = /*#__PURE__*/lazy(() => import('./redirect-to-logout-5d5fc361.esm.js' /* webpackChunkName: "redirect-to-logout" */));
759
561
 
760
562
  const RedirectToProjectCreate = /*#__PURE__*/lazy(() => import('./redirect-to-project-create-9249e554.esm.js' /* webpackChunkName: "redirect-to-project-create" */));
761
563
 
@@ -767,15 +569,16 @@ var AllFeaturesQuery = { kind: "Document", definitions: [{ kind: "OperationDefin
767
569
  // is no need to be concerned about security.
768
570
  const ldClientSideIdProduction = '5979d95f6040390cd07b5e01';
769
571
  function getUserContextForLaunchDarklyAdapter(user, projectKey) {
572
+ var _user$launchdarklyTra, _user$launchdarklyTra2, _user$launchdarklyTra3, _user$launchdarklyTra4, _user$launchdarklyTra5;
770
573
  return {
771
574
  kind: 'user',
772
- key: user?.id,
773
- project: projectKey ?? '',
774
- id: user?.launchdarklyTrackingId ?? '',
775
- team: user?.launchdarklyTrackingTeam ?? [],
776
- group: user?.launchdarklyTrackingGroup ?? '',
777
- subgroup: user?.launchdarklyTrackingSubgroup ?? '',
778
- cloudEnvironment: user?.launchdarklyTrackingCloudEnvironment ?? ''
575
+ key: user === null || user === void 0 ? void 0 : user.id,
576
+ project: projectKey !== null && projectKey !== void 0 ? projectKey : '',
577
+ id: (_user$launchdarklyTra = user === null || user === void 0 ? void 0 : user.launchdarklyTrackingId) !== null && _user$launchdarklyTra !== void 0 ? _user$launchdarklyTra : '',
578
+ team: (_user$launchdarklyTra2 = user === null || user === void 0 ? void 0 : user.launchdarklyTrackingTeam) !== null && _user$launchdarklyTra2 !== void 0 ? _user$launchdarklyTra2 : [],
579
+ group: (_user$launchdarklyTra3 = user === null || user === void 0 ? void 0 : user.launchdarklyTrackingGroup) !== null && _user$launchdarklyTra3 !== void 0 ? _user$launchdarklyTra3 : '',
580
+ subgroup: (_user$launchdarklyTra4 = user === null || user === void 0 ? void 0 : user.launchdarklyTrackingSubgroup) !== null && _user$launchdarklyTra4 !== void 0 ? _user$launchdarklyTra4 : '',
581
+ cloudEnvironment: (_user$launchdarklyTra5 = user === null || user === void 0 ? void 0 : user.launchdarklyTrackingCloudEnvironment) !== null && _user$launchdarklyTra5 !== void 0 ? _user$launchdarklyTra5 : ''
779
582
  };
780
583
  }
781
584
  const parseFlags = fetchedFlags => {
@@ -807,47 +610,51 @@ const SetupFlopFlipProvider = props => {
807
610
  }
808
611
  }, [enableLongLivedFeatureFlags]);
809
612
  const defaultFlags = useMemo(() => _objectSpread$9(_objectSpread$9({}, featureFlags.DEFAULT_FLAGS), props.defaultFlags), [props.defaultFlags]);
810
- const adapterArgs = useMemo(() => ({
811
- user: {
812
- key: props.user?.id
813
- },
814
- launchdarkly: {
815
- cacheIdentifier: cacheIdentifiers.local,
816
- cacheMode: getCacheMode(adapterIdentifiers.launchdarkly),
817
- sdk: {
818
- // Allow to overwrite the client ID, passed via the `additionalEnv` properties
819
- // of the application config.
820
- // This is mostly useful for internal usage on our staging environments.
821
- clientSideId: props.ldClientSideId ?? ldClientSideIdProduction,
822
- clientOptions: {
823
- sendEventsOnlyForVariation: true
824
- }
825
- },
826
- flags,
827
- context: getUserContextForLaunchDarklyAdapter(props.user, props.projectKey)
828
- },
829
- http: {
830
- // polling interval set to 15 minutes
831
- pollingIntervalMs: 1000 * 60 * 15,
832
- cacheIdentifier: cacheIdentifiers.local,
833
- cacheMode: getCacheMode(adapterIdentifiers.http),
613
+ const adapterArgs = useMemo(() => {
614
+ var _props$user, _props$ldClientSideId, _props$user2;
615
+ return {
834
616
  user: {
835
- key: props.user?.id
617
+ key: (_props$user = props.user) === null || _props$user === void 0 ? void 0 : _props$user.id
836
618
  },
837
- execute: async adapterArgs => {
838
- const response = await apolloClient.query({
839
- query: AllFeaturesQuery,
840
- errorPolicy: 'ignore',
841
- fetchPolicy: 'network-only',
842
- context: {
843
- target: GRAPHQL_TARGETS.MERCHANT_CENTER_BACKEND,
844
- projectKey: adapterArgs.user?.project
619
+ launchdarkly: {
620
+ cacheIdentifier: cacheIdentifiers.local,
621
+ cacheMode: getCacheMode(adapterIdentifiers.launchdarkly),
622
+ sdk: {
623
+ // Allow to overwrite the client ID, passed via the `additionalEnv` properties
624
+ // of the application config.
625
+ // This is mostly useful for internal usage on our staging environments.
626
+ clientSideId: (_props$ldClientSideId = props.ldClientSideId) !== null && _props$ldClientSideId !== void 0 ? _props$ldClientSideId : ldClientSideIdProduction,
627
+ clientOptions: {
628
+ sendEventsOnlyForVariation: true
845
629
  }
846
- });
847
- return parseFlags(response.data);
630
+ },
631
+ flags,
632
+ context: getUserContextForLaunchDarklyAdapter(props.user, props.projectKey)
633
+ },
634
+ http: {
635
+ // polling interval set to 15 minutes
636
+ pollingIntervalMs: 1000 * 60 * 15,
637
+ cacheIdentifier: cacheIdentifiers.local,
638
+ cacheMode: getCacheMode(adapterIdentifiers.http),
639
+ user: {
640
+ key: (_props$user2 = props.user) === null || _props$user2 === void 0 ? void 0 : _props$user2.id
641
+ },
642
+ execute: async adapterArgs => {
643
+ var _adapterArgs$user;
644
+ const response = await apolloClient.query({
645
+ query: AllFeaturesQuery,
646
+ errorPolicy: 'ignore',
647
+ fetchPolicy: 'network-only',
648
+ context: {
649
+ target: GRAPHQL_TARGETS.MERCHANT_CENTER_BACKEND,
650
+ projectKey: (_adapterArgs$user = adapterArgs.user) === null || _adapterArgs$user === void 0 ? void 0 : _adapterArgs$user.project
651
+ }
652
+ });
653
+ return parseFlags(response.data);
654
+ }
848
655
  }
849
- }
850
- }), [apolloClient, flags, props.ldClientSideId, props.projectKey, props.user]);
656
+ };
657
+ }, [apolloClient, flags, props.ldClientSideId, props.projectKey, props.user]);
851
658
 
852
659
  /**
853
660
  * The `<ApplicationShell />` tests itself. When it does so it can not setup and use
@@ -905,7 +712,7 @@ const MainContainer = /*#__PURE__*/_styled("main", process.env.NODE_ENV === "pro
905
712
  styles: "grid-column:2/3;grid-row:3/4;min-width:0;overflow-x:hidden;overflow-y:scroll;display:flex;flex-direction:column;position:relative"
906
713
  } : {
907
714
  name: "evthls",
908
- styles: "grid-column:2/3;grid-row:3/4;min-width:0;overflow-x:hidden;overflow-y:scroll;display:flex;flex-direction:column;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AA4EwC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport ProjectDataLocale from '../project-data-locale';\nimport QuickAccess from '../quick-access';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <Route>\n                          {() => {\n                            if (!projectKeyFromUrl) return <QuickAccess />;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isProjectLoading, project }) => {\n                                  if (isProjectLoading || !project) return null;\n\n                                  // when used outside of a project context,\n                                  // or when the project is expired or supsended\n                                  const shouldUseProjectContext = !(\n                                    (project.suspension &&\n                                      project.suspension.isActive) ||\n                                    (project.expiry && project.expiry.isActive)\n                                  );\n\n                                  if (!shouldUseProjectContext)\n                                    return <QuickAccess />;\n\n                                  return (\n                                    <ProjectDataLocale\n                                      locales={project.languages}\n                                    >\n                                      {({\n                                        locale: dataLocale,\n                                        setProjectDataLocale,\n                                      }) => (\n                                        <ApplicationContextProvider\n                                          user={normalizedUser}\n                                          project={project}\n                                          projectDataLocale={dataLocale}\n                                          environment={applicationEnvironment}\n                                        >\n                                          <QuickAccess\n                                            onChangeProjectDataLocale={\n                                              setProjectDataLocale\n                                            }\n                                          />\n                                        </ApplicationContextProvider>\n                                      )}\n                                    </ProjectDataLocale>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          }}\n                        </Route>\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
715
+ styles: "grid-column:2/3;grid-row:3/4;min-width:0;overflow-x:hidden;overflow-y:scroll;display:flex;flex-direction:column;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AA0EwC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
909
716
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
910
717
  });
911
718
 
@@ -918,7 +725,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
918
725
  styles: "flex-grow:1;display:flex;flex-direction:column;position:relative;>*:not(:first-of-type){flex-grow:1;display:flex;flex-direction:column;}"
919
726
  } : {
920
727
  name: "1y4p4ln-ApplicationShellAuthenticated",
921
- styles: "flex-grow:1;display:flex;flex-direction:column;position:relative;>*:not(:first-of-type){flex-grow:1;display:flex;flex-direction:column;};label:ApplicationShellAuthenticated;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AAqXsC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport ProjectDataLocale from '../project-data-locale';\nimport QuickAccess from '../quick-access';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <Route>\n                          {() => {\n                            if (!projectKeyFromUrl) return <QuickAccess />;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isProjectLoading, project }) => {\n                                  if (isProjectLoading || !project) return null;\n\n                                  // when used outside of a project context,\n                                  // or when the project is expired or supsended\n                                  const shouldUseProjectContext = !(\n                                    (project.suspension &&\n                                      project.suspension.isActive) ||\n                                    (project.expiry && project.expiry.isActive)\n                                  );\n\n                                  if (!shouldUseProjectContext)\n                                    return <QuickAccess />;\n\n                                  return (\n                                    <ProjectDataLocale\n                                      locales={project.languages}\n                                    >\n                                      {({\n                                        locale: dataLocale,\n                                        setProjectDataLocale,\n                                      }) => (\n                                        <ApplicationContextProvider\n                                          user={normalizedUser}\n                                          project={project}\n                                          projectDataLocale={dataLocale}\n                                          environment={applicationEnvironment}\n                                        >\n                                          <QuickAccess\n                                            onChangeProjectDataLocale={\n                                              setProjectDataLocale\n                                            }\n                                          />\n                                        </ApplicationContextProvider>\n                                      )}\n                                    </ProjectDataLocale>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          }}\n                        </Route>\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
728
+ styles: "flex-grow:1;display:flex;flex-direction:column;position:relative;>*:not(:first-of-type){flex-grow:1;display:flex;flex-direction:column;};label:ApplicationShellAuthenticated;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AAoUsC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
922
729
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
923
730
  };
924
731
  var _ref2 = process.env.NODE_ENV === "production" ? {
@@ -926,7 +733,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
926
733
  styles: "grid-column:1/2;grid-row:2/4;overflow:hidden"
927
734
  } : {
928
735
  name: "b768-ApplicationShellAuthenticated",
929
- styles: "grid-column:1/2;grid-row:2/4;overflow:hidden;label:ApplicationShellAuthenticated;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AAsTkC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport ProjectDataLocale from '../project-data-locale';\nimport QuickAccess from '../quick-access';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <Route>\n                          {() => {\n                            if (!projectKeyFromUrl) return <QuickAccess />;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isProjectLoading, project }) => {\n                                  if (isProjectLoading || !project) return null;\n\n                                  // when used outside of a project context,\n                                  // or when the project is expired or supsended\n                                  const shouldUseProjectContext = !(\n                                    (project.suspension &&\n                                      project.suspension.isActive) ||\n                                    (project.expiry && project.expiry.isActive)\n                                  );\n\n                                  if (!shouldUseProjectContext)\n                                    return <QuickAccess />;\n\n                                  return (\n                                    <ProjectDataLocale\n                                      locales={project.languages}\n                                    >\n                                      {({\n                                        locale: dataLocale,\n                                        setProjectDataLocale,\n                                      }) => (\n                                        <ApplicationContextProvider\n                                          user={normalizedUser}\n                                          project={project}\n                                          projectDataLocale={dataLocale}\n                                          environment={applicationEnvironment}\n                                        >\n                                          <QuickAccess\n                                            onChangeProjectDataLocale={\n                                              setProjectDataLocale\n                                            }\n                                          />\n                                        </ApplicationContextProvider>\n                                      )}\n                                    </ProjectDataLocale>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          }}\n                        </Route>\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
736
+ styles: "grid-column:1/2;grid-row:2/4;overflow:hidden;label:ApplicationShellAuthenticated;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AAqQkC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
930
737
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
931
738
  };
932
739
  var _ref3 = process.env.NODE_ENV === "production" ? {
@@ -934,7 +741,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
934
741
  styles: "grid-row:'2/3';grid-column:'2/3'"
935
742
  } : {
936
743
  name: "arpkii-ApplicationShellAuthenticated",
937
- styles: "grid-row:'2/3';grid-column:'2/3';label:ApplicationShellAuthenticated;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AA0SkC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport ProjectDataLocale from '../project-data-locale';\nimport QuickAccess from '../quick-access';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <Route>\n                          {() => {\n                            if (!projectKeyFromUrl) return <QuickAccess />;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isProjectLoading, project }) => {\n                                  if (isProjectLoading || !project) return null;\n\n                                  // when used outside of a project context,\n                                  // or when the project is expired or supsended\n                                  const shouldUseProjectContext = !(\n                                    (project.suspension &&\n                                      project.suspension.isActive) ||\n                                    (project.expiry && project.expiry.isActive)\n                                  );\n\n                                  if (!shouldUseProjectContext)\n                                    return <QuickAccess />;\n\n                                  return (\n                                    <ProjectDataLocale\n                                      locales={project.languages}\n                                    >\n                                      {({\n                                        locale: dataLocale,\n                                        setProjectDataLocale,\n                                      }) => (\n                                        <ApplicationContextProvider\n                                          user={normalizedUser}\n                                          project={project}\n                                          projectDataLocale={dataLocale}\n                                          environment={applicationEnvironment}\n                                        >\n                                          <QuickAccess\n                                            onChangeProjectDataLocale={\n                                              setProjectDataLocale\n                                            }\n                                          />\n                                        </ApplicationContextProvider>\n                                      )}\n                                    </ProjectDataLocale>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          }}\n                        </Route>\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
744
+ styles: "grid-row:'2/3';grid-column:'2/3';label:ApplicationShellAuthenticated;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AAyPkC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
938
745
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
939
746
  };
940
747
  var _ref4 = process.env.NODE_ENV === "production" ? {
@@ -942,7 +749,7 @@ var _ref4 = process.env.NODE_ENV === "production" ? {
942
749
  styles: "grid-row:1;grid-column:1/3"
943
750
  } : {
944
751
  name: "u4fwut-ApplicationShellAuthenticated",
945
- styles: "grid-row:1;grid-column:1/3;label:ApplicationShellAuthenticated;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AAiPkC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport ProjectDataLocale from '../project-data-locale';\nimport QuickAccess from '../quick-access';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <Route>\n                          {() => {\n                            if (!projectKeyFromUrl) return <QuickAccess />;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isProjectLoading, project }) => {\n                                  if (isProjectLoading || !project) return null;\n\n                                  // when used outside of a project context,\n                                  // or when the project is expired or supsended\n                                  const shouldUseProjectContext = !(\n                                    (project.suspension &&\n                                      project.suspension.isActive) ||\n                                    (project.expiry && project.expiry.isActive)\n                                  );\n\n                                  if (!shouldUseProjectContext)\n                                    return <QuickAccess />;\n\n                                  return (\n                                    <ProjectDataLocale\n                                      locales={project.languages}\n                                    >\n                                      {({\n                                        locale: dataLocale,\n                                        setProjectDataLocale,\n                                      }) => (\n                                        <ApplicationContextProvider\n                                          user={normalizedUser}\n                                          project={project}\n                                          projectDataLocale={dataLocale}\n                                          environment={applicationEnvironment}\n                                        >\n                                          <QuickAccess\n                                            onChangeProjectDataLocale={\n                                              setProjectDataLocale\n                                            }\n                                          />\n                                        </ApplicationContextProvider>\n                                      )}\n                                    </ProjectDataLocale>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          }}\n                        </Route>\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
752
+ styles: "grid-row:1;grid-column:1/3;label:ApplicationShellAuthenticated;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AA+OkC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */",
946
753
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
947
754
  };
948
755
  const ApplicationShellAuthenticated = props => {
@@ -999,16 +806,16 @@ const ApplicationShellAuthenticated = props => {
999
806
  const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);
1000
807
 
1001
808
  // Check if user is ct staff, and if so get language selected via staff bar from local storage
1002
- const staffBarLanguage = user?.launchdarklyTrackingGroup === 'commercetools' || user?.launchdarklyTrackingGroup === 'mailosaur' ? selectUserLanguageFromStorage() : undefined;
809
+ const staffBarLanguage = (user === null || user === void 0 ? void 0 : user.launchdarklyTrackingGroup) === 'commercetools' || (user === null || user === void 0 ? void 0 : user.launchdarklyTrackingGroup) === 'mailosaur' ? selectUserLanguageFromStorage() : undefined;
1003
810
  const normalizedUser = user ? _objectSpread$8(_objectSpread$8({}, user), {}, {
1004
811
  // set the staff bar language if applicable
1005
- language: staffBarLanguage ?? user.language
812
+ language: staffBarLanguage !== null && staffBarLanguage !== void 0 ? staffBarLanguage : user.language
1006
813
  }) : undefined;
1007
814
  return jsx(ApplicationContextProvider, {
1008
815
  user: normalizedUser,
1009
816
  environment: applicationEnvironment,
1010
817
  children: jsx(AsyncLocaleData, {
1011
- locale: normalizedUser?.language,
818
+ locale: normalizedUser === null || normalizedUser === void 0 ? void 0 : normalizedUser.language,
1012
819
  applicationMessages: props.applicationMessages,
1013
820
  children: _ref7 => {
1014
821
  let isLoadingLocaleData = _ref7.isLoading,
@@ -1031,7 +838,7 @@ const ApplicationShellAuthenticated = props => {
1031
838
  children: [jsx(ThemeSwitcher, {}), jsx(RequestsInFlightLoader, {}), jsx(SentryUserTracker, {
1032
839
  user: normalizedUser
1033
840
  }), jsxs("div", {
1034
- css: /*#__PURE__*/css("height:100vh;display:grid;grid-template-rows:auto ", DIMENSIONS.header, " 1fr;grid-template-columns:min-content 1fr;" + (process.env.NODE_ENV === "production" ? "" : ";label:ApplicationShellAuthenticated;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AAsOgC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport ProjectDataLocale from '../project-data-locale';\nimport QuickAccess from '../quick-access';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <Route>\n                          {() => {\n                            if (!projectKeyFromUrl) return <QuickAccess />;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isProjectLoading, project }) => {\n                                  if (isProjectLoading || !project) return null;\n\n                                  // when used outside of a project context,\n                                  // or when the project is expired or supsended\n                                  const shouldUseProjectContext = !(\n                                    (project.suspension &&\n                                      project.suspension.isActive) ||\n                                    (project.expiry && project.expiry.isActive)\n                                  );\n\n                                  if (!shouldUseProjectContext)\n                                    return <QuickAccess />;\n\n                                  return (\n                                    <ProjectDataLocale\n                                      locales={project.languages}\n                                    >\n                                      {({\n                                        locale: dataLocale,\n                                        setProjectDataLocale,\n                                      }) => (\n                                        <ApplicationContextProvider\n                                          user={normalizedUser}\n                                          project={project}\n                                          projectDataLocale={dataLocale}\n                                          environment={applicationEnvironment}\n                                        >\n                                          <QuickAccess\n                                            onChangeProjectDataLocale={\n                                              setProjectDataLocale\n                                            }\n                                          />\n                                        </ApplicationContextProvider>\n                                      )}\n                                    </ProjectDataLocale>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          }}\n                        </Route>\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */"),
841
+ css: /*#__PURE__*/css("height:100vh;display:grid;grid-template-rows:auto ", DIMENSIONS.header, " 1fr;grid-template-columns:min-content 1fr;" + (process.env.NODE_ENV === "production" ? "" : ";label:ApplicationShellAuthenticated;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["application-shell-authenticated.tsx"],"names":[],"mappings":"AAoOgC","file":"application-shell-authenticated.tsx","sourcesContent":["import {\n  JSX,\n  type ReactNode,\n  type RefObject,\n  type SyntheticEvent,\n  useRef,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport type { ApolloError } from '@apollo/client/errors';\nimport type { TFlags } from '@flopflip/types';\nimport { Redirect, Route, Switch, useLocation } from 'react-router-dom';\nimport { PortalsContainer } from '@commercetools-frontend/application-components';\nimport {\n  ApplicationContextProvider,\n  selectProjectKeyFromUrl,\n  useApplicationContext,\n  selectUserLanguageFromStorage,\n  type TApplicationContext,\n} from '@commercetools-frontend/application-shell-connectors';\nimport { DOMAINS, LOGOUT_REASONS } from '@commercetools-frontend/constants';\nimport type { TAsyncLocaleDataProps } from '@commercetools-frontend/i18n';\nimport { AsyncLocaleData } from '@commercetools-frontend/i18n';\nimport { NotificationsList } from '@commercetools-frontend/react-notifications';\nimport {\n  reportErrorToSentry,\n  SentryUserTracker,\n} from '@commercetools-frontend/sentry';\nimport { DIMENSIONS, NAVBAR } from '../../constants';\nimport { TFetchLoggedInUserQuery } from '../../types/generated/mc';\nimport { getPreviousProjectKey } from '../../utils';\nimport AppBar from '../app-bar';\nimport ApplicationLoader from '../application-loader';\nimport { getBrowserLocale } from '../application-shell-provider/utils';\nimport ConfigureIntlProvider from '../configure-intl-provider';\nimport ErrorApologizer from '../error-apologizer';\nimport FetchProject from '../fetch-project';\nimport FetchUser from '../fetch-user';\nimport NavBar from '../navbar';\nimport ProjectContainer from '../project-container';\nimport RedirectToLogout from '../redirect-to-logout';\nimport RedirectToProjectCreate from '../redirect-to-project-create';\nimport RequestsInFlightLoader from '../requests-in-flight-loader';\nimport RouteCatchAll from '../route-catch-all';\nimport SetupFlopFlipProvider from '../setup-flop-flip-provider';\nimport ThemeSwitcher from '../theme-switcher';\n\ntype TApplicationShellAuthenticationProps = {\n  featureFlags?: TFlags;\n  defaultFeatureFlags?: TFlags;\n  applicationMessages: TAsyncLocaleDataProps['applicationMessages'];\n  onMenuItemClick?: (event: SyntheticEvent<HTMLAnchorElement>) => void;\n  disableRoutePermissionCheck?: boolean;\n  render?: () => JSX.Element;\n  children?: ReactNode;\n};\n\nconst getHasUnauthorizedError = (graphQLErrors: ApolloError['graphQLErrors']) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.extensions &&\n      gqlError.extensions.code &&\n      gqlError.extensions.code === 'UNAUTHENTICATED'\n  );\nconst getHasUserBeenDeletedError = (\n  graphQLErrors: ApolloError['graphQLErrors']\n) =>\n  graphQLErrors.find(\n    (gqlError) =>\n      gqlError.message &&\n      // NOTE: The CTP API does not provide an error code in this case.\n      gqlError.message.includes('was not found.')\n  );\n\nexport const MainContainer = styled.main`\n  grid-column: 2/3;\n  grid-row: 3/4;\n\n  /*\n    Allow the this flex child to grow smaller than its smallest content.\n    This is needed when there is a really wide text inside that would stretch\n    this node to be wider than the parent.\n  */\n  min-width: 0;\n  overflow-x: hidden;\n  overflow-y: scroll;\n\n  /*\n    layout the children. There will always be the page and side notification\n    about the actual content. The content should stretch to fill the rest of\n    the page.\n  */\n  display: flex;\n  flex-direction: column;\n\n  /*\n    set position to relative to layout notifications and modals\n  */\n  position: relative;\n`;\n\n/**\n * This component is rendered whenever the user is considered \"authenticated\"\n * and contains the \"restricted\" application part.\n */\n\nexport const ApplicationShellAuthenticated = (\n  props: TApplicationShellAuthenticationProps\n) => {\n  const applicationEnvironment = useApplicationContext(\n    (context) => context.environment\n  ) as TApplicationContext<{}>['environment'];\n  // TODO: using this hook will subscribe the component to route updates.\n  // This is currently useful for detecting a change in the project key\n  // from URL (\"/\" --> \"/:projectKey\").\n  // However, every route change will trigger a re-render. This is probably\n  // ok-ish but we might want to look into a more performant solution.\n  const location = useLocation();\n\n  const notificationsGlobalRef = useRef<HTMLDivElement>(null);\n  const notificationsPageRef = useRef<HTMLDivElement>(null);\n  const layoutRefs = useRef<{\n    notificationsGlobalRef: RefObject<HTMLDivElement | null>;\n    notificationsPageRef: RefObject<HTMLDivElement | null>;\n  }>({\n    notificationsGlobalRef,\n    notificationsPageRef,\n  });\n\n  return (\n    <FetchUser>\n      {({ isLoading: isLoadingUser, user, error }) => {\n        if (error) {\n          // In case there is an unauthorized error, we redirect to the login page\n          if (error.graphQLErrors && Array.isArray(error.graphQLErrors)) {\n            const hasUnauthorizedError = getHasUnauthorizedError(\n              error.graphQLErrors\n            );\n            const hasUserBeenDeletedError = getHasUserBeenDeletedError(\n              error.graphQLErrors\n            );\n\n            if (hasUnauthorizedError || hasUserBeenDeletedError) {\n              let logoutReason:\n                | (typeof LOGOUT_REASONS)[keyof typeof LOGOUT_REASONS]\n                | undefined;\n              if (hasUnauthorizedError)\n                logoutReason = LOGOUT_REASONS.UNAUTHORIZED;\n              else if (hasUserBeenDeletedError)\n                logoutReason = LOGOUT_REASONS.DELETED;\n              return <RedirectToLogout reason={logoutReason} />;\n            }\n          }\n          // Since we do not know the locale of the user, we pick it from the\n          // user's browser to attempt to match the language for the correct translations.\n\n          const userLocale = getBrowserLocale(window);\n\n          return (\n            <AsyncLocaleData\n              locale={userLocale}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ locale, messages }) => {\n                reportErrorToSentry(error, {});\n                return (\n                  <ConfigureIntlProvider locale={locale} messages={messages}>\n                    <ErrorApologizer />\n                  </ConfigureIntlProvider>\n                );\n              }}\n            </AsyncLocaleData>\n          );\n        }\n\n        const projectKeyFromUrl = selectProjectKeyFromUrl(location.pathname);\n\n        // Check if user is ct staff, and if so get language selected via staff bar from local storage\n        const staffBarLanguage =\n          user?.launchdarklyTrackingGroup === 'commercetools' ||\n          user?.launchdarklyTrackingGroup === 'mailosaur'\n            ? selectUserLanguageFromStorage()\n            : undefined;\n\n        const normalizedUser: TFetchLoggedInUserQuery['user'] | undefined = user\n          ? {\n              ...user,\n              // set the staff bar language if applicable\n              language: staffBarLanguage ?? user.language,\n            }\n          : undefined;\n\n        return (\n          <ApplicationContextProvider\n            user={normalizedUser}\n            environment={applicationEnvironment}\n          >\n            {/*\n            NOTE: we do not want to load the locale data as long as we do not\n            know the user setting. This is important in order to avoid flashing\n            of translated content on subsequent re-renders.\n            Therefore, as long as there is no locale, the children should consider using the\n            `isLoading` prop to decide what to render.\n          */}\n            <AsyncLocaleData\n              locale={normalizedUser?.language}\n              applicationMessages={props.applicationMessages}\n            >\n              {({ isLoading: isLoadingLocaleData, locale, messages }) => (\n                <ConfigureIntlProvider\n                  // We do not want to pass the language as long as the locale data\n                  // is not loaded.\n                  {...(isLoadingLocaleData ? {} : { locale, messages })}\n                >\n                  <SetupFlopFlipProvider\n                    user={normalizedUser}\n                    projectKey={projectKeyFromUrl}\n                    ldClientSideId={applicationEnvironment.ldClientSideId}\n                    flags={props.featureFlags}\n                    defaultFlags={props.defaultFeatureFlags}\n                  >\n                    <>\n                      <ThemeSwitcher />\n                      {/* NOTE: the requests in flight loader will render a loading\n                      spinner into the AppBar. */}\n                      <RequestsInFlightLoader />\n                      <SentryUserTracker user={normalizedUser} />\n                      <div\n                        css={css`\n                          height: 100vh;\n                          display: grid;\n                          grid-template-rows: auto ${DIMENSIONS.header} 1fr;\n                          grid-template-columns: min-content 1fr;\n                        `}\n                      >\n                        <div\n                          ref={notificationsGlobalRef}\n                          role=\"region\"\n                          aria-live=\"polite\"\n                          css={css`\n                            grid-row: 1;\n                            grid-column: 1/3;\n                          `}\n                        >\n                          <div id=\"above-top-navigation\" />\n                          <NotificationsList domain={DOMAINS.GLOBAL} />\n                        </div>\n\n                        <header\n                          css={css`\n                            grid-row: '2/3';\n                            grid-column: '2/3';\n                          `}\n                        >\n                          <AppBar\n                            user={normalizedUser}\n                            projectKeyFromUrl={projectKeyFromUrl}\n                          />\n                        </header>\n\n                        <aside\n                          css={css`\n                            grid-column: 1/2;\n                            grid-row: 2/4;\n                            overflow: hidden;\n                          `}\n                        >\n                          {(() => {\n                            // The <NavBar> should only be rendered within a project\n                            // context, therefore when there is a `projectKey`.\n                            // If there is no `projectKey` in the URL (e.g. `/account`\n                            // routes), we don't render it.\n                            // NOTE: we also \"cache\" the `projectKey` in localStorage\n                            // but this should only be used to \"re-hydrate\" the URL\n                            // location (e.g when you go to `/`, there should be a\n                            // redirect to `/:projectKey`). Therefore, we should not\n                            // rely on the value in localStorage to determine which\n                            // `projectKey` is currently used.\n                            if (!projectKeyFromUrl) return null;\n                            return (\n                              <FetchProject projectKey={projectKeyFromUrl}>\n                                {({ isLoading: isLoadingProject, project }) => {\n                                  const isLoading =\n                                    isLoadingUser ||\n                                    isLoadingLocaleData ||\n                                    isLoadingProject ||\n                                    !locale ||\n                                    !project;\n\n                                  return (\n                                    <ApplicationContextProvider\n                                      user={normalizedUser}\n                                      environment={applicationEnvironment}\n                                      // NOTE: do not pass the `project` into the application context.\n                                      // The permissions for the Navbar are resolved separately, within\n                                      // a different React context.\n                                    >\n                                      <NavBar\n                                        applicationLocale={locale}\n                                        projectKey={projectKeyFromUrl}\n                                        project={project}\n                                        environment={applicationEnvironment}\n                                        onMenuItemClick={props.onMenuItemClick}\n                                        isLoading={isLoading}\n                                      />\n                                    </ApplicationContextProvider>\n                                  );\n                                }}\n                              </FetchProject>\n                            );\n                          })()}\n                        </aside>\n\n                        {isLoadingUser || isLoadingLocaleData ? (\n                          <MainContainer role=\"main\">\n                            <ApplicationLoader />\n                          </MainContainer>\n                        ) : (\n                          <MainContainer role=\"main\">\n                            <div ref={notificationsPageRef}>\n                              <NotificationsList domain={DOMAINS.PAGE} />\n                            </div>\n                            <NotificationsList domain={DOMAINS.SIDE} />\n                            <div\n                              css={css`\n                                flex-grow: 1;\n                                display: flex;\n                                flex-direction: column;\n                                position: relative;\n\n                                /*\n                                This is only necessary because we have an intermediary <div> wrapping the\n                                <View> component that is used to wrap every content-view. This intermediary\n                                <div> is solely used for adding the tracking context to the content-view.\n                                However, this could be done by passing the tracking context to the <View>\n                                and let it do the layout, so we can avoid laying our from the outside as we\n                                do here.\n                              */\n                                > *:not(:first-of-type) {\n                                  flex-grow: 1;\n                                  display: flex;\n                                  flex-direction: column;\n                                }\n                              `}\n                            >\n                              <PortalsContainer\n                                // @ts-ignore\n                                ref={layoutRefs}\n                                offsetTop={DIMENSIONS.header}\n                                offsetLeft={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigation\n                                    : '0px'\n                                }\n                                offsetLeftOnExpandedMenu={\n                                  projectKeyFromUrl\n                                    ? NAVBAR.widthLeftNavigationWhenExpanded\n                                    : '0px'\n                                }\n                              />\n                              <Switch>\n                                <Route\n                                  path=\"/profile\"\n                                  render={() => (\n                                    <Redirect to=\"/account/profile\" />\n                                  )}\n                                />\n\n                                <Route path=\"/account\">\n                                  {\n                                    /**\n                                     * In case the AppShell uses the `render` function, we assume it's one of two cases:\n                                     * 1. The application does not use `children` and therefore implements the routes including\n                                     * the <RouteCatchAll> (this is the \"legacy\" behavior).\n                                     * 2. It's the account application, which always uses `render` and therefore should render as normal.\n                                     *\n                                     * In case the AppShell uses the `children` function, we can always assume that\n                                     * it's a normal Custom Application and that it should trigger a force reload.\n                                     */\n                                    props.render ? (\n                                      <>{props.render()}</>\n                                    ) : (\n                                      <RouteCatchAll />\n                                    )\n                                  }\n                                </Route>\n                                {/* Project routes */}\n                                <Route exact={true} path=\"/\">\n                                  {(() => {\n                                    const previousProjectKey =\n                                      getPreviousProjectKey(\n                                        normalizedUser?.defaultProjectKey ??\n                                          undefined\n                                      );\n\n                                    /**\n                                     * NOTE:\n                                     *   Given the user has not been loaded a loading spinner is shown.\n                                     *   Given the user was not working on a project previously nor has a default\n                                     *   project, the user will be prompted to create one.\n                                     *   Given the user was working on a project previously or has a default\n                                     *   project, the application will redirect to that project.\n                                     */\n                                    if (!normalizedUser)\n                                      return <ApplicationLoader />;\n                                    if (!previousProjectKey)\n                                      return <RedirectToProjectCreate />;\n                                    return (\n                                      <Redirect to={`/${previousProjectKey}`} />\n                                    );\n                                  })()}\n                                </Route>\n                                <Route exact={false} path=\"/:projectKey\">\n                                  <ProjectContainer\n                                    user={normalizedUser}\n                                    environment={applicationEnvironment}\n                                    disableRoutePermissionCheck={\n                                      props.disableRoutePermissionCheck\n                                    }\n                                    // This effectively renders the\n                                    // children, which is the application\n                                    // specific part\n                                    render={props.render}\n                                  >\n                                    {props.children}\n                                  </ProjectContainer>\n                                </Route>\n                              </Switch>\n                            </div>\n                          </MainContainer>\n                        )}\n                      </div>\n                    </>\n                  </SetupFlopFlipProvider>\n                </ConfigureIntlProvider>\n              )}\n            </AsyncLocaleData>\n          </ApplicationContextProvider>\n        );\n      }}\n    </FetchUser>\n  );\n};\nApplicationShellAuthenticated.displayName = 'ApplicationShellAuthenticated';\n\nexport default ApplicationShellAuthenticated;\n"]} */"),
1035
842
  children: [jsxs("div", {
1036
843
  ref: notificationsGlobalRef,
1037
844
  role: "region",
@@ -1042,39 +849,6 @@ const ApplicationShellAuthenticated = props => {
1042
849
  }), jsx(NotificationsList, {
1043
850
  domain: DOMAINS.GLOBAL
1044
851
  })]
1045
- }), jsx(Route, {
1046
- children: () => {
1047
- if (!projectKeyFromUrl) return jsx(QuickAccessTrigger, {});
1048
- return jsx(FetchProject, {
1049
- projectKey: projectKeyFromUrl,
1050
- children: _ref8 => {
1051
- let isProjectLoading = _ref8.isLoading,
1052
- project = _ref8.project;
1053
- if (isProjectLoading || !project) return null;
1054
-
1055
- // when used outside of a project context,
1056
- // or when the project is expired or supsended
1057
- const shouldUseProjectContext = !(project.suspension && project.suspension.isActive || project.expiry && project.expiry.isActive);
1058
- if (!shouldUseProjectContext) return jsx(QuickAccessTrigger, {});
1059
- return jsx(ProjectDataLocale, {
1060
- locales: project.languages,
1061
- children: _ref9 => {
1062
- let dataLocale = _ref9.locale,
1063
- setProjectDataLocale = _ref9.setProjectDataLocale;
1064
- return jsx(ApplicationContextProvider, {
1065
- user: normalizedUser,
1066
- project: project,
1067
- projectDataLocale: dataLocale,
1068
- environment: applicationEnvironment,
1069
- children: jsx(QuickAccessTrigger, {
1070
- onChangeProjectDataLocale: setProjectDataLocale
1071
- })
1072
- });
1073
- }
1074
- });
1075
- }
1076
- });
1077
- }
1078
852
  }), jsx("header", {
1079
853
  css: _ref3,
1080
854
  children: jsx(AppBar, {
@@ -1097,9 +871,9 @@ const ApplicationShellAuthenticated = props => {
1097
871
  if (!projectKeyFromUrl) return null;
1098
872
  return jsx(FetchProject, {
1099
873
  projectKey: projectKeyFromUrl,
1100
- children: _ref0 => {
1101
- let isLoadingProject = _ref0.isLoading,
1102
- project = _ref0.project;
874
+ children: _ref8 => {
875
+ let isLoadingProject = _ref8.isLoading,
876
+ project = _ref8.project;
1103
877
  const isLoading = isLoadingUser || isLoadingLocaleData || isLoadingProject || !locale || !project;
1104
878
  return jsx(ApplicationContextProvider, {
1105
879
  user: normalizedUser,
@@ -1165,8 +939,8 @@ const ApplicationShellAuthenticated = props => {
1165
939
  }), jsx(Route, {
1166
940
  exact: true,
1167
941
  path: "/",
1168
- children: (() => {
1169
- const previousProjectKey = getPreviousProjectKey(normalizedUser?.defaultProjectKey ?? undefined);
942
+ children: (_normalizedUser$defau => {
943
+ const previousProjectKey = getPreviousProjectKey((_normalizedUser$defau = normalizedUser === null || normalizedUser === void 0 ? void 0 : normalizedUser.defaultProjectKey) !== null && _normalizedUser$defau !== void 0 ? _normalizedUser$defau : undefined);
1170
944
 
1171
945
  /**
1172
946
  * NOTE:
@@ -1179,7 +953,7 @@ const ApplicationShellAuthenticated = props => {
1179
953
  if (!normalizedUser) return jsx(ApplicationLoader, {});
1180
954
  if (!previousProjectKey) return jsx(RedirectToProjectCreate, {});
1181
955
  return jsx(Redirect, {
1182
- to: `/${previousProjectKey}`
956
+ to: "/".concat(previousProjectKey)
1183
957
  });
1184
958
  })()
1185
959
  }), jsx(Route, {
@@ -1355,31 +1129,37 @@ const withoutProjectKeyClaim = scope => {
1355
1129
  return _filterInstanceProperty(_context = scope.split(' ')).call(_context, claim => !_startsWithInstanceProperty(claim).call(claim, OIDC_CLAIMS.PROJECT_KEY)).join(' ');
1356
1130
  };
1357
1131
  const hasCachedAuthenticationState = () => {
1358
- if (window.app.__DEVELOPMENT__?.oidc?.authorizeUrl) {
1132
+ var _window$app$__DEVELOP;
1133
+ if ((_window$app$__DEVELOP = window.app.__DEVELOPMENT__) !== null && _window$app$__DEVELOP !== void 0 && (_window$app$__DEVELOP = _window$app$__DEVELOP.oidc) !== null && _window$app$__DEVELOP !== void 0 && _window$app$__DEVELOP.authorizeUrl) {
1359
1134
  try {
1135
+ var _window$app$__DEVELOP8, _window$app$__DEVELOP9, _window$app$__DEVELOP0, _window$app$__DEVELOP1;
1360
1136
  let activeProjectKey = oidcStorage.getActiveProjectKey();
1361
1137
  if (activeProjectKey) {
1138
+ var _window$app$__DEVELOP2, _window$app$__DEVELOP3, _window$app$__DEVELOP4;
1362
1139
  // GIVEN The application is not requesting a project key,
1363
1140
  // THEN we assume that the application does not need a project context.
1364
1141
  // GIVEN The application is not requesting a project key,
1365
1142
  // THEN we remove the cached project key.
1366
1143
  // This is the case of an application like `account`.
1367
- if (!window.app.__DEVELOPMENT__?.oidc?.initialProjectKey) {
1144
+ if (!((_window$app$__DEVELOP2 = window.app.__DEVELOPMENT__) !== null && _window$app$__DEVELOP2 !== void 0 && (_window$app$__DEVELOP2 = _window$app$__DEVELOP2.oidc) !== null && _window$app$__DEVELOP2 !== void 0 && _window$app$__DEVELOP2.initialProjectKey)) {
1368
1145
  oidcStorage.removeActiveProjectKey();
1369
1146
  }
1370
1147
 
1371
1148
  // If the project key we had in the storage does not match the one
1372
1149
  // we have in the development config, then we need to discard it and
1373
1150
  // use the one from the development config.
1374
- if (window.app.__DEVELOPMENT__?.oidc?.initialProjectKey && window.app.__DEVELOPMENT__?.oidc?.initialProjectKey !== activeProjectKey) {
1375
- activeProjectKey = window.app.__DEVELOPMENT__?.oidc?.initialProjectKey;
1151
+ if ((_window$app$__DEVELOP3 = window.app.__DEVELOPMENT__) !== null && _window$app$__DEVELOP3 !== void 0 && (_window$app$__DEVELOP3 = _window$app$__DEVELOP3.oidc) !== null && _window$app$__DEVELOP3 !== void 0 && _window$app$__DEVELOP3.initialProjectKey && ((_window$app$__DEVELOP4 = window.app.__DEVELOPMENT__) === null || _window$app$__DEVELOP4 === void 0 || (_window$app$__DEVELOP4 = _window$app$__DEVELOP4.oidc) === null || _window$app$__DEVELOP4 === void 0 ? void 0 : _window$app$__DEVELOP4.initialProjectKey) !== activeProjectKey) {
1152
+ var _window$app$__DEVELOP5;
1153
+ activeProjectKey = (_window$app$__DEVELOP5 = window.app.__DEVELOPMENT__) === null || _window$app$__DEVELOP5 === void 0 || (_window$app$__DEVELOP5 = _window$app$__DEVELOP5.oidc) === null || _window$app$__DEVELOP5 === void 0 ? void 0 : _window$app$__DEVELOP5.initialProjectKey;
1376
1154
  oidcStorage.setActiveProjectKey(activeProjectKey);
1377
1155
  }
1378
1156
  } else {
1379
- if (window.app.__DEVELOPMENT__?.oidc?.initialProjectKey) {
1157
+ var _window$app$__DEVELOP6;
1158
+ if ((_window$app$__DEVELOP6 = window.app.__DEVELOPMENT__) !== null && _window$app$__DEVELOP6 !== void 0 && (_window$app$__DEVELOP6 = _window$app$__DEVELOP6.oidc) !== null && _window$app$__DEVELOP6 !== void 0 && _window$app$__DEVELOP6.initialProjectKey) {
1159
+ var _window$app$__DEVELOP7;
1380
1160
  // Here we store the initial project key in local storage,
1381
1161
  // so that it gets picked up when we initiate the login flow.
1382
- oidcStorage.setActiveProjectKey(window.app.__DEVELOPMENT__?.oidc?.initialProjectKey);
1162
+ oidcStorage.setActiveProjectKey((_window$app$__DEVELOP7 = window.app.__DEVELOPMENT__) === null || _window$app$__DEVELOP7 === void 0 || (_window$app$__DEVELOP7 = _window$app$__DEVELOP7.oidc) === null || _window$app$__DEVELOP7 === void 0 ? void 0 : _window$app$__DEVELOP7.initialProjectKey);
1383
1163
  }
1384
1164
  }
1385
1165
 
@@ -1394,11 +1174,11 @@ const hasCachedAuthenticationState = () => {
1394
1174
  }
1395
1175
  // Rebuild the requested OIDC scope to verify that it didn't change.
1396
1176
  const requestedScope = buildOidcScope({
1397
- projectKey: activeProjectKey ?? undefined,
1398
- oAuthScopes: window.app.__DEVELOPMENT__?.oidc?.oAuthScopes,
1399
- additionalOAuthScopes: window.app.__DEVELOPMENT__?.oidc?.additionalOAuthScopes,
1400
- teamId: window.app.__DEVELOPMENT__?.oidc?.teamId,
1401
- applicationId: window.app.__DEVELOPMENT__?.oidc?.applicationId
1177
+ projectKey: activeProjectKey !== null && activeProjectKey !== void 0 ? activeProjectKey : undefined,
1178
+ oAuthScopes: (_window$app$__DEVELOP8 = window.app.__DEVELOPMENT__) === null || _window$app$__DEVELOP8 === void 0 || (_window$app$__DEVELOP8 = _window$app$__DEVELOP8.oidc) === null || _window$app$__DEVELOP8 === void 0 ? void 0 : _window$app$__DEVELOP8.oAuthScopes,
1179
+ additionalOAuthScopes: (_window$app$__DEVELOP9 = window.app.__DEVELOPMENT__) === null || _window$app$__DEVELOP9 === void 0 || (_window$app$__DEVELOP9 = _window$app$__DEVELOP9.oidc) === null || _window$app$__DEVELOP9 === void 0 ? void 0 : _window$app$__DEVELOP9.additionalOAuthScopes,
1180
+ teamId: (_window$app$__DEVELOP0 = window.app.__DEVELOPMENT__) === null || _window$app$__DEVELOP0 === void 0 || (_window$app$__DEVELOP0 = _window$app$__DEVELOP0.oidc) === null || _window$app$__DEVELOP0 === void 0 ? void 0 : _window$app$__DEVELOP0.teamId,
1181
+ applicationId: (_window$app$__DEVELOP1 = window.app.__DEVELOPMENT__) === null || _window$app$__DEVELOP1 === void 0 || (_window$app$__DEVELOP1 = _window$app$__DEVELOP1.oidc) === null || _window$app$__DEVELOP1 === void 0 ? void 0 : _window$app$__DEVELOP1.applicationId
1402
1182
  });
1403
1183
  // Omit the project key from the check. This allows to switch projects
1404
1184
  // without having to log in again.
@@ -1416,11 +1196,12 @@ const hasCachedAuthenticationState = () => {
1416
1196
  return window.localStorage.getItem(STORAGE_KEYS.IS_AUTHENTICATED) === 'true';
1417
1197
  };
1418
1198
 
1419
- const OidcCallback = /*#__PURE__*/lazy(() => import('./oidc-callback-5f3d5280.esm.js' /* webpackChunkName: "oidc-callback" */));
1199
+ const OidcCallback = /*#__PURE__*/lazy(() => import('./oidc-callback-019d623d.esm.js' /* webpackChunkName: "oidc-callback" */));
1420
1200
 
1421
1201
  function ownKeys$4(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
1422
1202
  function _objectSpread$4(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$4(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$4(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1423
1203
  const Authenticated = props => {
1204
+ var _window$app$__DEVELOP;
1424
1205
  // We attempt to see if the user was already authenticated by looking
1425
1206
  // at the "cached" flag in local storage.
1426
1207
  const cachedAuthenticationState = hasCachedAuthenticationState();
@@ -1434,7 +1215,7 @@ const Authenticated = props => {
1434
1215
 
1435
1216
  // When using the OIDC workflow, we always return false, to trigger
1436
1217
  // the redirect to the login page.
1437
- if (window.app.__DEVELOPMENT__?.oidc?.authorizeUrl) {
1218
+ if ((_window$app$__DEVELOP = window.app.__DEVELOPMENT__) !== null && _window$app$__DEVELOP !== void 0 && (_window$app$__DEVELOP = _window$app$__DEVELOP.oidc) !== null && _window$app$__DEVELOP !== void 0 && _window$app$__DEVELOP.authorizeUrl) {
1438
1219
  return jsx(Fragment, {
1439
1220
  children: props.render({
1440
1221
  isAuthenticated: false
@@ -1448,13 +1229,13 @@ const Authenticated = props => {
1448
1229
  Authenticated.displayName = 'Authenticated';
1449
1230
  const AuthenticationRoutes = props => jsxs(Switch, {
1450
1231
  children: [jsx(SuspendedRoute, {
1451
- path: `/account/oidc/callback`,
1232
+ path: "/account/oidc/callback",
1452
1233
  children: jsx(OidcCallback, {
1453
1234
  locale: props.locale,
1454
1235
  applicationMessages: props.applicationMessages
1455
1236
  })
1456
1237
  }), jsx(SuspendedRoute, {
1457
- path: `/:projectKey/:identifier/oidc/callback`,
1238
+ path: "/:projectKey/:identifier/oidc/callback",
1458
1239
  children: jsx(OidcCallback, {
1459
1240
  locale: props.locale,
1460
1241
  applicationMessages: props.applicationMessages
@@ -1465,6 +1246,63 @@ const AuthenticationRoutes = props => jsxs(Switch, {
1465
1246
  });
1466
1247
  AuthenticationRoutes.displayName = 'AuthenticationRoutes';
1467
1248
 
1249
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? _Reflect$construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
1250
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function () { return !!t; })(); }
1251
+ let ErrorBoundary = /*#__PURE__*/function (_Component) {
1252
+ function ErrorBoundary() {
1253
+ var _this;
1254
+ _classCallCheck(this, ErrorBoundary);
1255
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
1256
+ args[_key] = arguments[_key];
1257
+ }
1258
+ _this = _callSuper(this, ErrorBoundary, [...args]);
1259
+ _this.state = {
1260
+ hasError: false
1261
+ };
1262
+ return _this;
1263
+ }
1264
+ _inherits(ErrorBoundary, _Component);
1265
+ return _createClass(ErrorBoundary, [{
1266
+ key: "componentDidUpdate",
1267
+ value: function componentDidUpdate(prevProps) {
1268
+ const hasRouteChanged = prevProps.pathname !== this.props.pathname;
1269
+ this.setState(prevState => hasRouteChanged && prevState.hasError ? {
1270
+ hasError: false
1271
+ } : null);
1272
+ }
1273
+ }, {
1274
+ key: "componentDidCatch",
1275
+ value: function componentDidCatch(error, errorInfo) {
1276
+ // Note: In development mode componentDidCatch is not based on try-catch
1277
+ // to catch exceptions. Thus exceptions caught here will also be caught in
1278
+ // the global `error` event listener (setup-global-error-listener.js).
1279
+ // see: https://github.com/facebook/react/issues/10474
1280
+ reportErrorToSentry(error, {
1281
+ extra: errorInfo
1282
+ });
1283
+ }
1284
+ }, {
1285
+ key: "render",
1286
+ value: function render() {
1287
+ if (this.state.hasError) {
1288
+ return jsx(ErrorApologizer, {});
1289
+ }
1290
+ return jsx(Fragment, {
1291
+ children: this.props.children
1292
+ });
1293
+ }
1294
+ }], [{
1295
+ key: "getDerivedStateFromError",
1296
+ value: function getDerivedStateFromError(/* error */
1297
+ ) {
1298
+ // Update state so the next render will show the fallback UI.
1299
+ return {
1300
+ hasError: true
1301
+ };
1302
+ }
1303
+ }]);
1304
+ }(Component);
1305
+
1468
1306
  function ownKeys$3(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
1469
1307
  function _objectSpread$3(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context2 = ownKeys$3(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context3 = ownKeys$3(Object(t))).call(_context3, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1470
1308
  /**
@@ -1510,7 +1348,10 @@ const useCoercedEnvironmentValues = environment => {
1510
1348
  };
1511
1349
 
1512
1350
  const ApplicationShellProvider = props => {
1513
- const apolloClient = useMemo(() => props.apolloClient ?? createApolloClient(), [props.apolloClient]);
1351
+ const apolloClient = useMemo(() => {
1352
+ var _props$apolloClient;
1353
+ return (_props$apolloClient = props.apolloClient) !== null && _props$apolloClient !== void 0 ? _props$apolloClient : createApolloClient();
1354
+ }, [props.apolloClient]);
1514
1355
  useEffect(() => {
1515
1356
  setCachedApolloClient(apolloClient);
1516
1357
  }, [apolloClient]);
@@ -1561,7 +1402,7 @@ const ApplicationShellProvider = props => {
1561
1402
  };
1562
1403
  ApplicationShellProvider.displayName = 'ApplicationShellProvider';
1563
1404
 
1564
- const RedirectToLogin = /*#__PURE__*/lazy(() => import('./redirect-to-login-2944c890.esm.js' /* webpackChunkName: "redirect-to-login" */));
1405
+ const RedirectToLogin = /*#__PURE__*/lazy(() => import('./redirect-to-login-edbfacbc.esm.js' /* webpackChunkName: "redirect-to-login" */));
1565
1406
 
1566
1407
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
1567
1408
  const styles = process.env.NODE_ENV === "production" ? {
@@ -1589,7 +1430,8 @@ const StrictModeEnablement$1 = props => {
1589
1430
  };
1590
1431
  const ApplicationShell = props => {
1591
1432
  useEffect(() => {
1592
- props.onRegisterErrorListeners?.({
1433
+ var _props$onRegisterErro;
1434
+ (_props$onRegisterErro = props.onRegisterErrorListeners) === null || _props$onRegisterErro === void 0 || _props$onRegisterErro.call(props, {
1593
1435
  dispatch: internalReduxStore.dispatch
1594
1436
  });
1595
1437
  // eslint-disable-next-line react-hooks/exhaustive-deps
@@ -1629,14 +1471,18 @@ const ApplicationShell = props => {
1629
1471
  ApplicationShell.displayName = 'ApplicationShell';
1630
1472
  ApplicationShell.version = version;
1631
1473
 
1632
- const CustomViewDevHost = /*#__PURE__*/lazy(() => import('./custom-view-dev-host-6091b78a.esm.js' /* webpackChunkName: "custom-view-dev-host" */));
1474
+ const CustomViewDevHost = /*#__PURE__*/lazy(() => import('./custom-view-dev-host-091163ea.esm.js' /* webpackChunkName: "custom-view-dev-host" */));
1633
1475
 
1634
1476
  function CustomViewFlopFlipProvider(props) {
1635
- const adapterArgs = useMemo(() => ({
1636
- user: {
1637
- key: props.user?.id
1638
- }
1639
- }), [props.user?.id]);
1477
+ var _props$user2;
1478
+ const adapterArgs = useMemo(() => {
1479
+ var _props$user;
1480
+ return {
1481
+ user: {
1482
+ key: (_props$user = props.user) === null || _props$user === void 0 ? void 0 : _props$user.id
1483
+ }
1484
+ };
1485
+ }, [(_props$user2 = props.user) === null || _props$user2 === void 0 ? void 0 : _props$user2.id]);
1640
1486
  return jsx(ConfigureFlopFlip, {
1641
1487
  adapter: adapter$3,
1642
1488
  defaultFlags: _flagsInstanceProperty(props),
@@ -1672,7 +1518,7 @@ function CustomViewShellAuthenticated(props) {
1672
1518
  return jsx(ApplicationLoader, {});
1673
1519
  }
1674
1520
  return jsx(AsyncLocaleData, {
1675
- locale: user?.language || browserLocale,
1521
+ locale: (user === null || user === void 0 ? void 0 : user.language) || browserLocale,
1676
1522
  applicationMessages: props.messages,
1677
1523
  children: _ref2 => {
1678
1524
  let isLoadingLocaleData = _ref2.isLoading,
@@ -1735,15 +1581,15 @@ function CustomViewShellAuthenticated(props) {
1735
1581
  const customViewsThemesOverrides = {
1736
1582
  default: {
1737
1583
  marginForCustomViewsSelectorAsTabular: '0',
1738
- marginForPageContent: `${designTokens.spacing50} 0`,
1739
- paddingForDetailPageHeader: `0 0 ${designTokens.spacing40} 0`,
1584
+ marginForPageContent: "".concat(designTokens.spacing50, " 0"),
1585
+ paddingForDetailPageHeader: "0 0 ".concat(designTokens.spacing40, " 0"),
1740
1586
  paddingForMainPageHeader: '0',
1741
1587
  paddingForTabularPageHeader: '0'
1742
1588
  }
1743
1589
  };
1744
1590
 
1745
1591
  function ownKeys$1(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
1746
- function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1592
+ function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context3 = ownKeys$1(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context4 = ownKeys$1(Object(t))).call(_context4, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1747
1593
  const browserLocale = getBrowserLocale(window);
1748
1594
  function NotificationsContainer(props) {
1749
1595
  return jsxs(Fragment, {
@@ -1803,6 +1649,7 @@ function CustomViewThemeProvider() {
1803
1649
  */
1804
1650
  const isLocalProdMode = process.env.NODE_ENV === 'production' && window.app.env === 'development';
1805
1651
  function CustomViewShell(props) {
1652
+ var _window$app$__DEVELOP;
1806
1653
  const _useState = useState(),
1807
1654
  _useState2 = _slicedToArray(_useState, 2),
1808
1655
  hostContext = _useState2[0],
@@ -1818,20 +1665,21 @@ function CustomViewShell(props) {
1818
1665
  if (event.data.eventName === CUSTOM_VIEWS_EVENTS_NAMES.CUSTOM_VIEW_INITIALIZATION) {
1819
1666
  setHostContext(event.data.eventData.context);
1820
1667
  } else {
1821
- console.warn(`CustomViewShell: Unknown received event with name: ${event.data.eventName}`, {
1668
+ console.warn("CustomViewShell: Unknown received event with name: ".concat(event.data.eventName), {
1822
1669
  event
1823
1670
  });
1824
1671
  }
1825
1672
  }, []);
1826
1673
  const handleClose = useCallback(() => {
1827
- iFrameCommunicationPort.current?.postMessage({
1674
+ var _iFrameCommunicationP, _context;
1675
+ (_iFrameCommunicationP = iFrameCommunicationPort.current) === null || _iFrameCommunicationP === void 0 || _iFrameCommunicationP.postMessage({
1828
1676
  origin: window.location.origin,
1829
- source: `${CUSTOM_VIEWS_EVENTS_META.CUSTOM_VIEW_KEY_PREFIX}${hostContext?.customViewConfig.id}`,
1677
+ source: _concatInstanceProperty(_context = "".concat(CUSTOM_VIEWS_EVENTS_META.CUSTOM_VIEW_KEY_PREFIX)).call(_context, hostContext === null || hostContext === void 0 ? void 0 : hostContext.customViewConfig.id),
1830
1678
  destination: CUSTOM_VIEWS_EVENTS_META.HOST_APPLICATION_CODE,
1831
1679
  eventName: CUSTOM_VIEWS_EVENTS_NAMES.CUSTOM_VIEW_CLOSE,
1832
1680
  eventData: {}
1833
1681
  });
1834
- }, [hostContext?.customViewConfig.id]);
1682
+ }, [hostContext === null || hostContext === void 0 ? void 0 : hostContext.customViewConfig.id]);
1835
1683
  useEffect(() => {
1836
1684
  const bootstrapMessageHandler = event => {
1837
1685
  if ((event.origin === window.location.origin ||
@@ -1863,7 +1711,8 @@ function CustomViewShell(props) {
1863
1711
  useEffect(() => {
1864
1712
  // Close the channel when the component unmounts
1865
1713
  return () => {
1866
- iFrameCommunicationPort.current?.close();
1714
+ var _iFrameCommunicationP2;
1715
+ (_iFrameCommunicationP2 = iFrameCommunicationPort.current) === null || _iFrameCommunicationP2 === void 0 || _iFrameCommunicationP2.close();
1867
1716
  iFrameCommunicationPort.current = undefined;
1868
1717
  };
1869
1718
  }, []);
@@ -1872,7 +1721,7 @@ function CustomViewShell(props) {
1872
1721
  showLogo: true
1873
1722
  });
1874
1723
  }
1875
- const hostUrl = process.env.NODE_ENV === 'development' || isLocalProdMode ? window.app.__DEVELOPMENT__?.customViewHostUrl : hostContext.hostUrl;
1724
+ const hostUrl = process.env.NODE_ENV === 'development' || isLocalProdMode ? (_window$app$__DEVELOP = window.app.__DEVELOPMENT__) === null || _window$app$__DEVELOP === void 0 ? void 0 : _window$app$__DEVELOP.customViewHostUrl : hostContext.hostUrl;
1876
1725
  return jsxs(Fragment, {
1877
1726
  children: [jsx(GlobalStyles, {}), jsx(ApplicationShellProvider, {
1878
1727
  environment: window.app,
@@ -1881,6 +1730,7 @@ function CustomViewShell(props) {
1881
1730
  children: _ref => {
1882
1731
  let isAuthenticated = _ref.isAuthenticated;
1883
1732
  if (isAuthenticated) {
1733
+ var _context2;
1884
1734
  return jsx(CustomViewContextProvider, {
1885
1735
  hostUrl: hostUrl,
1886
1736
  customViewConfig: hostContext.customViewConfig,
@@ -1899,7 +1749,7 @@ function CustomViewShell(props) {
1899
1749
  notificationsGlobalRef: notificationsGlobalRef,
1900
1750
  notificationsPageRef: notificationsPageRef
1901
1751
  }), jsxs(Route, {
1902
- path: `/custom-views/${hostContext.customViewConfig.id}/projects/${hostContext.projectKey}`,
1752
+ path: _concatInstanceProperty(_context2 = "/custom-views/".concat(hostContext.customViewConfig.id, "/projects/")).call(_context2, hostContext.projectKey),
1903
1753
  children: [jsx(ModalPageTopBar, {
1904
1754
  onClose: handleClose,
1905
1755
  hidePathLabel: true
@@ -2038,7 +1888,7 @@ function setupGlobalErrorListener() {
2038
1888
  }
2039
1889
 
2040
1890
  function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
2041
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context, _context2; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context = ownKeys(Object(t), !0)).call(_context, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context2 = ownKeys(Object(t))).call(_context2, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
1891
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context2 = ownKeys(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context3 = ownKeys(Object(t))).call(_context3, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
2042
1892
 
2043
1893
  /**
2044
1894
  * The route path to match. Usually it starts with `/:projectKey/my-entry-point`.
@@ -2048,7 +1898,8 @@ const makeRoute = (routePath, routeOptions) => {
2048
1898
  const getUrl = (nextParams, nextQueryParams) => {
2049
1899
  const baseUrl = generatePath(routePath, _objectSpread(_objectSpread({}, routeOptions.params), nextParams));
2050
1900
  if (nextQueryParams) {
2051
- return `${baseUrl}?${nextQueryParams.toString()}`;
1901
+ var _context;
1902
+ return _concatInstanceProperty(_context = "".concat(baseUrl, "?")).call(_context, nextQueryParams.toString());
2052
1903
  }
2053
1904
  return baseUrl;
2054
1905
  };
@@ -2077,4 +1928,4 @@ function useRoutesCreator() {
2077
1928
  };
2078
1929
  }
2079
1930
 
2080
- export { ApplicationShell as A, ButlerContainer as B, ConfigureIntlProvider as C, ErrorBoundary as E, FetchProject as F, InjectReducers as I, ProjectDataLocale as P, RedirectToLogin as R, SetupFlopFlipProvider as S, RedirectToProjectCreate as a, ApplicationLoader as b, REQUESTS_IN_FLIGHT_LOADER_DOM_ID as c, ProjectSwitcher as d, ApplicationShellProvider as e, ApplicationPageTitle as f, getBrowserLocale as g, CustomViewShellWrapper as h, FetchUser as i, ErrorApologizer as j, RedirectToLogout as k, SuspendedRoute as l, ProtectedRoute as m, SuspendedProtectedRoute as n, getPreviousProjectKey as o, pimIndexerStates as p, setupGlobalErrorListener as s, useRoutesCreator as u, version as v };
1931
+ export { ApplicationShell as A, ConfigureIntlProvider as C, ErrorBoundary as E, FetchProject as F, InjectReducers as I, ProjectSwitcher as P, RedirectToLogin as R, SetupFlopFlipProvider as S, RedirectToProjectCreate as a, ApplicationLoader as b, REQUESTS_IN_FLIGHT_LOADER_DOM_ID as c, ApplicationShellProvider as d, ApplicationPageTitle as e, CustomViewShellWrapper as f, getBrowserLocale as g, FetchUser as h, ErrorApologizer as i, RedirectToLogout as j, SuspendedRoute as k, ProtectedRoute as l, SuspendedProtectedRoute as m, getPreviousProjectKey as n, setupGlobalErrorListener as s, useRoutesCreator as u, version as v };