@commercetools-frontend/application-shell 24.13.0 → 25.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/dist/{application-entry-point-1b23fb6b.esm.js → application-entry-point-10a5e1a5.esm.js} +4 -6
  2. package/dist/{application-entry-point-74a06151.cjs.prod.js → application-entry-point-8c4b8e53.cjs.prod.js} +3 -4
  3. package/dist/{application-entry-point-18d8fba0.cjs.dev.js → application-entry-point-c87294b0.cjs.dev.js} +4 -7
  4. package/dist/commercetools-frontend-application-shell.cjs.dev.js +4 -5
  5. package/dist/commercetools-frontend-application-shell.cjs.prod.js +4 -5
  6. package/dist/commercetools-frontend-application-shell.esm.js +4 -5
  7. package/dist/{custom-view-dev-host-f688743e.cjs.dev.js → custom-view-dev-host-5350eda4.cjs.dev.js} +10 -15
  8. package/dist/{custom-view-dev-host-bf11de47.cjs.prod.js → custom-view-dev-host-9d70ed5a.cjs.prod.js} +10 -15
  9. package/dist/{custom-view-dev-host-b4f856d8.esm.js → custom-view-dev-host-d5c02c31.esm.js} +10 -14
  10. package/dist/{index-52c724ed.cjs.prod.js → index-245e2980.cjs.prod.js} +2 -2
  11. package/dist/{index-dcd3d8a3.cjs.dev.js → index-2b8a5370.cjs.dev.js} +108 -132
  12. package/dist/{index-242af4d2.cjs.prod.js → index-3ce8bcb0.cjs.prod.js} +108 -132
  13. package/dist/{index-25183095.cjs.dev.js → index-614accc4.cjs.dev.js} +2 -2
  14. package/dist/{index-5aaa33bb.esm.js → index-86039df7.esm.js} +2 -2
  15. package/dist/{index-d8c26ca0.esm.js → index-c8c7dc44.esm.js} +108 -131
  16. package/dist/{navbar-0bad8bc8.esm.js → navbar-9a40ead9.esm.js} +89 -104
  17. package/dist/{navbar-d4189469.cjs.dev.js → navbar-c51e0607.cjs.dev.js} +89 -105
  18. package/dist/{navbar-7653417f.cjs.prod.js → navbar-e287ce25.cjs.prod.js} +89 -105
  19. package/dist/oidc-8827f9fe.cjs.dev.js +98 -0
  20. package/dist/oidc-b2520905.esm.js +84 -0
  21. package/dist/{oidc-callback-11dae6b7.cjs.dev.js → oidc-callback-10369351.cjs.dev.js} +8 -10
  22. package/dist/{oidc-callback-82aa6be5.esm.js → oidc-callback-43725da4.esm.js} +8 -10
  23. package/dist/{oidc-callback-300966ee.cjs.prod.js → oidc-callback-d0f0ab00.cjs.prod.js} +8 -10
  24. package/dist/oidc-d74e6aa2.cjs.prod.js +98 -0
  25. package/dist/{project-container-991a64a8.cjs.dev.js → project-container-1ee088eb.cjs.dev.js} +11 -14
  26. package/dist/{project-container-2f98a9d6.cjs.prod.js → project-container-64823e34.cjs.prod.js} +11 -14
  27. package/dist/{project-container-ce0f6228.esm.js → project-container-da53bf6d.esm.js} +11 -14
  28. package/dist/{project-expired-f753ba58.cjs.prod.js → project-expired-b3656692.cjs.prod.js} +5 -6
  29. package/dist/{project-expired-49e78c8c.esm.js → project-expired-c5239755.esm.js} +5 -6
  30. package/dist/{project-expired-fa4a86df.cjs.dev.js → project-expired-cd366d1f.cjs.dev.js} +5 -6
  31. package/dist/{project-not-found-d594db71.cjs.prod.js → project-not-found-278f33b4.cjs.prod.js} +4 -5
  32. package/dist/{project-not-found-ac82676b.esm.js → project-not-found-329638a6.esm.js} +4 -5
  33. package/dist/{project-not-found-261f37e8.cjs.dev.js → project-not-found-e7381918.cjs.dev.js} +4 -5
  34. package/dist/{project-not-initialized-4c02d4b2.esm.js → project-not-initialized-80b21ac8.esm.js} +5 -6
  35. package/dist/{project-not-initialized-c3a87ba6.cjs.dev.js → project-not-initialized-9e5f45ed.cjs.dev.js} +5 -6
  36. package/dist/{project-not-initialized-5a77d844.cjs.prod.js → project-not-initialized-df5f697e.cjs.prod.js} +5 -6
  37. package/dist/{project-suspended-cd66814e.esm.js → project-suspended-41550cb8.esm.js} +4 -5
  38. package/dist/{project-suspended-42a90ea6.cjs.dev.js → project-suspended-9eb2139a.cjs.dev.js} +4 -5
  39. package/dist/{project-suspended-dccadfd7.cjs.prod.js → project-suspended-defdb3bb.cjs.prod.js} +4 -5
  40. package/dist/{redirect-to-login-3e4a6434.cjs.prod.js → redirect-to-login-12f467b8.cjs.prod.js} +10 -13
  41. package/dist/{redirect-to-login-edbfacbc.esm.js → redirect-to-login-2944c890.esm.js} +10 -13
  42. package/dist/{redirect-to-login-66ea895a.cjs.dev.js → redirect-to-login-3bee13ba.cjs.dev.js} +10 -13
  43. package/dist/{redirect-to-logout-99db4db7.cjs.prod.js → redirect-to-logout-4c6e4cb5.cjs.prod.js} +6 -8
  44. package/dist/{redirect-to-logout-ba40d106.esm.js → redirect-to-logout-a6daf354.esm.js} +6 -8
  45. package/dist/{redirect-to-logout-ab0c374b.cjs.dev.js → redirect-to-logout-bb92fd28.cjs.dev.js} +6 -8
  46. package/dist/{redirector-c858d578.cjs.prod.js → redirector-0c72d0a4.cjs.prod.js} +3 -4
  47. package/dist/{redirector-0efdd994.cjs.dev.js → redirector-72ccfbc2.cjs.dev.js} +3 -4
  48. package/dist/{redirector-656c6ee7.esm.js → redirector-d856975f.esm.js} +3 -4
  49. package/dist/{requests-in-flight-loader-64a40481.esm.js → requests-in-flight-loader-32ab77e4.esm.js} +4 -5
  50. package/dist/{requests-in-flight-loader-df9d1de3.cjs.prod.js → requests-in-flight-loader-59388ad8.cjs.prod.js} +4 -5
  51. package/dist/{requests-in-flight-loader-878840c1.cjs.dev.js → requests-in-flight-loader-98a1e540.cjs.dev.js} +4 -5
  52. package/dist/{service-page-project-switcher-532df57f.cjs.prod.js → service-page-project-switcher-9405f62f.cjs.prod.js} +1 -1
  53. package/dist/{service-page-project-switcher-0f1c1d7f.cjs.dev.js → service-page-project-switcher-b9a7c9d6.cjs.dev.js} +1 -1
  54. package/dist/{service-page-project-switcher-aca41b09.esm.js → service-page-project-switcher-bb959b99.esm.js} +1 -1
  55. package/dist/{use-applications-menu-21c7420b.cjs.prod.js → use-applications-menu-8984efa1.cjs.prod.js} +39 -47
  56. package/dist/{use-applications-menu-8ff2d130.esm.js → use-applications-menu-bc2b9a66.esm.js} +37 -44
  57. package/dist/{use-applications-menu-7a85c3ee.cjs.dev.js → use-applications-menu-bd718ac8.cjs.dev.js} +39 -47
  58. package/dist/{user-settings-menu-2d3bfa75.cjs.prod.js → user-settings-menu-013f0041.cjs.prod.js} +22 -29
  59. package/dist/{user-settings-menu-31e6bb38.esm.js → user-settings-menu-16e8d020.esm.js} +22 -29
  60. package/dist/{user-settings-menu-c37b343f.cjs.dev.js → user-settings-menu-dc598434.cjs.dev.js} +22 -29
  61. package/package.json +18 -19
  62. package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.dev.js +1 -2
  63. package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.prod.js +1 -2
  64. package/ssr/dist/commercetools-frontend-application-shell-ssr.esm.js +1 -2
  65. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.dev.js +22 -26
  66. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.prod.js +22 -26
  67. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.esm.js +17 -20
  68. package/dist/oidc-258fc018.cjs.prod.js +0 -115
  69. package/dist/oidc-35e8e62a.esm.js +0 -100
  70. 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-35e8e62a.esm.js';
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-8ff2d130.esm.js';
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(_templateObject$1 || (_templateObject$1 = _taggedTemplateLiteral(["\nfrom {opacity: 0;}\n to { opacity: 1;}\n"])));
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
- var _templateObject;
208
- const visible = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n"])));
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: "group-".concat(props.id),
409
- "data-testid": "group-".concat(props.id),
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 (flag === null || flag === void 0 ? void 0 : flag.value) === 'boolean';
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
- 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
- };
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
- 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) {
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 === null || navBarMenuGroupA === void 0 ? void 0 : navBarMenuGroupA.key) - Number(navBarMenuGroupB === null || navBarMenuGroupB === void 0 ? void 0 : navBarMenuGroupB.key));
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 _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; }
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
- 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
- }));
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 _context3, _props$menu$featureTo, _props$menu$actionRig, _props$menu$dataFence, _context4, _context5;
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
- 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;
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', _concatInstanceProperty(_context2 = "".concat(safeX, "% ")).call(_context2, safeY, "%"));
1034
+ submenuRef.current.style.setProperty('--safe-start', `${safeX}% ${safeY}%`);
1037
1035
  }, [percentageX, percentageY]);
1038
1036
  const callbackFn = useCallback(entries => {
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;
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 === null || observer === void 0 ? void 0 : observer.disconnect();
1075
+ return () => observer?.disconnect();
1082
1076
  }, [menuItemIdentifier, props.isMenuOpen, props.handleToggleItem, callbackFn]);
1083
1077
  const isMainMenuRouteActive = Boolean(matchPath(props.location.pathname, {
1084
- path: _concatInstanceProperty(_context3 = "/".concat(props.projectKey, "/")).call(_context3, props.menu.uriPath),
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
- var _submenuRef$current;
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
- 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();
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: (_props$menu$featureTo = props.menu.featureToggle) !== null && _props$menu$featureTo !== void 0 ? _props$menu$featureTo : undefined,
1102
+ featureToggle: props.menu.featureToggle ?? undefined,
1111
1103
  permissions: props.menu.permissions,
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,
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: _concatInstanceProperty(_context4 = "/".concat(props.projectKey, "/")).call(_context4, props.menu.uriPath),
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: "group-".concat(props.menu.key),
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": "group-".concat(props.menu.key),
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(_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
- })
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
- }, _concatInstanceProperty(_context6 = "".concat(props.menu.key, "-submenu-")).call(_context6, submenu.key));
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
- 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]);
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 _context8;
1242
+ var _context2;
1257
1243
  return jsx("div", {
1258
- children: _mapInstanceProperty(_context8 = navbarMenuGroup.items).call(_context8, menu => {
1259
- var _context9;
1244
+ children: _mapInstanceProperty(_context2 = navbarMenuGroup.items).call(_context2, menu => {
1260
1245
  const menuType = 'scrollable';
1261
- const itemIndex = _concatInstanceProperty(_context9 = "".concat(menuType, "-")).call(_context9, menu.key);
1246
+ const itemIndex = `${menuType}-${menu.key}`;
1262
1247
  return jsx(ApplicationMenu, {
1263
1248
  location: location,
1264
1249
  menu: menu,