@commercetools-frontend/application-shell 24.11.0 → 24.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (79) hide show
  1. package/dist/{application-entry-point-c87294b0.cjs.dev.js → application-entry-point-18d8fba0.cjs.dev.js} +7 -4
  2. package/dist/{application-entry-point-10a5e1a5.esm.js → application-entry-point-1b23fb6b.esm.js} +6 -4
  3. package/dist/{application-entry-point-8c4b8e53.cjs.prod.js → application-entry-point-74a06151.cjs.prod.js} +4 -3
  4. package/dist/commercetools-frontend-application-shell.cjs.dev.js +12 -11
  5. package/dist/commercetools-frontend-application-shell.cjs.prod.js +12 -11
  6. package/dist/commercetools-frontend-application-shell.esm.js +12 -11
  7. package/dist/{custom-view-dev-host-6091b78a.esm.js → custom-view-dev-host-b4f856d8.esm.js} +20 -16
  8. package/dist/{custom-view-dev-host-3a171a01.cjs.prod.js → custom-view-dev-host-bf11de47.cjs.prod.js} +21 -16
  9. package/dist/{custom-view-dev-host-40b33836.cjs.dev.js → custom-view-dev-host-f688743e.cjs.dev.js} +21 -16
  10. package/dist/declarations/src/types/generated/mc.d.ts +9 -8
  11. package/dist/declarations-connectors/src/components/application-context/index.d.ts +2 -3
  12. package/dist/declarations-connectors/src/components/application-context/normalizers.d.ts +1 -5
  13. package/dist/declarations-connectors/src/export-types.d.ts +1 -2
  14. package/dist/declarations-connectors/src/index.d.ts +1 -1
  15. package/dist/declarations-connectors/src/types/generated/mc.d.ts +9 -8
  16. package/dist/{index-7bdde97c.cjs.prod.js → index-242af4d2.cjs.prod.js} +201 -344
  17. package/dist/{index-614accc4.cjs.dev.js → index-25183095.cjs.dev.js} +2 -2
  18. package/dist/{index-245e2980.cjs.prod.js → index-52c724ed.cjs.prod.js} +2 -2
  19. package/dist/{index-86039df7.esm.js → index-5aaa33bb.esm.js} +2 -2
  20. package/dist/{index-67a5d8e8.esm.js → index-d8c26ca0.esm.js} +214 -363
  21. package/dist/{index-a57c8458.cjs.dev.js → index-dcd3d8a3.cjs.dev.js} +213 -364
  22. package/dist/{navbar-844d350d.esm.js → navbar-0bad8bc8.esm.js} +106 -110
  23. package/dist/{navbar-acc2cd1b.cjs.prod.js → navbar-7653417f.cjs.prod.js} +108 -112
  24. package/dist/{navbar-022383bd.cjs.dev.js → navbar-d4189469.cjs.dev.js} +108 -112
  25. package/dist/oidc-258fc018.cjs.prod.js +115 -0
  26. package/dist/oidc-35e8e62a.esm.js +100 -0
  27. package/dist/oidc-87d116c1.cjs.dev.js +115 -0
  28. package/dist/{oidc-callback-e07f0c20.cjs.dev.js → oidc-callback-11dae6b7.cjs.dev.js} +16 -14
  29. package/dist/{oidc-callback-ce8cbdfe.cjs.prod.js → oidc-callback-300966ee.cjs.prod.js} +16 -14
  30. package/dist/{oidc-callback-5f3d5280.esm.js → oidc-callback-82aa6be5.esm.js} +16 -14
  31. package/dist/{project-container-2d3d027a.cjs.prod.js → project-container-2f98a9d6.cjs.prod.js} +53 -19
  32. package/dist/{project-container-a11a31ca.cjs.dev.js → project-container-991a64a8.cjs.dev.js} +53 -19
  33. package/dist/{project-container-fba09841.esm.js → project-container-ce0f6228.esm.js} +52 -19
  34. package/dist/{project-expired-ede4d485.esm.js → project-expired-49e78c8c.esm.js} +12 -11
  35. package/dist/{project-expired-f38a712a.cjs.prod.js → project-expired-f753ba58.cjs.prod.js} +12 -11
  36. package/dist/{project-expired-9620dee4.cjs.dev.js → project-expired-fa4a86df.cjs.dev.js} +12 -11
  37. package/dist/{project-not-found-05683f8e.cjs.dev.js → project-not-found-261f37e8.cjs.dev.js} +11 -10
  38. package/dist/{project-not-found-093ab795.esm.js → project-not-found-ac82676b.esm.js} +11 -10
  39. package/dist/{project-not-found-cfa934da.cjs.prod.js → project-not-found-d594db71.cjs.prod.js} +11 -10
  40. package/dist/{project-not-initialized-1d934ae7.esm.js → project-not-initialized-4c02d4b2.esm.js} +12 -11
  41. package/dist/{project-not-initialized-b5a1400f.cjs.prod.js → project-not-initialized-5a77d844.cjs.prod.js} +12 -11
  42. package/dist/{project-not-initialized-1ed56a00.cjs.dev.js → project-not-initialized-c3a87ba6.cjs.dev.js} +12 -11
  43. package/dist/{project-suspended-68e80299.cjs.dev.js → project-suspended-42a90ea6.cjs.dev.js} +11 -10
  44. package/dist/{project-suspended-e0722654.esm.js → project-suspended-cd66814e.esm.js} +11 -10
  45. package/dist/{project-suspended-8e15a452.cjs.prod.js → project-suspended-dccadfd7.cjs.prod.js} +11 -10
  46. package/dist/{redirect-to-login-12f467b8.cjs.prod.js → redirect-to-login-3e4a6434.cjs.prod.js} +13 -10
  47. package/dist/{redirect-to-login-3bee13ba.cjs.dev.js → redirect-to-login-66ea895a.cjs.dev.js} +13 -10
  48. package/dist/{redirect-to-login-2944c890.esm.js → redirect-to-login-edbfacbc.esm.js} +13 -10
  49. package/dist/{redirect-to-logout-2802852c.cjs.prod.js → redirect-to-logout-99db4db7.cjs.prod.js} +14 -12
  50. package/dist/{redirect-to-logout-74b72fe8.cjs.dev.js → redirect-to-logout-ab0c374b.cjs.dev.js} +14 -12
  51. package/dist/{redirect-to-logout-5db48f16.esm.js → redirect-to-logout-ba40d106.esm.js} +14 -12
  52. package/dist/{redirector-72ccfbc2.cjs.dev.js → redirector-0efdd994.cjs.dev.js} +4 -3
  53. package/dist/{redirector-d856975f.esm.js → redirector-656c6ee7.esm.js} +4 -3
  54. package/dist/{redirector-0c72d0a4.cjs.prod.js → redirector-c858d578.cjs.prod.js} +4 -3
  55. package/dist/{requests-in-flight-loader-e25f4c31.esm.js → requests-in-flight-loader-64a40481.esm.js} +11 -10
  56. package/dist/{requests-in-flight-loader-bc904171.cjs.dev.js → requests-in-flight-loader-878840c1.cjs.dev.js} +11 -10
  57. package/dist/{requests-in-flight-loader-877c1541.cjs.prod.js → requests-in-flight-loader-df9d1de3.cjs.prod.js} +11 -10
  58. package/dist/{service-page-project-switcher-af044ac6.cjs.dev.js → service-page-project-switcher-0f1c1d7f.cjs.dev.js} +1 -1
  59. package/dist/{service-page-project-switcher-1dad9871.cjs.prod.js → service-page-project-switcher-532df57f.cjs.prod.js} +1 -1
  60. package/dist/{service-page-project-switcher-f3eac18a.esm.js → service-page-project-switcher-aca41b09.esm.js} +1 -1
  61. package/dist/{use-applications-menu-14a5a1f4.cjs.prod.js → use-applications-menu-21c7420b.cjs.prod.js} +48 -40
  62. package/dist/{use-applications-menu-823a2492.cjs.dev.js → use-applications-menu-7a85c3ee.cjs.dev.js} +48 -40
  63. package/dist/{use-applications-menu-1514af11.esm.js → use-applications-menu-8ff2d130.esm.js} +45 -38
  64. package/dist/{user-settings-menu-d75f4958.cjs.prod.js → user-settings-menu-2d3bfa75.cjs.prod.js} +29 -22
  65. package/dist/{user-settings-menu-f98bea89.esm.js → user-settings-menu-31e6bb38.esm.js} +29 -22
  66. package/dist/{user-settings-menu-6113cdd3.cjs.dev.js → user-settings-menu-c37b343f.cjs.dev.js} +29 -22
  67. package/package.json +16 -16
  68. package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.dev.js +2 -1
  69. package/ssr/dist/commercetools-frontend-application-shell-ssr.cjs.prod.js +2 -1
  70. package/ssr/dist/commercetools-frontend-application-shell-ssr.esm.js +2 -1
  71. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.dev.js +26 -22
  72. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.cjs.prod.js +26 -22
  73. package/test-utils/dist/commercetools-frontend-application-shell-test-utils.esm.js +20 -17
  74. package/dist/oidc-8827f9fe.cjs.dev.js +0 -98
  75. package/dist/oidc-b2520905.esm.js +0 -84
  76. package/dist/oidc-d74e6aa2.cjs.prod.js +0 -98
  77. package/dist/quick-access-9dd197bb.cjs.prod.js +0 -1875
  78. package/dist/quick-access-a665bbb7.cjs.dev.js +0 -1893
  79. package/dist/quick-access-dfc1f8a9.esm.js +0 -1865
@@ -4,12 +4,13 @@ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
4
4
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
5
5
  var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
6
6
  var _startsWithInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/starts-with');
7
- var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
8
- var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
7
+ var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
9
8
  var _Array$isArray = require('@babel/runtime-corejs3/core-js-stable/array/is-array');
10
9
  var _Number$isFinite = require('@babel/runtime-corejs3/core-js-stable/number/is-finite');
10
+ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
11
11
  var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
12
12
  var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
13
+ var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
13
14
  var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
14
15
  var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
15
16
  var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
@@ -24,14 +25,14 @@ var LogoSVG = require('@commercetools-frontend/assets/logos/commercetools_small-
24
25
  var constants = require('@commercetools-frontend/constants');
25
26
  var icons = require('@commercetools-uikit/icons');
26
27
  var Spacings = require('@commercetools-uikit/spacings');
28
+ var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
27
29
  var _styled = require('@emotion/styled/base');
28
30
  var react = require('@emotion/react');
29
31
  var applicationComponents = require('@commercetools-frontend/application-components');
30
32
  var designSystem = require('@commercetools-uikit/design-system');
31
- var oidc = require('./oidc-8827f9fe.cjs.dev.js');
33
+ var oidc = require('./oidc-87d116c1.cjs.dev.js');
32
34
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
33
35
  var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
34
- var _everyInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/every');
35
36
  var reactBroadcast = require('@flopflip/react-broadcast');
36
37
  var classnames = require('classnames');
37
38
  var MissingImageSvg = require('@commercetools-frontend/assets/images/diagonal-line.svg');
@@ -43,7 +44,7 @@ var _keysInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/insta
43
44
  var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
44
45
  var isNil = require('lodash/isNil');
45
46
  var throttle = require('lodash/throttle');
46
- var useApplicationsMenu = require('./use-applications-menu-823a2492.cjs.dev.js');
47
+ var useApplicationsMenu = require('./use-applications-menu-7a85c3ee.cjs.dev.js');
47
48
  require('@apollo/client');
48
49
  require('@commercetools-frontend/l10n');
49
50
 
@@ -51,12 +52,13 @@ function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e };
51
52
 
52
53
  var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
53
54
  var _startsWithInstanceProperty__default = /*#__PURE__*/_interopDefault(_startsWithInstanceProperty);
54
- var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
55
- var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
55
+ var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
56
56
  var _Array$isArray__default = /*#__PURE__*/_interopDefault(_Array$isArray);
57
57
  var _Number$isFinite__default = /*#__PURE__*/_interopDefault(_Number$isFinite);
58
+ var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
58
59
  var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
59
60
  var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
61
+ var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
60
62
  var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
61
63
  var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
62
64
  var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
@@ -67,7 +69,6 @@ var LogoSVG__default = /*#__PURE__*/_interopDefault(LogoSVG);
67
69
  var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
68
70
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
69
71
  var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
70
- var _everyInstanceProperty__default = /*#__PURE__*/_interopDefault(_everyInstanceProperty);
71
72
  var classnames__default = /*#__PURE__*/_interopDefault(classnames);
72
73
  var MissingImageSvg__default = /*#__PURE__*/_interopDefault(MissingImageSvg);
73
74
  var InlineSvg__default = /*#__PURE__*/_interopDefault(InlineSvg);
@@ -116,6 +117,7 @@ const Title = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_E
116
117
  label: "Title"
117
118
  })("flex:1;font-weight:600;font-size:", designSystem.designTokens.fontSize20, ";line-height:", designSystem.designTokens.lineHeight20, ";color:", designSystem.designTokens.colorNeutral, ";opacity:0;transition:", oidc.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== */"));
118
119
 
120
+ var _templateObject$1;
119
121
  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)."; }
120
122
  const getSubmenuPositionBasedOnMenuItemPosition = (isSubmenuAboveMenuItem, submenuVerticalPosition) => /*#__PURE__*/react.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"]} */");
121
123
  var _ref4 = process.env.NODE_ENV === "production" ? {
@@ -135,10 +137,7 @@ var _ref5 = process.env.NODE_ENV === "production" ? {
135
137
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
136
138
  };
137
139
  const getContainerPositionBasedOnMenuItemPosition = (isSubmenuAboveMenuItem, isSublistActiveWhileIsMenuExpanded, isSublistActiveWhileIsMenuCollapsed) => [isSublistActiveWhileIsMenuCollapsed && /*#__PURE__*/react.css(isSubmenuAboveMenuItem ? 'bottom' : 'top', ":-", oidc.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];
138
- const fadeIn = react.keyframes`
139
- from {opacity: 0;}
140
- to { opacity: 1;}
141
- `;
140
+ const fadeIn = react.keyframes(_templateObject$1 || (_templateObject$1 = _taggedTemplateLiteral(["\nfrom {opacity: 0;}\n to { opacity: 1;}\n"])));
142
141
  var _ref3 = process.env.NODE_ENV === "production" ? {
143
142
  name: "eivff4",
144
143
  styles: "display:none"
@@ -236,14 +235,8 @@ const SafeArea = /*#__PURE__*/_styled__default["default"]("span", process.env.NO
236
235
  label: "SafeArea"
237
236
  })("position:absolute;top:0;bottom:0;right:100%;width:calc(100% - ", designSystem.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"]} */"));
238
237
 
239
- const visible = react.keyframes`
240
- from {
241
- opacity: 0;
242
- }
243
- to {
244
- opacity: 1;
245
- }
246
- `;
238
+ var _templateObject;
239
+ const visible = react.keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n"])));
247
240
  const FixedMenu = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
248
241
  target: "e1meml8k10"
249
242
  } : {
@@ -443,8 +436,8 @@ const MenuGroup = /*#__PURE__*/react$1.forwardRef((props, ref) => {
443
436
  return jsxRuntime.jsx(MenuList, {
444
437
  ref: ref && props.level === 2 ? ref : null,
445
438
  level: props.level,
446
- id: `group-${props.id}`,
447
- "data-testid": `group-${props.id}`,
439
+ id: "group-".concat(props.id),
440
+ "data-testid": "group-".concat(props.id),
448
441
  role: "menu",
449
442
  onKeyDown: props.handleKeyDown,
450
443
  className: classnames__default["default"]({
@@ -542,18 +535,14 @@ const MenuItemLink = _ref3 => {
542
535
  });
543
536
  };
544
537
  MenuItemLink.displayName = 'MenuItemLink';
545
- const isEveryMenuVisibilitySetToHidden = (menuVisibilities, namesOfMenuVisibilities) => _Array$isArray__default["default"](namesOfMenuVisibilities) && namesOfMenuVisibilities.length > 0 && _everyInstanceProperty__default["default"](namesOfMenuVisibilities).call(namesOfMenuVisibilities, nameOfMenuVisibility => menuVisibilities && menuVisibilities[nameOfMenuVisibility] === true);
546
538
  function isLongLivedFlag(flag) {
547
- return typeof flag?.value === 'boolean';
539
+ return typeof (flag === null || flag === void 0 ? void 0 : flag.value) === 'boolean';
548
540
  }
549
541
  const RestrictedMenuItem = _ref4 => {
550
542
  let _ref4$permissions = _ref4.permissions,
551
543
  permissions$1 = _ref4$permissions === void 0 ? [] : _ref4$permissions,
552
544
  props = _objectWithoutProperties(_ref4, _excluded3);
553
- // NOTE: Custom application are activated/deactivated while their
554
- // visibility is not controlled via a visibiility overwrite.
555
545
  const flagVariation = reactBroadcast.useFlagVariation(props.featureToggle);
556
- if (isEveryMenuVisibilitySetToHidden(props.menuVisibilities, props.namesOfMenuVisibilities)) return null;
557
546
  const permissionsWrapper = _Array$isArray__default["default"](permissions$1) && permissions$1.length > 0 || _Array$isArray__default["default"](props.dataFences) && props.dataFences.length > 0 ? jsxRuntime.jsx(permissions.RestrictedByPermissions, {
558
547
  permissions: permissions$1,
559
548
  actionRights: props.actionRights,
@@ -795,13 +784,15 @@ const reducer = (state, action) => {
795
784
  return state;
796
785
  }
797
786
  };
798
- const isFocusOutEventCalledBySubmenuItem = event =>
799
- // a case when a submenu item loses focus
800
- event.type === 'focusout' &&
801
- // element receiving focus
802
- event.relatedTarget?.matches('a[data-link-level="text-link"]') &&
803
- // element losing focus
804
- event.target?.matches('a[data-link-level="text-link-sublist"]');
787
+ const isFocusOutEventCalledBySubmenuItem = event => {
788
+ var _event$relatedTarget, _event$target;
789
+ return (
790
+ // a case when a submenu item loses focus
791
+ event.type === 'focusout' && (// element receiving focus
792
+ (_event$relatedTarget = event.relatedTarget) === null || _event$relatedTarget === void 0 ? void 0 : _event$relatedTarget.matches('a[data-link-level="text-link"]')) && (// element losing focus
793
+ (_event$target = event.target) === null || _event$target === void 0 ? void 0 : _event$target.matches('a[data-link-level="text-link-sublist"]'))
794
+ );
795
+ };
805
796
  const useNavbarStateManager = props => {
806
797
  var _context, _context2, _context4, _context5;
807
798
  const navBarNode = react$1.useRef(null);
@@ -831,7 +822,6 @@ const useNavbarStateManager = props => {
831
822
  permissions: application.mainMenuLink.permissions,
832
823
  defaultLabel: application.mainMenuLink.defaultLabel,
833
824
  featureToggle: undefined,
834
- menuVisibility: undefined,
835
825
  actionRights: undefined,
836
826
  dataFences: undefined,
837
827
  submenu: _mapInstanceProperty__default["default"](_context3 = application.submenuLinks || []).call(_context3, submenuLink => ({
@@ -841,7 +831,6 @@ const useNavbarStateManager = props => {
841
831
  permissions: submenuLink.permissions,
842
832
  defaultLabel: submenuLink.defaultLabel,
843
833
  featureToggle: undefined,
844
- menuVisibility: undefined,
845
834
  actionRights: undefined,
846
835
  dataFences: undefined
847
836
  }))
@@ -897,7 +886,8 @@ const useNavbarStateManager = props => {
897
886
  }
898
887
  }, 100), [isForcedMenuOpen, state.isExpanderVisible, state.isMenuOpen]);
899
888
  const shouldCloseMenuFly = react$1.useCallback(event => {
900
- if (!navBarNode?.current?.contains(event.target) && !state.isMenuOpen) {
889
+ var _navBarNode$current;
890
+ if (!(navBarNode !== null && navBarNode !== void 0 && (_navBarNode$current = navBarNode.current) !== null && _navBarNode$current !== void 0 && _navBarNode$current.contains(event.target)) && !state.isMenuOpen) {
901
891
  dispatch({
902
892
  type: 'unsetActiveItemIndex'
903
893
  });
@@ -962,7 +952,7 @@ const useNavbarStateManager = props => {
962
952
  const allApplicationsNavbarMenuGroups = _sortInstanceProperty__default["default"](_context4 = _mapInstanceProperty__default["default"](_context5 = applicationsNavBarMenuGroups || []).call(_context5, navbarMenuGroup => navbarMenuGroup.key === '2' && allCustomApplicationsNavbarMenu.length > 0 ? {
963
953
  key: navbarMenuGroup.key,
964
954
  items: [...navbarMenuGroup.items, ...allCustomApplicationsNavbarMenu]
965
- } : navbarMenuGroup)).call(_context4, (navBarMenuGroupA, navBarMenuGroupB) => Number(navBarMenuGroupA?.key) - Number(navBarMenuGroupB?.key));
955
+ } : 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));
966
956
  return _objectSpread$1(_objectSpread$1({}, state), {}, {
967
957
  navBarNode,
968
958
  handleToggleItem,
@@ -974,7 +964,7 @@ const useNavbarStateManager = props => {
974
964
  };
975
965
 
976
966
  function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
977
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context5, _context6; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context5 = ownKeys(Object(t), !0)).call(_context5, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context6 = ownKeys(Object(t))).call(_context6, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
967
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context0, _context1; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context0 = ownKeys(Object(t), !0)).call(_context0, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context1 = ownKeys(Object(t))).call(_context1, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
978
968
  // Helper function to extract accessible label from menu objects
979
969
  const getMenuAccessibleLabel = (labelAllLocales, defaultLabel, applicationLocale) => {
980
970
  const localizedLabel = _findInstanceProperty__default["default"](labelAllLocales).call(labelAllLocales, loc => _startsWithInstanceProperty__default["default"](applicationLocale).call(applicationLocale, loc.locale));
@@ -982,18 +972,16 @@ const getMenuAccessibleLabel = (labelAllLocales, defaultLabel, applicationLocale
982
972
  if (defaultLabel) return defaultLabel;
983
973
  return constants.NO_VALUE_FALLBACK;
984
974
  };
985
- const getMenuVisibilitiesOfSubmenus = menu => {
986
- var _context, _context2;
987
- return _filterInstanceProperty__default["default"](_context = _mapInstanceProperty__default["default"](_context2 = menu.submenu).call(_context2, submenu => submenu.menuVisibility)).call(_context, nonNullable);
975
+ const getIsSubmenuRouteActive = (uriPath, props) => {
976
+ var _context;
977
+ return Boolean(reactRouterDom.matchPath(props.location.pathname, {
978
+ path: _concatInstanceProperty__default["default"](_context = "/".concat(props.projectKey, "/")).call(_context, uriPath),
979
+ exact: true,
980
+ strict: false
981
+ }));
988
982
  };
989
- const getMenuVisibilityOfMainmenu = menu => menu.menuVisibility ? [menu.menuVisibility] : [];
990
- const getIsSubmenuRouteActive = (uriPath, props) => Boolean(reactRouterDom.matchPath(props.location.pathname, {
991
- path: `/${props.projectKey}/${uriPath}`,
992
- exact: true,
993
- strict: false
994
- }));
995
983
  const ApplicationMenu = props => {
996
- var _context3;
984
+ var _context3, _props$menu$featureTo, _props$menu$actionRig, _props$menu$dataFence, _context4, _context5;
997
985
  const _useState = react$1.useState(0),
998
986
  _useState2 = _slicedToArray(_useState, 2),
999
987
  submenuVerticalPosition = _useState2[0],
@@ -1020,12 +1008,13 @@ const ApplicationMenu = props => {
1020
1008
  const hasSubmenu = _Array$isArray__default["default"](props.menu.submenu) && props.menu.submenu.length > 0;
1021
1009
  const menuItemIdentifier = snakeCase__default["default"](props.menu.key);
1022
1010
  const calculateSafeAreaStartPositon = react$1.useCallback(e => {
1023
- const currentSafeAreaRect = submenuSafeAreaRef.current?.getBoundingClientRect();
1024
- const menuItemRect = document.querySelector(`[data-menuitem="${menuItemIdentifier}"]`)?.getBoundingClientRect();
1025
- const currentSafeAreaLeft = currentSafeAreaRect?.left || 0;
1026
- const currentSafeAreaTop = currentSafeAreaRect?.top || 0;
1027
- const currentSafeAreaWidth = currentSafeAreaRect?.width || 0;
1028
- const currentSafeAreaHeight = currentSafeAreaRect?.height || 0;
1011
+ var _submenuSafeAreaRef$c, _document$querySelect;
1012
+ const currentSafeAreaRect = (_submenuSafeAreaRef$c = submenuSafeAreaRef.current) === null || _submenuSafeAreaRef$c === void 0 ? void 0 : _submenuSafeAreaRef$c.getBoundingClientRect();
1013
+ const menuItemRect = (_document$querySelect = document.querySelector("[data-menuitem=\"".concat(menuItemIdentifier, "\"]"))) === null || _document$querySelect === void 0 ? void 0 : _document$querySelect.getBoundingClientRect();
1014
+ const currentSafeAreaLeft = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.left) || 0;
1015
+ const currentSafeAreaTop = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.top) || 0;
1016
+ const currentSafeAreaWidth = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.width) || 0;
1017
+ const currentSafeAreaHeight = (currentSafeAreaRect === null || currentSafeAreaRect === void 0 ? void 0 : currentSafeAreaRect.height) || 0;
1029
1018
  const localX = e.clientX - currentSafeAreaLeft;
1030
1019
  const localY = e.clientY - currentSafeAreaTop;
1031
1020
  let minXPercent = 0;
@@ -1071,15 +1060,17 @@ const ApplicationMenu = props => {
1071
1060
  };
1072
1061
  }, [calculateSafeAreaStartPositon]);
1073
1062
  react$1.useLayoutEffect(() => {
1063
+ var _context2;
1074
1064
  if (!submenuRef.current) return;
1075
1065
  const safeX = _Number$isFinite__default["default"](percentageX) ? percentageX : 0;
1076
1066
  const safeY = _Number$isFinite__default["default"](percentageY) ? percentageY : 100;
1077
- submenuRef.current.style.setProperty('--safe-start', `${safeX}% ${safeY}%`);
1067
+ submenuRef.current.style.setProperty('--safe-start', _concatInstanceProperty__default["default"](_context2 = "".concat(safeX, "% ")).call(_context2, safeY, "%"));
1078
1068
  }, [percentageX, percentageY]);
1079
1069
  const callbackFn = react$1.useCallback(entries => {
1080
- const menuItemBoundingClientRect = document.querySelector(`[data-menuitem="${menuItemIdentifier}"]`)?.getBoundingClientRect();
1081
- const menuItemTop = menuItemBoundingClientRect?.top || 0;
1082
- const menuItemBottom = menuItemBoundingClientRect?.bottom || 0;
1070
+ var _document$querySelect2;
1071
+ const menuItemBoundingClientRect = (_document$querySelect2 = document.querySelector("[data-menuitem=\"".concat(menuItemIdentifier, "\"]"))) === null || _document$querySelect2 === void 0 ? void 0 : _document$querySelect2.getBoundingClientRect();
1072
+ const menuItemTop = (menuItemBoundingClientRect === null || menuItemBoundingClientRect === void 0 ? void 0 : menuItemBoundingClientRect.top) || 0;
1073
+ const menuItemBottom = (menuItemBoundingClientRect === null || menuItemBoundingClientRect === void 0 ? void 0 : menuItemBoundingClientRect.bottom) || 0;
1083
1074
  const _entries = _slicedToArray(entries, 1),
1084
1075
  entry = _entries[0];
1085
1076
 
@@ -1105,7 +1096,10 @@ const ApplicationMenu = props => {
1105
1096
  observerRef.current = new IntersectionObserver(callbackFn, {
1106
1097
  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
1107
1098
  });
1108
- return () => observerRef.current?.disconnect();
1099
+ return () => {
1100
+ var _observerRef$current;
1101
+ return (_observerRef$current = observerRef.current) === null || _observerRef$current === void 0 ? void 0 : _observerRef$current.disconnect();
1102
+ };
1109
1103
  }, [callbackFn, props.isMenuOpen]);
1110
1104
  react$1.useLayoutEffect(() => {
1111
1105
  const currentSubmenuRef = submenuRef.current;
@@ -1115,10 +1109,10 @@ const ApplicationMenu = props => {
1115
1109
  observer.observe(currentSubmenuRef);
1116
1110
  }
1117
1111
  setIsSubmenuFocused(false);
1118
- return () => observer?.disconnect();
1112
+ return () => observer === null || observer === void 0 ? void 0 : observer.disconnect();
1119
1113
  }, [menuItemIdentifier, props.isMenuOpen, props.handleToggleItem, callbackFn]);
1120
1114
  const isMainMenuRouteActive = Boolean(reactRouterDom.matchPath(props.location.pathname, {
1121
- path: `/${props.projectKey}/${props.menu.uriPath}`,
1115
+ path: _concatInstanceProperty__default["default"](_context3 = "/".concat(props.projectKey, "/")).call(_context3, props.menu.uriPath),
1122
1116
  exact: false,
1123
1117
  strict: false
1124
1118
  }));
@@ -1131,25 +1125,24 @@ const ApplicationMenu = props => {
1131
1125
  // eslint-disable-next-line react-hooks/exhaustive-deps
1132
1126
  }, [props.isMenuOpen]); // <-- (re)run this only when the all menu expands
1133
1127
 
1134
- const namesOfMenuVisibilitiesOfAllSubmenus = hasSubmenu ? getMenuVisibilitiesOfSubmenus(props.menu) : getMenuVisibilityOfMainmenu(props.menu);
1135
1128
  const handleKeyDown = e => {
1136
- const currentlyFocusedItem = submenuRef.current?.querySelector(':focus');
1129
+ var _submenuRef$current;
1130
+ const currentlyFocusedItem = (_submenuRef$current = submenuRef.current) === null || _submenuRef$current === void 0 ? void 0 : _submenuRef$current.querySelector(':focus');
1137
1131
  if (e.key === 'Enter') {
1138
1132
  setIsSubmenuFocused(true);
1139
1133
  if (!currentlyFocusedItem) {
1140
- submenuRef.current?.querySelector('a')?.focus();
1134
+ var _submenuRef$current2;
1135
+ (_submenuRef$current2 = submenuRef.current) === null || _submenuRef$current2 === void 0 || (_submenuRef$current2 = _submenuRef$current2.querySelector('a')) === null || _submenuRef$current2 === void 0 || _submenuRef$current2.focus();
1141
1136
  }
1142
1137
  }
1143
1138
  };
1144
1139
  return jsxRuntime.jsx(RestrictedMenuItem, {
1145
1140
  keyOfMenuItem: props.menu.key,
1146
- featureToggle: props.menu.featureToggle ?? undefined,
1141
+ featureToggle: (_props$menu$featureTo = props.menu.featureToggle) !== null && _props$menu$featureTo !== void 0 ? _props$menu$featureTo : undefined,
1147
1142
  permissions: props.menu.permissions,
1148
- actionRights: props.menu.actionRights ?? undefined,
1149
- dataFences: props.menu.dataFences ?? undefined,
1143
+ actionRights: (_props$menu$actionRig = props.menu.actionRights) !== null && _props$menu$actionRig !== void 0 ? _props$menu$actionRig : undefined,
1144
+ dataFences: (_props$menu$dataFence = props.menu.dataFences) !== null && _props$menu$dataFence !== void 0 ? _props$menu$dataFence : undefined,
1150
1145
  projectPermissions: props.projectPermissions,
1151
- menuVisibilities: props.menuVisibilities,
1152
- namesOfMenuVisibilities: namesOfMenuVisibilitiesOfAllSubmenus,
1153
1146
  children: jsxRuntime.jsxs(MenuItem$1, {
1154
1147
  hasSubmenu: hasSubmenu,
1155
1148
  isActive: props.isActive,
@@ -1163,7 +1156,7 @@ const ApplicationMenu = props => {
1163
1156
  identifier: menuItemIdentifier,
1164
1157
  ariaLabel: getMenuAccessibleLabel(props.menu.labelAllLocales, props.menu.defaultLabel, props.applicationLocale),
1165
1158
  children: [jsxRuntime.jsx(MenuItemLink, {
1166
- linkTo: `/${props.projectKey}/${props.menu.uriPath}`,
1159
+ linkTo: _concatInstanceProperty__default["default"](_context4 = "/".concat(props.projectKey, "/")).call(_context4, props.menu.uriPath),
1167
1160
  useFullRedirectsForLinks: props.useFullRedirectsForLinks,
1168
1161
  onClick: props.onMenuItemClick,
1169
1162
  ariaLabel: getMenuAccessibleLabel(props.menu.labelAllLocales, props.menu.defaultLabel, props.applicationLocale),
@@ -1175,7 +1168,7 @@ const ApplicationMenu = props => {
1175
1168
  isMenuOpen: props.isMenuOpen
1176
1169
  })
1177
1170
  }), jsxRuntime.jsxs(MenuGroup, {
1178
- id: `group-${props.menu.key}`,
1171
+ id: "group-".concat(props.menu.key),
1179
1172
  level: 2,
1180
1173
  isActive: props.isActive,
1181
1174
  isExpanded: props.isMenuOpen,
@@ -1186,7 +1179,7 @@ const ApplicationMenu = props => {
1186
1179
  children: [!props.isMenuOpen && jsxRuntime.jsx(TooltipContainer, {
1187
1180
  alignsAgainstBottom: isSubmenuAboveMenuItem,
1188
1181
  children: jsxRuntime.jsx(Tooltip, {
1189
- "aria-owns": `group-${props.menu.key}`,
1182
+ "aria-owns": "group-".concat(props.menu.key),
1190
1183
  role: "tooltip",
1191
1184
  children: jsxRuntime.jsx(MenuLabel, {
1192
1185
  labelAllLocales: props.menu.labelAllLocales,
@@ -1194,38 +1187,39 @@ const ApplicationMenu = props => {
1194
1187
  applicationLocale: props.applicationLocale
1195
1188
  })
1196
1189
  })
1197
- }), hasSubmenu ? _mapInstanceProperty__default["default"](_context3 = props.menu.submenu).call(_context3, submenu => jsxRuntime.jsx(RestrictedMenuItem, {
1198
- keyOfMenuItem: submenu.key,
1199
- featureToggle: submenu.featureToggle ?? undefined,
1200
- permissions: submenu.permissions,
1201
- actionRights: submenu.actionRights ?? undefined,
1202
- dataFences: submenu.dataFences ?? undefined,
1203
- projectPermissions: props.projectPermissions,
1204
- menuVisibilities: props.menuVisibilities,
1205
- namesOfMenuVisibilities: submenu.menuVisibility ? [submenu.menuVisibility] : undefined,
1206
- children: jsxRuntime.jsx(SublistItem, {
1207
- isActive: getIsSubmenuRouteActive(submenu.uriPath, props),
1208
- children: jsxRuntime.jsx(Text, {
1209
- children: jsxRuntime.jsx(MenuItemLink, {
1210
- linkTo: `/${props.projectKey}/${submenu.uriPath}`
1211
- // We want to use an exact matching strategy to avoid multiple
1212
- // links matching sub-routes.
1213
- ,
1214
- exactMatch: true,
1215
- useFullRedirectsForLinks: props.useFullRedirectsForLinks,
1216
- onClick: props.onMenuItemClick,
1217
- isSubmenuLink: true,
1218
- isSubmenuFocused: isSubmenuFocused,
1219
- ariaLabel: getMenuAccessibleLabel(submenu.labelAllLocales, submenu.defaultLabel, props.applicationLocale),
1220
- children: jsxRuntime.jsx(MenuLabel, {
1221
- labelAllLocales: submenu.labelAllLocales,
1222
- defaultLabel: submenu.defaultLabel,
1223
- applicationLocale: props.applicationLocale
1190
+ }), hasSubmenu ? _mapInstanceProperty__default["default"](_context5 = props.menu.submenu).call(_context5, submenu => {
1191
+ var _context6, _submenu$featureToggl, _submenu$actionRights, _submenu$dataFences, _context7;
1192
+ return jsxRuntime.jsx(RestrictedMenuItem, {
1193
+ keyOfMenuItem: submenu.key,
1194
+ featureToggle: (_submenu$featureToggl = submenu.featureToggle) !== null && _submenu$featureToggl !== void 0 ? _submenu$featureToggl : undefined,
1195
+ permissions: submenu.permissions,
1196
+ actionRights: (_submenu$actionRights = submenu.actionRights) !== null && _submenu$actionRights !== void 0 ? _submenu$actionRights : undefined,
1197
+ dataFences: (_submenu$dataFences = submenu.dataFences) !== null && _submenu$dataFences !== void 0 ? _submenu$dataFences : undefined,
1198
+ projectPermissions: props.projectPermissions,
1199
+ children: jsxRuntime.jsx(SublistItem, {
1200
+ isActive: getIsSubmenuRouteActive(submenu.uriPath, props),
1201
+ children: jsxRuntime.jsx(Text, {
1202
+ children: jsxRuntime.jsx(MenuItemLink, {
1203
+ linkTo: _concatInstanceProperty__default["default"](_context7 = "/".concat(props.projectKey, "/")).call(_context7, submenu.uriPath)
1204
+ // We want to use an exact matching strategy to avoid multiple
1205
+ // links matching sub-routes.
1206
+ ,
1207
+ exactMatch: true,
1208
+ useFullRedirectsForLinks: props.useFullRedirectsForLinks,
1209
+ onClick: props.onMenuItemClick,
1210
+ isSubmenuLink: true,
1211
+ isSubmenuFocused: isSubmenuFocused,
1212
+ ariaLabel: getMenuAccessibleLabel(submenu.labelAllLocales, submenu.defaultLabel, props.applicationLocale),
1213
+ children: jsxRuntime.jsx(MenuLabel, {
1214
+ labelAllLocales: submenu.labelAllLocales,
1215
+ defaultLabel: submenu.defaultLabel,
1216
+ applicationLocale: props.applicationLocale
1217
+ })
1224
1218
  })
1225
1219
  })
1226
1220
  })
1227
- })
1228
- }, `${props.menu.key}-submenu-${submenu.key}`)) : null, jsxRuntime.jsx(SafeArea, {
1221
+ }, _concatInstanceProperty__default["default"](_context6 = "".concat(props.menu.key, "-submenu-")).call(_context6, submenu.key));
1222
+ }) : null, jsxRuntime.jsx(SafeArea, {
1229
1223
  ref: submenuSafeAreaRef
1230
1224
  })]
1231
1225
  })]
@@ -1252,12 +1246,14 @@ const NavBar = props => {
1252
1246
  const location = reactRouterDom.useLocation();
1253
1247
  const _useIntl = reactIntl.useIntl(),
1254
1248
  formatMessage = _useIntl.formatMessage;
1255
- const projectPermissions = react$1.useMemo(() => ({
1256
- permissions: applicationShellConnectors.normalizeAllAppliedPermissions(props.project?.allPermissionsForAllApplications.allAppliedPermissions),
1257
- actionRights: applicationShellConnectors.normalizeAllAppliedActionRights(props.project?.allPermissionsForAllApplications.allAppliedActionRights),
1258
- dataFences: applicationShellConnectors.normalizeAllAppliedDataFences(props.project?.allPermissionsForAllApplications.allAppliedDataFences)
1259
- }), [props.project]);
1260
- const menuVisibilities = react$1.useMemo(() => applicationShellConnectors.normalizeAllAppliedMenuVisibilities(props.project?.allPermissionsForAllApplications.allAppliedMenuVisibilities), [props.project]);
1249
+ const projectPermissions = react$1.useMemo(() => {
1250
+ var _props$project, _props$project2, _props$project3;
1251
+ return {
1252
+ permissions: applicationShellConnectors.normalizeAllAppliedPermissions((_props$project = props.project) === null || _props$project === void 0 ? void 0 : _props$project.allPermissionsForAllApplications.allAppliedPermissions),
1253
+ actionRights: applicationShellConnectors.normalizeAllAppliedActionRights((_props$project2 = props.project) === null || _props$project2 === void 0 ? void 0 : _props$project2.allPermissionsForAllApplications.allAppliedActionRights),
1254
+ dataFences: applicationShellConnectors.normalizeAllAppliedDataFences((_props$project3 = props.project) === null || _props$project3 === void 0 ? void 0 : _props$project3.allPermissionsForAllApplications.allAppliedDataFences)
1255
+ };
1256
+ }, [props.project]);
1261
1257
  const applicationLocale = props.applicationLocale;
1262
1258
 
1263
1259
  // Render the loading navbar as long as all the data
@@ -1288,11 +1284,12 @@ const NavBar = props => {
1288
1284
  children: jsxRuntime.jsx(Spacings__default["default"].Stack, {
1289
1285
  scale: "l",
1290
1286
  children: _mapInstanceProperty__default["default"](allApplicationsNavbarMenuGroups).call(allApplicationsNavbarMenuGroups, navbarMenuGroup => {
1291
- var _context4;
1287
+ var _context8;
1292
1288
  return jsxRuntime.jsx("div", {
1293
- children: _mapInstanceProperty__default["default"](_context4 = navbarMenuGroup.items).call(_context4, menu => {
1289
+ children: _mapInstanceProperty__default["default"](_context8 = navbarMenuGroup.items).call(_context8, menu => {
1290
+ var _context9;
1294
1291
  const menuType = 'scrollable';
1295
- const itemIndex = `${menuType}-${menu.key}`;
1292
+ const itemIndex = _concatInstanceProperty__default["default"](_context9 = "".concat(menuType, "-")).call(_context9, menu.key);
1296
1293
  return jsxRuntime.jsx(ApplicationMenu, {
1297
1294
  location: location,
1298
1295
  menu: menu,
@@ -1301,7 +1298,6 @@ const NavBar = props => {
1301
1298
  isMenuOpen: isMenuOpen,
1302
1299
  shouldCloseMenuFly: shouldCloseMenuFly,
1303
1300
  projectPermissions: projectPermissions,
1304
- menuVisibilities: menuVisibilities,
1305
1301
  applicationLocale: applicationLocale,
1306
1302
  projectKey: props.projectKey,
1307
1303
  useFullRedirectsForLinks: useFullRedirectsForLinks,