@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
|
@@ -2,12 +2,13 @@ import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
|
2
2
|
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
3
3
|
import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
|
|
4
4
|
import _startsWithInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/starts-with';
|
|
5
|
-
import
|
|
6
|
-
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
5
|
+
import _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
7
6
|
import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
|
|
8
7
|
import _Number$isFinite from '@babel/runtime-corejs3/core-js-stable/number/is-finite';
|
|
8
|
+
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
9
9
|
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
10
10
|
import _Object$getOwnPropertySymbols from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols';
|
|
11
|
+
import _filterInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/filter';
|
|
11
12
|
import _Object$getOwnPropertyDescriptor from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor';
|
|
12
13
|
import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/for-each';
|
|
13
14
|
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
@@ -17,19 +18,19 @@ import { forwardRef, Fragment as Fragment$1, lazy, useRef, useReducer, useCallba
|
|
|
17
18
|
import snakeCase from 'lodash/snakeCase';
|
|
18
19
|
import { defineMessages, useIntl, FormattedMessage } from 'react-intl';
|
|
19
20
|
import { NavLink, matchPath, useLocation } from 'react-router-dom';
|
|
20
|
-
import { useMcQuery, normalizeAllAppliedPermissions, normalizeAllAppliedActionRights, normalizeAllAppliedDataFences
|
|
21
|
+
import { useMcQuery, normalizeAllAppliedPermissions, normalizeAllAppliedActionRights, normalizeAllAppliedDataFences } from '@commercetools-frontend/application-shell-connectors';
|
|
21
22
|
import LogoSVG from '@commercetools-frontend/assets/logos/commercetools_small-logo.svg';
|
|
22
23
|
import { NO_VALUE_FALLBACK, GRAPHQL_TARGETS, STORAGE_KEYS, SUPPORT_PORTAL_URL } from '@commercetools-frontend/constants';
|
|
23
24
|
import { SidebarCollapseIcon, SidebarExpandIcon, SupportIcon } from '@commercetools-uikit/icons';
|
|
24
25
|
import Spacings from '@commercetools-uikit/spacings';
|
|
26
|
+
import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
|
|
25
27
|
import _styled from '@emotion/styled/base';
|
|
26
28
|
import { keyframes, css, Global } from '@emotion/react';
|
|
27
29
|
import { designTokens as designTokens$1 } from '@commercetools-frontend/application-components';
|
|
28
30
|
import { designTokens } from '@commercetools-uikit/design-system';
|
|
29
|
-
import { N as NAVBAR, D as DIMENSIONS, W as WINDOW_SIZES } from './oidc-
|
|
31
|
+
import { N as NAVBAR, D as DIMENSIONS, W as WINDOW_SIZES } from './oidc-35e8e62a.esm.js';
|
|
30
32
|
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
31
33
|
import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes';
|
|
32
|
-
import _everyInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/every';
|
|
33
34
|
import { useFlagVariation } from '@flopflip/react-broadcast';
|
|
34
35
|
import classnames from 'classnames';
|
|
35
36
|
import MissingImageSvg from '@commercetools-frontend/assets/images/diagonal-line.svg';
|
|
@@ -41,7 +42,7 @@ import _keysInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instanc
|
|
|
41
42
|
import _sortInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/sort';
|
|
42
43
|
import isNil from 'lodash/isNil';
|
|
43
44
|
import throttle from 'lodash/throttle';
|
|
44
|
-
import { u as useApplicationsMenu } from './use-applications-menu-
|
|
45
|
+
import { u as useApplicationsMenu } from './use-applications-menu-8ff2d130.esm.js';
|
|
45
46
|
import '@apollo/client';
|
|
46
47
|
import '@commercetools-frontend/l10n';
|
|
47
48
|
|
|
@@ -85,6 +86,7 @@ const Title = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production"
|
|
|
85
86
|
label: "Title"
|
|
86
87
|
})("flex:1;font-weight:600;font-size:", designTokens.fontSize20, ";line-height:", designTokens.lineHeight20, ";color:", designTokens.colorNeutral, ";opacity:0;transition:", NAVBAR.leftNavigationTransition, ";text-align:left;text-decoration:none;z-index:1;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNoYXJlZC5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJ3QiIsImZpbGUiOiJzaGFyZWQuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIGFzIHVpS2l0RGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBOQVZCQVIgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIHdpZHRoOiBhdXRvO1xuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbmA7XG5jb25zdCBJY29uID0gc3R5bGVkLmRpdmBcbiAgd2lkdGg6ICR7TkFWQkFSLmljb25TaXplfTtcbiAgaGVpZ2h0OiAke05BVkJBUi5pY29uU2l6ZX07XG4gIHRyYW5zaXRpb246ICR7TkFWQkFSLmxlZnROYXZpZ2F0aW9uVHJhbnNpdGlvbn07XG5cbiAgPiBzdmcgKjpub3QoW2ZpbGw9J25vbmUnXSkge1xuICAgIGZpbGw6ICR7dWlLaXREZXNpZ25Ub2tlbnMuY29sb3JTdXJmYWNlfTtcbiAgfVxuYDtcblxuY29uc3QgSXRlbUljb25UZXh0ID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBUaXRsZSA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIGZvbnQtc2l6ZTogJHt1aUtpdERlc2lnblRva2Vucy5mb250U2l6ZTIwfTtcbiAgbGluZS1oZWlnaHQ6ICR7dWlLaXREZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgY29sb3I6ICR7dWlLaXREZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsfTtcbiAgb3BhY2l0eTogMDtcbiAgdHJhbnNpdGlvbjogJHtOQVZCQVIubGVmdE5hdmlnYXRpb25UcmFuc2l0aW9ufTtcbiAgdGV4dC1hbGlnbjogbGVmdDtcbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICB6LWluZGV4OiAxO1xuYDtcblxuZXhwb3J0IHsgSWNvbiwgSWNvbldyYXBwZXIsIEl0ZW1JY29uVGV4dCwgVGl0bGUgfTtcbiJdfQ== */"));
|
|
87
88
|
|
|
89
|
+
var _templateObject$1;
|
|
88
90
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { 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)."; }
|
|
89
91
|
const getSubmenuPositionBasedOnMenuItemPosition = (isSubmenuAboveMenuItem, submenuVerticalPosition) => /*#__PURE__*/css(isSubmenuAboveMenuItem ? 'bottom' : 'top', ":", submenuVerticalPosition, "px;" + (process.env.NODE_ENV === "production" ? "" : ";label:getSubmenuPositionBasedOnMenuItemPosition;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["menu-items.styles.ts"],"names":[],"mappings":"AAWQ","file":"menu-items.styles.ts","sourcesContent":["import { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { designTokens as appKitDesignTokens } from '@commercetools-frontend/application-components';\nimport { designTokens as uiKitDesignTokens } from '@commercetools-uikit/design-system';\nimport { NAVBAR } from '../../constants';\nimport type { MenuGroupProps } from './menu-items';\nimport { Icon, IconWrapper, ItemIconText, Title } from './shared.styles';\n\nconst getSubmenuPositionBasedOnMenuItemPosition = (\n  isSubmenuAboveMenuItem?: boolean,\n  submenuVerticalPosition?: number\n) => css`\n  ${isSubmenuAboveMenuItem ? 'bottom' : 'top'}: ${submenuVerticalPosition}px\n`;\n\nconst getContainerPositionBasedOnMenuItemPosition = (\n  isSubmenuAboveMenuItem?: boolean,\n  isSublistActiveWhileIsMenuExpanded?: boolean,\n  isSublistActiveWhileIsMenuCollapsed?: boolean\n) => [\n  isSublistActiveWhileIsMenuCollapsed &&\n    css`\n      ${isSubmenuAboveMenuItem ? 'bottom' : 'top'}: -${NAVBAR.itemSize};\n    `,\n  isSublistActiveWhileIsMenuExpanded &&\n    isSubmenuAboveMenuItem &&\n    css`\n      bottom: 0;\n    `,\n  isSublistActiveWhileIsMenuExpanded &&\n    !isSubmenuAboveMenuItem &&\n    css`\n      top: 0;\n    `,\n];\n\nconst fadeIn = keyframes`\nfrom {opacity: 0;}\n  to { opacity: 1;}\n`;\n\nconst Expander = styled.li<{ isVisible: boolean }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background: ${uiKitDesignTokens.colorPrimary10};\n  padding: ${uiKitDesignTokens.spacing30} ${uiKitDesignTokens.spacing25};\n  ${(props) =>\n    !props.isVisible &&\n    css`\n      display: none;\n    `}\n\n  /* Divider */\n  ::before {\n    content: '';\n    position: absolute;\n    top: ${NAVBAR.itemHeight};\n    height: 1px;\n    background: rgba(255, 255, 255, 0.5);\n    width: calc(100% - 2 * ${uiKitDesignTokens.spacing30});\n  }\n`;\n\nconst ExpanderIcon = styled.div`\n  height: ${NAVBAR.expanderSize};\n  width: ${NAVBAR.expanderSize};\n  border-radius: ${uiKitDesignTokens.borderRadius4};\n  padding: ${uiKitDesignTokens.spacing20};\n  background: rgba(255, 255, 255, 0.2);\n  display: flex;\n  justify-content: center;\n  align-items: center;\n\n  :hover,\n  :focus {\n    background: rgba(255, 255, 255, 0.3);\n    cursor: pointer;\n  }\n`;\n\nconst LeftNavigation = styled.nav`\n  display: grid;\n  width: ${NAVBAR.widthLeftNavigation};\n  background: ${appKitDesignTokens.backgroundColorForNavbar};\n  height: 100%;\n  grid-template-rows: 56px 1fr;\n  transition: ${NAVBAR.leftNavigationTransition};\n`;\n\nconst TextLinkSublistWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n`;\n\nconst NavlinkClickableContent = styled.div`\n  height: 100%;\n  width: 100%;\n  display: block;\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  -webkit-box-orient: vertical;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  transition: all 150ms ease-out;\n\n  position: relative;\n  left: calc(-1 * ${uiKitDesignTokens.spacing20});\n`;\n\nconst listStyles = css`\n  margin: 0;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  min-height: 0;\n  flex: 1 1 0;\n`;\n\nconst sublistStyles = css`\n  padding: ${uiKitDesignTokens.spacing30};\n  font-weight: ${uiKitDesignTokens.fontWeight400};\n  font-size: ${uiKitDesignTokens.fontSize20};\n  background-color: ${uiKitDesignTokens.colorAccent10};\n  left: ${NAVBAR.sublistIndentationWhenCollapsed};\n  z-index: -1;\n  list-style: none;\n  position: fixed;\n  display: none;\n`;\n\nconst MenuList = styled.ul<\n  MenuGroupProps & {\n    isSublistActiveWhileIsMenuExpanded: boolean;\n    isSublistActiveWhileIsMenuCollapsed: boolean;\n    isSublistCollapsedAndActive: boolean;\n    isSublistCollapsedAndActiveAndAbove: boolean;\n  }\n>`\n  ${(props) => [\n    props.level === 1 && listStyles,\n    getSubmenuPositionBasedOnMenuItemPosition(\n      props.isSubmenuAboveMenuItem,\n      props.submenuVerticalPosition\n    ),\n    props.level === 2 && sublistStyles,\n    // prevent glitchy behavior during the initial render when the submenu's vertical position is evaluated as 0\n    props.submenuVerticalPosition === 0 &&\n      css`\n        visibility: hidden;\n      `,\n    (props.isSublistActiveWhileIsMenuExpanded ||\n      props.isSublistCollapsedAndActive ||\n      props.isSublistCollapsedAndActiveAndAbove) &&\n      css`\n        opacity: 0;\n        display: none;\n        text-align: left;\n        background-color: ${uiKitDesignTokens.colorAccent20};\n\n        /* This pseudo-element is required to enable smooth coursor movement from the main menu item to submenu items with the gap in between */\n        ::before {\n          content: '';\n          position: absolute;\n          display: block;\n          width: calc(${NAVBAR.sublistWidth} + ${uiKitDesignTokens.spacing20});\n          height: ${NAVBAR.itemSize};\n          left: calc(-1 * ${uiKitDesignTokens.spacing20});\n\n          ${getContainerPositionBasedOnMenuItemPosition(\n            props.isSubmenuAboveMenuItem,\n            props.isSublistActiveWhileIsMenuExpanded,\n            props.isSublistActiveWhileIsMenuCollapsed\n          )}\n        }\n      `,\n  ]}\n\n  & .highlighted,\n  & .highlighted ${Title} {\n    color: ${uiKitDesignTokens.colorSurface} !important;\n    font-weight: ${uiKitDesignTokens.fontWeight600};\n  }\n`;\n\nconst SublistItem = styled.li<{ isActive: boolean }>`\n  display: flex;\n  align-items: center;\n  align-self: stretch;\n  border-radius: ${uiKitDesignTokens.borderRadius4};\n\n  ${(props) => [\n    props.isActive &&\n      css`\n        background: ${uiKitDesignTokens.colorPrimary40};\n      `,\n    !props.isActive &&\n      css`\n        :hover,\n        :focus-within {\n          color: ${uiKitDesignTokens.colorSurface};\n          font-weight: ${uiKitDesignTokens.fontWeight600};\n          border-radius: ${uiKitDesignTokens.borderRadius4};\n          background: ${uiKitDesignTokens.colorPrimary95};\n\n          [data-link-level='text-link-sublist'] {\n            > ${NavlinkClickableContent} {\n              left: 0;\n            }\n          }\n        }\n      `,\n  ]}\n`;\n\nconst MenuListItem = styled.li<{\n  isActive: boolean;\n  isRouteActive: boolean;\n  isCollapsed: boolean;\n}>`\n  height: ${NAVBAR.itemSize};\n  width: ${NAVBAR.itemSize};\n  margin: 0;\n  background: ${appKitDesignTokens.backgroundColorForNavbar};\n  list-style: none;\n  cursor: pointer;\n\n  ${IconWrapper} {\n    width: auto;\n    display: flex;\n    justify-content: center;\n  }\n\n  ${(props) => [\n    props.isRouteActive &&\n      css`\n        background: ${uiKitDesignTokens.colorPrimary25};\n        border-radius: ${uiKitDesignTokens.borderRadius8};\n      `,\n    !props.isRouteActive &&\n      css`\n        :hover,\n        :focus-within {\n          background-color: ${uiKitDesignTokens.colorPrimary20};\n          border-radius: ${uiKitDesignTokens.borderRadius8};\n        }\n      `,\n    props.isActive &&\n      css`\n        ${ItemIconText} {\n          justify-content: flex-start;\n        }\n      `,\n    !props.isActive &&\n      css`\n        :hover ${Icon} > svg *:not([fill='none']),\n        :focus-within ${Icon} > svg *:not([fill='none']) {\n          fill: ${uiKitDesignTokens.colorSurface};\n        }\n\n        :hover .${Title}, :focus-within ${Title} {\n          color: ${uiKitDesignTokens.colorSurface};\n        }\n      `,\n    props.isCollapsed &&\n      css`\n        text-align: center;\n      `,\n  ]}\n\n  :hover ${Title},\n  :focus-within ${Title} {\n    margin-left: calc(${uiKitDesignTokens.spacing25} + 2px);\n  }\n\n  :hover ${Icon}, :focus-within ${Icon} {\n    /* 1.16 is roughly the ratio of NAVBAR.iconSizeHover to NAVBAR.iconSize */\n    transform: scale(1.2);\n  }\n\n  :hover\n    ${MenuList}.sublist-collapsed__active,\n    :hover\n    ${MenuList}.sublist-collapsed__active__above,\n    :hover\n    ${MenuList}.sublist-expanded__active,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active__above,\n    :focus-within\n    ${MenuList}.sublist-expanded__active {\n    animation-name: ${fadeIn};\n    animation-duration: 16ms;\n    animation-delay: 100ms;\n    animation-fill-mode: forwards;\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    background-color: ${uiKitDesignTokens.colorSurface};\n    min-height: ${NAVBAR.sublistItemMinHeight};\n    width: ${NAVBAR.sublistWidth};\n    border-radius: ${uiKitDesignTokens.borderRadius8};\n    /* z-index value must be higher than AppBar's z-index */\n    z-index: 20001;\n    box-shadow: -2px 4px 25px 0 rgba(89, 89, 89, 0.5);\n  }\n\n  :hover\n    ${MenuList}.sublist-collapsed__active.sublist-collapsed__empty,\n    :hover\n    ${MenuList}.sublist-collapsed__active__above.sublist-collapsed__empty,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active.sublist-collapsed__empty,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active__above.sublist-collapsed__empty {\n    visibility: hidden;\n  }\n\n  :hover\n    ${MenuList}.sublist-expanded__active,\n    :focus-within\n    ${MenuList}.sublist-expanded__active {\n    left: ${NAVBAR.sublistIndentationWhenExpanded};\n  }\n`;\n\nconst SafeArea = styled.span`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 100%;\n  /** Ensure the full width of the safe triangle is 100% of the scrollable menu area, less of its left padding (16px)\n   * which is also the starting point of the safe triangle/menu item.\n   */\n  width: calc(100% - ${uiKitDesignTokens.spacing30});\n  clip-path: polygon(var(--safe-start), 100% 100%, 100% 0);\n`;\n\nexport {\n  Expander,\n  ExpanderIcon,\n  LeftNavigation,\n  MenuList,\n  MenuListItem,\n  SublistItem,\n  TextLinkSublistWrapper,\n  NavlinkClickableContent,\n  SafeArea,\n};\n"]} */");
|
|
90
92
|
var _ref4 = process.env.NODE_ENV === "production" ? {
|
|
@@ -104,10 +106,7 @@ var _ref5 = process.env.NODE_ENV === "production" ? {
|
|
|
104
106
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
105
107
|
};
|
|
106
108
|
const getContainerPositionBasedOnMenuItemPosition = (isSubmenuAboveMenuItem, isSublistActiveWhileIsMenuExpanded, isSublistActiveWhileIsMenuCollapsed) => [isSublistActiveWhileIsMenuCollapsed && /*#__PURE__*/css(isSubmenuAboveMenuItem ? 'bottom' : 'top', ":-", NAVBAR.itemSize, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getContainerPositionBasedOnMenuItemPosition;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["menu-items.styles.ts"],"names":[],"mappings":"AAqBO","file":"menu-items.styles.ts","sourcesContent":["import { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { designTokens as appKitDesignTokens } from '@commercetools-frontend/application-components';\nimport { designTokens as uiKitDesignTokens } from '@commercetools-uikit/design-system';\nimport { NAVBAR } from '../../constants';\nimport type { MenuGroupProps } from './menu-items';\nimport { Icon, IconWrapper, ItemIconText, Title } from './shared.styles';\n\nconst getSubmenuPositionBasedOnMenuItemPosition = (\n  isSubmenuAboveMenuItem?: boolean,\n  submenuVerticalPosition?: number\n) => css`\n  ${isSubmenuAboveMenuItem ? 'bottom' : 'top'}: ${submenuVerticalPosition}px\n`;\n\nconst getContainerPositionBasedOnMenuItemPosition = (\n  isSubmenuAboveMenuItem?: boolean,\n  isSublistActiveWhileIsMenuExpanded?: boolean,\n  isSublistActiveWhileIsMenuCollapsed?: boolean\n) => [\n  isSublistActiveWhileIsMenuCollapsed &&\n    css`\n      ${isSubmenuAboveMenuItem ? 'bottom' : 'top'}: -${NAVBAR.itemSize};\n    `,\n  isSublistActiveWhileIsMenuExpanded &&\n    isSubmenuAboveMenuItem &&\n    css`\n      bottom: 0;\n    `,\n  isSublistActiveWhileIsMenuExpanded &&\n    !isSubmenuAboveMenuItem &&\n    css`\n      top: 0;\n    `,\n];\n\nconst fadeIn = keyframes`\nfrom {opacity: 0;}\n  to { opacity: 1;}\n`;\n\nconst Expander = styled.li<{ isVisible: boolean }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background: ${uiKitDesignTokens.colorPrimary10};\n  padding: ${uiKitDesignTokens.spacing30} ${uiKitDesignTokens.spacing25};\n  ${(props) =>\n    !props.isVisible &&\n    css`\n      display: none;\n    `}\n\n  /* Divider */\n  ::before {\n    content: '';\n    position: absolute;\n    top: ${NAVBAR.itemHeight};\n    height: 1px;\n    background: rgba(255, 255, 255, 0.5);\n    width: calc(100% - 2 * ${uiKitDesignTokens.spacing30});\n  }\n`;\n\nconst ExpanderIcon = styled.div`\n  height: ${NAVBAR.expanderSize};\n  width: ${NAVBAR.expanderSize};\n  border-radius: ${uiKitDesignTokens.borderRadius4};\n  padding: ${uiKitDesignTokens.spacing20};\n  background: rgba(255, 255, 255, 0.2);\n  display: flex;\n  justify-content: center;\n  align-items: center;\n\n  :hover,\n  :focus {\n    background: rgba(255, 255, 255, 0.3);\n    cursor: pointer;\n  }\n`;\n\nconst LeftNavigation = styled.nav`\n  display: grid;\n  width: ${NAVBAR.widthLeftNavigation};\n  background: ${appKitDesignTokens.backgroundColorForNavbar};\n  height: 100%;\n  grid-template-rows: 56px 1fr;\n  transition: ${NAVBAR.leftNavigationTransition};\n`;\n\nconst TextLinkSublistWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n`;\n\nconst NavlinkClickableContent = styled.div`\n  height: 100%;\n  width: 100%;\n  display: block;\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  -webkit-box-orient: vertical;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  transition: all 150ms ease-out;\n\n  position: relative;\n  left: calc(-1 * ${uiKitDesignTokens.spacing20});\n`;\n\nconst listStyles = css`\n  margin: 0;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  min-height: 0;\n  flex: 1 1 0;\n`;\n\nconst sublistStyles = css`\n  padding: ${uiKitDesignTokens.spacing30};\n  font-weight: ${uiKitDesignTokens.fontWeight400};\n  font-size: ${uiKitDesignTokens.fontSize20};\n  background-color: ${uiKitDesignTokens.colorAccent10};\n  left: ${NAVBAR.sublistIndentationWhenCollapsed};\n  z-index: -1;\n  list-style: none;\n  position: fixed;\n  display: none;\n`;\n\nconst MenuList = styled.ul<\n  MenuGroupProps & {\n    isSublistActiveWhileIsMenuExpanded: boolean;\n    isSublistActiveWhileIsMenuCollapsed: boolean;\n    isSublistCollapsedAndActive: boolean;\n    isSublistCollapsedAndActiveAndAbove: boolean;\n  }\n>`\n  ${(props) => [\n    props.level === 1 && listStyles,\n    getSubmenuPositionBasedOnMenuItemPosition(\n      props.isSubmenuAboveMenuItem,\n      props.submenuVerticalPosition\n    ),\n    props.level === 2 && sublistStyles,\n    // prevent glitchy behavior during the initial render when the submenu's vertical position is evaluated as 0\n    props.submenuVerticalPosition === 0 &&\n      css`\n        visibility: hidden;\n      `,\n    (props.isSublistActiveWhileIsMenuExpanded ||\n      props.isSublistCollapsedAndActive ||\n      props.isSublistCollapsedAndActiveAndAbove) &&\n      css`\n        opacity: 0;\n        display: none;\n        text-align: left;\n        background-color: ${uiKitDesignTokens.colorAccent20};\n\n        /* This pseudo-element is required to enable smooth coursor movement from the main menu item to submenu items with the gap in between */\n        ::before {\n          content: '';\n          position: absolute;\n          display: block;\n          width: calc(${NAVBAR.sublistWidth} + ${uiKitDesignTokens.spacing20});\n          height: ${NAVBAR.itemSize};\n          left: calc(-1 * ${uiKitDesignTokens.spacing20});\n\n          ${getContainerPositionBasedOnMenuItemPosition(\n            props.isSubmenuAboveMenuItem,\n            props.isSublistActiveWhileIsMenuExpanded,\n            props.isSublistActiveWhileIsMenuCollapsed\n          )}\n        }\n      `,\n  ]}\n\n  & .highlighted,\n  & .highlighted ${Title} {\n    color: ${uiKitDesignTokens.colorSurface} !important;\n    font-weight: ${uiKitDesignTokens.fontWeight600};\n  }\n`;\n\nconst SublistItem = styled.li<{ isActive: boolean }>`\n  display: flex;\n  align-items: center;\n  align-self: stretch;\n  border-radius: ${uiKitDesignTokens.borderRadius4};\n\n  ${(props) => [\n    props.isActive &&\n      css`\n        background: ${uiKitDesignTokens.colorPrimary40};\n      `,\n    !props.isActive &&\n      css`\n        :hover,\n        :focus-within {\n          color: ${uiKitDesignTokens.colorSurface};\n          font-weight: ${uiKitDesignTokens.fontWeight600};\n          border-radius: ${uiKitDesignTokens.borderRadius4};\n          background: ${uiKitDesignTokens.colorPrimary95};\n\n          [data-link-level='text-link-sublist'] {\n            > ${NavlinkClickableContent} {\n              left: 0;\n            }\n          }\n        }\n      `,\n  ]}\n`;\n\nconst MenuListItem = styled.li<{\n  isActive: boolean;\n  isRouteActive: boolean;\n  isCollapsed: boolean;\n}>`\n  height: ${NAVBAR.itemSize};\n  width: ${NAVBAR.itemSize};\n  margin: 0;\n  background: ${appKitDesignTokens.backgroundColorForNavbar};\n  list-style: none;\n  cursor: pointer;\n\n  ${IconWrapper} {\n    width: auto;\n    display: flex;\n    justify-content: center;\n  }\n\n  ${(props) => [\n    props.isRouteActive &&\n      css`\n        background: ${uiKitDesignTokens.colorPrimary25};\n        border-radius: ${uiKitDesignTokens.borderRadius8};\n      `,\n    !props.isRouteActive &&\n      css`\n        :hover,\n        :focus-within {\n          background-color: ${uiKitDesignTokens.colorPrimary20};\n          border-radius: ${uiKitDesignTokens.borderRadius8};\n        }\n      `,\n    props.isActive &&\n      css`\n        ${ItemIconText} {\n          justify-content: flex-start;\n        }\n      `,\n    !props.isActive &&\n      css`\n        :hover ${Icon} > svg *:not([fill='none']),\n        :focus-within ${Icon} > svg *:not([fill='none']) {\n          fill: ${uiKitDesignTokens.colorSurface};\n        }\n\n        :hover .${Title}, :focus-within ${Title} {\n          color: ${uiKitDesignTokens.colorSurface};\n        }\n      `,\n    props.isCollapsed &&\n      css`\n        text-align: center;\n      `,\n  ]}\n\n  :hover ${Title},\n  :focus-within ${Title} {\n    margin-left: calc(${uiKitDesignTokens.spacing25} + 2px);\n  }\n\n  :hover ${Icon}, :focus-within ${Icon} {\n    /* 1.16 is roughly the ratio of NAVBAR.iconSizeHover to NAVBAR.iconSize */\n    transform: scale(1.2);\n  }\n\n  :hover\n    ${MenuList}.sublist-collapsed__active,\n    :hover\n    ${MenuList}.sublist-collapsed__active__above,\n    :hover\n    ${MenuList}.sublist-expanded__active,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active__above,\n    :focus-within\n    ${MenuList}.sublist-expanded__active {\n    animation-name: ${fadeIn};\n    animation-duration: 16ms;\n    animation-delay: 100ms;\n    animation-fill-mode: forwards;\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    background-color: ${uiKitDesignTokens.colorSurface};\n    min-height: ${NAVBAR.sublistItemMinHeight};\n    width: ${NAVBAR.sublistWidth};\n    border-radius: ${uiKitDesignTokens.borderRadius8};\n    /* z-index value must be higher than AppBar's z-index */\n    z-index: 20001;\n    box-shadow: -2px 4px 25px 0 rgba(89, 89, 89, 0.5);\n  }\n\n  :hover\n    ${MenuList}.sublist-collapsed__active.sublist-collapsed__empty,\n    :hover\n    ${MenuList}.sublist-collapsed__active__above.sublist-collapsed__empty,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active.sublist-collapsed__empty,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active__above.sublist-collapsed__empty {\n    visibility: hidden;\n  }\n\n  :hover\n    ${MenuList}.sublist-expanded__active,\n    :focus-within\n    ${MenuList}.sublist-expanded__active {\n    left: ${NAVBAR.sublistIndentationWhenExpanded};\n  }\n`;\n\nconst SafeArea = styled.span`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 100%;\n  /** Ensure the full width of the safe triangle is 100% of the scrollable menu area, less of its left padding (16px)\n   * which is also the starting point of the safe triangle/menu item.\n   */\n  width: calc(100% - ${uiKitDesignTokens.spacing30});\n  clip-path: polygon(var(--safe-start), 100% 100%, 100% 0);\n`;\n\nexport {\n  Expander,\n  ExpanderIcon,\n  LeftNavigation,\n  MenuList,\n  MenuListItem,\n  SublistItem,\n  TextLinkSublistWrapper,\n  NavlinkClickableContent,\n  SafeArea,\n};\n"]} */"), isSublistActiveWhileIsMenuExpanded && isSubmenuAboveMenuItem && _ref5, isSublistActiveWhileIsMenuExpanded && !isSubmenuAboveMenuItem && _ref4];
|
|
107
|
-
const fadeIn = keyframes
|
|
108
|
-
from {opacity: 0;}
|
|
109
|
-
to { opacity: 1;}
|
|
110
|
-
`;
|
|
109
|
+
const fadeIn = keyframes(_templateObject$1 || (_templateObject$1 = _taggedTemplateLiteral(["\nfrom {opacity: 0;}\n to { opacity: 1;}\n"])));
|
|
111
110
|
var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
112
111
|
name: "eivff4",
|
|
113
112
|
styles: "display:none"
|
|
@@ -205,14 +204,8 @@ const SafeArea = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "producti
|
|
|
205
204
|
label: "SafeArea"
|
|
206
205
|
})("position:absolute;top:0;bottom:0;right:100%;width:calc(100% - ", designTokens.spacing30, ");clip-path:polygon(var(--safe-start), 100% 100%, 100% 0);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["menu-items.styles.ts"],"names":[],"mappings":"AAyU4B","file":"menu-items.styles.ts","sourcesContent":["import { css, keyframes } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { designTokens as appKitDesignTokens } from '@commercetools-frontend/application-components';\nimport { designTokens as uiKitDesignTokens } from '@commercetools-uikit/design-system';\nimport { NAVBAR } from '../../constants';\nimport type { MenuGroupProps } from './menu-items';\nimport { Icon, IconWrapper, ItemIconText, Title } from './shared.styles';\n\nconst getSubmenuPositionBasedOnMenuItemPosition = (\n  isSubmenuAboveMenuItem?: boolean,\n  submenuVerticalPosition?: number\n) => css`\n  ${isSubmenuAboveMenuItem ? 'bottom' : 'top'}: ${submenuVerticalPosition}px\n`;\n\nconst getContainerPositionBasedOnMenuItemPosition = (\n  isSubmenuAboveMenuItem?: boolean,\n  isSublistActiveWhileIsMenuExpanded?: boolean,\n  isSublistActiveWhileIsMenuCollapsed?: boolean\n) => [\n  isSublistActiveWhileIsMenuCollapsed &&\n    css`\n      ${isSubmenuAboveMenuItem ? 'bottom' : 'top'}: -${NAVBAR.itemSize};\n    `,\n  isSublistActiveWhileIsMenuExpanded &&\n    isSubmenuAboveMenuItem &&\n    css`\n      bottom: 0;\n    `,\n  isSublistActiveWhileIsMenuExpanded &&\n    !isSubmenuAboveMenuItem &&\n    css`\n      top: 0;\n    `,\n];\n\nconst fadeIn = keyframes`\nfrom {opacity: 0;}\n  to { opacity: 1;}\n`;\n\nconst Expander = styled.li<{ isVisible: boolean }>`\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background: ${uiKitDesignTokens.colorPrimary10};\n  padding: ${uiKitDesignTokens.spacing30} ${uiKitDesignTokens.spacing25};\n  ${(props) =>\n    !props.isVisible &&\n    css`\n      display: none;\n    `}\n\n  /* Divider */\n  ::before {\n    content: '';\n    position: absolute;\n    top: ${NAVBAR.itemHeight};\n    height: 1px;\n    background: rgba(255, 255, 255, 0.5);\n    width: calc(100% - 2 * ${uiKitDesignTokens.spacing30});\n  }\n`;\n\nconst ExpanderIcon = styled.div`\n  height: ${NAVBAR.expanderSize};\n  width: ${NAVBAR.expanderSize};\n  border-radius: ${uiKitDesignTokens.borderRadius4};\n  padding: ${uiKitDesignTokens.spacing20};\n  background: rgba(255, 255, 255, 0.2);\n  display: flex;\n  justify-content: center;\n  align-items: center;\n\n  :hover,\n  :focus {\n    background: rgba(255, 255, 255, 0.3);\n    cursor: pointer;\n  }\n`;\n\nconst LeftNavigation = styled.nav`\n  display: grid;\n  width: ${NAVBAR.widthLeftNavigation};\n  background: ${appKitDesignTokens.backgroundColorForNavbar};\n  height: 100%;\n  grid-template-rows: 56px 1fr;\n  transition: ${NAVBAR.leftNavigationTransition};\n`;\n\nconst TextLinkSublistWrapper = styled.div`\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n`;\n\nconst NavlinkClickableContent = styled.div`\n  height: 100%;\n  width: 100%;\n  display: block;\n  display: -webkit-box;\n  -webkit-line-clamp: 2;\n  -webkit-box-orient: vertical;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  transition: all 150ms ease-out;\n\n  position: relative;\n  left: calc(-1 * ${uiKitDesignTokens.spacing20});\n`;\n\nconst listStyles = css`\n  margin: 0;\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  min-height: 0;\n  flex: 1 1 0;\n`;\n\nconst sublistStyles = css`\n  padding: ${uiKitDesignTokens.spacing30};\n  font-weight: ${uiKitDesignTokens.fontWeight400};\n  font-size: ${uiKitDesignTokens.fontSize20};\n  background-color: ${uiKitDesignTokens.colorAccent10};\n  left: ${NAVBAR.sublistIndentationWhenCollapsed};\n  z-index: -1;\n  list-style: none;\n  position: fixed;\n  display: none;\n`;\n\nconst MenuList = styled.ul<\n  MenuGroupProps & {\n    isSublistActiveWhileIsMenuExpanded: boolean;\n    isSublistActiveWhileIsMenuCollapsed: boolean;\n    isSublistCollapsedAndActive: boolean;\n    isSublistCollapsedAndActiveAndAbove: boolean;\n  }\n>`\n  ${(props) => [\n    props.level === 1 && listStyles,\n    getSubmenuPositionBasedOnMenuItemPosition(\n      props.isSubmenuAboveMenuItem,\n      props.submenuVerticalPosition\n    ),\n    props.level === 2 && sublistStyles,\n    // prevent glitchy behavior during the initial render when the submenu's vertical position is evaluated as 0\n    props.submenuVerticalPosition === 0 &&\n      css`\n        visibility: hidden;\n      `,\n    (props.isSublistActiveWhileIsMenuExpanded ||\n      props.isSublistCollapsedAndActive ||\n      props.isSublistCollapsedAndActiveAndAbove) &&\n      css`\n        opacity: 0;\n        display: none;\n        text-align: left;\n        background-color: ${uiKitDesignTokens.colorAccent20};\n\n        /* This pseudo-element is required to enable smooth coursor movement from the main menu item to submenu items with the gap in between */\n        ::before {\n          content: '';\n          position: absolute;\n          display: block;\n          width: calc(${NAVBAR.sublistWidth} + ${uiKitDesignTokens.spacing20});\n          height: ${NAVBAR.itemSize};\n          left: calc(-1 * ${uiKitDesignTokens.spacing20});\n\n          ${getContainerPositionBasedOnMenuItemPosition(\n            props.isSubmenuAboveMenuItem,\n            props.isSublistActiveWhileIsMenuExpanded,\n            props.isSublistActiveWhileIsMenuCollapsed\n          )}\n        }\n      `,\n  ]}\n\n  & .highlighted,\n  & .highlighted ${Title} {\n    color: ${uiKitDesignTokens.colorSurface} !important;\n    font-weight: ${uiKitDesignTokens.fontWeight600};\n  }\n`;\n\nconst SublistItem = styled.li<{ isActive: boolean }>`\n  display: flex;\n  align-items: center;\n  align-self: stretch;\n  border-radius: ${uiKitDesignTokens.borderRadius4};\n\n  ${(props) => [\n    props.isActive &&\n      css`\n        background: ${uiKitDesignTokens.colorPrimary40};\n      `,\n    !props.isActive &&\n      css`\n        :hover,\n        :focus-within {\n          color: ${uiKitDesignTokens.colorSurface};\n          font-weight: ${uiKitDesignTokens.fontWeight600};\n          border-radius: ${uiKitDesignTokens.borderRadius4};\n          background: ${uiKitDesignTokens.colorPrimary95};\n\n          [data-link-level='text-link-sublist'] {\n            > ${NavlinkClickableContent} {\n              left: 0;\n            }\n          }\n        }\n      `,\n  ]}\n`;\n\nconst MenuListItem = styled.li<{\n  isActive: boolean;\n  isRouteActive: boolean;\n  isCollapsed: boolean;\n}>`\n  height: ${NAVBAR.itemSize};\n  width: ${NAVBAR.itemSize};\n  margin: 0;\n  background: ${appKitDesignTokens.backgroundColorForNavbar};\n  list-style: none;\n  cursor: pointer;\n\n  ${IconWrapper} {\n    width: auto;\n    display: flex;\n    justify-content: center;\n  }\n\n  ${(props) => [\n    props.isRouteActive &&\n      css`\n        background: ${uiKitDesignTokens.colorPrimary25};\n        border-radius: ${uiKitDesignTokens.borderRadius8};\n      `,\n    !props.isRouteActive &&\n      css`\n        :hover,\n        :focus-within {\n          background-color: ${uiKitDesignTokens.colorPrimary20};\n          border-radius: ${uiKitDesignTokens.borderRadius8};\n        }\n      `,\n    props.isActive &&\n      css`\n        ${ItemIconText} {\n          justify-content: flex-start;\n        }\n      `,\n    !props.isActive &&\n      css`\n        :hover ${Icon} > svg *:not([fill='none']),\n        :focus-within ${Icon} > svg *:not([fill='none']) {\n          fill: ${uiKitDesignTokens.colorSurface};\n        }\n\n        :hover .${Title}, :focus-within ${Title} {\n          color: ${uiKitDesignTokens.colorSurface};\n        }\n      `,\n    props.isCollapsed &&\n      css`\n        text-align: center;\n      `,\n  ]}\n\n  :hover ${Title},\n  :focus-within ${Title} {\n    margin-left: calc(${uiKitDesignTokens.spacing25} + 2px);\n  }\n\n  :hover ${Icon}, :focus-within ${Icon} {\n    /* 1.16 is roughly the ratio of NAVBAR.iconSizeHover to NAVBAR.iconSize */\n    transform: scale(1.2);\n  }\n\n  :hover\n    ${MenuList}.sublist-collapsed__active,\n    :hover\n    ${MenuList}.sublist-collapsed__active__above,\n    :hover\n    ${MenuList}.sublist-expanded__active,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active__above,\n    :focus-within\n    ${MenuList}.sublist-expanded__active {\n    animation-name: ${fadeIn};\n    animation-duration: 16ms;\n    animation-delay: 100ms;\n    animation-fill-mode: forwards;\n    display: flex;\n    flex-direction: column;\n    align-items: flex-start;\n    background-color: ${uiKitDesignTokens.colorSurface};\n    min-height: ${NAVBAR.sublistItemMinHeight};\n    width: ${NAVBAR.sublistWidth};\n    border-radius: ${uiKitDesignTokens.borderRadius8};\n    /* z-index value must be higher than AppBar's z-index */\n    z-index: 20001;\n    box-shadow: -2px 4px 25px 0 rgba(89, 89, 89, 0.5);\n  }\n\n  :hover\n    ${MenuList}.sublist-collapsed__active.sublist-collapsed__empty,\n    :hover\n    ${MenuList}.sublist-collapsed__active__above.sublist-collapsed__empty,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active.sublist-collapsed__empty,\n    :focus-within\n    ${MenuList}.sublist-collapsed__active__above.sublist-collapsed__empty {\n    visibility: hidden;\n  }\n\n  :hover\n    ${MenuList}.sublist-expanded__active,\n    :focus-within\n    ${MenuList}.sublist-expanded__active {\n    left: ${NAVBAR.sublistIndentationWhenExpanded};\n  }\n`;\n\nconst SafeArea = styled.span`\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  right: 100%;\n  /** Ensure the full width of the safe triangle is 100% of the scrollable menu area, less of its left padding (16px)\n   * which is also the starting point of the safe triangle/menu item.\n   */\n  width: calc(100% - ${uiKitDesignTokens.spacing30});\n  clip-path: polygon(var(--safe-start), 100% 100%, 100% 0);\n`;\n\nexport {\n  Expander,\n  ExpanderIcon,\n  LeftNavigation,\n  MenuList,\n  MenuListItem,\n  SublistItem,\n  TextLinkSublistWrapper,\n  NavlinkClickableContent,\n  SafeArea,\n};\n"]} */"));
|
|
207
206
|
|
|
208
|
-
|
|
209
|
-
from {
|
|
210
|
-
opacity: 0;
|
|
211
|
-
}
|
|
212
|
-
to {
|
|
213
|
-
opacity: 1;
|
|
214
|
-
}
|
|
215
|
-
`;
|
|
207
|
+
var _templateObject;
|
|
208
|
+
const visible = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n"])));
|
|
216
209
|
const FixedMenu = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
217
210
|
target: "e1meml8k10"
|
|
218
211
|
} : {
|
|
@@ -412,8 +405,8 @@ const MenuGroup = /*#__PURE__*/forwardRef((props, ref) => {
|
|
|
412
405
|
return jsx(MenuList, {
|
|
413
406
|
ref: ref && props.level === 2 ? ref : null,
|
|
414
407
|
level: props.level,
|
|
415
|
-
id:
|
|
416
|
-
"data-testid":
|
|
408
|
+
id: "group-".concat(props.id),
|
|
409
|
+
"data-testid": "group-".concat(props.id),
|
|
417
410
|
role: "menu",
|
|
418
411
|
onKeyDown: props.handleKeyDown,
|
|
419
412
|
className: classnames({
|
|
@@ -511,18 +504,14 @@ const MenuItemLink = _ref3 => {
|
|
|
511
504
|
});
|
|
512
505
|
};
|
|
513
506
|
MenuItemLink.displayName = 'MenuItemLink';
|
|
514
|
-
const isEveryMenuVisibilitySetToHidden = (menuVisibilities, namesOfMenuVisibilities) => _Array$isArray(namesOfMenuVisibilities) && namesOfMenuVisibilities.length > 0 && _everyInstanceProperty(namesOfMenuVisibilities).call(namesOfMenuVisibilities, nameOfMenuVisibility => menuVisibilities && menuVisibilities[nameOfMenuVisibility] === true);
|
|
515
507
|
function isLongLivedFlag(flag) {
|
|
516
|
-
return typeof flag
|
|
508
|
+
return typeof (flag === null || flag === void 0 ? void 0 : flag.value) === 'boolean';
|
|
517
509
|
}
|
|
518
510
|
const RestrictedMenuItem = _ref4 => {
|
|
519
511
|
let _ref4$permissions = _ref4.permissions,
|
|
520
512
|
permissions = _ref4$permissions === void 0 ? [] : _ref4$permissions,
|
|
521
513
|
props = _objectWithoutProperties(_ref4, _excluded3);
|
|
522
|
-
// NOTE: Custom application are activated/deactivated while their
|
|
523
|
-
// visibility is not controlled via a visibiility overwrite.
|
|
524
514
|
const flagVariation = useFlagVariation(props.featureToggle);
|
|
525
|
-
if (isEveryMenuVisibilitySetToHidden(props.menuVisibilities, props.namesOfMenuVisibilities)) return null;
|
|
526
515
|
const permissionsWrapper = _Array$isArray(permissions) && permissions.length > 0 || _Array$isArray(props.dataFences) && props.dataFences.length > 0 ? jsx(RestrictedByPermissions, {
|
|
527
516
|
permissions: permissions,
|
|
528
517
|
actionRights: props.actionRights,
|
|
@@ -764,13 +753,15 @@ const reducer = (state, action) => {
|
|
|
764
753
|
return state;
|
|
765
754
|
}
|
|
766
755
|
};
|
|
767
|
-
const isFocusOutEventCalledBySubmenuItem = event =>
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
//
|
|
771
|
-
event.
|
|
772
|
-
// element losing focus
|
|
773
|
-
event.target
|
|
756
|
+
const isFocusOutEventCalledBySubmenuItem = event => {
|
|
757
|
+
var _event$relatedTarget, _event$target;
|
|
758
|
+
return (
|
|
759
|
+
// a case when a submenu item loses focus
|
|
760
|
+
event.type === 'focusout' && (// element receiving focus
|
|
761
|
+
(_event$relatedTarget = event.relatedTarget) === null || _event$relatedTarget === void 0 ? void 0 : _event$relatedTarget.matches('a[data-link-level="text-link"]')) && (// element losing focus
|
|
762
|
+
(_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.matches('a[data-link-level="text-link-sublist"]'))
|
|
763
|
+
);
|
|
764
|
+
};
|
|
774
765
|
const useNavbarStateManager = props => {
|
|
775
766
|
var _context, _context2, _context4, _context5;
|
|
776
767
|
const navBarNode = useRef(null);
|
|
@@ -800,7 +791,6 @@ const useNavbarStateManager = props => {
|
|
|
800
791
|
permissions: application.mainMenuLink.permissions,
|
|
801
792
|
defaultLabel: application.mainMenuLink.defaultLabel,
|
|
802
793
|
featureToggle: undefined,
|
|
803
|
-
menuVisibility: undefined,
|
|
804
794
|
actionRights: undefined,
|
|
805
795
|
dataFences: undefined,
|
|
806
796
|
submenu: _mapInstanceProperty(_context3 = application.submenuLinks || []).call(_context3, submenuLink => ({
|
|
@@ -810,7 +800,6 @@ const useNavbarStateManager = props => {
|
|
|
810
800
|
permissions: submenuLink.permissions,
|
|
811
801
|
defaultLabel: submenuLink.defaultLabel,
|
|
812
802
|
featureToggle: undefined,
|
|
813
|
-
menuVisibility: undefined,
|
|
814
803
|
actionRights: undefined,
|
|
815
804
|
dataFences: undefined
|
|
816
805
|
}))
|
|
@@ -866,7 +855,8 @@ const useNavbarStateManager = props => {
|
|
|
866
855
|
}
|
|
867
856
|
}, 100), [isForcedMenuOpen, state.isExpanderVisible, state.isMenuOpen]);
|
|
868
857
|
const shouldCloseMenuFly = useCallback(event => {
|
|
869
|
-
|
|
858
|
+
var _navBarNode$current;
|
|
859
|
+
if (!(navBarNode !== null && navBarNode !== void 0 && (_navBarNode$current = navBarNode.current) !== null && _navBarNode$current !== void 0 && _navBarNode$current.contains(event.target)) && !state.isMenuOpen) {
|
|
870
860
|
dispatch({
|
|
871
861
|
type: 'unsetActiveItemIndex'
|
|
872
862
|
});
|
|
@@ -931,7 +921,7 @@ const useNavbarStateManager = props => {
|
|
|
931
921
|
const allApplicationsNavbarMenuGroups = _sortInstanceProperty(_context4 = _mapInstanceProperty(_context5 = applicationsNavBarMenuGroups || []).call(_context5, navbarMenuGroup => navbarMenuGroup.key === '2' && allCustomApplicationsNavbarMenu.length > 0 ? {
|
|
932
922
|
key: navbarMenuGroup.key,
|
|
933
923
|
items: [...navbarMenuGroup.items, ...allCustomApplicationsNavbarMenu]
|
|
934
|
-
} : navbarMenuGroup)).call(_context4, (navBarMenuGroupA, navBarMenuGroupB) => Number(navBarMenuGroupA
|
|
924
|
+
} : navbarMenuGroup)).call(_context4, (navBarMenuGroupA, navBarMenuGroupB) => Number(navBarMenuGroupA === null || navBarMenuGroupA === void 0 ? void 0 : navBarMenuGroupA.key) - Number(navBarMenuGroupB === null || navBarMenuGroupB === void 0 ? void 0 : navBarMenuGroupB.key));
|
|
935
925
|
return _objectSpread$1(_objectSpread$1({}, state), {}, {
|
|
936
926
|
navBarNode,
|
|
937
927
|
handleToggleItem,
|
|
@@ -943,7 +933,7 @@ const useNavbarStateManager = props => {
|
|
|
943
933
|
};
|
|
944
934
|
|
|
945
935
|
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; }
|
|
946
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var
|
|
936
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context0, _context1; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context0 = ownKeys(Object(t), !0)).call(_context0, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context1 = ownKeys(Object(t))).call(_context1, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
947
937
|
// Helper function to extract accessible label from menu objects
|
|
948
938
|
const getMenuAccessibleLabel = (labelAllLocales, defaultLabel, applicationLocale) => {
|
|
949
939
|
const localizedLabel = _findInstanceProperty(labelAllLocales).call(labelAllLocales, loc => _startsWithInstanceProperty(applicationLocale).call(applicationLocale, loc.locale));
|
|
@@ -951,18 +941,16 @@ const getMenuAccessibleLabel = (labelAllLocales, defaultLabel, applicationLocale
|
|
|
951
941
|
if (defaultLabel) return defaultLabel;
|
|
952
942
|
return NO_VALUE_FALLBACK;
|
|
953
943
|
};
|
|
954
|
-
const
|
|
955
|
-
var _context
|
|
956
|
-
return
|
|
944
|
+
const getIsSubmenuRouteActive = (uriPath, props) => {
|
|
945
|
+
var _context;
|
|
946
|
+
return Boolean(matchPath(props.location.pathname, {
|
|
947
|
+
path: _concatInstanceProperty(_context = "/".concat(props.projectKey, "/")).call(_context, uriPath),
|
|
948
|
+
exact: true,
|
|
949
|
+
strict: false
|
|
950
|
+
}));
|
|
957
951
|
};
|
|
958
|
-
const getMenuVisibilityOfMainmenu = menu => menu.menuVisibility ? [menu.menuVisibility] : [];
|
|
959
|
-
const getIsSubmenuRouteActive = (uriPath, props) => Boolean(matchPath(props.location.pathname, {
|
|
960
|
-
path: `/${props.projectKey}/${uriPath}`,
|
|
961
|
-
exact: true,
|
|
962
|
-
strict: false
|
|
963
|
-
}));
|
|
964
952
|
const ApplicationMenu = props => {
|
|
965
|
-
var _context3;
|
|
953
|
+
var _context3, _props$menu$featureTo, _props$menu$actionRig, _props$menu$dataFence, _context4, _context5;
|
|
966
954
|
const _useState = useState(0),
|
|
967
955
|
_useState2 = _slicedToArray(_useState, 2),
|
|
968
956
|
submenuVerticalPosition = _useState2[0],
|
|
@@ -989,12 +977,13 @@ const ApplicationMenu = props => {
|
|
|
989
977
|
const hasSubmenu = _Array$isArray(props.menu.submenu) && props.menu.submenu.length > 0;
|
|
990
978
|
const menuItemIdentifier = snakeCase(props.menu.key);
|
|
991
979
|
const calculateSafeAreaStartPositon = useCallback(e => {
|
|
992
|
-
|
|
993
|
-
const
|
|
994
|
-
const
|
|
995
|
-
const
|
|
996
|
-
const
|
|
997
|
-
const
|
|
980
|
+
var _submenuSafeAreaRef$c, _document$querySelect;
|
|
981
|
+
const currentSafeAreaRect = (_submenuSafeAreaRef$c = submenuSafeAreaRef.current) === null || _submenuSafeAreaRef$c === void 0 ? void 0 : _submenuSafeAreaRef$c.getBoundingClientRect();
|
|
982
|
+
const menuItemRect = (_document$querySelect = document.querySelector("[data-menuitem=\"".concat(menuItemIdentifier, "\"]"))) === null || _document$querySelect === void 0 ? void 0 : _document$querySelect.getBoundingClientRect();
|
|
983
|
+
const currentSafeAreaLeft = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.left) || 0;
|
|
984
|
+
const currentSafeAreaTop = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.top) || 0;
|
|
985
|
+
const currentSafeAreaWidth = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.width) || 0;
|
|
986
|
+
const currentSafeAreaHeight = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.height) || 0;
|
|
998
987
|
const localX = e.clientX - currentSafeAreaLeft;
|
|
999
988
|
const localY = e.clientY - currentSafeAreaTop;
|
|
1000
989
|
let minXPercent = 0;
|
|
@@ -1040,15 +1029,17 @@ const ApplicationMenu = props => {
|
|
|
1040
1029
|
};
|
|
1041
1030
|
}, [calculateSafeAreaStartPositon]);
|
|
1042
1031
|
useLayoutEffect(() => {
|
|
1032
|
+
var _context2;
|
|
1043
1033
|
if (!submenuRef.current) return;
|
|
1044
1034
|
const safeX = _Number$isFinite(percentageX) ? percentageX : 0;
|
|
1045
1035
|
const safeY = _Number$isFinite(percentageY) ? percentageY : 100;
|
|
1046
|
-
submenuRef.current.style.setProperty('--safe-start',
|
|
1036
|
+
submenuRef.current.style.setProperty('--safe-start', _concatInstanceProperty(_context2 = "".concat(safeX, "% ")).call(_context2, safeY, "%"));
|
|
1047
1037
|
}, [percentageX, percentageY]);
|
|
1048
1038
|
const callbackFn = useCallback(entries => {
|
|
1049
|
-
|
|
1050
|
-
const
|
|
1051
|
-
const
|
|
1039
|
+
var _document$querySelect2;
|
|
1040
|
+
const menuItemBoundingClientRect = (_document$querySelect2 = document.querySelector("[data-menuitem=\"".concat(menuItemIdentifier, "\"]"))) === null || _document$querySelect2 === void 0 ? void 0 : _document$querySelect2.getBoundingClientRect();
|
|
1041
|
+
const menuItemTop = (menuItemBoundingClientRect === null || menuItemBoundingClientRect === void 0 ? void 0 : menuItemBoundingClientRect.top) || 0;
|
|
1042
|
+
const menuItemBottom = (menuItemBoundingClientRect === null || menuItemBoundingClientRect === void 0 ? void 0 : menuItemBoundingClientRect.bottom) || 0;
|
|
1052
1043
|
const _entries = _slicedToArray(entries, 1),
|
|
1053
1044
|
entry = _entries[0];
|
|
1054
1045
|
|
|
@@ -1074,7 +1065,10 @@ const ApplicationMenu = props => {
|
|
|
1074
1065
|
observerRef.current = new IntersectionObserver(callbackFn, {
|
|
1075
1066
|
rootMargin: '-100% 0px 0px 0px' // we want to observe if the submenu crosses the bottom line of the viewport - therefore we set the root element top margin to -100% of the viewport height
|
|
1076
1067
|
});
|
|
1077
|
-
return () =>
|
|
1068
|
+
return () => {
|
|
1069
|
+
var _observerRef$current;
|
|
1070
|
+
return (_observerRef$current = observerRef.current) === null || _observerRef$current === void 0 ? void 0 : _observerRef$current.disconnect();
|
|
1071
|
+
};
|
|
1078
1072
|
}, [callbackFn, props.isMenuOpen]);
|
|
1079
1073
|
useLayoutEffect(() => {
|
|
1080
1074
|
const currentSubmenuRef = submenuRef.current;
|
|
@@ -1084,10 +1078,10 @@ const ApplicationMenu = props => {
|
|
|
1084
1078
|
observer.observe(currentSubmenuRef);
|
|
1085
1079
|
}
|
|
1086
1080
|
setIsSubmenuFocused(false);
|
|
1087
|
-
return () => observer
|
|
1081
|
+
return () => observer === null || observer === void 0 ? void 0 : observer.disconnect();
|
|
1088
1082
|
}, [menuItemIdentifier, props.isMenuOpen, props.handleToggleItem, callbackFn]);
|
|
1089
1083
|
const isMainMenuRouteActive = Boolean(matchPath(props.location.pathname, {
|
|
1090
|
-
path:
|
|
1084
|
+
path: _concatInstanceProperty(_context3 = "/".concat(props.projectKey, "/")).call(_context3, props.menu.uriPath),
|
|
1091
1085
|
exact: false,
|
|
1092
1086
|
strict: false
|
|
1093
1087
|
}));
|
|
@@ -1100,25 +1094,24 @@ const ApplicationMenu = props => {
|
|
|
1100
1094
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
1101
1095
|
}, [props.isMenuOpen]); // <-- (re)run this only when the all menu expands
|
|
1102
1096
|
|
|
1103
|
-
const namesOfMenuVisibilitiesOfAllSubmenus = hasSubmenu ? getMenuVisibilitiesOfSubmenus(props.menu) : getMenuVisibilityOfMainmenu(props.menu);
|
|
1104
1097
|
const handleKeyDown = e => {
|
|
1105
|
-
|
|
1098
|
+
var _submenuRef$current;
|
|
1099
|
+
const currentlyFocusedItem = (_submenuRef$current = submenuRef.current) === null || _submenuRef$current === void 0 ? void 0 : _submenuRef$current.querySelector(':focus');
|
|
1106
1100
|
if (e.key === 'Enter') {
|
|
1107
1101
|
setIsSubmenuFocused(true);
|
|
1108
1102
|
if (!currentlyFocusedItem) {
|
|
1109
|
-
|
|
1103
|
+
var _submenuRef$current2;
|
|
1104
|
+
(_submenuRef$current2 = submenuRef.current) === null || _submenuRef$current2 === void 0 || (_submenuRef$current2 = _submenuRef$current2.querySelector('a')) === null || _submenuRef$current2 === void 0 || _submenuRef$current2.focus();
|
|
1110
1105
|
}
|
|
1111
1106
|
}
|
|
1112
1107
|
};
|
|
1113
1108
|
return jsx(RestrictedMenuItem, {
|
|
1114
1109
|
keyOfMenuItem: props.menu.key,
|
|
1115
|
-
featureToggle: props.menu.featureToggle
|
|
1110
|
+
featureToggle: (_props$menu$featureTo = props.menu.featureToggle) !== null && _props$menu$featureTo !== void 0 ? _props$menu$featureTo : undefined,
|
|
1116
1111
|
permissions: props.menu.permissions,
|
|
1117
|
-
actionRights: props.menu.actionRights
|
|
1118
|
-
dataFences: props.menu.dataFences
|
|
1112
|
+
actionRights: (_props$menu$actionRig = props.menu.actionRights) !== null && _props$menu$actionRig !== void 0 ? _props$menu$actionRig : undefined,
|
|
1113
|
+
dataFences: (_props$menu$dataFence = props.menu.dataFences) !== null && _props$menu$dataFence !== void 0 ? _props$menu$dataFence : undefined,
|
|
1119
1114
|
projectPermissions: props.projectPermissions,
|
|
1120
|
-
menuVisibilities: props.menuVisibilities,
|
|
1121
|
-
namesOfMenuVisibilities: namesOfMenuVisibilitiesOfAllSubmenus,
|
|
1122
1115
|
children: jsxs(MenuItem$1, {
|
|
1123
1116
|
hasSubmenu: hasSubmenu,
|
|
1124
1117
|
isActive: props.isActive,
|
|
@@ -1132,7 +1125,7 @@ const ApplicationMenu = props => {
|
|
|
1132
1125
|
identifier: menuItemIdentifier,
|
|
1133
1126
|
ariaLabel: getMenuAccessibleLabel(props.menu.labelAllLocales, props.menu.defaultLabel, props.applicationLocale),
|
|
1134
1127
|
children: [jsx(MenuItemLink, {
|
|
1135
|
-
linkTo:
|
|
1128
|
+
linkTo: _concatInstanceProperty(_context4 = "/".concat(props.projectKey, "/")).call(_context4, props.menu.uriPath),
|
|
1136
1129
|
useFullRedirectsForLinks: props.useFullRedirectsForLinks,
|
|
1137
1130
|
onClick: props.onMenuItemClick,
|
|
1138
1131
|
ariaLabel: getMenuAccessibleLabel(props.menu.labelAllLocales, props.menu.defaultLabel, props.applicationLocale),
|
|
@@ -1144,7 +1137,7 @@ const ApplicationMenu = props => {
|
|
|
1144
1137
|
isMenuOpen: props.isMenuOpen
|
|
1145
1138
|
})
|
|
1146
1139
|
}), jsxs(MenuGroup, {
|
|
1147
|
-
id:
|
|
1140
|
+
id: "group-".concat(props.menu.key),
|
|
1148
1141
|
level: 2,
|
|
1149
1142
|
isActive: props.isActive,
|
|
1150
1143
|
isExpanded: props.isMenuOpen,
|
|
@@ -1155,7 +1148,7 @@ const ApplicationMenu = props => {
|
|
|
1155
1148
|
children: [!props.isMenuOpen && jsx(TooltipContainer, {
|
|
1156
1149
|
alignsAgainstBottom: isSubmenuAboveMenuItem,
|
|
1157
1150
|
children: jsx(Tooltip, {
|
|
1158
|
-
"aria-owns":
|
|
1151
|
+
"aria-owns": "group-".concat(props.menu.key),
|
|
1159
1152
|
role: "tooltip",
|
|
1160
1153
|
children: jsx(MenuLabel, {
|
|
1161
1154
|
labelAllLocales: props.menu.labelAllLocales,
|
|
@@ -1163,38 +1156,39 @@ const ApplicationMenu = props => {
|
|
|
1163
1156
|
applicationLocale: props.applicationLocale
|
|
1164
1157
|
})
|
|
1165
1158
|
})
|
|
1166
|
-
}), hasSubmenu ? _mapInstanceProperty(
|
|
1167
|
-
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1171
|
-
|
|
1172
|
-
|
|
1173
|
-
|
|
1174
|
-
|
|
1175
|
-
|
|
1176
|
-
|
|
1177
|
-
|
|
1178
|
-
|
|
1179
|
-
|
|
1180
|
-
|
|
1181
|
-
|
|
1182
|
-
|
|
1183
|
-
|
|
1184
|
-
|
|
1185
|
-
|
|
1186
|
-
|
|
1187
|
-
|
|
1188
|
-
|
|
1189
|
-
|
|
1190
|
-
|
|
1191
|
-
|
|
1192
|
-
|
|
1159
|
+
}), hasSubmenu ? _mapInstanceProperty(_context5 = props.menu.submenu).call(_context5, submenu => {
|
|
1160
|
+
var _context6, _submenu$featureToggl, _submenu$actionRights, _submenu$dataFences, _context7;
|
|
1161
|
+
return jsx(RestrictedMenuItem, {
|
|
1162
|
+
keyOfMenuItem: submenu.key,
|
|
1163
|
+
featureToggle: (_submenu$featureToggl = submenu.featureToggle) !== null && _submenu$featureToggl !== void 0 ? _submenu$featureToggl : undefined,
|
|
1164
|
+
permissions: submenu.permissions,
|
|
1165
|
+
actionRights: (_submenu$actionRights = submenu.actionRights) !== null && _submenu$actionRights !== void 0 ? _submenu$actionRights : undefined,
|
|
1166
|
+
dataFences: (_submenu$dataFences = submenu.dataFences) !== null && _submenu$dataFences !== void 0 ? _submenu$dataFences : undefined,
|
|
1167
|
+
projectPermissions: props.projectPermissions,
|
|
1168
|
+
children: jsx(SublistItem, {
|
|
1169
|
+
isActive: getIsSubmenuRouteActive(submenu.uriPath, props),
|
|
1170
|
+
children: jsx(Text, {
|
|
1171
|
+
children: jsx(MenuItemLink, {
|
|
1172
|
+
linkTo: _concatInstanceProperty(_context7 = "/".concat(props.projectKey, "/")).call(_context7, submenu.uriPath)
|
|
1173
|
+
// We want to use an exact matching strategy to avoid multiple
|
|
1174
|
+
// links matching sub-routes.
|
|
1175
|
+
,
|
|
1176
|
+
exactMatch: true,
|
|
1177
|
+
useFullRedirectsForLinks: props.useFullRedirectsForLinks,
|
|
1178
|
+
onClick: props.onMenuItemClick,
|
|
1179
|
+
isSubmenuLink: true,
|
|
1180
|
+
isSubmenuFocused: isSubmenuFocused,
|
|
1181
|
+
ariaLabel: getMenuAccessibleLabel(submenu.labelAllLocales, submenu.defaultLabel, props.applicationLocale),
|
|
1182
|
+
children: jsx(MenuLabel, {
|
|
1183
|
+
labelAllLocales: submenu.labelAllLocales,
|
|
1184
|
+
defaultLabel: submenu.defaultLabel,
|
|
1185
|
+
applicationLocale: props.applicationLocale
|
|
1186
|
+
})
|
|
1193
1187
|
})
|
|
1194
1188
|
})
|
|
1195
1189
|
})
|
|
1196
|
-
})
|
|
1197
|
-
}
|
|
1190
|
+
}, _concatInstanceProperty(_context6 = "".concat(props.menu.key, "-submenu-")).call(_context6, submenu.key));
|
|
1191
|
+
}) : null, jsx(SafeArea, {
|
|
1198
1192
|
ref: submenuSafeAreaRef
|
|
1199
1193
|
})]
|
|
1200
1194
|
})]
|
|
@@ -1221,12 +1215,14 @@ const NavBar = props => {
|
|
|
1221
1215
|
const location = useLocation();
|
|
1222
1216
|
const _useIntl = useIntl(),
|
|
1223
1217
|
formatMessage = _useIntl.formatMessage;
|
|
1224
|
-
const projectPermissions = useMemo(() =>
|
|
1225
|
-
|
|
1226
|
-
|
|
1227
|
-
|
|
1228
|
-
|
|
1229
|
-
|
|
1218
|
+
const projectPermissions = useMemo(() => {
|
|
1219
|
+
var _props$project, _props$project2, _props$project3;
|
|
1220
|
+
return {
|
|
1221
|
+
permissions: normalizeAllAppliedPermissions((_props$project = props.project) === null || _props$project === void 0 ? void 0 : _props$project.allPermissionsForAllApplications.allAppliedPermissions),
|
|
1222
|
+
actionRights: normalizeAllAppliedActionRights((_props$project2 = props.project) === null || _props$project2 === void 0 ? void 0 : _props$project2.allPermissionsForAllApplications.allAppliedActionRights),
|
|
1223
|
+
dataFences: normalizeAllAppliedDataFences((_props$project3 = props.project) === null || _props$project3 === void 0 ? void 0 : _props$project3.allPermissionsForAllApplications.allAppliedDataFences)
|
|
1224
|
+
};
|
|
1225
|
+
}, [props.project]);
|
|
1230
1226
|
const applicationLocale = props.applicationLocale;
|
|
1231
1227
|
|
|
1232
1228
|
// Render the loading navbar as long as all the data
|
|
@@ -1257,11 +1253,12 @@ const NavBar = props => {
|
|
|
1257
1253
|
children: jsx(Spacings.Stack, {
|
|
1258
1254
|
scale: "l",
|
|
1259
1255
|
children: _mapInstanceProperty(allApplicationsNavbarMenuGroups).call(allApplicationsNavbarMenuGroups, navbarMenuGroup => {
|
|
1260
|
-
var
|
|
1256
|
+
var _context8;
|
|
1261
1257
|
return jsx("div", {
|
|
1262
|
-
children: _mapInstanceProperty(
|
|
1258
|
+
children: _mapInstanceProperty(_context8 = navbarMenuGroup.items).call(_context8, menu => {
|
|
1259
|
+
var _context9;
|
|
1263
1260
|
const menuType = 'scrollable';
|
|
1264
|
-
const itemIndex =
|
|
1261
|
+
const itemIndex = _concatInstanceProperty(_context9 = "".concat(menuType, "-")).call(_context9, menu.key);
|
|
1265
1262
|
return jsx(ApplicationMenu, {
|
|
1266
1263
|
location: location,
|
|
1267
1264
|
menu: menu,
|
|
@@ -1270,7 +1267,6 @@ const NavBar = props => {
|
|
|
1270
1267
|
isMenuOpen: isMenuOpen,
|
|
1271
1268
|
shouldCloseMenuFly: shouldCloseMenuFly,
|
|
1272
1269
|
projectPermissions: projectPermissions,
|
|
1273
|
-
menuVisibilities: menuVisibilities,
|
|
1274
1270
|
applicationLocale: applicationLocale,
|
|
1275
1271
|
projectKey: props.projectKey,
|
|
1276
1272
|
useFullRedirectsForLinks: useFullRedirectsForLinks,
|