@commercetools-frontend/application-shell 24.11.0 → 24.13.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{application-entry-point-c87294b0.cjs.dev.js → application-entry-point-18d8fba0.cjs.dev.js} +7 -4
- package/dist/{application-entry-point-10a5e1a5.esm.js → application-entry-point-1b23fb6b.esm.js} +6 -4
- package/dist/{application-entry-point-8c4b8e53.cjs.prod.js → application-entry-point-74a06151.cjs.prod.js} +4 -3
- package/dist/commercetools-frontend-application-shell.cjs.dev.js +12 -11
- package/dist/commercetools-frontend-application-shell.cjs.prod.js +12 -11
- package/dist/commercetools-frontend-application-shell.esm.js +12 -11
- package/dist/{custom-view-dev-host-6091b78a.esm.js → custom-view-dev-host-b4f856d8.esm.js} +20 -16
- package/dist/{custom-view-dev-host-3a171a01.cjs.prod.js → custom-view-dev-host-bf11de47.cjs.prod.js} +21 -16
- package/dist/{custom-view-dev-host-40b33836.cjs.dev.js → custom-view-dev-host-f688743e.cjs.dev.js} +21 -16
- package/dist/declarations/src/types/generated/mc.d.ts +9 -8
- package/dist/declarations-connectors/src/components/application-context/index.d.ts +2 -3
- package/dist/declarations-connectors/src/components/application-context/normalizers.d.ts +1 -5
- package/dist/declarations-connectors/src/export-types.d.ts +1 -2
- package/dist/declarations-connectors/src/index.d.ts +1 -1
- package/dist/declarations-connectors/src/types/generated/mc.d.ts +9 -8
- package/dist/{index-7bdde97c.cjs.prod.js → index-242af4d2.cjs.prod.js} +201 -344
- package/dist/{index-614accc4.cjs.dev.js → index-25183095.cjs.dev.js} +2 -2
- package/dist/{index-245e2980.cjs.prod.js → index-52c724ed.cjs.prod.js} +2 -2
- package/dist/{index-86039df7.esm.js → index-5aaa33bb.esm.js} +2 -2
- package/dist/{index-67a5d8e8.esm.js → index-d8c26ca0.esm.js} +214 -363
- package/dist/{index-a57c8458.cjs.dev.js → index-dcd3d8a3.cjs.dev.js} +213 -364
- package/dist/{navbar-844d350d.esm.js → navbar-0bad8bc8.esm.js} +106 -110
- package/dist/{navbar-acc2cd1b.cjs.prod.js → navbar-7653417f.cjs.prod.js} +108 -112
- package/dist/{navbar-022383bd.cjs.dev.js → navbar-d4189469.cjs.dev.js} +108 -112
- package/dist/oidc-258fc018.cjs.prod.js +115 -0
- package/dist/oidc-35e8e62a.esm.js +100 -0
- package/dist/oidc-87d116c1.cjs.dev.js +115 -0
- package/dist/{oidc-callback-e07f0c20.cjs.dev.js → oidc-callback-11dae6b7.cjs.dev.js} +16 -14
- package/dist/{oidc-callback-ce8cbdfe.cjs.prod.js → oidc-callback-300966ee.cjs.prod.js} +16 -14
- package/dist/{oidc-callback-5f3d5280.esm.js → oidc-callback-82aa6be5.esm.js} +16 -14
- package/dist/{project-container-2d3d027a.cjs.prod.js → project-container-2f98a9d6.cjs.prod.js} +53 -19
- package/dist/{project-container-a11a31ca.cjs.dev.js → project-container-991a64a8.cjs.dev.js} +53 -19
- package/dist/{project-container-fba09841.esm.js → project-container-ce0f6228.esm.js} +52 -19
- package/dist/{project-expired-ede4d485.esm.js → project-expired-49e78c8c.esm.js} +12 -11
- package/dist/{project-expired-f38a712a.cjs.prod.js → project-expired-f753ba58.cjs.prod.js} +12 -11
- package/dist/{project-expired-9620dee4.cjs.dev.js → project-expired-fa4a86df.cjs.dev.js} +12 -11
- package/dist/{project-not-found-05683f8e.cjs.dev.js → project-not-found-261f37e8.cjs.dev.js} +11 -10
- package/dist/{project-not-found-093ab795.esm.js → project-not-found-ac82676b.esm.js} +11 -10
- package/dist/{project-not-found-cfa934da.cjs.prod.js → project-not-found-d594db71.cjs.prod.js} +11 -10
- package/dist/{project-not-initialized-1d934ae7.esm.js → project-not-initialized-4c02d4b2.esm.js} +12 -11
- package/dist/{project-not-initialized-b5a1400f.cjs.prod.js → project-not-initialized-5a77d844.cjs.prod.js} +12 -11
- package/dist/{project-not-initialized-1ed56a00.cjs.dev.js → project-not-initialized-c3a87ba6.cjs.dev.js} +12 -11
- package/dist/{project-suspended-68e80299.cjs.dev.js → project-suspended-42a90ea6.cjs.dev.js} +11 -10
- package/dist/{project-suspended-e0722654.esm.js → project-suspended-cd66814e.esm.js} +11 -10
- package/dist/{project-suspended-8e15a452.cjs.prod.js → project-suspended-dccadfd7.cjs.prod.js} +11 -10
- package/dist/{redirect-to-login-12f467b8.cjs.prod.js → redirect-to-login-3e4a6434.cjs.prod.js} +13 -10
- package/dist/{redirect-to-login-3bee13ba.cjs.dev.js → redirect-to-login-66ea895a.cjs.dev.js} +13 -10
- package/dist/{redirect-to-login-2944c890.esm.js → redirect-to-login-edbfacbc.esm.js} +13 -10
- package/dist/{redirect-to-logout-2802852c.cjs.prod.js → redirect-to-logout-99db4db7.cjs.prod.js} +14 -12
- package/dist/{redirect-to-logout-74b72fe8.cjs.dev.js → redirect-to-logout-ab0c374b.cjs.dev.js} +14 -12
- package/dist/{redirect-to-logout-5db48f16.esm.js → redirect-to-logout-ba40d106.esm.js} +14 -12
- package/dist/{redirector-72ccfbc2.cjs.dev.js → redirector-0efdd994.cjs.dev.js} +4 -3
- package/dist/{redirector-d856975f.esm.js → redirector-656c6ee7.esm.js} +4 -3
- package/dist/{redirector-0c72d0a4.cjs.prod.js → redirector-c858d578.cjs.prod.js} +4 -3
- package/dist/{requests-in-flight-loader-e25f4c31.esm.js → requests-in-flight-loader-64a40481.esm.js} +11 -10
- package/dist/{requests-in-flight-loader-bc904171.cjs.dev.js → requests-in-flight-loader-878840c1.cjs.dev.js} +11 -10
- package/dist/{requests-in-flight-loader-877c1541.cjs.prod.js → requests-in-flight-loader-df9d1de3.cjs.prod.js} +11 -10
- package/dist/{service-page-project-switcher-af044ac6.cjs.dev.js → service-page-project-switcher-0f1c1d7f.cjs.dev.js} +1 -1
- package/dist/{service-page-project-switcher-1dad9871.cjs.prod.js → service-page-project-switcher-532df57f.cjs.prod.js} +1 -1
- package/dist/{service-page-project-switcher-f3eac18a.esm.js → service-page-project-switcher-aca41b09.esm.js} +1 -1
- package/dist/{use-applications-menu-14a5a1f4.cjs.prod.js → use-applications-menu-21c7420b.cjs.prod.js} +48 -40
- package/dist/{use-applications-menu-823a2492.cjs.dev.js → use-applications-menu-7a85c3ee.cjs.dev.js} +48 -40
- package/dist/{use-applications-menu-1514af11.esm.js → use-applications-menu-8ff2d130.esm.js} +45 -38
- package/dist/{user-settings-menu-d75f4958.cjs.prod.js → user-settings-menu-2d3bfa75.cjs.prod.js} +29 -22
- package/dist/{user-settings-menu-f98bea89.esm.js → user-settings-menu-31e6bb38.esm.js} +29 -22
- package/dist/{user-settings-menu-6113cdd3.cjs.dev.js → user-settings-menu-c37b343f.cjs.dev.js} +29 -22
- package/package.json +16 -16
- package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.dev.js +2 -1
- package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.prod.js +2 -1
- package/ssr/dist/commercetools-frontend-application-shell-ssr.esm.js +2 -1
- package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.dev.js +26 -22
- package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.prod.js +26 -22
- package/test-utils/dist/commercetools-frontend-application-shell-test-utils.esm.js +20 -17
- package/dist/oidc-8827f9fe.cjs.dev.js +0 -98
- package/dist/oidc-b2520905.esm.js +0 -84
- package/dist/oidc-d74e6aa2.cjs.prod.js +0 -98
- package/dist/quick-access-9dd197bb.cjs.prod.js +0 -1875
- package/dist/quick-access-a665bbb7.cjs.dev.js +0 -1893
- package/dist/quick-access-dfc1f8a9.esm.js +0 -1865
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { lazy, useEffect,
|
|
2
|
-
import { useLocation,
|
|
3
|
-
import { R as RouteCatchAll, i as internalReduxStore } from './index-
|
|
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-
|
|
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.
|
|
75
|
+
var version = "24.13.0";
|
|
74
76
|
|
|
75
|
-
const RequestsInFlightLoader = /*#__PURE__*/lazy(() => import('./requests-in-flight-loader-
|
|
77
|
+
const RequestsInFlightLoader = /*#__PURE__*/lazy(() => import('./requests-in-flight-loader-64a40481.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(
|
|
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
|
-
|
|
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__$
|
|
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__$
|
|
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
|
-
|
|
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(
|
|
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-
|
|
359
|
+
const UserSettingsMenu = /*#__PURE__*/lazy(() => import('./user-settings-menu-31e6bb38.esm.js' /* webpackChunkName: "user-settings-menu" */));
|
|
363
360
|
|
|
364
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
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__$
|
|
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__$
|
|
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__$
|
|
384
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
388
385
|
};
|
|
389
386
|
const AppBar = props => {
|
|
390
|
-
|
|
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
|
|
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
|
|
@@ -509,7 +507,7 @@ ConfigureIntlProvider.displayName = 'ConfigureIntlProvider';
|
|
|
509
507
|
|
|
510
508
|
const ErrorApologizer = /*#__PURE__*/lazy(() => import('./error-apologizer-76f087f4.esm.js' /* webpackChunkName: "error-apologizer" */));
|
|
511
509
|
|
|
512
|
-
var ProjectQuery = { kind: "Document", definitions: [{ kind: "OperationDefinition", operation: "query", name: { kind: "Name", value: "FetchProject" }, variableDefinitions: [{ kind: "VariableDefinition", variable: { kind: "Variable", name: { kind: "Name", value: "projectKey" } }, type: { kind: "NamedType", name: { kind: "Name", value: "String" } }, directives: [] }], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "project" }, arguments: [{ kind: "Argument", name: { kind: "Name", value: "key" }, value: { kind: "Variable", name: { kind: "Name", value: "projectKey" } } }], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "key" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "version" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "countries" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "currencies" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "languages" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "initialized" }, 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: "daysLeft" }, 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: "reason" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "isProductionProject" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "allAppliedPermissions" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "allAppliedActionRights" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "group" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "allAppliedDataFences" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "InlineFragment", typeCondition: { kind: "NamedType", name: { kind: "Name", value: "StoreDataFence" } }, directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "type" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "group" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "__typename" }, arguments: [], directives: [] }] } }] } }, { kind: "Field", name: { kind: "Name", value: "allPermissionsForAllApplications" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "allAppliedPermissions" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "allAppliedActionRights" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "group" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "
|
|
510
|
+
var ProjectQuery = { kind: "Document", definitions: [{ kind: "OperationDefinition", operation: "query", name: { kind: "Name", value: "FetchProject" }, variableDefinitions: [{ kind: "VariableDefinition", variable: { kind: "Variable", name: { kind: "Name", value: "projectKey" } }, type: { kind: "NamedType", name: { kind: "Name", value: "String" } }, directives: [] }], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "project" }, arguments: [{ kind: "Argument", name: { kind: "Name", value: "key" }, value: { kind: "Variable", name: { kind: "Name", value: "projectKey" } } }], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "key" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "version" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "countries" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "currencies" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "languages" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "initialized" }, 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: "daysLeft" }, 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: "reason" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "isProductionProject" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "allAppliedPermissions" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "allAppliedActionRights" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "group" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "allAppliedDataFences" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "InlineFragment", typeCondition: { kind: "NamedType", name: { kind: "Name", value: "StoreDataFence" } }, directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "type" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "group" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "__typename" }, arguments: [], directives: [] }] } }] } }, { kind: "Field", name: { kind: "Name", value: "allPermissionsForAllApplications" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "allAppliedPermissions" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "allAppliedActionRights" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "group" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "allAppliedDataFences" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "InlineFragment", typeCondition: { kind: "NamedType", name: { kind: "Name", value: "StoreDataFence" } }, directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "type" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "value" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "group" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "__typename" }, arguments: [], directives: [] }] } }] } }] } }, { kind: "Field", name: { kind: "Name", value: "owner" }, arguments: [], directives: [], selectionSet: { kind: "SelectionSet", selections: [{ kind: "Field", name: { kind: "Name", value: "id" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "name" }, arguments: [], directives: [] }] } }, { kind: "Field", name: { kind: "Name", value: "sampleDataImportDataset" }, arguments: [], directives: [] }, { kind: "Field", name: { kind: "Name", value: "isUserAdminOfCurrentProject" }, arguments: [], directives: [] }] } }] } }], loc: { start: 0, end: 1011, source: { body: "query FetchProject($projectKey: String) {\n project(key: $projectKey) {\n key\n version\n name\n countries\n currencies\n languages\n initialized\n expiry {\n isActive\n daysLeft\n }\n suspension {\n isActive\n reason\n }\n isProductionProject\n allAppliedPermissions {\n name\n value\n }\n allAppliedActionRights {\n group\n name\n value\n }\n allAppliedDataFences {\n ... on StoreDataFence {\n type\n name\n value\n group\n __typename\n }\n }\n allPermissionsForAllApplications {\n allAppliedPermissions {\n name\n value\n }\n allAppliedActionRights {\n group\n name\n value\n }\n allAppliedDataFences {\n ... on StoreDataFence {\n type\n name\n value\n group\n __typename\n }\n }\n }\n owner {\n id\n name\n }\n sampleDataImportDataset\n isUserAdminOfCurrentProject\n }\n}\n", name: "GraphQL request", locationOffset: { line: 1, column: 1 } } } };
|
|
513
511
|
const FetchProject = props => {
|
|
514
512
|
const _useMcQuery = useMcQuery(ProjectQuery, {
|
|
515
513
|
variables: {
|
|
@@ -555,207 +553,11 @@ const FetchUser = props => {
|
|
|
555
553
|
};
|
|
556
554
|
FetchUser.displayName = 'FetchUser';
|
|
557
555
|
|
|
558
|
-
const Navbar = /*#__PURE__*/lazy(() => import('./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-0bad8bc8.esm.js' /* webpackChunkName: "navbar" */));
|
|
648
557
|
|
|
649
|
-
|
|
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-ce0f6228.esm.js' /* webpackChunkName: "project-container" */));
|
|
663
559
|
|
|
664
|
-
|
|
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-ba40d106.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
|
|
773
|
-
project: projectKey
|
|
774
|
-
id: user
|
|
775
|
-
team: user
|
|
776
|
-
group: user
|
|
777
|
-
subgroup: user
|
|
778
|
-
cloudEnvironment: user
|
|
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
|
-
|
|
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
|
|
617
|
+
key: (_props$user = props.user) === null || _props$user === void 0 ? void 0 : _props$user.id
|
|
836
618
|
},
|
|
837
|
-
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
|
|
844
|
-
|
|
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
|
-
|
|
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
|
-
}
|
|
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
|
|
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
|
|
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
|
|
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:
|
|
1101
|
-
let isLoadingProject =
|
|
1102
|
-
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
|
|
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:
|
|
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
|
-
|
|
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__
|
|
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__
|
|
1375
|
-
|
|
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
|
-
|
|
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__
|
|
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
|
|
1398
|
-
oAuthScopes: window.app.__DEVELOPMENT__
|
|
1399
|
-
additionalOAuthScopes: window.app.__DEVELOPMENT__
|
|
1400
|
-
teamId: window.app.__DEVELOPMENT__
|
|
1401
|
-
applicationId: window.app.__DEVELOPMENT__
|
|
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-
|
|
1199
|
+
const OidcCallback = /*#__PURE__*/lazy(() => import('./oidc-callback-82aa6be5.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__
|
|
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:
|
|
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:
|
|
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(() =>
|
|
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-
|
|
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
|
-
|
|
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-
|
|
1474
|
+
const CustomViewDevHost = /*#__PURE__*/lazy(() => import('./custom-view-dev-host-b4f856d8.esm.js' /* webpackChunkName: "custom-view-dev-host" */));
|
|
1633
1475
|
|
|
1634
1476
|
function CustomViewFlopFlipProvider(props) {
|
|
1635
|
-
|
|
1636
|
-
|
|
1637
|
-
|
|
1638
|
-
|
|
1639
|
-
|
|
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
|
|
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:
|
|
1739
|
-
paddingForDetailPageHeader:
|
|
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
|
|
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(
|
|
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
|
-
|
|
1674
|
+
var _iFrameCommunicationP, _context;
|
|
1675
|
+
(_iFrameCommunicationP = iFrameCommunicationPort.current) === null || _iFrameCommunicationP === void 0 || _iFrameCommunicationP.postMessage({
|
|
1828
1676
|
origin: window.location.origin,
|
|
1829
|
-
source:
|
|
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
|
|
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
|
-
|
|
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__
|
|
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:
|
|
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
|
|
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
|
-
|
|
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,
|
|
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 };
|