@commercetools-frontend/application-shell 25.0.0 → 25.2.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-1b23fb6b.esm.js → application-entry-point-10a5e1a5.esm.js} +4 -6
- package/dist/{application-entry-point-74a06151.cjs.prod.js → application-entry-point-8c4b8e53.cjs.prod.js} +3 -4
- package/dist/{application-entry-point-18d8fba0.cjs.dev.js → application-entry-point-c87294b0.cjs.dev.js} +4 -7
- package/dist/commercetools-frontend-application-shell.cjs.dev.js +4 -5
- package/dist/commercetools-frontend-application-shell.cjs.prod.js +4 -5
- package/dist/commercetools-frontend-application-shell.esm.js +4 -5
- package/dist/{custom-view-dev-host-dc7f2835.cjs.dev.js → custom-view-dev-host-116479c1.cjs.dev.js} +10 -15
- package/dist/{custom-view-dev-host-d72f9ae0.cjs.prod.js → custom-view-dev-host-8dd01b96.cjs.prod.js} +10 -15
- package/dist/{custom-view-dev-host-98432fc5.esm.js → custom-view-dev-host-c47927c7.esm.js} +10 -14
- package/dist/{index-208c3cdd.cjs.dev.js → index-1bdcc336.cjs.dev.js} +108 -132
- package/dist/{index-52c724ed.cjs.prod.js → index-245e2980.cjs.prod.js} +2 -2
- package/dist/{index-25183095.cjs.dev.js → index-614accc4.cjs.dev.js} +2 -2
- package/dist/{index-5aaa33bb.esm.js → index-86039df7.esm.js} +2 -2
- package/dist/{index-af2cc053.cjs.prod.js → index-aa7211d5.cjs.prod.js} +108 -132
- package/dist/{index-75206fba.esm.js → index-b26c8745.esm.js} +108 -131
- package/dist/{navbar-0bad8bc8.esm.js → navbar-9a40ead9.esm.js} +89 -104
- package/dist/{navbar-d4189469.cjs.dev.js → navbar-c51e0607.cjs.dev.js} +89 -105
- package/dist/{navbar-7653417f.cjs.prod.js → navbar-e287ce25.cjs.prod.js} +89 -105
- package/dist/oidc-8827f9fe.cjs.dev.js +98 -0
- package/dist/oidc-b2520905.esm.js +84 -0
- package/dist/{oidc-callback-3f9e25bc.cjs.prod.js → oidc-callback-13f8e123.cjs.prod.js} +8 -10
- package/dist/{oidc-callback-b6584fe8.esm.js → oidc-callback-39ea9b04.esm.js} +8 -10
- package/dist/{oidc-callback-f2f37906.cjs.dev.js → oidc-callback-59160485.cjs.dev.js} +8 -10
- package/dist/oidc-d74e6aa2.cjs.prod.js +98 -0
- package/dist/{project-container-27db6a7e.cjs.dev.js → project-container-a6c01dbf.cjs.dev.js} +11 -14
- package/dist/{project-container-0c9ee557.cjs.prod.js → project-container-ad2b76c9.cjs.prod.js} +11 -14
- package/dist/{project-container-8f8e017f.esm.js → project-container-f874583d.esm.js} +11 -14
- package/dist/{project-expired-b35819a4.cjs.dev.js → project-expired-743bae82.cjs.dev.js} +5 -6
- package/dist/{project-expired-da5d431c.cjs.prod.js → project-expired-a52200df.cjs.prod.js} +5 -6
- package/dist/{project-expired-bfa29d75.esm.js → project-expired-d917372c.esm.js} +5 -6
- package/dist/{project-not-found-fdb50d15.cjs.dev.js → project-not-found-5f0b2a72.cjs.dev.js} +4 -5
- package/dist/{project-not-found-695fadf6.cjs.prod.js → project-not-found-e4f79d38.cjs.prod.js} +4 -5
- package/dist/{project-not-found-5fc657c1.esm.js → project-not-found-ee259f9b.esm.js} +4 -5
- package/dist/{project-not-initialized-06d78b62.cjs.dev.js → project-not-initialized-58002613.cjs.dev.js} +5 -6
- package/dist/{project-not-initialized-a3b358cc.esm.js → project-not-initialized-6a3a2473.esm.js} +5 -6
- package/dist/{project-not-initialized-1603b228.cjs.prod.js → project-not-initialized-cfbd7c01.cjs.prod.js} +5 -6
- package/dist/{project-suspended-324978bc.cjs.prod.js → project-suspended-18764104.cjs.prod.js} +4 -5
- package/dist/{project-suspended-7e2257ac.cjs.dev.js → project-suspended-9cc251b0.cjs.dev.js} +4 -5
- package/dist/{project-suspended-d85025fe.esm.js → project-suspended-befd6810.esm.js} +4 -5
- package/dist/{redirect-to-login-3e4a6434.cjs.prod.js → redirect-to-login-12f467b8.cjs.prod.js} +10 -13
- package/dist/{redirect-to-login-edbfacbc.esm.js → redirect-to-login-2944c890.esm.js} +10 -13
- package/dist/{redirect-to-login-66ea895a.cjs.dev.js → redirect-to-login-3bee13ba.cjs.dev.js} +10 -13
- package/dist/{redirect-to-logout-ab5d2b07.cjs.dev.js → redirect-to-logout-7a1fd867.cjs.dev.js} +6 -8
- package/dist/{redirect-to-logout-aea7e913.esm.js → redirect-to-logout-ace73e1b.esm.js} +6 -8
- package/dist/{redirect-to-logout-f96c0c4b.cjs.prod.js → redirect-to-logout-ba4a0b0b.cjs.prod.js} +6 -8
- package/dist/{redirector-c858d578.cjs.prod.js → redirector-0c72d0a4.cjs.prod.js} +3 -4
- package/dist/{redirector-0efdd994.cjs.dev.js → redirector-72ccfbc2.cjs.dev.js} +3 -4
- package/dist/{redirector-656c6ee7.esm.js → redirector-d856975f.esm.js} +3 -4
- package/dist/{requests-in-flight-loader-5f216050.esm.js → requests-in-flight-loader-78c4428e.esm.js} +4 -5
- package/dist/{requests-in-flight-loader-3ffee0c0.cjs.prod.js → requests-in-flight-loader-b7225f9e.cjs.prod.js} +4 -5
- package/dist/{requests-in-flight-loader-08ef339c.cjs.dev.js → requests-in-flight-loader-cbc5faa0.cjs.dev.js} +4 -5
- package/dist/{service-page-project-switcher-9c5c86df.cjs.dev.js → service-page-project-switcher-09e3adc9.cjs.dev.js} +1 -1
- package/dist/{service-page-project-switcher-99b35fc0.esm.js → service-page-project-switcher-9cac7971.esm.js} +1 -1
- package/dist/{service-page-project-switcher-b21619c0.cjs.prod.js → service-page-project-switcher-d8772801.cjs.prod.js} +1 -1
- package/dist/{use-applications-menu-21c7420b.cjs.prod.js → use-applications-menu-8984efa1.cjs.prod.js} +39 -47
- package/dist/{use-applications-menu-8ff2d130.esm.js → use-applications-menu-bc2b9a66.esm.js} +37 -44
- package/dist/{use-applications-menu-7a85c3ee.cjs.dev.js → use-applications-menu-bd718ac8.cjs.dev.js} +39 -47
- package/dist/{user-settings-menu-2d3bfa75.cjs.prod.js → user-settings-menu-013f0041.cjs.prod.js} +22 -29
- package/dist/{user-settings-menu-31e6bb38.esm.js → user-settings-menu-16e8d020.esm.js} +22 -29
- package/dist/{user-settings-menu-c37b343f.cjs.dev.js → user-settings-menu-dc598434.cjs.dev.js} +22 -29
- package/package.json +17 -17
- package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.dev.js +1 -2
- package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.prod.js +1 -2
- package/ssr/dist/commercetools-frontend-application-shell-ssr.esm.js +1 -2
- package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.dev.js +22 -26
- package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.prod.js +22 -26
- package/test-utils/dist/commercetools-frontend-application-shell-test-utils.esm.js +17 -20
- package/dist/oidc-258fc018.cjs.prod.js +0 -115
- package/dist/oidc-35e8e62a.esm.js +0 -100
- package/dist/oidc-87d116c1.cjs.dev.js +0 -115
|
@@ -2,7 +2,6 @@ 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 _concatInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/concat';
|
|
6
5
|
import _Array$isArray from '@babel/runtime-corejs3/core-js-stable/array/is-array';
|
|
7
6
|
import _Number$isFinite from '@babel/runtime-corejs3/core-js-stable/number/is-finite';
|
|
8
7
|
import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
|
|
@@ -23,12 +22,11 @@ import LogoSVG from '@commercetools-frontend/assets/logos/commercetools_small-lo
|
|
|
23
22
|
import { NO_VALUE_FALLBACK, GRAPHQL_TARGETS, STORAGE_KEYS, SUPPORT_PORTAL_URL } from '@commercetools-frontend/constants';
|
|
24
23
|
import { SidebarCollapseIcon, SidebarExpandIcon, SupportIcon } from '@commercetools-uikit/icons';
|
|
25
24
|
import Spacings from '@commercetools-uikit/spacings';
|
|
26
|
-
import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
|
|
27
25
|
import _styled from '@emotion/styled/base';
|
|
28
26
|
import { keyframes, css, Global } from '@emotion/react';
|
|
29
27
|
import { designTokens as designTokens$1 } from '@commercetools-frontend/application-components';
|
|
30
28
|
import { designTokens } from '@commercetools-uikit/design-system';
|
|
31
|
-
import { N as NAVBAR, D as DIMENSIONS, W as WINDOW_SIZES } from './oidc-
|
|
29
|
+
import { N as NAVBAR, D as DIMENSIONS, W as WINDOW_SIZES } from './oidc-b2520905.esm.js';
|
|
32
30
|
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
33
31
|
import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes';
|
|
34
32
|
import { useFlagVariation } from '@flopflip/react-broadcast';
|
|
@@ -42,7 +40,7 @@ import _keysInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instanc
|
|
|
42
40
|
import _sortInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/sort';
|
|
43
41
|
import isNil from 'lodash/isNil';
|
|
44
42
|
import throttle from 'lodash/throttle';
|
|
45
|
-
import { u as useApplicationsMenu } from './use-applications-menu-
|
|
43
|
+
import { u as useApplicationsMenu } from './use-applications-menu-bc2b9a66.esm.js';
|
|
46
44
|
import '@apollo/client';
|
|
47
45
|
import '@commercetools-frontend/l10n';
|
|
48
46
|
|
|
@@ -86,7 +84,6 @@ const Title = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production"
|
|
|
86
84
|
label: "Title"
|
|
87
85
|
})("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== */"));
|
|
88
86
|
|
|
89
|
-
var _templateObject$1;
|
|
90
87
|
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)."; }
|
|
91
88
|
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"]} */");
|
|
92
89
|
var _ref4 = process.env.NODE_ENV === "production" ? {
|
|
@@ -106,7 +103,10 @@ var _ref5 = process.env.NODE_ENV === "production" ? {
|
|
|
106
103
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
|
|
107
104
|
};
|
|
108
105
|
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];
|
|
109
|
-
const fadeIn = keyframes
|
|
106
|
+
const fadeIn = keyframes`
|
|
107
|
+
from {opacity: 0;}
|
|
108
|
+
to { opacity: 1;}
|
|
109
|
+
`;
|
|
110
110
|
var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
111
111
|
name: "eivff4",
|
|
112
112
|
styles: "display:none"
|
|
@@ -204,8 +204,14 @@ const SafeArea = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "producti
|
|
|
204
204
|
label: "SafeArea"
|
|
205
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"]} */"));
|
|
206
206
|
|
|
207
|
-
|
|
208
|
-
|
|
207
|
+
const visible = keyframes`
|
|
208
|
+
from {
|
|
209
|
+
opacity: 0;
|
|
210
|
+
}
|
|
211
|
+
to {
|
|
212
|
+
opacity: 1;
|
|
213
|
+
}
|
|
214
|
+
`;
|
|
209
215
|
const FixedMenu = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
210
216
|
target: "e1meml8k10"
|
|
211
217
|
} : {
|
|
@@ -405,8 +411,8 @@ const MenuGroup = /*#__PURE__*/forwardRef((props, ref) => {
|
|
|
405
411
|
return jsx(MenuList, {
|
|
406
412
|
ref: ref && props.level === 2 ? ref : null,
|
|
407
413
|
level: props.level,
|
|
408
|
-
id:
|
|
409
|
-
"data-testid":
|
|
414
|
+
id: `group-${props.id}`,
|
|
415
|
+
"data-testid": `group-${props.id}`,
|
|
410
416
|
role: "menu",
|
|
411
417
|
onKeyDown: props.handleKeyDown,
|
|
412
418
|
className: classnames({
|
|
@@ -505,7 +511,7 @@ const MenuItemLink = _ref3 => {
|
|
|
505
511
|
};
|
|
506
512
|
MenuItemLink.displayName = 'MenuItemLink';
|
|
507
513
|
function isLongLivedFlag(flag) {
|
|
508
|
-
return typeof
|
|
514
|
+
return typeof flag?.value === 'boolean';
|
|
509
515
|
}
|
|
510
516
|
const RestrictedMenuItem = _ref4 => {
|
|
511
517
|
let _ref4$permissions = _ref4.permissions,
|
|
@@ -753,15 +759,13 @@ const reducer = (state, action) => {
|
|
|
753
759
|
return state;
|
|
754
760
|
}
|
|
755
761
|
};
|
|
756
|
-
const isFocusOutEventCalledBySubmenuItem = event =>
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
);
|
|
764
|
-
};
|
|
762
|
+
const isFocusOutEventCalledBySubmenuItem = event =>
|
|
763
|
+
// a case when a submenu item loses focus
|
|
764
|
+
event.type === 'focusout' &&
|
|
765
|
+
// element receiving focus
|
|
766
|
+
event.relatedTarget?.matches('a[data-link-level="text-link"]') &&
|
|
767
|
+
// element losing focus
|
|
768
|
+
event.target?.matches('a[data-link-level="text-link-sublist"]');
|
|
765
769
|
const useNavbarStateManager = props => {
|
|
766
770
|
var _context, _context2, _context4, _context5;
|
|
767
771
|
const navBarNode = useRef(null);
|
|
@@ -855,8 +859,7 @@ const useNavbarStateManager = props => {
|
|
|
855
859
|
}
|
|
856
860
|
}, 100), [isForcedMenuOpen, state.isExpanderVisible, state.isMenuOpen]);
|
|
857
861
|
const shouldCloseMenuFly = useCallback(event => {
|
|
858
|
-
|
|
859
|
-
if (!(navBarNode !== null && navBarNode !== void 0 && (_navBarNode$current = navBarNode.current) !== null && _navBarNode$current !== void 0 && _navBarNode$current.contains(event.target)) && !state.isMenuOpen) {
|
|
862
|
+
if (!navBarNode?.current?.contains(event.target) && !state.isMenuOpen) {
|
|
860
863
|
dispatch({
|
|
861
864
|
type: 'unsetActiveItemIndex'
|
|
862
865
|
});
|
|
@@ -921,7 +924,7 @@ const useNavbarStateManager = props => {
|
|
|
921
924
|
const allApplicationsNavbarMenuGroups = _sortInstanceProperty(_context4 = _mapInstanceProperty(_context5 = applicationsNavBarMenuGroups || []).call(_context5, navbarMenuGroup => navbarMenuGroup.key === '2' && allCustomApplicationsNavbarMenu.length > 0 ? {
|
|
922
925
|
key: navbarMenuGroup.key,
|
|
923
926
|
items: [...navbarMenuGroup.items, ...allCustomApplicationsNavbarMenu]
|
|
924
|
-
} : navbarMenuGroup)).call(_context4, (navBarMenuGroupA, navBarMenuGroupB) => Number(navBarMenuGroupA
|
|
927
|
+
} : navbarMenuGroup)).call(_context4, (navBarMenuGroupA, navBarMenuGroupB) => Number(navBarMenuGroupA?.key) - Number(navBarMenuGroupB?.key));
|
|
925
928
|
return _objectSpread$1(_objectSpread$1({}, state), {}, {
|
|
926
929
|
navBarNode,
|
|
927
930
|
handleToggleItem,
|
|
@@ -933,7 +936,7 @@ const useNavbarStateManager = props => {
|
|
|
933
936
|
};
|
|
934
937
|
|
|
935
938
|
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; }
|
|
936
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var
|
|
939
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context3 = ownKeys(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context4 = ownKeys(Object(t))).call(_context4, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
937
940
|
// Helper function to extract accessible label from menu objects
|
|
938
941
|
const getMenuAccessibleLabel = (labelAllLocales, defaultLabel, applicationLocale) => {
|
|
939
942
|
const localizedLabel = _findInstanceProperty(labelAllLocales).call(labelAllLocales, loc => _startsWithInstanceProperty(applicationLocale).call(applicationLocale, loc.locale));
|
|
@@ -941,16 +944,13 @@ const getMenuAccessibleLabel = (labelAllLocales, defaultLabel, applicationLocale
|
|
|
941
944
|
if (defaultLabel) return defaultLabel;
|
|
942
945
|
return NO_VALUE_FALLBACK;
|
|
943
946
|
};
|
|
944
|
-
const getIsSubmenuRouteActive = (uriPath, props) => {
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
|
|
949
|
-
strict: false
|
|
950
|
-
}));
|
|
951
|
-
};
|
|
947
|
+
const getIsSubmenuRouteActive = (uriPath, props) => Boolean(matchPath(props.location.pathname, {
|
|
948
|
+
path: `/${props.projectKey}/${uriPath}`,
|
|
949
|
+
exact: true,
|
|
950
|
+
strict: false
|
|
951
|
+
}));
|
|
952
952
|
const ApplicationMenu = props => {
|
|
953
|
-
var
|
|
953
|
+
var _context;
|
|
954
954
|
const _useState = useState(0),
|
|
955
955
|
_useState2 = _slicedToArray(_useState, 2),
|
|
956
956
|
submenuVerticalPosition = _useState2[0],
|
|
@@ -977,13 +977,12 @@ const ApplicationMenu = props => {
|
|
|
977
977
|
const hasSubmenu = _Array$isArray(props.menu.submenu) && props.menu.submenu.length > 0;
|
|
978
978
|
const menuItemIdentifier = snakeCase(props.menu.key);
|
|
979
979
|
const calculateSafeAreaStartPositon = useCallback(e => {
|
|
980
|
-
|
|
981
|
-
const
|
|
982
|
-
const
|
|
983
|
-
const
|
|
984
|
-
const
|
|
985
|
-
const
|
|
986
|
-
const currentSafeAreaHeight = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.height) || 0;
|
|
980
|
+
const currentSafeAreaRect = submenuSafeAreaRef.current?.getBoundingClientRect();
|
|
981
|
+
const menuItemRect = document.querySelector(`[data-menuitem="${menuItemIdentifier}"]`)?.getBoundingClientRect();
|
|
982
|
+
const currentSafeAreaLeft = currentSafeAreaRect?.left || 0;
|
|
983
|
+
const currentSafeAreaTop = currentSafeAreaRect?.top || 0;
|
|
984
|
+
const currentSafeAreaWidth = currentSafeAreaRect?.width || 0;
|
|
985
|
+
const currentSafeAreaHeight = currentSafeAreaRect?.height || 0;
|
|
987
986
|
const localX = e.clientX - currentSafeAreaLeft;
|
|
988
987
|
const localY = e.clientY - currentSafeAreaTop;
|
|
989
988
|
let minXPercent = 0;
|
|
@@ -1029,17 +1028,15 @@ const ApplicationMenu = props => {
|
|
|
1029
1028
|
};
|
|
1030
1029
|
}, [calculateSafeAreaStartPositon]);
|
|
1031
1030
|
useLayoutEffect(() => {
|
|
1032
|
-
var _context2;
|
|
1033
1031
|
if (!submenuRef.current) return;
|
|
1034
1032
|
const safeX = _Number$isFinite(percentageX) ? percentageX : 0;
|
|
1035
1033
|
const safeY = _Number$isFinite(percentageY) ? percentageY : 100;
|
|
1036
|
-
submenuRef.current.style.setProperty('--safe-start',
|
|
1034
|
+
submenuRef.current.style.setProperty('--safe-start', `${safeX}% ${safeY}%`);
|
|
1037
1035
|
}, [percentageX, percentageY]);
|
|
1038
1036
|
const callbackFn = useCallback(entries => {
|
|
1039
|
-
|
|
1040
|
-
const
|
|
1041
|
-
const
|
|
1042
|
-
const menuItemBottom = (menuItemBoundingClientRect === null || menuItemBoundingClientRect === void 0 ? void 0 : menuItemBoundingClientRect.bottom) || 0;
|
|
1037
|
+
const menuItemBoundingClientRect = document.querySelector(`[data-menuitem="${menuItemIdentifier}"]`)?.getBoundingClientRect();
|
|
1038
|
+
const menuItemTop = menuItemBoundingClientRect?.top || 0;
|
|
1039
|
+
const menuItemBottom = menuItemBoundingClientRect?.bottom || 0;
|
|
1043
1040
|
const _entries = _slicedToArray(entries, 1),
|
|
1044
1041
|
entry = _entries[0];
|
|
1045
1042
|
|
|
@@ -1065,10 +1062,7 @@ const ApplicationMenu = props => {
|
|
|
1065
1062
|
observerRef.current = new IntersectionObserver(callbackFn, {
|
|
1066
1063
|
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
|
|
1067
1064
|
});
|
|
1068
|
-
return () =>
|
|
1069
|
-
var _observerRef$current;
|
|
1070
|
-
return (_observerRef$current = observerRef.current) === null || _observerRef$current === void 0 ? void 0 : _observerRef$current.disconnect();
|
|
1071
|
-
};
|
|
1065
|
+
return () => observerRef.current?.disconnect();
|
|
1072
1066
|
}, [callbackFn, props.isMenuOpen]);
|
|
1073
1067
|
useLayoutEffect(() => {
|
|
1074
1068
|
const currentSubmenuRef = submenuRef.current;
|
|
@@ -1078,10 +1072,10 @@ const ApplicationMenu = props => {
|
|
|
1078
1072
|
observer.observe(currentSubmenuRef);
|
|
1079
1073
|
}
|
|
1080
1074
|
setIsSubmenuFocused(false);
|
|
1081
|
-
return () => observer
|
|
1075
|
+
return () => observer?.disconnect();
|
|
1082
1076
|
}, [menuItemIdentifier, props.isMenuOpen, props.handleToggleItem, callbackFn]);
|
|
1083
1077
|
const isMainMenuRouteActive = Boolean(matchPath(props.location.pathname, {
|
|
1084
|
-
path:
|
|
1078
|
+
path: `/${props.projectKey}/${props.menu.uriPath}`,
|
|
1085
1079
|
exact: false,
|
|
1086
1080
|
strict: false
|
|
1087
1081
|
}));
|
|
@@ -1095,22 +1089,20 @@ const ApplicationMenu = props => {
|
|
|
1095
1089
|
}, [props.isMenuOpen]); // <-- (re)run this only when the all menu expands
|
|
1096
1090
|
|
|
1097
1091
|
const handleKeyDown = e => {
|
|
1098
|
-
|
|
1099
|
-
const currentlyFocusedItem = (_submenuRef$current = submenuRef.current) === null || _submenuRef$current === void 0 ? void 0 : _submenuRef$current.querySelector(':focus');
|
|
1092
|
+
const currentlyFocusedItem = submenuRef.current?.querySelector(':focus');
|
|
1100
1093
|
if (e.key === 'Enter') {
|
|
1101
1094
|
setIsSubmenuFocused(true);
|
|
1102
1095
|
if (!currentlyFocusedItem) {
|
|
1103
|
-
|
|
1104
|
-
(_submenuRef$current2 = submenuRef.current) === null || _submenuRef$current2 === void 0 || (_submenuRef$current2 = _submenuRef$current2.querySelector('a')) === null || _submenuRef$current2 === void 0 || _submenuRef$current2.focus();
|
|
1096
|
+
submenuRef.current?.querySelector('a')?.focus();
|
|
1105
1097
|
}
|
|
1106
1098
|
}
|
|
1107
1099
|
};
|
|
1108
1100
|
return jsx(RestrictedMenuItem, {
|
|
1109
1101
|
keyOfMenuItem: props.menu.key,
|
|
1110
|
-
featureToggle:
|
|
1102
|
+
featureToggle: props.menu.featureToggle ?? undefined,
|
|
1111
1103
|
permissions: props.menu.permissions,
|
|
1112
|
-
actionRights:
|
|
1113
|
-
dataFences:
|
|
1104
|
+
actionRights: props.menu.actionRights ?? undefined,
|
|
1105
|
+
dataFences: props.menu.dataFences ?? undefined,
|
|
1114
1106
|
projectPermissions: props.projectPermissions,
|
|
1115
1107
|
children: jsxs(MenuItem$1, {
|
|
1116
1108
|
hasSubmenu: hasSubmenu,
|
|
@@ -1125,7 +1117,7 @@ const ApplicationMenu = props => {
|
|
|
1125
1117
|
identifier: menuItemIdentifier,
|
|
1126
1118
|
ariaLabel: getMenuAccessibleLabel(props.menu.labelAllLocales, props.menu.defaultLabel, props.applicationLocale),
|
|
1127
1119
|
children: [jsx(MenuItemLink, {
|
|
1128
|
-
linkTo:
|
|
1120
|
+
linkTo: `/${props.projectKey}/${props.menu.uriPath}`,
|
|
1129
1121
|
useFullRedirectsForLinks: props.useFullRedirectsForLinks,
|
|
1130
1122
|
onClick: props.onMenuItemClick,
|
|
1131
1123
|
ariaLabel: getMenuAccessibleLabel(props.menu.labelAllLocales, props.menu.defaultLabel, props.applicationLocale),
|
|
@@ -1137,7 +1129,7 @@ const ApplicationMenu = props => {
|
|
|
1137
1129
|
isMenuOpen: props.isMenuOpen
|
|
1138
1130
|
})
|
|
1139
1131
|
}), jsxs(MenuGroup, {
|
|
1140
|
-
id:
|
|
1132
|
+
id: `group-${props.menu.key}`,
|
|
1141
1133
|
level: 2,
|
|
1142
1134
|
isActive: props.isActive,
|
|
1143
1135
|
isExpanded: props.isMenuOpen,
|
|
@@ -1148,7 +1140,7 @@ const ApplicationMenu = props => {
|
|
|
1148
1140
|
children: [!props.isMenuOpen && jsx(TooltipContainer, {
|
|
1149
1141
|
alignsAgainstBottom: isSubmenuAboveMenuItem,
|
|
1150
1142
|
children: jsx(Tooltip, {
|
|
1151
|
-
"aria-owns":
|
|
1143
|
+
"aria-owns": `group-${props.menu.key}`,
|
|
1152
1144
|
role: "tooltip",
|
|
1153
1145
|
children: jsx(MenuLabel, {
|
|
1154
1146
|
labelAllLocales: props.menu.labelAllLocales,
|
|
@@ -1156,39 +1148,36 @@ const ApplicationMenu = props => {
|
|
|
1156
1148
|
applicationLocale: props.applicationLocale
|
|
1157
1149
|
})
|
|
1158
1150
|
})
|
|
1159
|
-
}), hasSubmenu ? _mapInstanceProperty(
|
|
1160
|
-
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
children: jsx(
|
|
1169
|
-
|
|
1170
|
-
|
|
1171
|
-
|
|
1172
|
-
|
|
1173
|
-
|
|
1174
|
-
|
|
1175
|
-
|
|
1176
|
-
|
|
1177
|
-
|
|
1178
|
-
|
|
1179
|
-
|
|
1180
|
-
|
|
1181
|
-
|
|
1182
|
-
|
|
1183
|
-
|
|
1184
|
-
defaultLabel: submenu.defaultLabel,
|
|
1185
|
-
applicationLocale: props.applicationLocale
|
|
1186
|
-
})
|
|
1151
|
+
}), hasSubmenu ? _mapInstanceProperty(_context = props.menu.submenu).call(_context, submenu => jsx(RestrictedMenuItem, {
|
|
1152
|
+
keyOfMenuItem: submenu.key,
|
|
1153
|
+
featureToggle: submenu.featureToggle ?? undefined,
|
|
1154
|
+
permissions: submenu.permissions,
|
|
1155
|
+
actionRights: submenu.actionRights ?? undefined,
|
|
1156
|
+
dataFences: submenu.dataFences ?? undefined,
|
|
1157
|
+
projectPermissions: props.projectPermissions,
|
|
1158
|
+
children: jsx(SublistItem, {
|
|
1159
|
+
isActive: getIsSubmenuRouteActive(submenu.uriPath, props),
|
|
1160
|
+
children: jsx(Text, {
|
|
1161
|
+
children: jsx(MenuItemLink, {
|
|
1162
|
+
linkTo: `/${props.projectKey}/${submenu.uriPath}`
|
|
1163
|
+
// We want to use an exact matching strategy to avoid multiple
|
|
1164
|
+
// links matching sub-routes.
|
|
1165
|
+
,
|
|
1166
|
+
exactMatch: true,
|
|
1167
|
+
useFullRedirectsForLinks: props.useFullRedirectsForLinks,
|
|
1168
|
+
onClick: props.onMenuItemClick,
|
|
1169
|
+
isSubmenuLink: true,
|
|
1170
|
+
isSubmenuFocused: isSubmenuFocused,
|
|
1171
|
+
ariaLabel: getMenuAccessibleLabel(submenu.labelAllLocales, submenu.defaultLabel, props.applicationLocale),
|
|
1172
|
+
children: jsx(MenuLabel, {
|
|
1173
|
+
labelAllLocales: submenu.labelAllLocales,
|
|
1174
|
+
defaultLabel: submenu.defaultLabel,
|
|
1175
|
+
applicationLocale: props.applicationLocale
|
|
1187
1176
|
})
|
|
1188
1177
|
})
|
|
1189
1178
|
})
|
|
1190
|
-
}
|
|
1191
|
-
}) : null, jsx(SafeArea, {
|
|
1179
|
+
})
|
|
1180
|
+
}, `${props.menu.key}-submenu-${submenu.key}`)) : null, jsx(SafeArea, {
|
|
1192
1181
|
ref: submenuSafeAreaRef
|
|
1193
1182
|
})]
|
|
1194
1183
|
})]
|
|
@@ -1215,14 +1204,11 @@ const NavBar = props => {
|
|
|
1215
1204
|
const location = useLocation();
|
|
1216
1205
|
const _useIntl = useIntl(),
|
|
1217
1206
|
formatMessage = _useIntl.formatMessage;
|
|
1218
|
-
const projectPermissions = useMemo(() => {
|
|
1219
|
-
|
|
1220
|
-
|
|
1221
|
-
|
|
1222
|
-
|
|
1223
|
-
dataFences: normalizeAllAppliedDataFences((_props$project3 = props.project) === null || _props$project3 === void 0 ? void 0 : _props$project3.allPermissionsForAllApplications.allAppliedDataFences)
|
|
1224
|
-
};
|
|
1225
|
-
}, [props.project]);
|
|
1207
|
+
const projectPermissions = useMemo(() => ({
|
|
1208
|
+
permissions: normalizeAllAppliedPermissions(props.project?.allPermissionsForAllApplications.allAppliedPermissions),
|
|
1209
|
+
actionRights: normalizeAllAppliedActionRights(props.project?.allPermissionsForAllApplications.allAppliedActionRights),
|
|
1210
|
+
dataFences: normalizeAllAppliedDataFences(props.project?.allPermissionsForAllApplications.allAppliedDataFences)
|
|
1211
|
+
}), [props.project]);
|
|
1226
1212
|
const applicationLocale = props.applicationLocale;
|
|
1227
1213
|
|
|
1228
1214
|
// Render the loading navbar as long as all the data
|
|
@@ -1253,12 +1239,11 @@ const NavBar = props => {
|
|
|
1253
1239
|
children: jsx(Spacings.Stack, {
|
|
1254
1240
|
scale: "l",
|
|
1255
1241
|
children: _mapInstanceProperty(allApplicationsNavbarMenuGroups).call(allApplicationsNavbarMenuGroups, navbarMenuGroup => {
|
|
1256
|
-
var
|
|
1242
|
+
var _context2;
|
|
1257
1243
|
return jsx("div", {
|
|
1258
|
-
children: _mapInstanceProperty(
|
|
1259
|
-
var _context9;
|
|
1244
|
+
children: _mapInstanceProperty(_context2 = navbarMenuGroup.items).call(_context2, menu => {
|
|
1260
1245
|
const menuType = 'scrollable';
|
|
1261
|
-
const itemIndex =
|
|
1246
|
+
const itemIndex = `${menuType}-${menu.key}`;
|
|
1262
1247
|
return jsx(ApplicationMenu, {
|
|
1263
1248
|
location: location,
|
|
1264
1249
|
menu: menu,
|