@uxf/cms 10.0.0-beta.9 → 10.0.1

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 (124) hide show
  1. package/config/container.d.ts +3 -3
  2. package/deprecated/api/api-client.js +1 -1
  3. package/deprecated/hoc/with-authenticate.js +3 -3
  4. package/deprecated/redux/configure-store.js +2 -2
  5. package/deprecated/redux/entities/actions.d.ts +1 -1
  6. package/deprecated/redux/entities/index.d.ts +1 -1
  7. package/deprecated/redux/entities/index.js +1 -1
  8. package/deprecated/redux/entities/selectors.d.ts +1 -1
  9. package/deprecated/redux/index.d.ts +2 -2
  10. package/deprecated/redux/index.js +4 -4
  11. package/deprecated/redux/types.d.ts +1 -1
  12. package/deprecated/redux/user/index.d.ts +1 -1
  13. package/deprecated/redux/user/index.js +1 -1
  14. package/forms/change-password-form/change-password-form.js +2 -2
  15. package/forms/components/wysiwyg-input/wysiwyg-input.d.ts +2 -2
  16. package/forms/components/wysiwyg-input/wysiwyg-input.js +2 -2
  17. package/forms/forgotten-password-form/forgotten-password-form.js +1 -1
  18. package/forms/invite-user-form/invite-user-form.js +2 -1
  19. package/forms/login-form/login-form.js +1 -1
  20. package/lib/api/create-use-axios-request.js +1 -1
  21. package/lib/layout/breadcrumbs.js +5 -5
  22. package/lib/layout/index.d.ts +1 -1
  23. package/lib/layout/index.js +1 -1
  24. package/lib/layout/layout-container.js +3 -3
  25. package/lib/layout/layout.js +26 -24
  26. package/lib/layout/sidebar.js +35 -21
  27. package/lib/layout/types.d.ts +1 -0
  28. package/lib/login-layout/login-layout.js +7 -9
  29. package/lib/menu/factory.d.ts +5 -5
  30. package/lib/menu/factory.js +6 -4
  31. package/lib/menu/index.d.ts +3 -3
  32. package/lib/menu/index.js +3 -3
  33. package/lib/menu/mobile-bar.d.ts +4 -2
  34. package/lib/menu/mobile-bar.js +12 -14
  35. package/lib/menu/model.d.ts +8 -4
  36. package/lib/menu/model.js +7 -0
  37. package/lib/menu/types.d.ts +1 -1
  38. package/lib/menu/ui/list-item/list-item.js +18 -17
  39. package/lib/menu/ui/list-item/types.d.ts +6 -5
  40. package/lib/menu/ui/menu-custom-item.js +2 -4
  41. package/lib/menu/ui/menu-item.js +11 -12
  42. package/lib/menu/ui/menu-super-section-item.js +4 -6
  43. package/lib/menu/ui/menu.js +2 -2
  44. package/lib/menu/ui/sub-menu/{sub-menuItem.js → sub-menu-item.js} +5 -7
  45. package/lib/menu/ui/sub-menu/sub-menu-mobile.js +7 -7
  46. package/lib/menu/ui/sub-menu/sub-menu.js +7 -7
  47. package/lib/menu/ui/sub-menu/use-sub-menu.d.ts +20 -12
  48. package/lib/menu/ui/sub-menu/use-sub-menu.js +16 -16
  49. package/lib/menu/ui/user-menu.js +13 -13
  50. package/package.json +34 -55
  51. package/pages/change-password-page/change-password-page.js +1 -1
  52. package/pages/change-password-page/types.d.ts +1 -1
  53. package/pages/content-builder/components/form-content.d.ts +1 -1
  54. package/pages/content-builder/components/form-content.js +5 -5
  55. package/pages/content-builder/components/form-root-fields.d.ts +1 -1
  56. package/pages/content-builder/components/form-root-fields.js +2 -2
  57. package/pages/content-builder/components/form.d.ts +2 -2
  58. package/pages/content-builder/components/form.js +4 -4
  59. package/pages/content-builder/components/header.js +2 -2
  60. package/pages/content-builder/content/feature-section.d.ts +1 -1
  61. package/pages/content-builder/content/feature-section.js +6 -6
  62. package/pages/content-builder/content/gallery.d.ts +1 -1
  63. package/pages/content-builder/content/gallery.js +3 -3
  64. package/pages/content-builder/content/hero-section.js +2 -2
  65. package/pages/content-builder/content/people.d.ts +1 -1
  66. package/pages/content-builder/content/people.js +7 -7
  67. package/pages/content-builder/content/wysiwyg.d.ts +2 -2
  68. package/pages/content-builder/content/wysiwyg.js +2 -2
  69. package/pages/content-builder/content-builder-page.js +4 -4
  70. package/pages/content-builder/content-field.d.ts +1 -1
  71. package/pages/content-builder/content-field.js +6 -6
  72. package/pages/content-builder/content-header.d.ts +1 -1
  73. package/pages/content-builder/content-header.js +5 -5
  74. package/pages/content-builder/hooks/use-sortable.js +1 -1
  75. package/pages/content-builder/index.d.ts +2 -2
  76. package/pages/content-builder/index.js +2 -2
  77. package/pages/content-builder/mapper.d.ts +1 -1
  78. package/pages/content-builder/types.d.ts +4 -6
  79. package/pages/form-page/base-field.js +14 -14
  80. package/pages/form-page/field-array.js +2 -2
  81. package/pages/form-page/form-page.d.ts +2 -1
  82. package/pages/form-page/form-page.js +7 -7
  83. package/pages/form-page/form.d.ts +2 -2
  84. package/pages/form-page/form.js +2 -2
  85. package/pages/form-page/index.d.ts +3 -3
  86. package/pages/form-page/index.js +3 -3
  87. package/pages/form-page/types.d.ts +1 -1
  88. package/pages/grid-page/grid-page.js +6 -6
  89. package/pages/grid-page/types.d.ts +2 -2
  90. package/pages/invite-user-page/invite-user-page.js +1 -0
  91. package/pages/invite-user-page/types.d.ts +1 -1
  92. package/pages/login-page/login-page.js +1 -1
  93. package/pages/renew-password-page/types.d.ts +1 -1
  94. package/ui/avatar/avatar.d.ts +11 -0
  95. package/ui/avatar/avatar.js +47 -0
  96. package/ui/avatar/get-avatar-user-letters.d.ts +1 -0
  97. package/ui/avatar/get-avatar-user-letters.js +17 -0
  98. package/ui/avatar/index.d.ts +3 -0
  99. package/ui/avatar/index.js +5 -0
  100. package/ui/avatar/theme.d.ts +11 -0
  101. package/ui/avatar/theme.js +2 -0
  102. package/ui/copy-to-clipboard-button/copy-to-clipboard-button.js +2 -2
  103. package/ui/styles/avatar.css +50 -0
  104. package/ui/styles/breadcrumbs.css +30 -0
  105. package/ui/styles/layout.css +132 -0
  106. package/ui/styles/login-layout.css +52 -0
  107. package/ui/styles/menu.css +217 -0
  108. package/ui/styles/mobile-bar.css +34 -0
  109. package/ui/styles/sidebar.css +108 -0
  110. package/ui/tw-tokens/tw-colors.d.ts +283 -282
  111. package/ui/tw-tokens/tw-colors.js +283 -282
  112. package/ui/tw-tokens/tw-line-height.d.ts +8 -8
  113. package/ui/tw-tokens/tw-line-height.js +8 -8
  114. package/ui/tw-tokens/tw-spacing.d.ts +34 -34
  115. package/ui/tw-tokens/tw-spacing.js +34 -34
  116. package/ui/tw-tokens/tw-z-index.d.ts +8 -7
  117. package/ui/tw-tokens/tw-z-index.js +8 -7
  118. package/ui/widget/index.d.ts +1 -1
  119. package/ui/widget/index.js +1 -1
  120. package/ui/widget/types.d.ts +1 -1
  121. package/ui/widget/widget.js +1 -1
  122. package/utils/styles.css +7 -43
  123. package/utils/tailwind.config.js +5 -0
  124. /package/lib/menu/ui/sub-menu/{sub-menuItem.d.ts → sub-menu-item.d.ts} +0 -0
@@ -4,19 +4,18 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.MobileBar = void 0;
7
- const react_1 = __importDefault(require("react"));
8
- const link_1 = __importDefault(require("next/link"));
7
+ const cx_1 = require("@uxf/core/utils/cx");
9
8
  const icon_1 = require("@uxf/ui/icon");
10
- const sub_menu_mobile_1 = require("./ui/sub-menu/sub-menu-mobile");
9
+ const link_1 = __importDefault(require("next/link"));
10
+ const react_1 = __importDefault(require("react"));
11
11
  const config_1 = require("../../config");
12
- const avatar_1 = require("@uxf/ui/avatar");
13
- const cx_1 = require("@uxf/core/utils/cx");
12
+ const avatar_1 = require("../../ui/avatar");
13
+ const get_avatar_user_letters_1 = require("../../ui/avatar/get-avatar-user-letters");
14
+ const sub_menu_mobile_1 = require("./ui/sub-menu/sub-menu-mobile");
14
15
  const MobileBar = (props) => {
15
- // eslint-disable-next-line react/destructuring-assignment
16
- const { menuConfiguration, toggleMenu } = props;
17
16
  const useLoggedUser = config_1.container.get("useLoggedUser");
18
17
  const loggedUser = useLoggedUser();
19
- const mobileBarMenu = menuConfiguration
18
+ const mobileBarMenu = props.menuConfiguration
20
19
  .flatMap((item) => {
21
20
  if (item.type === "link" || item.type === "section") {
22
21
  return item;
@@ -32,16 +31,15 @@ const MobileBar = (props) => {
32
31
  .filter((i) => i)
33
32
  .filter((item) => (item === null || item === void 0 ? void 0 : item.isVisible(loggedUser)) && (!item.children.length || item.hasVisibleChildren(loggedUser)))
34
33
  .splice(0, 4);
35
- const buttonClassName = (0, cx_1.cx)("flex h-10 grow items-center justify-center shrink-0", mobileBarMenu.length === 2 && "w-1/3", mobileBarMenu.length === 3 && "w-1/4", mobileBarMenu.length === 4 && "w-1/5");
36
- return (react_1.default.createElement("div", { className: "fixed inset-x-0 bottom-0 flex h-16 items-center border-t border-gray-700 bg-sidebar-background px-1 text-darkMedium md:hidden" },
34
+ const buttonClassName = (0, cx_1.cx)("uxf-cms-mobile-bar__button", mobileBarMenu.length === 2 && "w-1/3", mobileBarMenu.length === 3 && "w-1/4", mobileBarMenu.length === 4 && "w-1/5");
35
+ return (react_1.default.createElement("div", { className: "uxf-cms-mobile-bar" },
37
36
  mobileBarMenu.map((item, index) => {
38
37
  var _a, _b, _c, _d;
39
38
  if (item.children.length) {
40
39
  return (react_1.default.createElement(sub_menu_mobile_1.SubMenuMobile, { key: index, content: item.children, title: item.title },
41
- react_1.default.createElement("button", { type: "button", className: buttonClassName }, item.userMenuData ? (react_1.default.createElement(react_1.default.Fragment, null,
42
- react_1.default.createElement(avatar_1.Avatar, { className: "h-7 w-7", src: item.userMenuData.avatar }))) : (react_1.default.createElement(react_1.default.Fragment, null,
40
+ react_1.default.createElement("button", { type: "button", className: buttonClassName }, item.userMenuData ? (react_1.default.createElement(avatar_1.Avatar, { className: "uxf-cms-mobile-bar__avatar", letters: (0, get_avatar_user_letters_1.getAvatarUserLetters)(item.userMenuData.name), size: "sm", src: item.userMenuData.avatar, variant: "rounded" })) : (react_1.default.createElement(react_1.default.Fragment, null,
43
41
  react_1.default.createElement(icon_1.Icon, { name: (_a = item.icon) !== null && _a !== void 0 ? _a : "", size: 24 }),
44
- react_1.default.createElement(icon_1.Icon, { name: "caretDown", size: 16, className: "ml-1" }))))));
42
+ react_1.default.createElement(icon_1.Icon, { name: "caretDown", size: 16, className: "uxf-cms-mobile-bar__caret" }))))));
45
43
  }
46
44
  if (item.url || item.route) {
47
45
  return (react_1.default.createElement(link_1.default, { key: index, href: (_b = item.url) !== null && _b !== void 0 ? _b : config_1.container.get("route")(item.route, item.routeParams), target: item.isExternal ? "_blank" : undefined, rel: item.isExternal ? "noreferrer noopener" : undefined, className: buttonClassName },
@@ -50,7 +48,7 @@ const MobileBar = (props) => {
50
48
  return (react_1.default.createElement("span", { key: index, className: buttonClassName },
51
49
  react_1.default.createElement(icon_1.Icon, { name: (_d = item.icon) !== null && _d !== void 0 ? _d : "user", size: 24 })));
52
50
  }),
53
- react_1.default.createElement("button", { type: "button", className: buttonClassName, onClick: toggleMenu },
51
+ react_1.default.createElement("button", { type: "button", className: buttonClassName, onClick: props.toggleMenu },
54
52
  react_1.default.createElement(icon_1.Icon, { name: "bars", size: 24 }))));
55
53
  };
56
54
  exports.MobileBar = MobileBar;
@@ -1,11 +1,12 @@
1
+ import { ImageSource } from "@uxf/core/utils/resizer";
2
+ import { IconName } from "@uxf/ui/icon/types";
3
+ import { NextRouter } from "next/router";
4
+ import { ReactElement, ReactNode } from "react";
1
5
  import { LoggedUser } from "../../config/container";
2
6
  import { Resolver } from "./types";
3
- import { NextRouter } from "next/router";
4
- import { IconName } from "@uxf/ui/icon/types";
5
- import { ReactNode } from "react";
6
7
  type ItemType = "custom" | "super-section" | "section" | "link";
7
8
  export type UserMenuData = {
8
- avatar?: string;
9
+ avatar?: ImageSource;
9
10
  name: string;
10
11
  roles: string;
11
12
  };
@@ -18,6 +19,7 @@ export declare class MenuItem {
18
19
  private _routeParams?;
19
20
  private _isExternal?;
20
21
  private _icon?;
22
+ private _endElement?;
21
23
  private _activeItemResolver?;
22
24
  private _allowedRoles?;
23
25
  private _content?;
@@ -26,6 +28,7 @@ export declare class MenuItem {
26
28
  constructor(title: string, type: ItemType);
27
29
  setContent(content: ReactNode): MenuItem;
28
30
  setIcon(icon?: IconName): MenuItem;
31
+ setEndElement(endElement?: ReactElement): MenuItem;
29
32
  setChildren(children?: MenuItem[]): MenuItem;
30
33
  setRoute(route: string, routeParams?: object): MenuItem;
31
34
  setUrl(url: string): MenuItem;
@@ -45,6 +48,7 @@ export declare class MenuItem {
45
48
  get routeParams(): any;
46
49
  get isExternal(): boolean | undefined;
47
50
  get icon(): IconName | undefined;
51
+ get endElement(): ReactElement | undefined;
48
52
  get allowedRoles(): string[] | undefined;
49
53
  get content(): ReactNode;
50
54
  get userMenuData(): UserMenuData | undefined;
package/lib/menu/model.js CHANGED
@@ -18,6 +18,10 @@ class MenuItem {
18
18
  this._icon = icon;
19
19
  return this;
20
20
  }
21
+ setEndElement(endElement) {
22
+ this._endElement = endElement;
23
+ return this;
24
+ }
21
25
  setChildren(children) {
22
26
  this._children = children !== null && children !== void 0 ? children : [];
23
27
  return this;
@@ -91,6 +95,9 @@ class MenuItem {
91
95
  get icon() {
92
96
  return this._icon;
93
97
  }
98
+ get endElement() {
99
+ return this._endElement;
100
+ }
94
101
  get allowedRoles() {
95
102
  return this._allowedRoles;
96
103
  }
@@ -1,5 +1,5 @@
1
- import { MenuItem } from "./model";
2
1
  import { NextRouter } from "next/router";
2
+ import { MenuItem } from "./model";
3
3
  export type RouterResolver = (router: NextRouter, activeRoute: string) => boolean;
4
4
  export type Resolver = (item: MenuItem) => RouterResolver;
5
5
  export type MenuConfiguration = MenuItem[];
@@ -4,32 +4,33 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.ListItem = void 0;
7
- const react_1 = __importDefault(require("react"));
7
+ const classes_1 = require("@uxf/core/constants/classes");
8
8
  const icon_1 = require("@uxf/ui/icon");
9
9
  const link_1 = __importDefault(require("next/link"));
10
- const sub_menu_1 = require("../sub-menu/sub-menu");
10
+ const react_1 = __importDefault(require("react"));
11
11
  const config_1 = require("../../../../config");
12
+ const sub_menu_1 = require("../sub-menu/sub-menu");
12
13
  const ListItem = (props) => {
14
+ var _a, _b, _c, _d;
15
+ const hasSubMenu = !!((_a = props.subMenu) === null || _a === void 0 ? void 0 : _a.length);
16
+ const Content = (_b = props.children) !== null && _b !== void 0 ? _b : (react_1.default.createElement("div", { className: `uxf-cms-menu__item uxf-cms-menu__item--basic ${props.selected ? classes_1.CLASSES.IS_SELECTED : ""}` },
17
+ react_1.default.createElement("div", { className: `uxf-cms-menu__icon-wrapper ${props.level === 1 ? "uxf-cms-menu__icon-wrapper--level-one" : ""}` }, !!props.icon && props.level !== 1 && react_1.default.createElement(icon_1.Icon, { name: props.icon, size: 16 })),
18
+ react_1.default.createElement("div", { className: "uxf-cms-menu__item-label" }, props.label),
19
+ react_1.default.createElement("div", { className: "uxf-cms-menu__item-end-element" }, props.endElement),
20
+ hasSubMenu && (react_1.default.createElement(icon_1.Icon, { name: "caretDown", size: 16, className: `uxf-cms-menu__caret ${!props.isOpen ? classes_1.CLASSES.IS_OPEN : ""}` }))));
13
21
  // eslint-disable-next-line react/destructuring-assignment
14
- const { children, icon, label, level = 0, selected, href, route, params, subMenu, isOpen, toggle, isInitiallyOpen, isExternal, } = props;
15
- const hasSubMenu = !!(subMenu === null || subMenu === void 0 ? void 0 : subMenu.length);
16
- const Content = children !== null && children !== void 0 ? children : (react_1.default.createElement("div", { className: `mb-0.5 flex cursor-pointer items-center rounded-lg py-2.5 pl-2.5 pr-1 hover:bg-sidebar-hover ${selected ? "bg-sidebar-highlight font-bold text-darkHigh" : "bg-sidebar-background text-darkMedium"}` },
17
- react_1.default.createElement("div", { className: level === 1 ? "w-9" : "w-7" }, !!icon && level !== 1 && react_1.default.createElement(icon_1.Icon, { name: icon, size: 16 })),
18
- react_1.default.createElement("div", { className: "uxf-typo-body2" }, label),
19
- hasSubMenu && (react_1.default.createElement(icon_1.Icon, { name: "caretDown", size: 16, className: `ml-auto mr-2 ${!isOpen ? "-rotate-90" : ""}` }))));
20
- // eslint-disable-next-line react/destructuring-assignment
21
- const Button = ({ className }) => (react_1.default.createElement("button", { type: "button", onClick: toggle, className: className }, Content));
22
- if (href || route) {
23
- if (hasSubMenu && !isInitiallyOpen) {
22
+ const Button = ({ className }) => (react_1.default.createElement("button", { type: "button", onClick: props.toggle, className: className }, Content));
23
+ if (props.href || props.route) {
24
+ if (props.subMenu && hasSubMenu && !props.isInitiallyOpen) {
24
25
  return (react_1.default.createElement(react_1.default.Fragment, null,
25
- react_1.default.createElement(sub_menu_1.SubMenu, { content: subMenu },
26
- react_1.default.createElement(link_1.default, { href: href !== null && href !== void 0 ? href : config_1.container.get("route")(route, params), target: isExternal ? "_blank" : undefined, rel: isExternal ? "noreferrer noopener" : undefined }, Content)),
27
- react_1.default.createElement(Button, { className: "w-full md:hidden" })));
26
+ react_1.default.createElement(sub_menu_1.SubMenu, { content: props.subMenu },
27
+ react_1.default.createElement(link_1.default, { href: (_c = props.href) !== null && _c !== void 0 ? _c : config_1.container.get("route")(props.route, props.params), target: props.isExternal ? "_blank" : undefined, rel: props.isExternal ? "noreferrer noopener" : undefined }, Content)),
28
+ react_1.default.createElement(Button, { className: "uxf-cms-menu__submenu-button uxf-cms-menu__submenu-button--initially-closed" })));
28
29
  }
29
30
  if (hasSubMenu) {
30
- return react_1.default.createElement(Button, { className: "w-full md:pointer-events-none" });
31
+ return react_1.default.createElement(Button, { className: "uxf-cms-menu__submenu-button uxf-cms-menu__submenu-button--initially-open" });
31
32
  }
32
- return (react_1.default.createElement(link_1.default, { href: href !== null && href !== void 0 ? href : config_1.container.get("route")(route, params), target: isExternal ? "_blank" : undefined, rel: isExternal ? "noreferrer noopener" : undefined }, Content));
33
+ return (react_1.default.createElement(link_1.default, { href: (_d = props.href) !== null && _d !== void 0 ? _d : config_1.container.get("route")(props.route, props.params), target: props.isExternal ? "_blank" : undefined, rel: props.isExternal ? "noreferrer noopener" : undefined }, Content));
33
34
  }
34
35
  return Content;
35
36
  };
@@ -1,18 +1,19 @@
1
- import { ReactElement } from "react";
2
1
  import { IconName } from "@uxf/ui/icon/types";
2
+ import { ReactElement } from "react";
3
3
  import { MenuItem } from "../../model";
4
4
  export interface ListItemProps<RouteList> {
5
5
  children?: ReactElement;
6
+ endElement?: ReactElement;
7
+ href?: string;
6
8
  icon?: IconName;
9
+ isExternal?: boolean;
10
+ isInitiallyOpen?: boolean;
11
+ isOpen?: boolean;
7
12
  label: string;
8
13
  level?: number;
9
14
  params?: any;
10
15
  route?: keyof RouteList;
11
16
  selected?: boolean;
12
- href?: string;
13
17
  subMenu?: MenuItem[];
14
- isOpen?: boolean;
15
- isInitiallyOpen?: boolean;
16
18
  toggle?: () => void;
17
- isExternal?: boolean;
18
19
  }
@@ -7,13 +7,11 @@ exports.MenuCustomItem = void 0;
7
7
  const react_1 = __importDefault(require("react"));
8
8
  const config_1 = require("../../../config");
9
9
  const MenuCustomItem = (props) => {
10
- // eslint-disable-next-line react/destructuring-assignment
11
- const { item } = props;
12
10
  const useLoggedUser = config_1.container.get("useLoggedUser");
13
11
  const loggedUser = useLoggedUser();
14
- if (!item.isVisible(loggedUser)) {
12
+ if (!props.item.isVisible(loggedUser)) {
15
13
  return null;
16
14
  }
17
- return react_1.default.createElement("div", null, item.content);
15
+ return react_1.default.createElement("div", { className: "uxf-cms-menu__item-wrapper uxf-cms-menu__item-wrapper--custom" }, props.item.content);
18
16
  };
19
17
  exports.MenuCustomItem = MenuCustomItem;
@@ -24,33 +24,32 @@ var __importStar = (this && this.__importStar) || function (mod) {
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.MenuItem = void 0;
27
+ const router_1 = require("next/router");
27
28
  const react_1 = __importStar(require("react"));
28
29
  const config_1 = require("../../../config");
29
30
  const list_item_1 = require("./list-item");
30
- const router_1 = require("next/router");
31
31
  const MenuItem = (props) => {
32
32
  var _a, _b, _c, _d;
33
- // eslint-disable-next-line react/destructuring-assignment
34
- const { item } = props;
35
33
  const router = (0, router_1.useRouter)();
36
34
  const activeRoute = config_1.container.get("useActiveRoute")();
37
- const isActive = item.isActive(router, activeRoute);
38
- const hasActiveChildren = item.hasActiveChildren(router, activeRoute);
35
+ const isActive = props.item.isActive(router, activeRoute);
36
+ const hasActiveChildren = props.item.hasActiveChildren(router, activeRoute);
39
37
  const useLoggedUser = config_1.container.get("useLoggedUser");
40
38
  const loggedUser = useLoggedUser();
41
- const visibleChildren = item.children.filter((i) => i.isVisible(loggedUser));
39
+ const visibleChildren = props.item.children.filter((i) => i.isVisible(loggedUser));
42
40
  const firstVisibleChild = visibleChildren.length !== 0 ? visibleChildren[0] : undefined;
43
- const isInitiallyOpen = (isActive || hasActiveChildren) && item.children.length > 0;
41
+ const isInitiallyOpen = (isActive || hasActiveChildren) && props.item.children.length > 0;
44
42
  const [isSubmenuOpen, setIsSubmenuOpen] = (0, react_1.useState)(isInitiallyOpen);
45
43
  const toggle = () => setIsSubmenuOpen((prev) => !prev);
46
- if (!item.isVisible(loggedUser) || (item.children.length !== 0 && !item.hasVisibleChildren(loggedUser))) {
44
+ if (!props.item.isVisible(loggedUser) ||
45
+ (props.item.children.length !== 0 && !props.item.hasVisibleChildren(loggedUser))) {
47
46
  return null;
48
47
  }
49
- return (react_1.default.createElement(react_1.default.Fragment, null,
50
- react_1.default.createElement(list_item_1.ListItem, { label: item.title, icon: item.icon, href: (_a = item.url) !== null && _a !== void 0 ? _a : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.url, route: (_b = item.route) !== null && _b !== void 0 ? _b : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.route, params: (_d = (_c = item.routeParams) !== null && _c !== void 0 ? _c : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.routeParams) !== null && _d !== void 0 ? _d : null, selected: isActive, subMenu: item.children, isOpen: isSubmenuOpen, toggle: toggle, isInitiallyOpen: isInitiallyOpen, isExternal: item.isExternal }),
51
- isSubmenuOpen && (react_1.default.createElement("div", null, visibleChildren.map((i) => {
48
+ return (react_1.default.createElement("div", { className: "uxf-cms-menu__item-wrapper uxf-cms-menu__item-wrapper--basic" },
49
+ react_1.default.createElement(list_item_1.ListItem, { endElement: props.item.endElement, href: (_a = props.item.url) !== null && _a !== void 0 ? _a : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.url, icon: props.item.icon, isExternal: props.item.isExternal, isInitiallyOpen: isInitiallyOpen, isOpen: isSubmenuOpen, label: props.item.title, params: (_c = (_b = props.item.routeParams) !== null && _b !== void 0 ? _b : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.routeParams) !== null && _c !== void 0 ? _c : null, route: (_d = props.item.route) !== null && _d !== void 0 ? _d : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.route, selected: isActive, subMenu: props.item.children, toggle: toggle }),
50
+ isSubmenuOpen && (react_1.default.createElement("div", { className: "uxf-cms-menu__submenu-list" }, visibleChildren.map((i) => {
52
51
  const isSelected = i.isActive(router, activeRoute);
53
- return (react_1.default.createElement(list_item_1.ListItem, { key: i.title, label: i.title, href: i.url, icon: i.icon, route: i.route, params: i.routeParams, level: 1, selected: isSelected, isExternal: i.isExternal }));
52
+ return (react_1.default.createElement(list_item_1.ListItem, { endElement: i.endElement, href: i.url, icon: i.icon, isExternal: i.isExternal, key: i.title, label: i.title, level: 1, params: i.routeParams, route: i.route, selected: isSelected }));
54
53
  })))));
55
54
  };
56
55
  exports.MenuItem = MenuItem;
@@ -26,16 +26,14 @@ Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.MenuSuperSectionItem = void 0;
27
27
  const react_1 = __importStar(require("react"));
28
28
  const config_1 = require("../../../config");
29
- const menu_item_1 = require("./menu-item");
30
29
  const menu_custom_item_1 = require("./menu-custom-item");
30
+ const menu_item_1 = require("./menu-item");
31
31
  const MenuSuperSectionItem = (props) => {
32
- // eslint-disable-next-line react/destructuring-assignment
33
- const { item } = props;
34
32
  const useLoggedUser = config_1.container.get("useLoggedUser");
35
33
  const loggedUser = useLoggedUser();
36
- return (react_1.default.createElement("div", { className: item.userMenuData ? "md:hidden" : undefined },
37
- item.isVisible(loggedUser) && (react_1.default.createElement("p", { className: "uxf-typo-overline mb-3 mt-6 pl-2 uppercase text-darkLow" }, item.title)),
38
- item.children.map((i, index) => (react_1.default.createElement(react_1.Fragment, { key: index },
34
+ return (react_1.default.createElement("div", { className: `uxf-cms-menu__item-wrapper uxf-cms-menu__item-wrapper--super ${props.item.userMenuData ? "uxf-cms-menu__item-wrapper--user-menu" : ""}` },
35
+ props.item.isVisible(loggedUser) && (react_1.default.createElement("p", { className: "uxf-cms-menu__item uxf-cms-menu__item--super" }, props.item.title)),
36
+ props.item.children.map((i, index) => (react_1.default.createElement(react_1.Fragment, { key: index },
39
37
  i.type === "custom" && react_1.default.createElement(menu_custom_item_1.MenuCustomItem, { item: i }),
40
38
  (i.type === "section" || i.type === "link") && react_1.default.createElement(menu_item_1.MenuItem, { item: i }))))));
41
39
  };
@@ -25,11 +25,11 @@ var __importStar = (this && this.__importStar) || function (mod) {
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.Menu = void 0;
27
27
  const react_1 = __importStar(require("react"));
28
- const menu_item_1 = require("./menu-item");
29
28
  const menu_custom_item_1 = require("./menu-custom-item");
29
+ const menu_item_1 = require("./menu-item");
30
30
  const menu_super_section_item_1 = require("./menu-super-section-item");
31
31
  const Menu = (props) => {
32
- return (react_1.default.createElement("div", { className: "bg-sidebar-background px-2 pb-4" }, props.menu.map((item, index) => (react_1.default.createElement(react_1.Fragment, { key: index },
32
+ return (react_1.default.createElement("div", { className: "uxf-cms-menu" }, props.menu.map((item, index) => (react_1.default.createElement(react_1.Fragment, { key: index },
33
33
  item.type === "custom" && react_1.default.createElement(menu_custom_item_1.MenuCustomItem, { item: item }),
34
34
  item.type === "super-section" && react_1.default.createElement(menu_super_section_item_1.MenuSuperSectionItem, { item: item }),
35
35
  (item.type === "section" || item.type === "link") && react_1.default.createElement(menu_item_1.MenuItem, { item: item }))))));
@@ -4,21 +4,19 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.SubMenuItem = void 0;
7
+ const link_1 = __importDefault(require("next/link"));
7
8
  const react_1 = __importDefault(require("react"));
8
9
  const config_1 = require("../../../../config");
9
- const link_1 = __importDefault(require("next/link"));
10
10
  const SubMenuItem = (props) => {
11
11
  var _a;
12
- // eslint-disable-next-line react/destructuring-assignment
13
- const { item } = props;
14
12
  const useLoggedUser = config_1.container.get("useLoggedUser");
15
13
  const loggedUser = useLoggedUser();
16
- if (!item.isVisible(loggedUser)) {
14
+ if (!props.item.isVisible(loggedUser)) {
17
15
  return null;
18
16
  }
19
- const Content = (react_1.default.createElement("div", { className: "hover:text-darkLight w-full bg-sidebar-highlight px-4 py-3.5 text-body text-darkMedium hover:bg-sidebar-background md:text-body2" }, item.title));
20
- if (item.url || item.route) {
21
- return (react_1.default.createElement(link_1.default, { href: (_a = item.url) !== null && _a !== void 0 ? _a : config_1.container.get("route")(item.route, item.routeParams), target: item.isExternal ? "_blank" : undefined, rel: item.isExternal ? "noreferrer noopener" : undefined }, Content));
17
+ const Content = react_1.default.createElement("div", { className: "uxf-cms-sub-menu__item" }, props.item.title);
18
+ if (props.item.url || props.item.route) {
19
+ return (react_1.default.createElement(link_1.default, { href: (_a = props.item.url) !== null && _a !== void 0 ? _a : config_1.container.get("route")(props.item.route, props.item.routeParams), target: props.item.isExternal ? "_blank" : undefined, rel: props.item.isExternal ? "noreferrer noopener" : undefined }, Content));
22
20
  }
23
21
  return Content;
24
22
  };
@@ -24,12 +24,11 @@ var __importStar = (this && this.__importStar) || function (mod) {
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.SubMenuMobile = void 0;
27
+ const composeRefs_1 = require("@uxf/core/utils/composeRefs");
27
28
  const react_1 = __importStar(require("react"));
28
- const forwardRef_1 = require("@uxf/core/utils/forwardRef");
29
+ const sub_menu_item_1 = require("./sub-menu-item");
29
30
  const use_sub_menu_1 = require("./use-sub-menu");
30
- const composeRefs_1 = require("@uxf/core/utils/composeRefs");
31
- const sub_menuItem_1 = require("./sub-menuItem");
32
- exports.SubMenuMobile = (0, forwardRef_1.forwardRef)("SubMenuMobile", ({ children, content, title }, ref) => {
31
+ exports.SubMenuMobile = (0, react_1.forwardRef)(({ children, content, title }, ref) => {
33
32
  const subMenu = (0, use_sub_menu_1.useSubMenu)({ isMobile: true });
34
33
  const stableRef = (0, react_1.useMemo)(() => (0, composeRefs_1.composeRefs)(ref, subMenu.refs.setReference, children.ref), [ref, subMenu.refs.setReference, children]);
35
34
  return (react_1.default.createElement(react_1.default.Fragment, null,
@@ -39,10 +38,11 @@ exports.SubMenuMobile = (0, forwardRef_1.forwardRef)("SubMenuMobile", ({ childre
39
38
  "data-state": subMenu.open ? "open" : "closed",
40
39
  })),
41
40
  subMenu.open && (react_1.default.createElement("div", { ...subMenu.getFloatingProps({
42
- className: "sidebar__scrollbar bg-sidebar-background rounded-xl overflow-y-auto z-dropdown w-[calc(100vw_-_32px)] shadow-lg left-4",
41
+ className: "uxf-cms-sidebar__scrollbar uxf-cms-sub-menu__wrapper-mobile",
43
42
  ref: subMenu.refs.setFloating,
44
43
  style: subMenu.floatingStyles,
45
44
  }) },
46
- react_1.default.createElement("div", { className: "uxf-typo-body w-full bg-sidebar-background px-4 py-3.5 font-bold text-darkHigh" }, title),
47
- content.map((item, index) => (react_1.default.createElement(sub_menuItem_1.SubMenuItem, { key: index, item: item })))))));
45
+ react_1.default.createElement("div", { className: "uxf-cms-sub-menu__title" }, title),
46
+ content.map((item, index) => (react_1.default.createElement(sub_menu_item_1.SubMenuItem, { key: index, item: item })))))));
48
47
  });
48
+ exports.SubMenuMobile.displayName = "SubMenuMobile";
@@ -24,15 +24,14 @@ var __importStar = (this && this.__importStar) || function (mod) {
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.SubMenu = void 0;
27
+ const composeRefs_1 = require("@uxf/core/utils/composeRefs");
27
28
  const react_1 = __importStar(require("react"));
28
- const forwardRef_1 = require("@uxf/core/utils/forwardRef");
29
+ const sub_menu_item_1 = require("./sub-menu-item");
29
30
  const use_sub_menu_1 = require("./use-sub-menu");
30
- const composeRefs_1 = require("@uxf/core/utils/composeRefs");
31
- const sub_menuItem_1 = require("./sub-menuItem");
32
- exports.SubMenu = (0, forwardRef_1.forwardRef)("SubMenu", ({ children, content }, ref) => {
31
+ exports.SubMenu = (0, react_1.forwardRef)(({ children, content }, ref) => {
33
32
  const subMenu = (0, use_sub_menu_1.useSubMenu)({ isMobile: false });
34
33
  const stableRef = (0, react_1.useMemo)(() => (0, composeRefs_1.composeRefs)(ref, subMenu.refs.setReference, children.ref), [ref, subMenu.refs.setReference, children]);
35
- return (react_1.default.createElement("div", { className: "hidden md:block" },
34
+ return (react_1.default.createElement("div", { className: "uxf-cms-sub-menu" },
36
35
  (0, react_1.cloneElement)(children, subMenu.getReferenceProps({
37
36
  ref: stableRef,
38
37
  ...children.props,
@@ -41,6 +40,7 @@ exports.SubMenu = (0, forwardRef_1.forwardRef)("SubMenu", ({ children, content }
41
40
  subMenu.open && (react_1.default.createElement("div", { ...subMenu.getFloatingProps({
42
41
  ref: subMenu.refs.setFloating,
43
42
  style: subMenu.floatingStyles,
44
- className: "sidebar__scrollbar bg-sidebar-highlight rounded-xl overflow-y-auto z-dropdown max-w-64 shadow-lg w-full",
45
- }) }, content.map((item, index) => (react_1.default.createElement(sub_menuItem_1.SubMenuItem, { key: index, item: item })))))));
43
+ className: "uxf-cms-sidebar__scrollbar uxf-cms-sub-menu__wrapper",
44
+ }) }, content.map((item, index) => (react_1.default.createElement(sub_menu_item_1.SubMenuItem, { key: index, item: item })))))));
46
45
  });
46
+ exports.SubMenu.displayName = "SubMenu";
@@ -3,23 +3,35 @@ export interface SubMenuOptions {
3
3
  isMobile?: boolean;
4
4
  }
5
5
  export declare function useSubMenu(options: SubMenuOptions): {
6
- placement: import("@floating-ui/react").Placement;
7
- strategy: import("@floating-ui/react").Strategy;
8
- middlewareData: import("@floating-ui/react").MiddlewareData;
6
+ placement: import("@floating-ui/utils").Placement;
7
+ strategy: import("@floating-ui/utils").Strategy;
8
+ middlewareData: import("@floating-ui/core").MiddlewareData;
9
9
  x: number;
10
10
  y: number;
11
+ isPositioned: boolean;
11
12
  update: () => void;
13
+ floatingStyles: import("react").CSSProperties;
14
+ refs: {
15
+ reference: import("react").MutableRefObject<import("@floating-ui/react-dom").ReferenceType | null>;
16
+ floating: import("react").MutableRefObject<HTMLElement | null>;
17
+ setReference: (node: import("@floating-ui/react-dom").ReferenceType | null) => void;
18
+ setFloating: (node: HTMLElement | null) => void;
19
+ } & import("@floating-ui/react").ExtendedRefs<import("@floating-ui/react").ReferenceType>;
20
+ elements: {
21
+ reference: import("@floating-ui/react-dom").ReferenceType | null;
22
+ floating: HTMLElement | null;
23
+ } & import("@floating-ui/react").ExtendedElements<import("@floating-ui/react").ReferenceType>;
12
24
  context: {
13
25
  x: number;
14
26
  y: number;
15
- placement: import("@floating-ui/react").Placement;
16
- strategy: import("@floating-ui/react").Strategy;
17
- middlewareData: import("@floating-ui/react").MiddlewareData;
18
- update: () => void;
27
+ placement: import("@floating-ui/utils").Placement;
28
+ strategy: import("@floating-ui/utils").Strategy;
29
+ middlewareData: import("@floating-ui/core").MiddlewareData;
19
30
  isPositioned: boolean;
31
+ update: () => void;
20
32
  floatingStyles: import("react").CSSProperties;
21
33
  open: boolean;
22
- onOpenChange: (open: boolean) => void;
34
+ onOpenChange: (open: boolean, event?: Event | undefined) => void;
23
35
  events: import("@floating-ui/react").FloatingEvents;
24
36
  dataRef: import("react").MutableRefObject<import("@floating-ui/react").ContextData>;
25
37
  nodeId: string | undefined;
@@ -27,10 +39,6 @@ export declare function useSubMenu(options: SubMenuOptions): {
27
39
  refs: import("@floating-ui/react").ExtendedRefs<import("@floating-ui/react").ReferenceType>;
28
40
  elements: import("@floating-ui/react").ExtendedElements<import("@floating-ui/react").ReferenceType>;
29
41
  };
30
- refs: import("@floating-ui/react").ExtendedRefs<import("@floating-ui/react").ReferenceType>;
31
- elements: import("@floating-ui/react").ExtendedElements<import("@floating-ui/react").ReferenceType>;
32
- isPositioned: boolean;
33
- floatingStyles: import("react").CSSProperties;
34
42
  getReferenceProps: (userProps?: import("react").HTMLProps<Element> | undefined) => Record<string, unknown>;
35
43
  getFloatingProps: (userProps?: import("react").HTMLProps<HTMLElement> | undefined) => Record<string, unknown>;
36
44
  getItemProps: (userProps?: import("react").HTMLProps<HTMLElement> | undefined) => Record<string, unknown>;
@@ -1,16 +1,16 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.useSubMenu = void 0;
4
- const react_1 = require("react");
5
- const react_2 = require("@floating-ui/react");
4
+ const react_1 = require("@floating-ui/react");
5
+ const react_2 = require("react");
6
6
  function useSubMenu(options) {
7
- const [open, setOpen] = (0, react_1.useState)(false);
8
- const data = (0, react_2.useFloating)({
7
+ const [open, setOpen] = (0, react_2.useState)(false);
8
+ const data = (0, react_1.useFloating)({
9
9
  middleware: [
10
- (0, react_2.offset)(options.isMobile ? 24 : 16),
11
- (0, react_2.flip)(),
12
- (0, react_2.shift)({ padding: 8 }),
13
- (0, react_2.size)({
10
+ (0, react_1.offset)(options.isMobile ? 12 : 16),
11
+ (0, react_1.flip)(),
12
+ (0, react_1.shift)({ padding: 8 }),
13
+ (0, react_1.size)({
14
14
  apply({ availableHeight, elements }) {
15
15
  Object.assign(elements.floating.style, {
16
16
  maxHeight: Math.max(240, availableHeight) + "px",
@@ -21,22 +21,22 @@ function useSubMenu(options) {
21
21
  onOpenChange: setOpen,
22
22
  open,
23
23
  placement: options.isMobile ? "top" : "right-start",
24
- whileElementsMounted: (reference, floating, update) => (0, react_2.autoUpdate)(reference, floating, update, {
24
+ whileElementsMounted: (reference, floating, update) => (0, react_1.autoUpdate)(reference, floating, update, {
25
25
  elementResize: typeof ResizeObserver !== "undefined",
26
26
  }),
27
27
  });
28
28
  const context = data.context;
29
- const hover = (0, react_2.useHover)(context, {
29
+ const hover = (0, react_1.useHover)(context, {
30
30
  move: false,
31
31
  delay: 200,
32
- handleClose: (0, react_2.safePolygon)(),
32
+ handleClose: (0, react_1.safePolygon)(),
33
33
  enabled: !options.isMobile,
34
34
  });
35
- const click = (0, react_2.useClick)(context, { enabled: !!options.isMobile });
36
- const focus = (0, react_2.useFocus)(context);
37
- const dismiss = (0, react_2.useDismiss)(context);
38
- const interactions = (0, react_2.useInteractions)([hover, click, focus, dismiss]);
39
- return (0, react_1.useMemo)(() => ({
35
+ const click = (0, react_1.useClick)(context, { enabled: !!options.isMobile });
36
+ const focus = (0, react_1.useFocus)(context);
37
+ const dismiss = (0, react_1.useDismiss)(context);
38
+ const interactions = (0, react_1.useInteractions)([hover, click, focus, dismiss]);
39
+ return (0, react_2.useMemo)(() => ({
40
40
  open,
41
41
  setOpen,
42
42
  ...interactions,
@@ -24,28 +24,28 @@ var __importStar = (this && this.__importStar) || function (mod) {
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.UserMenu = void 0;
27
- const react_1 = __importStar(require("react"));
28
- const avatar_1 = require("@uxf/ui/avatar");
27
+ const classes_1 = require("@uxf/core/constants/classes");
29
28
  const icon_1 = require("@uxf/ui/icon");
29
+ const react_1 = __importStar(require("react"));
30
+ const avatar_1 = require("../../../ui/avatar");
31
+ const get_avatar_user_letters_1 = require("../../../ui/avatar/get-avatar-user-letters");
30
32
  const list_item_1 = require("./list-item");
31
33
  const Component = (props) => {
32
34
  const [isSubmenuOpen, setIsSubmenuOpen] = (0, react_1.useState)(false);
33
35
  const hasSubmenu = props.submenu.length > 0;
34
36
  const toggle = hasSubmenu ? () => setIsSubmenuOpen((prev) => !prev) : undefined;
35
- return (react_1.default.createElement("div", { className: "hidden border-t border-t-darkLow/10 p-3 pr-5 text-darkMedium md:block" },
36
- react_1.default.createElement("button", { className: "flex w-full items-center text-left", onClick: toggle },
37
- react_1.default.createElement(avatar_1.Avatar, { className: "mr-3 shrink-0", src: props.avatar }),
38
- react_1.default.createElement("div", { className: "truncate" },
39
- react_1.default.createElement("div", { className: "uxf-typo-body2 mb-1" }, props.name),
40
- react_1.default.createElement("div", { className: "uxf-typo-caption truncate text-darkLow" }, props.roles)),
41
- react_1.default.createElement("div", { className: "ml-auto" }, hasSubmenu && (react_1.default.createElement(icon_1.Icon, { name: "caretDown", size: 16, className: `ml-2 ${!isSubmenuOpen ? "-rotate-90" : ""}` })))),
42
- isSubmenuOpen && (react_1.default.createElement("div", { className: "mt-4" }, props.submenu.map((item, index) => (react_1.default.createElement(list_item_1.ListItem, { label: item.title, route: item.route, params: item.routeParams, icon: item.icon, key: index })))))));
37
+ return (react_1.default.createElement("div", { className: `uxf-cms-user-menu ${isSubmenuOpen ? classes_1.CLASSES.IS_OPEN : ""}` },
38
+ react_1.default.createElement("button", { className: "uxf-cms-user-menu__button", onClick: toggle },
39
+ react_1.default.createElement(avatar_1.Avatar, { className: "uxf-cms-user-menu__avatar", letters: (0, get_avatar_user_letters_1.getAvatarUserLetters)(props.name), size: "sm", src: props.avatar, variant: "rounded" }),
40
+ react_1.default.createElement("div", { className: "uxf-cms-user-menu__label-wrapper" },
41
+ react_1.default.createElement("div", { className: "uxf-cms-user-menu__name" }, props.name),
42
+ react_1.default.createElement("div", { className: "uxf-cms-user-menu__roles" }, props.roles)),
43
+ react_1.default.createElement("div", { className: "uxf-cms-user-menu__caret-wrapper" }, hasSubmenu && (react_1.default.createElement(icon_1.Icon, { name: "caretDown", size: 16, className: `uxf-cms-user-menu__caret ${!isSubmenuOpen ? classes_1.CLASSES.IS_OPEN : ""}` })))),
44
+ isSubmenuOpen && (react_1.default.createElement("div", { className: "uxf-cms-user-menu__sub-menu" }, props.submenu.map((item, index) => (react_1.default.createElement(list_item_1.ListItem, { endElement: item.endElement, href: item.url, label: item.title, route: item.route, params: item.routeParams, icon: item.icon, key: index })))))));
43
45
  };
44
46
  const UserMenu = (props) => {
45
47
  var _a, _b, _c, _d, _e, _f;
46
- // eslint-disable-next-line react/destructuring-assignment
47
- const { menu } = props;
48
- const userMenu = menu.find((item) => !!item.userMenuData);
48
+ const userMenu = props.menu.find((item) => !!item.userMenuData);
49
49
  return (react_1.default.createElement(Component, { submenu: (_a = userMenu === null || userMenu === void 0 ? void 0 : userMenu.children) !== null && _a !== void 0 ? _a : [], name: (_c = (_b = userMenu === null || userMenu === void 0 ? void 0 : userMenu.userMenuData) === null || _b === void 0 ? void 0 : _b.name) !== null && _c !== void 0 ? _c : "Uživatel", roles: (_e = (_d = userMenu === null || userMenu === void 0 ? void 0 : userMenu.userMenuData) === null || _d === void 0 ? void 0 : _d.roles) !== null && _e !== void 0 ? _e : "nepřihlášený", avatar: (_f = userMenu === null || userMenu === void 0 ? void 0 : userMenu.userMenuData) === null || _f === void 0 ? void 0 : _f.avatar }));
50
50
  };
51
51
  exports.UserMenu = UserMenu;