@indigina/ui-kit 1.1.83 → 1.1.84

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.
@@ -80,6 +80,12 @@ export class KitNavigationMenuComponent {
80
80
  else {
81
81
  item.expanded = false;
82
82
  item.active = matchLink(item);
83
+ if (item.active) {
84
+ this.selectedItem.set(item);
85
+ this.selectedAppsItems.set(null);
86
+ this.kitNavigationMenuService.setCollapsedState(true);
87
+ this.updateMenuState();
88
+ }
83
89
  }
84
90
  });
85
91
  }
@@ -114,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
114
120
  }], appsMenuItems: [{
115
121
  type: Input
116
122
  }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kit-navigation-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-kit/src/lib/components/kit-navigation-menu/kit-navigation-menu.component.ts","../../../../../../projects/ui-kit/src/lib/components/kit-navigation-menu/kit-navigation-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit, signal, WritableSignal } from '@angular/core';\nimport { KitNavigationMenuAppItem, KitNavigationMenuItem } from './kit-navigation-menu.model';\nimport { expandCollapseAnimation } from './kit-navigation-menu.util';\nimport { KitSvgIconType, KitSvgIcon } from '../kit-svg-icon/kit-svg-icon.const';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { filter } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { KitTooltipPosition } from '../../directives/kit-tooltip/kit-tooltip.directive';\nimport { KitNavigationMenuService } from './kit-navigation-menu.service';\n\n@Component({\n  selector: 'kit-navigation-menu',\n  templateUrl: './kit-navigation-menu.component.html',\n  styleUrl: './kit-navigation-menu.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    expandCollapseAnimation('width'),\n  ],\n})\nexport class KitNavigationMenuComponent implements OnInit {\n  /**\n   * An items list which is going to be rendered as menu items\n   */\n  @Input() menuItems: KitNavigationMenuItem[] = [];\n\n  /**\n   * An items list which is going to be rendered as apps menu items\n   */\n  @Input() appsMenuItems: KitNavigationMenuAppItem[] = [];\n\n  readonly selectedItem: WritableSignal<KitNavigationMenuItem | null> = signal(null);\n  readonly selectedAppsItems: WritableSignal<KitNavigationMenuAppItem[] | null> = signal(null);\n  readonly collapsed: WritableSignal<boolean> = this.kitNavigationMenuService.getCollapsedState();\n  readonly KitSvgIcon: typeof KitSvgIcon = KitSvgIcon;\n  readonly KitSvgIconType: typeof KitSvgIconType = KitSvgIconType;\n  readonly KitTooltipPosition: typeof KitTooltipPosition = KitTooltipPosition;\n\n  constructor(\n    private router: Router,\n    private kitNavigationMenuService: KitNavigationMenuService,\n  ) {\n    this.setExpandedStateOnRouterChange();\n  }\n\n  ngOnInit(): void {\n    this.updateNavigationState(this.menuItems, this.router.url);\n  }\n\n  handleClick(item: KitNavigationMenuItem): void {\n    !item.items ? this.collapseAllItems(this.menuItems) : this.toggleItem(item);\n    this.selectedAppsItems.set(null);\n    this.selectedItem.set(item);\n    this.updateMenuState();\n  }\n\n  handleLogoClick(): void {\n    this.collapseAllItems(this.menuItems);\n    this.selectedAppsItems.set(null);\n    this.selectedItem.set(null);\n    this.updateMenuState();\n  }\n\n  onAppsMenuButtonClick(): void {\n    if (this.selectedAppsItems() && !this.collapsed()) {\n      this.selectedAppsItems.set(null);\n      this.collapseAllItems(this.menuItems);\n    } else {\n      this.kitNavigationMenuService.setCollapsedState(false);\n      this.menuItems.forEach(item => item.expanded = false);\n      this.selectedAppsItems.set(this.appsMenuItems);\n    }\n\n    this.updateMenuState();\n  }\n\n  private setExpandedStateOnRouterChange(): void {\n    this.router.events.pipe(\n      filter(event => event instanceof NavigationEnd),\n      takeUntilDestroyed(),\n    ).subscribe(() => this.updateNavigationState(this.menuItems, this.router.url));\n  }\n\n  private updateNavigationState(items: KitNavigationMenuItem[], url: string): void {\n    const matchLink = (item: KitNavigationMenuItem): boolean => !!(item.link && url.startsWith(item.link));\n    items.forEach(item => {\n      if (item.items) {\n        this.updateNavigationState(item.items, url);\n        item.expanded = item.items.some(child => child.expanded) ||\n          item.items.some(child => matchLink(child));\n        item.active = item.items.some(child => child.active);\n        if (item.expanded) {\n          this.selectedItem.set(item);\n          this.selectedAppsItems.set(null);\n          this.kitNavigationMenuService.setCollapsedState(false);\n          this.updateMenuState();\n        }\n      } else {\n        item.expanded = false;\n        item.active = matchLink(item);\n      }\n    });\n  }\n\n  private collapseAllItems(items: KitNavigationMenuItem[]): void {\n    this.kitNavigationMenuService.setCollapsedState(true);\n    items.forEach(item => item.expanded = false);\n  }\n\n  private toggleItem(item: KitNavigationMenuItem): void {\n    if (this.collapsed() || item.expanded) {\n      this.kitNavigationMenuService.setCollapsedState(!this.collapsed());\n    } else {\n      this.menuItems.forEach(item => item.expanded = false);\n    }\n\n    item.expanded = !item.expanded;\n  }\n\n  private updateMenuState(): void {\n    this.kitNavigationMenuService.setSelectedState(!!this.selectedItem()?.items, !!this.selectedAppsItems());\n  }\n}\n","<div class=\"kit-navigation-menu\"\n     [class.collapsed]=\"collapsed()\">\n  <div class=\"main-panel\">\n    @if (appsMenuItems.length > 1) {\n      <button class=\"app-btn\"\n              [class.active]=\"selectedAppsItems() && !collapsed()\"\n              (click)=\"onAppsMenuButtonClick()\">\n        <kit-svg-icon class=\"app-btn-icon\"\n                      [icon]=\"KitSvgIcon.FOUR_SQUARE\"\n        ></kit-svg-icon>\n      </button>\n    }\n    <div class=\"nav-list\">\n      @for (item of menuItems; track item) {\n        @if (item.items?.length) {\n          <a class=\"nav-link\"\n             kitTooltip\n             kitTooltipFilter=\".nav-link\"\n             [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n             [title]=\"item.title\"\n             [class.active]=\"item.active\"\n             (click)=\"handleClick(item)\">\n            @if (item.icon) {\n              <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n              ></ng-container>\n            }\n          </a>\n        } @else {\n          @if (item.link) {\n            <a class=\"nav-link\"\n               routerLinkActive=\"active\"\n               kitTooltip\n               kitTooltipFilter=\".nav-link\"\n               [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n               [title]=\"item.title\"\n               [routerLink]=\"item?.link\"\n               (click)=\"handleClick(item)\">\n              @if (item.icon) {\n                <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n                ></ng-container>\n              }\n            </a>\n          }\n        }\n      }\n    </div>\n  </div>\n\n  @if (!collapsed() && (selectedItem()?.items || selectedAppsItems())) {\n    <kit-navigation-menu-submenu class=\"sub-panel\"\n                                 [@widthExpandCollapseAnimation]\n                                 [menuItem]=\"selectedItem()\"\n                                 [appsMenuItems]=\"selectedAppsItems()\"\n                                 (logoClicked)=\"handleLogoClick()\"\n    ></kit-navigation-menu-submenu>\n  }\n\n  <ng-template #linkIconTemplate let-item>\n    <kit-svg-icon class=\"nav-link-icon\"\n                  [icon]=\"item.icon\"\n                  [ngClass]=\"item?.iconType ?? KitSvgIconType.FILL\"\n    ></kit-svg-icon>\n  </ng-template>\n</div>\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kit-navigation-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-kit/src/lib/components/kit-navigation-menu/kit-navigation-menu.component.ts","../../../../../../projects/ui-kit/src/lib/components/kit-navigation-menu/kit-navigation-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit, signal, WritableSignal } from '@angular/core';\nimport { KitNavigationMenuAppItem, KitNavigationMenuItem } from './kit-navigation-menu.model';\nimport { expandCollapseAnimation } from './kit-navigation-menu.util';\nimport { KitSvgIconType, KitSvgIcon } from '../kit-svg-icon/kit-svg-icon.const';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { filter } from 'rxjs';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { KitTooltipPosition } from '../../directives/kit-tooltip/kit-tooltip.directive';\nimport { KitNavigationMenuService } from './kit-navigation-menu.service';\n\n@Component({\n  selector: 'kit-navigation-menu',\n  templateUrl: './kit-navigation-menu.component.html',\n  styleUrl: './kit-navigation-menu.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    expandCollapseAnimation('width'),\n  ],\n})\nexport class KitNavigationMenuComponent implements OnInit {\n  /**\n   * An items list which is going to be rendered as menu items\n   */\n  @Input() menuItems: KitNavigationMenuItem[] = [];\n\n  /**\n   * An items list which is going to be rendered as apps menu items\n   */\n  @Input() appsMenuItems: KitNavigationMenuAppItem[] = [];\n\n  readonly selectedItem: WritableSignal<KitNavigationMenuItem | null> = signal(null);\n  readonly selectedAppsItems: WritableSignal<KitNavigationMenuAppItem[] | null> = signal(null);\n  readonly collapsed: WritableSignal<boolean> = this.kitNavigationMenuService.getCollapsedState();\n  readonly KitSvgIcon: typeof KitSvgIcon = KitSvgIcon;\n  readonly KitSvgIconType: typeof KitSvgIconType = KitSvgIconType;\n  readonly KitTooltipPosition: typeof KitTooltipPosition = KitTooltipPosition;\n\n  constructor(\n    private router: Router,\n    private kitNavigationMenuService: KitNavigationMenuService,\n  ) {\n    this.setExpandedStateOnRouterChange();\n  }\n\n  ngOnInit(): void {\n    this.updateNavigationState(this.menuItems, this.router.url);\n  }\n\n  handleClick(item: KitNavigationMenuItem): void {\n    !item.items ? this.collapseAllItems(this.menuItems) : this.toggleItem(item);\n    this.selectedAppsItems.set(null);\n    this.selectedItem.set(item);\n    this.updateMenuState();\n  }\n\n  handleLogoClick(): void {\n    this.collapseAllItems(this.menuItems);\n    this.selectedAppsItems.set(null);\n    this.selectedItem.set(null);\n    this.updateMenuState();\n  }\n\n  onAppsMenuButtonClick(): void {\n    if (this.selectedAppsItems() && !this.collapsed()) {\n      this.selectedAppsItems.set(null);\n      this.collapseAllItems(this.menuItems);\n    } else {\n      this.kitNavigationMenuService.setCollapsedState(false);\n      this.menuItems.forEach(item => item.expanded = false);\n      this.selectedAppsItems.set(this.appsMenuItems);\n    }\n\n    this.updateMenuState();\n  }\n\n  private setExpandedStateOnRouterChange(): void {\n    this.router.events.pipe(\n      filter(event => event instanceof NavigationEnd),\n      takeUntilDestroyed(),\n    ).subscribe(() => this.updateNavigationState(this.menuItems, this.router.url));\n  }\n\n  private updateNavigationState(items: KitNavigationMenuItem[], url: string): void {\n    const matchLink = (item: KitNavigationMenuItem): boolean => !!(item.link && url.startsWith(item.link));\n    items.forEach(item => {\n      if (item.items) {\n        this.updateNavigationState(item.items, url);\n        item.expanded = item.items.some(child => child.expanded) ||\n          item.items.some(child => matchLink(child));\n        item.active = item.items.some(child => child.active);\n        if (item.expanded) {\n          this.selectedItem.set(item);\n          this.selectedAppsItems.set(null);\n          this.kitNavigationMenuService.setCollapsedState(false);\n          this.updateMenuState();\n        }\n      } else {\n        item.expanded = false;\n        item.active = matchLink(item);\n        if (item.active) {\n          this.selectedItem.set(item);\n          this.selectedAppsItems.set(null);\n          this.kitNavigationMenuService.setCollapsedState(true);\n          this.updateMenuState();\n        }\n      }\n    });\n  }\n\n  private collapseAllItems(items: KitNavigationMenuItem[]): void {\n    this.kitNavigationMenuService.setCollapsedState(true);\n    items.forEach(item => item.expanded = false);\n  }\n\n  private toggleItem(item: KitNavigationMenuItem): void {\n    if (this.collapsed() || item.expanded) {\n      this.kitNavigationMenuService.setCollapsedState(!this.collapsed());\n    } else {\n      this.menuItems.forEach(item => item.expanded = false);\n    }\n\n    item.expanded = !item.expanded;\n  }\n\n  private updateMenuState(): void {\n    this.kitNavigationMenuService.setSelectedState(!!this.selectedItem()?.items, !!this.selectedAppsItems());\n  }\n}\n","<div class=\"kit-navigation-menu\"\n     [class.collapsed]=\"collapsed()\">\n  <div class=\"main-panel\">\n    @if (appsMenuItems.length > 1) {\n      <button class=\"app-btn\"\n              [class.active]=\"selectedAppsItems() && !collapsed()\"\n              (click)=\"onAppsMenuButtonClick()\">\n        <kit-svg-icon class=\"app-btn-icon\"\n                      [icon]=\"KitSvgIcon.FOUR_SQUARE\"\n        ></kit-svg-icon>\n      </button>\n    }\n    <div class=\"nav-list\">\n      @for (item of menuItems; track item) {\n        @if (item.items?.length) {\n          <a class=\"nav-link\"\n             kitTooltip\n             kitTooltipFilter=\".nav-link\"\n             [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n             [title]=\"item.title\"\n             [class.active]=\"item.active\"\n             (click)=\"handleClick(item)\">\n            @if (item.icon) {\n              <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n              ></ng-container>\n            }\n          </a>\n        } @else {\n          @if (item.link) {\n            <a class=\"nav-link\"\n               routerLinkActive=\"active\"\n               kitTooltip\n               kitTooltipFilter=\".nav-link\"\n               [kitTooltipPosition]=\"KitTooltipPosition.RIGHT\"\n               [title]=\"item.title\"\n               [routerLink]=\"item?.link\"\n               (click)=\"handleClick(item)\">\n              @if (item.icon) {\n                <ng-container *ngTemplateOutlet=\"linkIconTemplate; context: { $implicit: item }\"\n                ></ng-container>\n              }\n            </a>\n          }\n        }\n      }\n    </div>\n  </div>\n\n  @if (!collapsed() && (selectedItem()?.items || selectedAppsItems())) {\n    <kit-navigation-menu-submenu class=\"sub-panel\"\n                                 [@widthExpandCollapseAnimation]\n                                 [menuItem]=\"selectedItem()\"\n                                 [appsMenuItems]=\"selectedAppsItems()\"\n                                 (logoClicked)=\"handleLogoClick()\"\n    ></kit-navigation-menu-submenu>\n  }\n\n  <ng-template #linkIconTemplate let-item>\n    <kit-svg-icon class=\"nav-link-icon\"\n                  [icon]=\"item.icon\"\n                  [ngClass]=\"item?.iconType ?? KitSvgIconType.FILL\"\n    ></kit-svg-icon>\n  </ng-template>\n</div>\n"]}
@@ -3922,6 +3922,12 @@ class KitNavigationMenuComponent {
3922
3922
  else {
3923
3923
  item.expanded = false;
3924
3924
  item.active = matchLink(item);
3925
+ if (item.active) {
3926
+ this.selectedItem.set(item);
3927
+ this.selectedAppsItems.set(null);
3928
+ this.kitNavigationMenuService.setCollapsedState(true);
3929
+ this.updateMenuState();
3930
+ }
3925
3931
  }
3926
3932
  });
3927
3933
  }