@ti-tecnologico-de-monterrey-oficial/ds-ng 1.5.1217-c → 1.5.1217-d

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.
@@ -38,7 +38,7 @@ export class BmbSidebarComponent {
38
38
  checkForButton({ isMobile, hasChildren }) {
39
39
  return isMobile && hasChildren;
40
40
  }
41
- getLink({ link, isMobile, hasChildren, }) {
41
+ getLink({ link, isMobile, hasChildren }) {
42
42
  if (this.checkForButton({ isMobile, hasChildren }))
43
43
  return '';
44
44
  return link || '';
@@ -97,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
97
97
  type: HostListener,
98
98
  args: ['window:focusout', ['$event']]
99
99
  }] } });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bmb-sidebar.component.js","sourceRoot":"","sources":["../../../../../../projects/ds-ng/src/lib/components/bmb-sidebar/bmb-sidebar.component.ts","../../../../../../projects/ds-ng/src/lib/components/bmb-sidebar/bmb-sidebar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  HostListener,\n  input,\n  ViewChild,\n  ElementRef,\n  OnInit,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { SidebarElement } from './bmb-sidebar.interface';\nimport { BmbIconComponent } from '../bmb-icon/bmb-icon.component';\nimport { BmbCheckExternalLinkButtonComponent } from '../bmb-check-external-link-button/bmb-check-external-link-button.component';\nimport { IPositionButtonMenu } from '../bmb-top-bar/types';\nimport { BmbActionIconComponent } from '../bmb-action-icon/bmb-action-icon.component';\n\ninterface IBmbIsButton {\n  link?: string;\n  isMobile: boolean;\n  hasChildren: boolean;\n}\n\n@Component({\n  selector: 'bmb-sidebar',\n  standalone: true,\n  imports: [\n    CommonModule,\n    BmbIconComponent,\n    BmbCheckExternalLinkButtonComponent,\n    BmbActionIconComponent,\n  ],\n  templateUrl: './bmb-sidebar.component.html',\n  styleUrl: './bmb-sidebar.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class BmbSidebarComponent implements OnInit {\n  elements = input<SidebarElement[][]>([]);\n  title = input<string>('Navigation');\n  position = input<IPositionButtonMenu>('left'); //Only for web\n\n  currentUrl: string = '';\n  isOpen: boolean = false;\n  selectedElement: SidebarElement | null = null;\n  isActive: boolean = false;\n  hasSubmenu: boolean = false;\n  maxChildrenLevel: number = 2;\n\n  @ViewChild('sideNav') sideNav!: ElementRef;\n\n  @HostListener('window:focusin', ['$event'])\n  onFocusIn() {\n    this.checkIfFocusInsideSidebar();\n  }\n\n  @HostListener('window:focusout', ['$event'])\n  onFocusOut() {\n    this.checkIfFocusInsideSidebar();\n  }\n\n  ngOnInit(): void {\n    if (this.elements()?.length > 2) {\n      console.error(\n        'The sidebar component only supports two levels of navigation',\n      );\n    }\n\n    if (this.elements()[0]?.length > 5) {\n      console.error(\n        'The sidebar component only supports a maximum of 5 elements in the first level of navigation',\n      );\n    }\n\n    if (this.elements()[1] && this.elements()[1]?.length > 3) {\n      console.error(\n        'The sidebar component only supports a maximum of 3 elements in the second level of navigation',\n      );\n    }\n\n    this.hasSubmenu = this.elements()?.some((element) =>\n      element?.some((el) => el.children),\n    );\n  }\n\n  checkForButton({\n    isMobile,\n    hasChildren\n  }: IBmbIsButton): boolean {\n    return isMobile && hasChildren;\n  }\n\n  getLink({\n    link,\n    isMobile,\n    hasChildren,\n  }: IBmbIsButton): string {\n    if (this.checkForButton({ isMobile, hasChildren })) return '';\n    return link || '';\n  }\n\n  closeSidebar() {\n    this.isOpen = false;\n    this.clearSelectElement();\n  }\n\n  clearSelectElement() {\n    this.selectedElement = null;\n  }\n\n  toggleChildren(element: SidebarElement) {\n    if (this.selectedElement === element) {\n      this.clearSelectElement();\n      return;\n    }\n\n    this.selectedElement = element;\n\n    if (element.children) {\n      element.isOpen = !element.isOpen;\n    }\n  }\n\n  checkIfFocusInsideSidebar() {\n    const sidebar = document.querySelector('.bmb_sidebar-desktop');\n    const activeElement = document.activeElement;\n    this.isActive =\n      (sidebar && activeElement && sidebar.contains(activeElement)) || false;\n  }\n\n  checkToCloseSidebar(event: any) {\n    if (event.link && !event.children) {\n      this.closeSidebar();\n      this.sideNav.nativeElement.classList.add('bmb_sidebar-desktop-close');\n\n      setTimeout(() => {\n        this.sideNav.nativeElement.classList.remove(\n          'bmb_sidebar-desktop-close',\n        );\n        this.sideNav.nativeElement.classList.remove('bmb-active');\n      }, 500);\n    }\n  }\n}\n","<!-- Template for element -->\n<ng-template\n  #elementTemplate\n  let-element=\"element\"\n  let-isHeader=\"isHeader\"\n  let-isFixed=\"isFixed\"\n  let-isChild=\"isChild\"\n  let-isMobile=\"isMobile\"\n  let-hasChildren=\"hasChildren\"\n>\n  @if (!isHeader && !!element.icon) {\n    <bmb-icon\n      class=\"bmb_sidebar-icon\"\n      [icon]=\"element.icon\"\n      [alt]=\"element.title\"\n      [size]=\"24\"\n    />\n  }\n  <span\n    [ngClass]=\"{\n      'bmb_sidebar-text': !isHeader,\n      'bmb_sidebar-header-text': isHeader\n    }\"\n  >\n    {{ element!.title }}\n  </span>\n  @if (isFixed) {\n    <bmb-action-icon\n      class=\"bmb_sidebar-header-icon\"\n      idElement=\"sidebar_close\"\n      icon=\"close\"\n      [iconSize]=\"24\"\n      [isAccentColor]=\"false\"\n      (buttonClick)=\"closeSidebar()\"\n    />\n  }\n</ng-template>\n\n<!-- Template for menu items -->\n<ng-template #itemsTemplate let-item=\"item\" let-isMobile=\"isMobile\">\n  <bmb-check-external-link-button\n    class=\"bmb_sidebar-link\"\n    [idElement]=\"'element' + item.id!\"\n    [link]=\"\n      getLink({ isMobile, hasChildren: !!item.children, link: item.link! })\n    \"\n    [target]=\"\n      checkForButton({\n        isMobile,\n        hasChildren: !!item.children\n      })\n        ? item.target!\n        : ''\n    \"\n    (buttonClick)=\"toggleChildren(item)\"\n  >\n    <ng-container\n      *ngTemplateOutlet=\"elementTemplate; context: { element: item, isMobile }\"\n    />\n    @if (!!item.children) {\n      <bmb-icon\n        class=\"bmb_sidebar-arrow\"\n        [icon]=\"\n          !isMobile && position() === 'right' ? 'chevron_left' : 'chevron_right'\n        \"\n        [size]=\"24\"\n      />\n    }\n  </bmb-check-external-link-button>\n</ng-template>\n\n<!-- Template for navigation -->\n<ng-template #sidebarTemplate let-level=\"level\" let-isMobile=\"isMobile\">\n  @for (group of elements().slice(0, 2); track $index) {\n    <ul class=\"bmb_sidebar-list\">\n      @for (element of group.slice(0, 5); track $index) {\n        <li\n          class=\"bmb_sidebar-item\"\n          [ngClass]=\"{\n            'bmb_sidebar-item-left-space':\n              position() === 'right' && hasSubmenu && !element.children?.length\n          }\"\n          (click)=\"checkToCloseSidebar(element)\"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"\n              itemsTemplate;\n              context: { item: element, isMobile }\n            \"\n          />\n          @if (!!element.children && level === 1) {\n            <ng-container\n              *ngTemplateOutlet=\"\n                sidebarElementTemplate;\n                context: {\n                  element: element,\n                  iconSize: 24,\n                  isFixed: true,\n                  level: 2,\n                  selectedElement,\n                  isMobile\n                }\n              \"\n            />\n          }\n        </li>\n      }\n    </ul>\n  }\n</ng-template>\n\n<ng-template\n  #sidebarElementTemplate\n  let-element=\"element\"\n  let-iconSize=\"iconSize\"\n  let-level=\"level\"\n  let-isHeader=\"isHeader\"\n  let-isFixed=\"isFixed\"\n  let-selectedElement=\"selectedElement\"\n  let-isMobile=\"isMobile\"\n>\n  @if (level == 1 && isMobile) {\n    <bmb-action-icon\n      class=\"bmb_sidebar-mobile-button\"\n      idElement=\"sidebar_main\"\n      icon=\"chevron_right\"\n      [iconSize]=\"iconSize\"\n      toggleIconActive=\"chevron_left\"\n      [isAccentColor]=\"false\"\n      [(isToggleActive)]=\"isOpen\"\n      (buttonClick)=\"clearSelectElement()\"\n    />\n  }\n  <section\n    [tabIndex]=\"-1\"\n    [ngClass]=\"{\n      'bmb_sidebar-children': level >= 2 && !!element.children,\n      'bmb_sidebar-children-open':\n        level >= 2 && !!element.children && selectedElement === element,\n      'bmb_sidebar-open': isMobile && level == 1 && isOpen,\n      bmb_sidebar: isMobile && level == 1,\n      'bmb_sidebar-mobile': isMobile && level == 1\n    }\"\n  >\n    @if (isOpen) {\n      <section\n        [ngClass]=\"{\n          'bmb_sidebar-header': level == 1,\n          'bmb_sidebar-title': level >= 2\n        }\"\n      >\n        @if (level >= 2 && !!selectedElement) {\n          <bmb-action-icon\n            class=\"bmb_sidebar-title-button\"\n            [idElement]=\"element.id.toString()\"\n            icon=\"chevron_left\"\n            [iconSize]=\"24\"\n            (buttonClick)=\"toggleChildren(element)\"\n          />\n        }\n        <!-- Header -->\n        <ng-container\n          *ngTemplateOutlet=\"\n            elementTemplate;\n            context: {\n              element,\n              isHeader: true,\n              isFixed,\n              hasChildren: !!element.children\n            }\n          \"\n        />\n      </section>\n\n      @if (level == 1) {\n        <!-- Menu -->\n        <ng-container\n          *ngTemplateOutlet=\"sidebarTemplate; context: { level, isMobile }\"\n        />\n      }\n    }\n    @if (level >= 2 && !!element.children) {\n      <ul class=\"bmb_sidebar-list\">\n        @for (child of element?.children?.slice(0, 6); track $index) {\n          <li class=\"bmb_sidebar-item\" (click)=\"checkToCloseSidebar(child)\">\n            <ng-container\n              *ngTemplateOutlet=\"\n                itemsTemplate;\n                context: { item: child, isMobile, isChild: true }\n              \"\n            />\n          </li>\n        }\n      </ul>\n    }\n  </section>\n</ng-template>\n\n<!-- Web -->\n<nav\n  #sideNav\n  class=\"bmb_sidebar bmb_sidebar-desktop\"\n  aria-label=\"Sidebar Navigation\"\n  [ngClass]=\"{\n    'bmb-active': isActive,\n    'bmb_sidebar-desktop-right': position() === 'right'\n  }\"\n  (mouseleave)=\"clearSelectElement()\"\n>\n  <div [tabIndex]=\"-1\" class=\"bmb_sidebar-content\">\n    <ng-container\n      *ngTemplateOutlet=\"\n        sidebarTemplate;\n        context: { level: 1, isMobile: false }\n      \"\n    />\n  </div>\n</nav>\n\n<!-- Mobile -->\n<nav class=\"bmb_sidebar-mobile\" aria-label=\"Sidebar Navigation\">\n  <ng-container\n    *ngTemplateOutlet=\"\n      sidebarElementTemplate;\n      context: {\n        element: {\n          title: title()\n        },\n        iconSize: 32,\n        isHeader: true,\n        isFixed: true,\n        level: 1,\n        isMobile: true\n      }\n    \"\n  />\n</nav>\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bmb-sidebar.component.js","sourceRoot":"","sources":["../../../../../../projects/ds-ng/src/lib/components/bmb-sidebar/bmb-sidebar.component.ts","../../../../../../projects/ds-ng/src/lib/components/bmb-sidebar/bmb-sidebar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  HostListener,\n  input,\n  ViewChild,\n  ElementRef,\n  OnInit,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { SidebarElement } from './bmb-sidebar.interface';\nimport { BmbIconComponent } from '../bmb-icon/bmb-icon.component';\nimport { BmbCheckExternalLinkButtonComponent } from '../bmb-check-external-link-button/bmb-check-external-link-button.component';\nimport { IPositionButtonMenu } from '../bmb-top-bar/types';\nimport { BmbActionIconComponent } from '../bmb-action-icon/bmb-action-icon.component';\n\ninterface IBmbIsButton {\n  link?: string;\n  isMobile: boolean;\n  hasChildren: boolean;\n}\n\n@Component({\n  selector: 'bmb-sidebar',\n  standalone: true,\n  imports: [\n    CommonModule,\n    BmbIconComponent,\n    BmbCheckExternalLinkButtonComponent,\n    BmbActionIconComponent,\n  ],\n  templateUrl: './bmb-sidebar.component.html',\n  styleUrl: './bmb-sidebar.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class BmbSidebarComponent implements OnInit {\n  elements = input<SidebarElement[][]>([]);\n  title = input<string>('Navigation');\n  position = input<IPositionButtonMenu>('left'); //Only for web\n\n  currentUrl: string = '';\n  isOpen: boolean = false;\n  selectedElement: SidebarElement | null = null;\n  isActive: boolean = false;\n  hasSubmenu: boolean = false;\n  maxChildrenLevel: number = 2;\n\n  @ViewChild('sideNav') sideNav!: ElementRef;\n\n  @HostListener('window:focusin', ['$event'])\n  onFocusIn() {\n    this.checkIfFocusInsideSidebar();\n  }\n\n  @HostListener('window:focusout', ['$event'])\n  onFocusOut() {\n    this.checkIfFocusInsideSidebar();\n  }\n\n  ngOnInit(): void {\n    if (this.elements()?.length > 2) {\n      console.error(\n        'The sidebar component only supports two levels of navigation',\n      );\n    }\n\n    if (this.elements()[0]?.length > 5) {\n      console.error(\n        'The sidebar component only supports a maximum of 5 elements in the first level of navigation',\n      );\n    }\n\n    if (this.elements()[1] && this.elements()[1]?.length > 3) {\n      console.error(\n        'The sidebar component only supports a maximum of 3 elements in the second level of navigation',\n      );\n    }\n\n    this.hasSubmenu = this.elements()?.some((element) =>\n      element?.some((el) => el.children),\n    );\n  }\n\n  checkForButton({ isMobile, hasChildren }: IBmbIsButton): boolean {\n    return isMobile && hasChildren;\n  }\n\n  getLink({ link, isMobile, hasChildren }: IBmbIsButton): string {\n    if (this.checkForButton({ isMobile, hasChildren })) return '';\n    return link || '';\n  }\n\n  closeSidebar() {\n    this.isOpen = false;\n    this.clearSelectElement();\n  }\n\n  clearSelectElement() {\n    this.selectedElement = null;\n  }\n\n  toggleChildren(element: SidebarElement) {\n    if (this.selectedElement === element) {\n      this.clearSelectElement();\n      return;\n    }\n\n    this.selectedElement = element;\n\n    if (element.children) {\n      element.isOpen = !element.isOpen;\n    }\n  }\n\n  checkIfFocusInsideSidebar() {\n    const sidebar = document.querySelector('.bmb_sidebar-desktop');\n    const activeElement = document.activeElement;\n    this.isActive =\n      (sidebar && activeElement && sidebar.contains(activeElement)) || false;\n  }\n\n  checkToCloseSidebar(event: any) {\n    if (event.link && !event.children) {\n      this.closeSidebar();\n      this.sideNav.nativeElement.classList.add('bmb_sidebar-desktop-close');\n\n      setTimeout(() => {\n        this.sideNav.nativeElement.classList.remove(\n          'bmb_sidebar-desktop-close',\n        );\n        this.sideNav.nativeElement.classList.remove('bmb-active');\n      }, 500);\n    }\n  }\n}\n","<!-- Template for element -->\n<ng-template\n  #elementTemplate\n  let-element=\"element\"\n  let-isHeader=\"isHeader\"\n  let-isFixed=\"isFixed\"\n  let-isChild=\"isChild\"\n  let-isMobile=\"isMobile\"\n  let-hasChildren=\"hasChildren\"\n>\n  @if (!isHeader && !!element.icon) {\n    <bmb-icon\n      class=\"bmb_sidebar-icon\"\n      [icon]=\"element.icon\"\n      [alt]=\"element.title\"\n      [size]=\"24\"\n    />\n  }\n  <span\n    [ngClass]=\"{\n      'bmb_sidebar-text': !isHeader,\n      'bmb_sidebar-header-text': isHeader\n    }\"\n  >\n    {{ element!.title }}\n  </span>\n  @if (isFixed) {\n    <bmb-action-icon\n      class=\"bmb_sidebar-header-icon\"\n      idElement=\"sidebar_close\"\n      icon=\"close\"\n      [iconSize]=\"24\"\n      [isAccentColor]=\"false\"\n      (buttonClick)=\"closeSidebar()\"\n    />\n  }\n</ng-template>\n\n<!-- Template for menu items -->\n<ng-template #itemsTemplate let-item=\"item\" let-isMobile=\"isMobile\">\n  <bmb-check-external-link-button\n    class=\"bmb_sidebar-link\"\n    [idElement]=\"'element' + item.id!\"\n    [link]=\"\n      getLink({ isMobile, hasChildren: !!item.children, link: item.link! })\n    \"\n    [target]=\"\n      checkForButton({\n        isMobile,\n        hasChildren: !!item.children\n      })\n        ? item.target!\n        : ''\n    \"\n    (buttonClick)=\"toggleChildren(item)\"\n  >\n    <ng-container\n      *ngTemplateOutlet=\"elementTemplate; context: { element: item, isMobile }\"\n    />\n    @if (!!item.children) {\n      <bmb-icon\n        class=\"bmb_sidebar-arrow\"\n        [icon]=\"\n          !isMobile && position() === 'right' ? 'chevron_left' : 'chevron_right'\n        \"\n        [size]=\"24\"\n      />\n    }\n  </bmb-check-external-link-button>\n</ng-template>\n\n<!-- Template for navigation -->\n<ng-template #sidebarTemplate let-level=\"level\" let-isMobile=\"isMobile\">\n  @for (group of elements().slice(0, 2); track $index) {\n    <ul class=\"bmb_sidebar-list\">\n      @for (element of group.slice(0, 5); track $index) {\n        <li\n          class=\"bmb_sidebar-item\"\n          [ngClass]=\"{\n            'bmb_sidebar-item-left-space':\n              position() === 'right' && hasSubmenu && !element.children?.length\n          }\"\n          (click)=\"checkToCloseSidebar(element)\"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"\n              itemsTemplate;\n              context: { item: element, isMobile }\n            \"\n          />\n          @if (!!element.children && level === 1) {\n            <ng-container\n              *ngTemplateOutlet=\"\n                sidebarElementTemplate;\n                context: {\n                  element: element,\n                  iconSize: 24,\n                  isFixed: true,\n                  level: 2,\n                  selectedElement,\n                  isMobile\n                }\n              \"\n            />\n          }\n        </li>\n      }\n    </ul>\n  }\n</ng-template>\n\n<ng-template\n  #sidebarElementTemplate\n  let-element=\"element\"\n  let-iconSize=\"iconSize\"\n  let-level=\"level\"\n  let-isHeader=\"isHeader\"\n  let-isFixed=\"isFixed\"\n  let-selectedElement=\"selectedElement\"\n  let-isMobile=\"isMobile\"\n>\n  @if (level == 1 && isMobile) {\n    <bmb-action-icon\n      class=\"bmb_sidebar-mobile-button\"\n      idElement=\"sidebar_main\"\n      icon=\"chevron_right\"\n      [iconSize]=\"iconSize\"\n      toggleIconActive=\"chevron_left\"\n      [isAccentColor]=\"false\"\n      [(isToggleActive)]=\"isOpen\"\n      (buttonClick)=\"clearSelectElement()\"\n    />\n  }\n  <section\n    [tabIndex]=\"-1\"\n    [ngClass]=\"{\n      'bmb_sidebar-children': level >= 2 && !!element.children,\n      'bmb_sidebar-children-open':\n        level >= 2 && !!element.children && selectedElement === element,\n      'bmb_sidebar-open': isMobile && level == 1 && isOpen,\n      bmb_sidebar: isMobile && level == 1,\n      'bmb_sidebar-mobile': isMobile && level == 1\n    }\"\n  >\n    @if (isOpen) {\n      <section\n        [ngClass]=\"{\n          'bmb_sidebar-header': level == 1,\n          'bmb_sidebar-title': level >= 2\n        }\"\n      >\n        @if (level >= 2 && !!selectedElement) {\n          <bmb-action-icon\n            class=\"bmb_sidebar-title-button\"\n            [idElement]=\"element.id.toString()\"\n            icon=\"chevron_left\"\n            [iconSize]=\"24\"\n            (buttonClick)=\"toggleChildren(element)\"\n          />\n        }\n        <!-- Header -->\n        <ng-container\n          *ngTemplateOutlet=\"\n            elementTemplate;\n            context: {\n              element,\n              isHeader: true,\n              isFixed,\n              hasChildren: !!element.children\n            }\n          \"\n        />\n      </section>\n\n      @if (level == 1) {\n        <!-- Menu -->\n        <ng-container\n          *ngTemplateOutlet=\"sidebarTemplate; context: { level, isMobile }\"\n        />\n      }\n    }\n    @if (level >= 2 && !!element.children) {\n      <ul class=\"bmb_sidebar-list\">\n        @for (child of element?.children?.slice(0, 6); track $index) {\n          <li class=\"bmb_sidebar-item\" (click)=\"checkToCloseSidebar(child)\">\n            <ng-container\n              *ngTemplateOutlet=\"\n                itemsTemplate;\n                context: { item: child, isMobile, isChild: true }\n              \"\n            />\n          </li>\n        }\n      </ul>\n    }\n  </section>\n</ng-template>\n\n<!-- Web -->\n<nav\n  #sideNav\n  class=\"bmb_sidebar bmb_sidebar-desktop\"\n  aria-label=\"Sidebar Navigation\"\n  [ngClass]=\"{\n    'bmb-active': isActive,\n    'bmb_sidebar-desktop-right': position() === 'right'\n  }\"\n  (mouseleave)=\"clearSelectElement()\"\n>\n  <div [tabIndex]=\"-1\" class=\"bmb_sidebar-content\">\n    <ng-container\n      *ngTemplateOutlet=\"\n        sidebarTemplate;\n        context: { level: 1, isMobile: false }\n      \"\n    />\n  </div>\n</nav>\n\n<!-- Mobile -->\n<nav class=\"bmb_sidebar-mobile\" aria-label=\"Sidebar Navigation\">\n  <ng-container\n    *ngTemplateOutlet=\"\n      sidebarElementTemplate;\n      context: {\n        element: {\n          title: title()\n        },\n        iconSize: 32,\n        isHeader: true,\n        isFixed: true,\n        level: 1,\n        isMobile: true\n      }\n    \"\n  />\n</nav>\n"]}