cmat 0.0.4 → 0.0.5

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 (21) hide show
  1. package/components/navigation/vertical/components/aside/aside.component.d.ts +5 -2
  2. package/components/navigation/vertical/components/basic/basic.component.d.ts +5 -2
  3. package/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +5 -2
  4. package/components/navigation/vertical/components/divider/divider.component.d.ts +5 -2
  5. package/components/navigation/vertical/components/group/group.component.d.ts +5 -2
  6. package/components/navigation/vertical/components/spacer/spacer.component.d.ts +5 -2
  7. package/components/navigation/vertical/vertical.component.d.ts +4 -1
  8. package/esm2022/components/navigation/vertical/components/aside/aside.component.mjs +13 -4
  9. package/esm2022/components/navigation/vertical/components/basic/basic.component.mjs +13 -4
  10. package/esm2022/components/navigation/vertical/components/collapsable/collapsable.component.mjs +13 -4
  11. package/esm2022/components/navigation/vertical/components/divider/divider.component.mjs +13 -4
  12. package/esm2022/components/navigation/vertical/components/group/group.component.mjs +13 -4
  13. package/esm2022/components/navigation/vertical/components/spacer/spacer.component.mjs +13 -4
  14. package/esm2022/components/navigation/vertical/vertical.component.mjs +12 -3
  15. package/esm2022/services/config/urlStateConfig.service.mjs +2 -2
  16. package/fesm2022/cmat-components-navigation.mjs +78 -15
  17. package/fesm2022/cmat-components-navigation.mjs.map +1 -1
  18. package/fesm2022/cmat-services-config.mjs +1 -1
  19. package/fesm2022/cmat-services-config.mjs.map +1 -1
  20. package/package.json +66 -66
  21. package/services/config/urlStateConfig.service.d.ts +1 -1
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';
1
+ import { ChangeDetectorRef, EventEmitter, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';
2
2
  import { Router } from '@angular/router';
3
3
  import { BooleanInput } from '@angular/cdk/coercion';
4
4
  import { CmatNavigationService } from '../../../navigation.service';
@@ -15,6 +15,8 @@ export declare class CmatVerticalNavigationAsideItemComponent implements OnChang
15
15
  item: CmatNavigationItem;
16
16
  name: string;
17
17
  skipChildren: boolean;
18
+ editState: boolean;
19
+ readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem>;
18
20
  active: boolean;
19
21
  private _cmatVerticalNavigationComponent;
20
22
  private _unsubscribeAll;
@@ -40,6 +42,7 @@ export declare class CmatVerticalNavigationAsideItemComponent implements OnChang
40
42
  * @param item
41
43
  */
42
44
  trackByFn(index: number, item: any): any;
45
+ selectItem(item: CmatNavigationItem): void;
43
46
  /**
44
47
  * Check if the given item has the given url
45
48
  * in one of its children
@@ -56,5 +59,5 @@ export declare class CmatVerticalNavigationAsideItemComponent implements OnChang
56
59
  */
57
60
  private _markIfActive;
58
61
  static ɵfac: i0.ɵɵFactoryDeclaration<CmatVerticalNavigationAsideItemComponent, never>;
59
- static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationAsideItemComponent, "cmat-vertical-navigation-aside-item", never, { "activeItemId": { "alias": "activeItemId"; "required": false; }; "autoCollapse": { "alias": "autoCollapse"; "required": false; }; "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; "skipChildren": { "alias": "skipChildren"; "required": false; }; }, {}, never, never, true, never>;
62
+ static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationAsideItemComponent, "cmat-vertical-navigation-aside-item", never, { "activeItemId": { "alias": "activeItemId"; "required": false; }; "autoCollapse": { "alias": "autoCollapse"; "required": false; }; "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; "skipChildren": { "alias": "skipChildren"; "required": false; }; "editState": { "alias": "editState"; "required": false; }; }, { "editSelectedItemChanged": "editSelectedItemChanged"; }, never, never, true, never>;
60
63
  }
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
1
+ import { ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
2
  import { IsActiveMatchOptions } from '@angular/router';
3
3
  import { CmatNavigationService } from '../../../navigation.service';
4
4
  import { CmatNavigationItem } from '../../../navigation.types';
@@ -10,6 +10,8 @@ export declare class CmatVerticalNavigationBasicItemComponent implements OnInit,
10
10
  private _cmatUtilsService;
11
11
  item: CmatNavigationItem;
12
12
  name: string;
13
+ editState: boolean;
14
+ readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem>;
13
15
  isActiveMatchOptions: IsActiveMatchOptions;
14
16
  private _cmatVerticalNavigationComponent;
15
17
  private _unsubscribeAll;
@@ -22,6 +24,7 @@ export declare class CmatVerticalNavigationBasicItemComponent implements OnInit,
22
24
  * On destroy
23
25
  */
24
26
  ngOnDestroy(): void;
27
+ selectItem(): void;
25
28
  static ɵfac: i0.ɵɵFactoryDeclaration<CmatVerticalNavigationBasicItemComponent, never>;
26
- static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationBasicItemComponent, "cmat-vertical-navigation-basic-item", never, { "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
29
+ static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationBasicItemComponent, "cmat-vertical-navigation-basic-item", never, { "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; "editState": { "alias": "editState"; "required": false; }; }, { "editSelectedItemChanged": "editSelectedItemChanged"; }, never, never, true, never>;
27
30
  }
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
1
+ import { ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
2
  import { Router } from '@angular/router';
3
3
  import { BooleanInput } from '@angular/cdk/coercion';
4
4
  import { CmatNavigationService } from '../../../navigation.service';
@@ -12,6 +12,8 @@ export declare class CmatVerticalNavigationCollapsableItemComponent implements O
12
12
  autoCollapse: boolean;
13
13
  item: CmatNavigationItem;
14
14
  name: string;
15
+ editState: boolean;
16
+ readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem>;
15
17
  isCollapsed: boolean;
16
18
  isExpanded: boolean;
17
19
  private _cmatVerticalNavigationComponent;
@@ -48,6 +50,7 @@ export declare class CmatVerticalNavigationCollapsableItemComponent implements O
48
50
  * @param item
49
51
  */
50
52
  trackByFn(index: number, item: any): any;
53
+ selectItem(item: CmatNavigationItem): void;
51
54
  /**
52
55
  * Check if the given item has the given url
53
56
  * in one of its children
@@ -67,5 +70,5 @@ export declare class CmatVerticalNavigationCollapsableItemComponent implements O
67
70
  */
68
71
  private _isChildrenOf;
69
72
  static ɵfac: i0.ɵɵFactoryDeclaration<CmatVerticalNavigationCollapsableItemComponent, never>;
70
- static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationCollapsableItemComponent, "cmat-vertical-navigation-collapsable-item", never, { "autoCollapse": { "alias": "autoCollapse"; "required": false; }; "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
73
+ static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationCollapsableItemComponent, "cmat-vertical-navigation-collapsable-item", never, { "autoCollapse": { "alias": "autoCollapse"; "required": false; }; "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; "editState": { "alias": "editState"; "required": false; }; }, { "editSelectedItemChanged": "editSelectedItemChanged"; }, never, never, true, never>;
71
74
  }
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
1
+ import { ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
2
  import { CmatNavigationService } from '../../../navigation.service';
3
3
  import { CmatNavigationItem } from '../../../navigation.types';
4
4
  import * as i0 from "@angular/core";
@@ -7,6 +7,8 @@ export declare class CmatVerticalNavigationDividerItemComponent implements OnIni
7
7
  private _cmatNavigationService;
8
8
  item: CmatNavigationItem;
9
9
  name: string;
10
+ editState: boolean;
11
+ readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem>;
10
12
  private _cmatVerticalNavigationComponent;
11
13
  private _unsubscribeAll;
12
14
  constructor(_changeDetectorRef: ChangeDetectorRef, _cmatNavigationService: CmatNavigationService);
@@ -18,6 +20,7 @@ export declare class CmatVerticalNavigationDividerItemComponent implements OnIni
18
20
  * On destroy
19
21
  */
20
22
  ngOnDestroy(): void;
23
+ selectItem(item: CmatNavigationItem): void;
21
24
  static ɵfac: i0.ɵɵFactoryDeclaration<CmatVerticalNavigationDividerItemComponent, never>;
22
- static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationDividerItemComponent, "cmat-vertical-navigation-divider-item", never, { "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
25
+ static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationDividerItemComponent, "cmat-vertical-navigation-divider-item", never, { "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; "editState": { "alias": "editState"; "required": false; }; }, { "editSelectedItemChanged": "editSelectedItemChanged"; }, never, never, true, never>;
23
26
  }
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
1
+ import { ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
2
  import { BooleanInput } from '@angular/cdk/coercion';
3
3
  import { CmatNavigationService } from '../../../navigation.service';
4
4
  import { CmatNavigationItem } from '../../../navigation.types';
@@ -10,6 +10,8 @@ export declare class CmatVerticalNavigationGroupItemComponent implements OnInit,
10
10
  autoCollapse: boolean;
11
11
  item: CmatNavigationItem;
12
12
  name: string;
13
+ editState: boolean;
14
+ readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem>;
13
15
  private _cmatVerticalNavigationComponent;
14
16
  private _unsubscribeAll;
15
17
  constructor(_changeDetectorRef: ChangeDetectorRef, _cmatNavigationService: CmatNavigationService);
@@ -28,6 +30,7 @@ export declare class CmatVerticalNavigationGroupItemComponent implements OnInit,
28
30
  * @param item
29
31
  */
30
32
  trackByFn(index: number, item: any): any;
33
+ selectItem(item: CmatNavigationItem): void;
31
34
  static ɵfac: i0.ɵɵFactoryDeclaration<CmatVerticalNavigationGroupItemComponent, never>;
32
- static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationGroupItemComponent, "cmat-vertical-navigation-group-item", never, { "autoCollapse": { "alias": "autoCollapse"; "required": false; }; "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationGroupItemComponent, "cmat-vertical-navigation-group-item", never, { "autoCollapse": { "alias": "autoCollapse"; "required": false; }; "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; "editState": { "alias": "editState"; "required": false; }; }, { "editSelectedItemChanged": "editSelectedItemChanged"; }, never, never, true, never>;
33
36
  }
@@ -1,4 +1,4 @@
1
- import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
1
+ import { ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
2
  import { CmatNavigationService } from '../../../navigation.service';
3
3
  import { CmatNavigationItem } from '../../../navigation.types';
4
4
  import * as i0 from "@angular/core";
@@ -7,6 +7,8 @@ export declare class CmatVerticalNavigationSpacerItemComponent implements OnInit
7
7
  private _cmatNavigationService;
8
8
  item: CmatNavigationItem;
9
9
  name: string;
10
+ editState: boolean;
11
+ readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem>;
10
12
  private _cmatVerticalNavigationComponent;
11
13
  private _unsubscribeAll;
12
14
  constructor(_changeDetectorRef: ChangeDetectorRef, _cmatNavigationService: CmatNavigationService);
@@ -18,6 +20,7 @@ export declare class CmatVerticalNavigationSpacerItemComponent implements OnInit
18
20
  * On destroy
19
21
  */
20
22
  ngOnDestroy(): void;
23
+ selectItem(item: CmatNavigationItem): void;
21
24
  static ɵfac: i0.ɵɵFactoryDeclaration<CmatVerticalNavigationSpacerItemComponent, never>;
22
- static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationSpacerItemComponent, "cmat-vertical-navigation-spacer-item", never, { "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; }, {}, never, never, true, never>;
25
+ static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationSpacerItemComponent, "cmat-vertical-navigation-spacer-item", never, { "item": { "alias": "item"; "required": false; }; "name": { "alias": "name"; "required": false; }; "editState": { "alias": "editState"; "required": false; }; }, { "editSelectedItemChanged": "editSelectedItemChanged"; }, never, never, true, never>;
23
26
  }
@@ -22,6 +22,7 @@ export declare class CmatVerticalNavigationComponent implements OnChanges, OnIni
22
22
  static ngAcceptInputType_transparentOverlay: BooleanInput;
23
23
  appearance: CmatVerticalNavigationAppearance;
24
24
  autoCollapse: boolean;
25
+ editState: boolean;
25
26
  inner: boolean;
26
27
  mode: CmatVerticalNavigationMode;
27
28
  name: string;
@@ -33,6 +34,7 @@ export declare class CmatVerticalNavigationComponent implements OnChanges, OnIni
33
34
  readonly modeChanged: EventEmitter<CmatVerticalNavigationMode>;
34
35
  readonly openedChanged: EventEmitter<boolean>;
35
36
  readonly positionChanged: EventEmitter<CmatVerticalNavigationPosition>;
37
+ readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem>;
36
38
  private _navigationContentEl;
37
39
  activeAsideItemId: string | null;
38
40
  onCollapsableItemCollapsed: ReplaySubject<CmatNavigationItem>;
@@ -125,6 +127,7 @@ export declare class CmatVerticalNavigationComponent implements OnChanges, OnIni
125
127
  * @param item
126
128
  */
127
129
  trackByFn(index: number, item: any): any;
130
+ selectItem(item: CmatNavigationItem): void;
128
131
  /**
129
132
  * Enable the animations
130
133
  *
@@ -169,5 +172,5 @@ export declare class CmatVerticalNavigationComponent implements OnChanges, OnIni
169
172
  */
170
173
  private _toggleOpened;
171
174
  static ɵfac: i0.ɵɵFactoryDeclaration<CmatVerticalNavigationComponent, never>;
172
- static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationComponent, "cmat-vertical-navigation", ["cmatVerticalNavigation"], { "appearance": { "alias": "appearance"; "required": false; }; "autoCollapse": { "alias": "autoCollapse"; "required": false; }; "inner": { "alias": "inner"; "required": false; }; "mode": { "alias": "mode"; "required": false; }; "name": { "alias": "name"; "required": false; }; "navigation": { "alias": "navigation"; "required": false; }; "opened": { "alias": "opened"; "required": false; }; "position": { "alias": "position"; "required": false; }; "transparentOverlay": { "alias": "transparentOverlay"; "required": false; }; }, { "appearanceChanged": "appearanceChanged"; "modeChanged": "modeChanged"; "openedChanged": "openedChanged"; "positionChanged": "positionChanged"; }, never, ["[cmatVerticalNavigationHeader]", "[cmatVerticalNavigationContentHeader]", "[cmatVerticalNavigationContentFooter]", "[cmatVerticalNavigationFooter]"], true, never>;
175
+ static ɵcmp: i0.ɵɵComponentDeclaration<CmatVerticalNavigationComponent, "cmat-vertical-navigation", ["cmatVerticalNavigation"], { "appearance": { "alias": "appearance"; "required": false; }; "autoCollapse": { "alias": "autoCollapse"; "required": false; }; "editState": { "alias": "editState"; "required": false; }; "inner": { "alias": "inner"; "required": false; }; "mode": { "alias": "mode"; "required": false; }; "name": { "alias": "name"; "required": false; }; "navigation": { "alias": "navigation"; "required": false; }; "opened": { "alias": "opened"; "required": false; }; "position": { "alias": "position"; "required": false; }; "transparentOverlay": { "alias": "transparentOverlay"; "required": false; }; }, { "appearanceChanged": "appearanceChanged"; "modeChanged": "modeChanged"; "openedChanged": "openedChanged"; "positionChanged": "positionChanged"; "editSelectedItemChanged": "editSelectedItemChanged"; }, never, ["[cmatVerticalNavigationHeader]", "[cmatVerticalNavigationContentHeader]", "[cmatVerticalNavigationContentFooter]", "[cmatVerticalNavigationFooter]"], true, never>;
173
176
  }
@@ -1,4 +1,4 @@
1
- import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { NavigationEnd } from '@angular/router';
3
3
  import { Subject } from 'rxjs';
4
4
  import { filter, takeUntil } from 'rxjs/operators';
@@ -20,6 +20,8 @@ export class CmatVerticalNavigationAsideItemComponent {
20
20
  this._changeDetectorRef = _changeDetectorRef;
21
21
  this._router = _router;
22
22
  this._cmatNavigationService = _cmatNavigationService;
23
+ this.editState = false;
24
+ this.editSelectedItemChanged = new EventEmitter();
23
25
  this.active = false;
24
26
  this._unsubscribeAll = new Subject();
25
27
  }
@@ -79,6 +81,9 @@ export class CmatVerticalNavigationAsideItemComponent {
79
81
  trackByFn(index, item) {
80
82
  return item.id || index;
81
83
  }
84
+ selectItem(item) {
85
+ this.editSelectedItemChanged.next(item);
86
+ }
82
87
  // -----------------------------------------------------------------------------------------------------
83
88
  // @ Private methods
84
89
  // -----------------------------------------------------------------------------------------------------
@@ -132,13 +137,13 @@ export class CmatVerticalNavigationAsideItemComponent {
132
137
  this._changeDetectorRef.markForCheck();
133
138
  }
134
139
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatVerticalNavigationAsideItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.Router }, { token: i2.CmatNavigationService }], target: i0.ɵɵFactoryTarget.Component }); }
135
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatVerticalNavigationAsideItemComponent, isStandalone: true, selector: "cmat-vertical-navigation-aside-item", inputs: { activeItemId: "activeItemId", autoCollapse: "autoCollapse", item: "item", name: "name", skipChildren: "skipChildren" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n [ngClass]=\"item.classes?.wrapper\">\n\n <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active': active,\r\n 'cmat-vertical-navigation-item-disabled': item.disabled,\r\n 'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\r\n\n <!-- Icon -->\n @if (item.icon) {\n <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n }\n\n <!-- Title & Subtitle -->\n <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n <div class=\"cmat-vertical-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n @if (item.subTitle) {\n <div class=\"cmat-vertical-navigation-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subTitle}}\n </span>\n </div>\n }\n </div>\n\n <!-- Badge -->\n @if (item.badge) {\n <div class=\"cmat-vertical-navigation-item-badge\">\n <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n }\n\n </div>\n\n</div>\n\n@if (!skipChildren) {\n <div class=\"cmat-vertical-navigation-item-children\">\n @for (item of item.children; track trackByFn($index, item)) {\n <!-- Skip the hidden items -->\n @if ((item.hidden && !item.hidden(item)) || !item.hidden) {\n <!-- Basic -->\n @if (item.type === 'basic') {\n <cmat-vertical-navigation-basic-item [item]=\"item\" [name]=\"name\">\n </cmat-vertical-navigation-basic-item>\n }\n <!-- Collapsable -->\n @if (item.type === 'collapsable') {\n <cmat-vertical-navigation-collapsable-item [item]=\"item\" [name]=\"name\"\n [autoCollapse]=\"autoCollapse\"></cmat-vertical-navigation-collapsable-item>\n }\n <!-- Divider -->\n @if (item.type === 'divider') {\n <cmat-vertical-navigation-divider-item [item]=\"item\" [name]=\"name\">\n </cmat-vertical-navigation-divider-item>\n }\n <!-- Group -->\n @if (item.type === 'group') {\n <cmat-vertical-navigation-group-item [item]=\"item\" [name]=\"name\">\n </cmat-vertical-navigation-group-item>\n }\n <!-- Spacer -->\n @if (item.type === 'spacer') {\n <cmat-vertical-navigation-spacer-item [item]=\"item\" [name]=\"name\">\n </cmat-vertical-navigation-spacer-item>\n }\n }\n }\n </div>\n}", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: CmatVerticalNavigationBasicItemComponent, selector: "cmat-vertical-navigation-basic-item", inputs: ["item", "name"] }, { kind: "component", type: CmatVerticalNavigationCollapsableItemComponent, selector: "cmat-vertical-navigation-collapsable-item", inputs: ["autoCollapse", "item", "name"] }, { kind: "component", type: CmatVerticalNavigationDividerItemComponent, selector: "cmat-vertical-navigation-divider-item", inputs: ["item", "name"] }, { kind: "component", type: CmatVerticalNavigationGroupItemComponent, selector: "cmat-vertical-navigation-group-item", inputs: ["autoCollapse", "item", "name"] }, { kind: "component", type: CmatVerticalNavigationSpacerItemComponent, selector: "cmat-vertical-navigation-spacer-item", inputs: ["item", "name"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
140
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatVerticalNavigationAsideItemComponent, isStandalone: true, selector: "cmat-vertical-navigation-aside-item", inputs: { activeItemId: "activeItemId", autoCollapse: "autoCollapse", item: "item", name: "name", skipChildren: "skipChildren", editState: "editState" }, outputs: { editSelectedItemChanged: "editSelectedItemChanged" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n [ngClass]=\"item.classes?.wrapper\" role=\"presentation\" (click)=\"selectItem(item);\">\n\n <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active': active,\n 'cmat-vertical-navigation-item-disabled': item.disabled,\n 'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n\n <!-- Icon -->\n @if (item.icon) {\n <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n }\n\n <!-- Title & Subtitle -->\n <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n <div class=\"cmat-vertical-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n @if (item.subTitle) {\n <div class=\"cmat-vertical-navigation-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subTitle}}\n </span>\n </div>\n }\n </div>\n\n <!-- Badge -->\n @if (item.badge) {\n <div class=\"cmat-vertical-navigation-item-badge\">\n <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n }\n\n </div>\n\n</div>\n\n@if (!skipChildren) {\n <div class=\"cmat-vertical-navigation-item-children\">\n @for (item of item.children; track trackByFn($index, item)) {\n <!-- Skip the hidden items -->\n @if ((item.hidden && !item.hidden(item)) || !item.hidden) {\n <!-- Basic -->\n @if (item.type === 'basic') {\n <cmat-vertical-navigation-basic-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n </cmat-vertical-navigation-basic-item>\n }\n <!-- Collapsable -->\n @if (item.type === 'collapsable') {\n <cmat-vertical-navigation-collapsable-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\"\n [autoCollapse]=\"autoCollapse\"></cmat-vertical-navigation-collapsable-item>\n }\n <!-- Divider -->\n @if (item.type === 'divider') {\n <cmat-vertical-navigation-divider-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n </cmat-vertical-navigation-divider-item>\n }\n <!-- Group -->\n @if (item.type === 'group') {\n <cmat-vertical-navigation-group-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n </cmat-vertical-navigation-group-item>\n }\n <!-- Spacer -->\n @if (item.type === 'spacer') {\n <cmat-vertical-navigation-spacer-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n </cmat-vertical-navigation-spacer-item>\n }\n }\n }\n </div>\n}", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: CmatVerticalNavigationBasicItemComponent, selector: "cmat-vertical-navigation-basic-item", inputs: ["item", "name", "editState"], outputs: ["editSelectedItemChanged"] }, { kind: "component", type: CmatVerticalNavigationCollapsableItemComponent, selector: "cmat-vertical-navigation-collapsable-item", inputs: ["autoCollapse", "item", "name", "editState"], outputs: ["editSelectedItemChanged"] }, { kind: "component", type: CmatVerticalNavigationDividerItemComponent, selector: "cmat-vertical-navigation-divider-item", inputs: ["item", "name", "editState"], outputs: ["editSelectedItemChanged"] }, { kind: "component", type: CmatVerticalNavigationGroupItemComponent, selector: "cmat-vertical-navigation-group-item", inputs: ["autoCollapse", "item", "name", "editState"], outputs: ["editSelectedItemChanged"] }, { kind: "component", type: CmatVerticalNavigationSpacerItemComponent, selector: "cmat-vertical-navigation-spacer-item", inputs: ["item", "name", "editState"], outputs: ["editSelectedItemChanged"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
136
141
  }
137
142
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatVerticalNavigationAsideItemComponent, decorators: [{
138
143
  type: Component,
139
144
  args: [{ selector: 'cmat-vertical-navigation-aside-item', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgClass, MatTooltipModule, MatIconModule, CmatVerticalNavigationBasicItemComponent,
140
145
  CmatVerticalNavigationCollapsableItemComponent, CmatVerticalNavigationDividerItemComponent,
141
- CmatVerticalNavigationGroupItemComponent, CmatVerticalNavigationSpacerItemComponent], template: "<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n [ngClass]=\"item.classes?.wrapper\">\n\n <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active': active,\r\n 'cmat-vertical-navigation-item-disabled': item.disabled,\r\n 'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\r\n\n <!-- Icon -->\n @if (item.icon) {\n <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n }\n\n <!-- Title & Subtitle -->\n <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n <div class=\"cmat-vertical-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n @if (item.subTitle) {\n <div class=\"cmat-vertical-navigation-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subTitle}}\n </span>\n </div>\n }\n </div>\n\n <!-- Badge -->\n @if (item.badge) {\n <div class=\"cmat-vertical-navigation-item-badge\">\n <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n }\n\n </div>\n\n</div>\n\n@if (!skipChildren) {\n <div class=\"cmat-vertical-navigation-item-children\">\n @for (item of item.children; track trackByFn($index, item)) {\n <!-- Skip the hidden items -->\n @if ((item.hidden && !item.hidden(item)) || !item.hidden) {\n <!-- Basic -->\n @if (item.type === 'basic') {\n <cmat-vertical-navigation-basic-item [item]=\"item\" [name]=\"name\">\n </cmat-vertical-navigation-basic-item>\n }\n <!-- Collapsable -->\n @if (item.type === 'collapsable') {\n <cmat-vertical-navigation-collapsable-item [item]=\"item\" [name]=\"name\"\n [autoCollapse]=\"autoCollapse\"></cmat-vertical-navigation-collapsable-item>\n }\n <!-- Divider -->\n @if (item.type === 'divider') {\n <cmat-vertical-navigation-divider-item [item]=\"item\" [name]=\"name\">\n </cmat-vertical-navigation-divider-item>\n }\n <!-- Group -->\n @if (item.type === 'group') {\n <cmat-vertical-navigation-group-item [item]=\"item\" [name]=\"name\">\n </cmat-vertical-navigation-group-item>\n }\n <!-- Spacer -->\n @if (item.type === 'spacer') {\n <cmat-vertical-navigation-spacer-item [item]=\"item\" [name]=\"name\">\n </cmat-vertical-navigation-spacer-item>\n }\n }\n }\n </div>\n}" }]
146
+ CmatVerticalNavigationGroupItemComponent, CmatVerticalNavigationSpacerItemComponent], template: "<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n [ngClass]=\"item.classes?.wrapper\" role=\"presentation\" (click)=\"selectItem(item);\">\n\n <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active': active,\n 'cmat-vertical-navigation-item-disabled': item.disabled,\n 'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n\n <!-- Icon -->\n @if (item.icon) {\n <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n }\n\n <!-- Title & Subtitle -->\n <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n <div class=\"cmat-vertical-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n @if (item.subTitle) {\n <div class=\"cmat-vertical-navigation-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subTitle}}\n </span>\n </div>\n }\n </div>\n\n <!-- Badge -->\n @if (item.badge) {\n <div class=\"cmat-vertical-navigation-item-badge\">\n <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n }\n\n </div>\n\n</div>\n\n@if (!skipChildren) {\n <div class=\"cmat-vertical-navigation-item-children\">\n @for (item of item.children; track trackByFn($index, item)) {\n <!-- Skip the hidden items -->\n @if ((item.hidden && !item.hidden(item)) || !item.hidden) {\n <!-- Basic -->\n @if (item.type === 'basic') {\n <cmat-vertical-navigation-basic-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n </cmat-vertical-navigation-basic-item>\n }\n <!-- Collapsable -->\n @if (item.type === 'collapsable') {\n <cmat-vertical-navigation-collapsable-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\"\n [autoCollapse]=\"autoCollapse\"></cmat-vertical-navigation-collapsable-item>\n }\n <!-- Divider -->\n @if (item.type === 'divider') {\n <cmat-vertical-navigation-divider-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n </cmat-vertical-navigation-divider-item>\n }\n <!-- Group -->\n @if (item.type === 'group') {\n <cmat-vertical-navigation-group-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n </cmat-vertical-navigation-group-item>\n }\n <!-- Spacer -->\n @if (item.type === 'spacer') {\n <cmat-vertical-navigation-spacer-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n </cmat-vertical-navigation-spacer-item>\n }\n }\n }\n </div>\n}" }]
142
147
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.Router }, { type: i2.CmatNavigationService }], propDecorators: { activeItemId: [{
143
148
  type: Input
144
149
  }], autoCollapse: [{
@@ -149,5 +154,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
149
154
  type: Input
150
155
  }], skipChildren: [{
151
156
  type: Input
157
+ }], editState: [{
158
+ type: Input
159
+ }], editSelectedItemChanged: [{
160
+ type: Output
152
161
  }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aside.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cmat/components/navigation/vertical/components/aside/aside.component.ts","../../../../../../../../projects/cmat/components/navigation/vertical/components/aside/aside.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { BooleanInput } from '@angular/cdk/coercion';\r\nimport { Subject } from 'rxjs';\r\nimport { filter, takeUntil } from 'rxjs/operators';\r\nimport { CmatVerticalNavigationComponent } from '../../../vertical/vertical.component';\r\nimport { CmatNavigationService } from '../../../navigation.service';\r\nimport { CmatNavigationItem } from '../../../navigation.types';\r\nimport { CmatVerticalNavigationSpacerItemComponent } from '../spacer/spacer.component';\r\nimport { CmatVerticalNavigationGroupItemComponent } from '../group/group.component';\r\nimport { CmatVerticalNavigationDividerItemComponent } from '../divider/divider.component';\r\nimport { CmatVerticalNavigationCollapsableItemComponent } from '../collapsable/collapsable.component';\r\nimport { CmatVerticalNavigationBasicItemComponent } from '../basic/basic.component';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { NgClass } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'cmat-vertical-navigation-aside-item',\r\n    templateUrl: './aside.component.html',\r\n    styles: [],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [NgClass, MatTooltipModule, MatIconModule, CmatVerticalNavigationBasicItemComponent,\r\n         CmatVerticalNavigationCollapsableItemComponent, CmatVerticalNavigationDividerItemComponent, \r\n         CmatVerticalNavigationGroupItemComponent, CmatVerticalNavigationSpacerItemComponent]\r\n})\r\nexport class CmatVerticalNavigationAsideItemComponent implements OnChanges, OnInit, OnDestroy {\r\n    /* eslint-disable @typescript-eslint/naming-convention */\r\n    static ngAcceptInputType_autoCollapse: BooleanInput;\r\n    static ngAcceptInputType_skipChildren: BooleanInput;\r\n    /* eslint-enable @typescript-eslint/naming-convention */\r\n\r\n    @Input() activeItemId: string | null;\r\n    @Input() autoCollapse: boolean;\r\n    @Input() item: CmatNavigationItem;\r\n    @Input() name: string;\r\n    @Input() skipChildren: boolean;   \r\n\r\n    active: boolean = false;\r\n    private _cmatVerticalNavigationComponent: CmatVerticalNavigationComponent;\r\n    private _unsubscribeAll: Subject<void> = new Subject<void>();\r\n\r\n    constructor(\r\n        private _changeDetectorRef: ChangeDetectorRef,\r\n        private _router: Router,\r\n        private _cmatNavigationService: CmatNavigationService\r\n    ) {\r\n    }\r\n\r\n    // -----------------------------------------------------------------------------------------------------\r\n    // @ Lifecycle hooks\r\n    // -----------------------------------------------------------------------------------------------------\r\n\r\n    /**\r\n     * On changes\r\n     *\r\n     * @param changes\r\n     */\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        // Active item id\r\n        if ('activeItemId' in changes) {\r\n            // Mark if active\r\n            this._markIfActive(this._router.url);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * On init\r\n     */\r\n    ngOnInit(): void {\r\n        // Mark if active\r\n        this._markIfActive(this._router.url);\r\n\r\n        // Attach a listener to the NavigationEnd event\r\n        this._router.events\r\n            .pipe(\r\n                filter((event): event is NavigationEnd => event instanceof NavigationEnd),\r\n                takeUntil(this._unsubscribeAll)\r\n            )\r\n            .subscribe((event: NavigationEnd) => {\r\n\r\n                // Mark if active\r\n                this._markIfActive(event.urlAfterRedirects);\r\n            });\r\n\r\n        // Get the parent navigation component\r\n        this._cmatVerticalNavigationComponent = this._cmatNavigationService.getComponent(this.name);\r\n\r\n        // Subscribe to onRefreshed on the navigation component\r\n        this._cmatVerticalNavigationComponent.onRefreshed.pipe(\r\n            takeUntil(this._unsubscribeAll)\r\n        ).subscribe(() => {\r\n\r\n            // Mark for check\r\n            this._changeDetectorRef.markForCheck();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * On destroy\r\n     */\r\n    ngOnDestroy(): void {\r\n        // Unsubscribe from all subscriptions\r\n        this._unsubscribeAll.next(void 0);\r\n        this._unsubscribeAll.complete();\r\n    }\r\n\r\n    // -----------------------------------------------------------------------------------------------------\r\n    // @ Public methods\r\n    // -----------------------------------------------------------------------------------------------------\r\n\r\n    /**\r\n     * Track by function for ngFor loops\r\n     *\r\n     * @param index\r\n     * @param item\r\n     */\r\n    trackByFn(index: number, item: any): any {\r\n        return item.id || index;\r\n    }\r\n\r\n    // -----------------------------------------------------------------------------------------------------\r\n    // @ Private methods\r\n    // -----------------------------------------------------------------------------------------------------\r\n\r\n    /**\r\n     * Check if the given item has the given url\r\n     * in one of its children\r\n     *\r\n     * @param item\r\n     * @param currentUrl\r\n     * @private\r\n     */\r\n    private _hasActiveChild(item: CmatNavigationItem, currentUrl: string): boolean {\r\n        const children = item.children;\r\n\r\n        if (!children) {\r\n            return false;\r\n        }\r\n\r\n        for (const child of children) {\r\n            if (child.children) {\r\n                if (this._hasActiveChild(child, currentUrl)) {\r\n                    return true;\r\n                }\r\n            }\r\n\r\n            // Skip items other than 'basic'\r\n            if (child.type !== 'basic') {\r\n                continue;\r\n            }\r\n\r\n            // Check if the child has a link and is active\r\n            if (child.link && this._router.isActive(child.link, {\r\n                paths: child.exactMatch || false ? 'exact' : 'subset',\r\n                queryParams: child.exactMatch || false ? 'exact' : 'subset', fragment: 'ignored', matrixParams: 'ignored'\r\n            })) {\r\n                return true;\r\n            }\r\n        }\r\n\r\n        return false;\r\n    }\r\n\r\n    /**\r\n     * Decide and mark if the item is active\r\n     *\r\n     * @private\r\n     */\r\n    private _markIfActive(currentUrl: string): void {\r\n        // Check if the activeItemId is equals to this item id\r\n        this.active = this.activeItemId === this.item.id;\r\n\r\n        // If the aside has a children that is active,\r\n        // always mark it as active\r\n        if (this._hasActiveChild(this.item, currentUrl)) {\r\n            this.active = true;\r\n        }\r\n\r\n        // Mark for check\r\n        this._changeDetectorRef.markForCheck();\r\n    }\r\n}\r\n","<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n  [ngClass]=\"item.classes?.wrapper\">\n\n    <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active': active,\r\n                    'cmat-vertical-navigation-item-disabled': item.disabled,\r\n                    'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\r\n\n    <!-- Icon -->\n    @if (item.icon) {\n      <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n      </mat-icon>\n    }\n\n    <!-- Title & Subtitle -->\n    <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n      <div class=\"cmat-vertical-navigation-item-title\">\n        <span [ngClass]=\"item.classes?.title\">\n          {{item.title}}\n        </span>\n      </div>\n      @if (item.subTitle) {\n        <div class=\"cmat-vertical-navigation-item-subtitle\">\n          <span [ngClass]=\"item.classes?.subtitle\">\n            {{item.subTitle}}\n          </span>\n        </div>\n      }\n    </div>\n\n    <!-- Badge -->\n    @if (item.badge) {\n      <div class=\"cmat-vertical-navigation-item-badge\">\n        <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n          {{item.badge.title}}\n        </div>\n      </div>\n    }\n\n  </div>\n\n</div>\n\n@if (!skipChildren) {\n  <div class=\"cmat-vertical-navigation-item-children\">\n    @for (item of item.children; track trackByFn($index, item)) {\n      <!-- Skip the hidden items -->\n      @if ((item.hidden && !item.hidden(item)) || !item.hidden) {\n        <!-- Basic -->\n        @if (item.type === 'basic') {\n          <cmat-vertical-navigation-basic-item [item]=\"item\" [name]=\"name\">\n          </cmat-vertical-navigation-basic-item>\n        }\n        <!-- Collapsable -->\n        @if (item.type === 'collapsable') {\n          <cmat-vertical-navigation-collapsable-item [item]=\"item\" [name]=\"name\"\n          [autoCollapse]=\"autoCollapse\"></cmat-vertical-navigation-collapsable-item>\n        }\n        <!-- Divider -->\n        @if (item.type === 'divider') {\n          <cmat-vertical-navigation-divider-item [item]=\"item\" [name]=\"name\">\n          </cmat-vertical-navigation-divider-item>\n        }\n        <!-- Group -->\n        @if (item.type === 'group') {\n          <cmat-vertical-navigation-group-item [item]=\"item\" [name]=\"name\">\n          </cmat-vertical-navigation-group-item>\n        }\n        <!-- Spacer -->\n        @if (item.type === 'spacer') {\n          <cmat-vertical-navigation-spacer-item [item]=\"item\" [name]=\"name\">\n          </cmat-vertical-navigation-spacer-item>\n        }\n      }\n    }\n  </div>\n}"]}
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aside.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cmat/components/navigation/vertical/components/aside/aside.component.ts","../../../../../../../../projects/cmat/components/navigation/vertical/components/aside/aside.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { BooleanInput } from '@angular/cdk/coercion';\r\nimport { Subject } from 'rxjs';\r\nimport { filter, takeUntil } from 'rxjs/operators';\r\nimport { CmatVerticalNavigationComponent } from '../../../vertical/vertical.component';\r\nimport { CmatNavigationService } from '../../../navigation.service';\r\nimport { CmatNavigationItem } from '../../../navigation.types';\r\nimport { CmatVerticalNavigationSpacerItemComponent } from '../spacer/spacer.component';\r\nimport { CmatVerticalNavigationGroupItemComponent } from '../group/group.component';\r\nimport { CmatVerticalNavigationDividerItemComponent } from '../divider/divider.component';\r\nimport { CmatVerticalNavigationCollapsableItemComponent } from '../collapsable/collapsable.component';\r\nimport { CmatVerticalNavigationBasicItemComponent } from '../basic/basic.component';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { NgClass } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'cmat-vertical-navigation-aside-item',\r\n    templateUrl: './aside.component.html',\r\n    styles: [],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [NgClass, MatTooltipModule, MatIconModule, CmatVerticalNavigationBasicItemComponent,\r\n         CmatVerticalNavigationCollapsableItemComponent, CmatVerticalNavigationDividerItemComponent, \r\n         CmatVerticalNavigationGroupItemComponent, CmatVerticalNavigationSpacerItemComponent]\r\n})\r\nexport class CmatVerticalNavigationAsideItemComponent implements OnChanges, OnInit, OnDestroy {\r\n    /* eslint-disable @typescript-eslint/naming-convention */\r\n    static ngAcceptInputType_autoCollapse: BooleanInput;\r\n    static ngAcceptInputType_skipChildren: BooleanInput;\r\n    /* eslint-enable @typescript-eslint/naming-convention */\r\n\r\n    @Input() activeItemId: string | null;\r\n    @Input() autoCollapse: boolean;\r\n    @Input() item: CmatNavigationItem;\r\n    @Input() name: string;\r\n    @Input() skipChildren: boolean;   \r\n    @Input() editState: boolean = false;\r\n    @Output() readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem> = new EventEmitter<CmatNavigationItem>();\r\n    \r\n    active: boolean = false;\r\n    private _cmatVerticalNavigationComponent: CmatVerticalNavigationComponent;\r\n    private _unsubscribeAll: Subject<void> = new Subject<void>();\r\n\r\n    constructor(\r\n        private _changeDetectorRef: ChangeDetectorRef,\r\n        private _router: Router,\r\n        private _cmatNavigationService: CmatNavigationService\r\n    ) {\r\n    }\r\n\r\n    // -----------------------------------------------------------------------------------------------------\r\n    // @ Lifecycle hooks\r\n    // -----------------------------------------------------------------------------------------------------\r\n\r\n    /**\r\n     * On changes\r\n     *\r\n     * @param changes\r\n     */\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        // Active item id\r\n        if ('activeItemId' in changes) {\r\n            // Mark if active\r\n            this._markIfActive(this._router.url);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * On init\r\n     */\r\n    ngOnInit(): void {\r\n        // Mark if active\r\n        this._markIfActive(this._router.url);\r\n\r\n        // Attach a listener to the NavigationEnd event\r\n        this._router.events\r\n            .pipe(\r\n                filter((event): event is NavigationEnd => event instanceof NavigationEnd),\r\n                takeUntil(this._unsubscribeAll)\r\n            )\r\n            .subscribe((event: NavigationEnd) => {\r\n\r\n                // Mark if active\r\n                this._markIfActive(event.urlAfterRedirects);\r\n            });\r\n\r\n        // Get the parent navigation component\r\n        this._cmatVerticalNavigationComponent = this._cmatNavigationService.getComponent(this.name);\r\n\r\n        // Subscribe to onRefreshed on the navigation component\r\n        this._cmatVerticalNavigationComponent.onRefreshed.pipe(\r\n            takeUntil(this._unsubscribeAll)\r\n        ).subscribe(() => {\r\n\r\n            // Mark for check\r\n            this._changeDetectorRef.markForCheck();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * On destroy\r\n     */\r\n    ngOnDestroy(): void {\r\n        // Unsubscribe from all subscriptions\r\n        this._unsubscribeAll.next(void 0);\r\n        this._unsubscribeAll.complete();\r\n    }\r\n\r\n    // -----------------------------------------------------------------------------------------------------\r\n    // @ Public methods\r\n    // -----------------------------------------------------------------------------------------------------\r\n\r\n    /**\r\n     * Track by function for ngFor loops\r\n     *\r\n     * @param index\r\n     * @param item\r\n     */\r\n    trackByFn(index: number, item: any): any {\r\n        return item.id || index;\r\n    }\r\n\r\n    selectItem(item: CmatNavigationItem): void {\r\n        this.editSelectedItemChanged.next(item);\r\n    }\r\n    // -----------------------------------------------------------------------------------------------------\r\n    // @ Private methods\r\n    // -----------------------------------------------------------------------------------------------------\r\n\r\n    /**\r\n     * Check if the given item has the given url\r\n     * in one of its children\r\n     *\r\n     * @param item\r\n     * @param currentUrl\r\n     * @private\r\n     */\r\n    private _hasActiveChild(item: CmatNavigationItem, currentUrl: string): boolean {\r\n        const children = item.children;\r\n\r\n        if (!children) {\r\n            return false;\r\n        }\r\n\r\n        for (const child of children) {\r\n            if (child.children) {\r\n                if (this._hasActiveChild(child, currentUrl)) {\r\n                    return true;\r\n                }\r\n            }\r\n\r\n            // Skip items other than 'basic'\r\n            if (child.type !== 'basic') {\r\n                continue;\r\n            }\r\n\r\n            // Check if the child has a link and is active\r\n            if (child.link && this._router.isActive(child.link, {\r\n                paths: child.exactMatch || false ? 'exact' : 'subset',\r\n                queryParams: child.exactMatch || false ? 'exact' : 'subset', fragment: 'ignored', matrixParams: 'ignored'\r\n            })) {\r\n                return true;\r\n            }\r\n        }\r\n\r\n        return false;\r\n    }\r\n\r\n    /**\r\n     * Decide and mark if the item is active\r\n     *\r\n     * @private\r\n     */\r\n    private _markIfActive(currentUrl: string): void {\r\n        // Check if the activeItemId is equals to this item id\r\n        this.active = this.activeItemId === this.item.id;\r\n\r\n        // If the aside has a children that is active,\r\n        // always mark it as active\r\n        if (this._hasActiveChild(this.item, currentUrl)) {\r\n            this.active = true;\r\n        }\r\n\r\n        // Mark for check\r\n        this._changeDetectorRef.markForCheck();\r\n    }\r\n}\r\n","<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n  [ngClass]=\"item.classes?.wrapper\" role=\"presentation\" (click)=\"selectItem(item);\">\n\n    <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active': active,\n                    'cmat-vertical-navigation-item-disabled': item.disabled,\n                    'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n\n    <!-- Icon -->\n    @if (item.icon) {\n      <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n      </mat-icon>\n    }\n\n    <!-- Title & Subtitle -->\n    <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n      <div class=\"cmat-vertical-navigation-item-title\">\n        <span [ngClass]=\"item.classes?.title\">\n          {{item.title}}\n        </span>\n      </div>\n      @if (item.subTitle) {\n        <div class=\"cmat-vertical-navigation-item-subtitle\">\n          <span [ngClass]=\"item.classes?.subtitle\">\n            {{item.subTitle}}\n          </span>\n        </div>\n      }\n    </div>\n\n    <!-- Badge -->\n    @if (item.badge) {\n      <div class=\"cmat-vertical-navigation-item-badge\">\n        <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n          {{item.badge.title}}\n        </div>\n      </div>\n    }\n\n  </div>\n\n</div>\n\n@if (!skipChildren) {\n  <div class=\"cmat-vertical-navigation-item-children\">\n    @for (item of item.children; track trackByFn($index, item)) {\n      <!-- Skip the hidden items -->\n      @if ((item.hidden && !item.hidden(item)) || !item.hidden) {\n        <!-- Basic -->\n        @if (item.type === 'basic') {\n          <cmat-vertical-navigation-basic-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n          </cmat-vertical-navigation-basic-item>\n        }\n        <!-- Collapsable -->\n        @if (item.type === 'collapsable') {\n          <cmat-vertical-navigation-collapsable-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\"\n          [autoCollapse]=\"autoCollapse\"></cmat-vertical-navigation-collapsable-item>\n        }\n        <!-- Divider -->\n        @if (item.type === 'divider') {\n          <cmat-vertical-navigation-divider-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n          </cmat-vertical-navigation-divider-item>\n        }\n        <!-- Group -->\n        @if (item.type === 'group') {\n          <cmat-vertical-navigation-group-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n          </cmat-vertical-navigation-group-item>\n        }\n        <!-- Spacer -->\n        @if (item.type === 'spacer') {\n          <cmat-vertical-navigation-spacer-item [item]=\"item\" [name]=\"name\" [editState]=\"editState\" (editSelectedItemChanged)=\"selectItem($event)\">\n          </cmat-vertical-navigation-spacer-item>\n        }\n      }\n    }\n  </div>\n}"]}
@@ -1,4 +1,4 @@
1
- import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { RouterLink, RouterLinkActive } from '@angular/router';
3
3
  import { Subject } from 'rxjs';
4
4
  import { takeUntil } from 'rxjs/operators';
@@ -15,6 +15,8 @@ export class CmatVerticalNavigationBasicItemComponent {
15
15
  this._changeDetectorRef = _changeDetectorRef;
16
16
  this._cmatNavigationService = _cmatNavigationService;
17
17
  this._cmatUtilsService = _cmatUtilsService;
18
+ this.editState = false;
19
+ this.editSelectedItemChanged = new EventEmitter();
18
20
  this._unsubscribeAll = new Subject();
19
21
  // Set the equivalent of {exact: false} as default for active match options.
20
22
  // We are not assigning the item.isActiveMatchOptions directly to the
@@ -54,15 +56,22 @@ export class CmatVerticalNavigationBasicItemComponent {
54
56
  this._unsubscribeAll.next(void 0);
55
57
  this._unsubscribeAll.complete();
56
58
  }
59
+ selectItem() {
60
+ this.editSelectedItemChanged.next(this.item);
61
+ }
57
62
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatVerticalNavigationBasicItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.CmatNavigationService }, { token: i2.CmatUtilsService }], target: i0.ɵɵFactoryTarget.Component }); }
58
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatVerticalNavigationBasicItemComponent, isStandalone: true, selector: "cmat-vertical-navigation-basic-item", inputs: { item: "item", name: "name" }, ngImport: i0, template: "<!-- Item wrapper -->\n<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n [ngClass]=\"item.classes?.wrapper\">\n\n <!-- Item with an internal link -->\n @if (item.link && !item.externalLink && !item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with an external link -->\n @if (item.link && item.externalLink && !item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with a function -->\n @if (!item.link && item.function && !item.disabled) {\n <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n <!-- Item with an internal link and function -->\n @if (item.link && !item.externalLink && item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with an external link and function -->\n @if (item.link && item.externalLink && item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with a no link and no function -->\n @if (!item.link && !item.function && !item.disabled) {\n <div class=\"cmat-vertical-navigation-item\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n <!-- Item is disabled -->\n @if (item.disabled) {\n <div class=\"cmat-vertical-navigation-item cmat-vertical-navigation-item-disabled\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n <!-- Icon -->\n @if (item.icon) {\n <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n }\n\n <!-- Title & Subtitle -->\n <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n <div class=\"cmat-vertical-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n @if (item.subTitle) {\n <div class=\"cmat-vertical-navigation-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subTitle}}\n </span>\n </div>\n }\n </div>\n\n <!-- Badge -->\n @if (item.badge) {\n <div class=\"cmat-vertical-navigation-item-badge\">\n <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n }\n</ng-template>", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
63
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatVerticalNavigationBasicItemComponent, isStandalone: true, selector: "cmat-vertical-navigation-basic-item", inputs: { item: "item", name: "name", editState: "editState" }, outputs: { editSelectedItemChanged: "editSelectedItemChanged" }, ngImport: i0, template: "<!-- Item wrapper -->\n<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n [ngClass]=\"item.classes?.wrapper\">\n\n @if(editState){\n <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n (click)=\"selectItem()\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }@else{\n <!-- Item with an internal link -->\n @if (item.link && !item.externalLink && !item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n [routerLink]=\"[item.link]\" [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\"\n [routerLinkActiveOptions]=\"isActiveMatchOptions\" [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with an external link -->\n @if (item.link && item.externalLink && !item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with a function -->\n @if (!item.link && item.function && !item.disabled) {\n <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n <!-- Item with an internal link and function -->\n @if (item.link && !item.externalLink && item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n [routerLink]=\"[item.link]\" [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\"\n [routerLinkActiveOptions]=\"isActiveMatchOptions\" [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with an external link and function -->\n @if (item.link && item.externalLink && item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with a no link and no function -->\n @if (!item.link && !item.function && !item.disabled) {\n <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n <!-- Item is disabled -->\n @if (item.disabled) {\n <div class=\"cmat-vertical-navigation-item cmat-vertical-navigation-item-disabled\" [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n }\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n <!-- Icon -->\n @if (item.icon) {\n <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n }\n\n <!-- Title & Subtitle -->\n <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n <div class=\"cmat-vertical-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n @if (item.subTitle) {\n <div class=\"cmat-vertical-navigation-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subTitle}}\n </span>\n </div>\n }\n </div>\n\n <!-- Badge -->\n @if (item.badge) {\n <div class=\"cmat-vertical-navigation-item-badge\">\n <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n }\n</ng-template>", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
59
64
  }
60
65
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatVerticalNavigationBasicItemComponent, decorators: [{
61
66
  type: Component,
62
- args: [{ selector: 'cmat-vertical-navigation-basic-item', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgClass, RouterLink, RouterLinkActive, MatTooltipModule, NgTemplateOutlet, MatIconModule], template: "<!-- Item wrapper -->\n<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n [ngClass]=\"item.classes?.wrapper\">\n\n <!-- Item with an internal link -->\n @if (item.link && !item.externalLink && !item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with an external link -->\n @if (item.link && item.externalLink && !item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with a function -->\n @if (!item.link && item.function && !item.disabled) {\n <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n <!-- Item with an internal link and function -->\n @if (item.link && !item.externalLink && item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with an external link and function -->\n @if (item.link && item.externalLink && item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with a no link and no function -->\n @if (!item.link && !item.function && !item.disabled) {\n <div class=\"cmat-vertical-navigation-item\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n <!-- Item is disabled -->\n @if (item.disabled) {\n <div class=\"cmat-vertical-navigation-item cmat-vertical-navigation-item-disabled\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n <!-- Icon -->\n @if (item.icon) {\n <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n }\n\n <!-- Title & Subtitle -->\n <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n <div class=\"cmat-vertical-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n @if (item.subTitle) {\n <div class=\"cmat-vertical-navigation-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subTitle}}\n </span>\n </div>\n }\n </div>\n\n <!-- Badge -->\n @if (item.badge) {\n <div class=\"cmat-vertical-navigation-item-badge\">\n <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n }\n</ng-template>" }]
67
+ args: [{ selector: 'cmat-vertical-navigation-basic-item', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgClass, RouterLink, RouterLinkActive, MatTooltipModule, NgTemplateOutlet, MatIconModule], template: "<!-- Item wrapper -->\n<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n [ngClass]=\"item.classes?.wrapper\">\n\n @if(editState){\n <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n (click)=\"selectItem()\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }@else{\n <!-- Item with an internal link -->\n @if (item.link && !item.externalLink && !item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n [routerLink]=\"[item.link]\" [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\"\n [routerLinkActiveOptions]=\"isActiveMatchOptions\" [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with an external link -->\n @if (item.link && item.externalLink && !item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with a function -->\n @if (!item.link && item.function && !item.disabled) {\n <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n <!-- Item with an internal link and function -->\n @if (item.link && !item.externalLink && item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n [routerLink]=\"[item.link]\" [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\"\n [routerLinkActiveOptions]=\"isActiveMatchOptions\" [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with an external link and function -->\n @if (item.link && item.externalLink && item.function && !item.disabled) {\n <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n }\n\n <!-- Item with a no link and no function -->\n @if (!item.link && !item.function && !item.disabled) {\n <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n\n <!-- Item is disabled -->\n @if (item.disabled) {\n <div class=\"cmat-vertical-navigation-item cmat-vertical-navigation-item-disabled\" [matTooltip]=\"item.tooltip || ''\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n }\n }\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n <!-- Icon -->\n @if (item.icon) {\n <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n </mat-icon>\n }\n\n <!-- Title & Subtitle -->\n <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n <div class=\"cmat-vertical-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{item.title}}\n </span>\n </div>\n @if (item.subTitle) {\n <div class=\"cmat-vertical-navigation-item-subtitle\">\n <span [ngClass]=\"item.classes?.subtitle\">\n {{item.subTitle}}\n </span>\n </div>\n }\n </div>\n\n <!-- Badge -->\n @if (item.badge) {\n <div class=\"cmat-vertical-navigation-item-badge\">\n <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n {{item.badge.title}}\n </div>\n </div>\n }\n</ng-template>" }]
63
68
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.CmatNavigationService }, { type: i2.CmatUtilsService }], propDecorators: { item: [{
64
69
  type: Input
65
70
  }], name: [{
66
71
  type: Input
72
+ }], editState: [{
73
+ type: Input
74
+ }], editSelectedItemChanged: [{
75
+ type: Output
67
76
  }] } });
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cmat/components/navigation/vertical/components/basic/basic.component.ts","../../../../../../../../projects/cmat/components/navigation/vertical/components/basic/basic.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAChH,OAAO,EAAwB,UAAU,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACrF,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAK3C,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;;;;;;AAU5D,MAAM,OAAO,wCAAwC;IAQjD,YACY,kBAAqC,EACrC,sBAA6C,EAC7C,iBAAmC;QAFnC,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,2BAAsB,GAAtB,sBAAsB,CAAuB;QAC7C,sBAAiB,GAAjB,iBAAiB,CAAkB;QALvC,oBAAe,GAAkB,IAAI,OAAO,EAAQ,CAAC;QAOzD,4EAA4E;QAC5E,qEAAqE;QACrE,8EAA8E;QAC9E,wCAAwC;QACxC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC;IAC1E,CAAC;IAED,wGAAwG;IACxG,oBAAoB;IACpB,wGAAwG;IAExG;;OAEG;IACH,QAAQ;QACJ,oDAAoD;QACpD,mDAAmD;QACnD,6BAA6B;QAC7B,IAAI,CAAC,oBAAoB;YACrB,IAAI,CAAC,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU;gBAClD,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,iBAAiB;gBAC1C,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC;QAEpD,sCAAsC;QACtC,IAAI,CAAC,gCAAgC,GAAG,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE5F,iBAAiB;QACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QAEvC,uDAAuD;QACvD,IAAI,CAAC,gCAAgC,CAAC,WAAW,CAAC,IAAI,CAClD,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAClC,CAAC,SAAS,CAAC,GAAG,EAAE;YAEb,iBAAiB;YACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QAC3C,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACH,WAAW;QACP,qCAAqC;QACrC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;8GA3DQ,wCAAwC;kGAAxC,wCAAwC,uICpBrD,6/HAoGc,4CDlFA,OAAO,oFAAE,UAAU,oOAAE,gBAAgB,6MAAE,gBAAgB,6TAAE,gBAAgB,mJAAE,aAAa;;2FAEzF,wCAAwC;kBARpD,SAAS;+BACI,qCAAqC,mBAG9B,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,aAAa,CAAC;yJAG1F,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { IsActiveMatchOptions, RouterLink, RouterLinkActive } from '@angular/router';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { CmatVerticalNavigationComponent } from '../../../vertical/vertical.component';\r\nimport { CmatNavigationService } from '../../../navigation.service';\r\nimport { CmatNavigationItem } from '../../../navigation.types';\r\nimport { CmatUtilsService } from 'cmat/services/utils';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'cmat-vertical-navigation-basic-item',\r\n    templateUrl: './basic.component.html',\r\n    styles: [],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [NgClass, RouterLink, RouterLinkActive, MatTooltipModule, NgTemplateOutlet, MatIconModule]\r\n})\r\nexport class CmatVerticalNavigationBasicItemComponent implements OnInit, OnDestroy {\r\n    @Input() item: CmatNavigationItem;\r\n    @Input() name: string;\r\n\r\n    isActiveMatchOptions: IsActiveMatchOptions;\r\n    private _cmatVerticalNavigationComponent: CmatVerticalNavigationComponent;\r\n    private _unsubscribeAll: Subject<void> = new Subject<void>();\r\n\r\n    constructor(\r\n        private _changeDetectorRef: ChangeDetectorRef,\r\n        private _cmatNavigationService: CmatNavigationService,\r\n        private _cmatUtilsService: CmatUtilsService\r\n    ) {\r\n        // Set the equivalent of {exact: false} as default for active match options.\r\n        // We are not assigning the item.isActiveMatchOptions directly to the\r\n        // [routerLinkActiveOptions] because if it's \"undefined\" initially, the router\r\n        // will throw an error and stop working.\r\n        this.isActiveMatchOptions = this._cmatUtilsService.subsetMatchOptions;\r\n    }\r\n\r\n    // -----------------------------------------------------------------------------------------------------\r\n    // @ Lifecycle hooks\r\n    // -----------------------------------------------------------------------------------------------------\r\n\r\n    /**\r\n     * On init\r\n     */\r\n    ngOnInit(): void {\r\n        // Set the \"isActiveMatchOptions\" either from item's\r\n        // \"isActiveMatchOptions\" or the equivalent form of\r\n        // item's \"exactMatch\" option\r\n        this.isActiveMatchOptions =\r\n            this.item.isActiveMatchOptions ?? this.item.exactMatch\r\n                ? this._cmatUtilsService.exactMatchOptions\r\n                : this._cmatUtilsService.subsetMatchOptions;\r\n\r\n        // Get the parent navigation component\r\n        this._cmatVerticalNavigationComponent = this._cmatNavigationService.getComponent(this.name);\r\n\r\n        // Mark for check\r\n        this._changeDetectorRef.markForCheck();\r\n\r\n        // Subscribe to onRefreshed on the navigation component\r\n        this._cmatVerticalNavigationComponent.onRefreshed.pipe(\r\n            takeUntil(this._unsubscribeAll)\r\n        ).subscribe(() => {\r\n\r\n            // Mark for check\r\n            this._changeDetectorRef.markForCheck();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * On destroy\r\n     */\r\n    ngOnDestroy(): void {\r\n        // Unsubscribe from all subscriptions\r\n        this._unsubscribeAll.next(void 0);\r\n        this._unsubscribeAll.complete();\r\n    }\r\n}\r\n","<!-- Item wrapper -->\n<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n  [ngClass]=\"item.classes?.wrapper\">\n\n  <!-- Item with an internal link -->\n  @if (item.link && !item.externalLink && !item.function && !item.disabled) {\n    <a class=\"cmat-vertical-navigation-item\"\n      [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n      [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n      [matTooltip]=\"item.tooltip || ''\">\n      <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </a>\n  }\n\n  <!-- Item with an external link -->\n  @if (item.link && item.externalLink && !item.function && !item.disabled) {\n    <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n      [matTooltip]=\"item.tooltip || ''\">\n      <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </a>\n  }\n\n  <!-- Item with a function -->\n  @if (!item.link && item.function && !item.disabled) {\n    <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n      [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n      (click)=\"item.function(item)\">\n      <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n  }\n\n  <!-- Item with an internal link and function -->\n  @if (item.link && !item.externalLink && item.function && !item.disabled) {\n    <a class=\"cmat-vertical-navigation-item\"\n      [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [routerLink]=\"[item.link]\"\n      [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\" [routerLinkActiveOptions]=\"isActiveMatchOptions\"\n      [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n      <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </a>\n  }\n\n  <!-- Item with an external link and function -->\n  @if (item.link && item.externalLink && item.function && !item.disabled) {\n    <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n      [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n      <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </a>\n  }\n\n  <!-- Item with a no link and no function -->\n  @if (!item.link && !item.function && !item.disabled) {\n    <div class=\"cmat-vertical-navigation-item\"\n      [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\">\n      <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n  }\n\n  <!-- Item is disabled -->\n  @if (item.disabled) {\n    <div class=\"cmat-vertical-navigation-item cmat-vertical-navigation-item-disabled\"\n      [matTooltip]=\"item.tooltip || ''\">\n      <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n  }\n\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n  <!-- Icon -->\n  @if (item.icon) {\n    <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n    </mat-icon>\n  }\n\n  <!-- Title & Subtitle -->\n  <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n    <div class=\"cmat-vertical-navigation-item-title\">\n      <span [ngClass]=\"item.classes?.title\">\n        {{item.title}}\n      </span>\n    </div>\n    @if (item.subTitle) {\n      <div class=\"cmat-vertical-navigation-item-subtitle\">\n        <span [ngClass]=\"item.classes?.subtitle\">\n          {{item.subTitle}}\n        </span>\n      </div>\n    }\n  </div>\n\n  <!-- Badge -->\n  @if (item.badge) {\n    <div class=\"cmat-vertical-navigation-item-badge\">\n      <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n        {{item.badge.title}}\n      </div>\n    </div>\n  }\n</ng-template>"]}
77
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic.component.js","sourceRoot":"","sources":["../../../../../../../../projects/cmat/components/navigation/vertical/components/basic/basic.component.ts","../../../../../../../../projects/cmat/components/navigation/vertical/components/basic/basic.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAE,MAAM,eAAe,CAAC;AACtI,OAAO,EAAwB,UAAU,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACrF,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAK3C,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;;;;;;AAU5D,MAAM,OAAO,wCAAwC;IAUjD,YACY,kBAAqC,EACrC,sBAA6C,EAC7C,iBAAmC;QAFnC,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,2BAAsB,GAAtB,sBAAsB,CAAuB;QAC7C,sBAAiB,GAAjB,iBAAiB,CAAkB;QAVtC,cAAS,GAAY,KAAK,CAAC;QACjB,4BAAuB,GAAqC,IAAI,YAAY,EAAsB,CAAC;QAI9G,oBAAe,GAAkB,IAAI,OAAO,EAAQ,CAAC;QAOzD,4EAA4E;QAC5E,qEAAqE;QACrE,8EAA8E;QAC9E,wCAAwC;QACxC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC;IAC1E,CAAC;IAED,wGAAwG;IACxG,oBAAoB;IACpB,wGAAwG;IAExG;;OAEG;IACH,QAAQ;QACJ,oDAAoD;QACpD,mDAAmD;QACnD,6BAA6B;QAC7B,IAAI,CAAC,oBAAoB;YACrB,IAAI,CAAC,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU;gBAClD,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,iBAAiB;gBAC1C,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC;QAEpD,sCAAsC;QACtC,IAAI,CAAC,gCAAgC,GAAG,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE5F,iBAAiB;QACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QAEvC,uDAAuD;QACvD,IAAI,CAAC,gCAAgC,CAAC,WAAW,CAAC,IAAI,CAClD,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAClC,CAAC,SAAS,CAAC,GAAG,EAAE;YAEb,iBAAiB;YACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QAC3C,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACH,WAAW;QACP,qCAAqC;QACrC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAED,UAAU;QACN,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjD,CAAC;8GAjEQ,wCAAwC;kGAAxC,wCAAwC,gOCpBrD,8tIAwGc,4CDtFA,OAAO,oFAAE,UAAU,oOAAE,gBAAgB,6MAAE,gBAAgB,6TAAE,gBAAgB,mJAAE,aAAa;;2FAEzF,wCAAwC;kBARpD,SAAS;+BACI,qCAAqC,mBAG9B,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,aAAa,CAAC;yJAG1F,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACa,uBAAuB;sBAAzC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { IsActiveMatchOptions, RouterLink, RouterLinkActive } from '@angular/router';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { CmatVerticalNavigationComponent } from '../../../vertical/vertical.component';\r\nimport { CmatNavigationService } from '../../../navigation.service';\r\nimport { CmatNavigationItem } from '../../../navigation.types';\r\nimport { CmatUtilsService } from 'cmat/services/utils';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'cmat-vertical-navigation-basic-item',\r\n    templateUrl: './basic.component.html',\r\n    styles: [],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [NgClass, RouterLink, RouterLinkActive, MatTooltipModule, NgTemplateOutlet, MatIconModule]\r\n})\r\nexport class CmatVerticalNavigationBasicItemComponent implements OnInit, OnDestroy {\r\n    @Input() item: CmatNavigationItem;\r\n    @Input() name: string;\r\n    @Input() editState: boolean = false;\r\n    @Output() readonly editSelectedItemChanged: EventEmitter<CmatNavigationItem> = new EventEmitter<CmatNavigationItem>();\r\n    \r\n    isActiveMatchOptions: IsActiveMatchOptions;\r\n    private _cmatVerticalNavigationComponent: CmatVerticalNavigationComponent;\r\n    private _unsubscribeAll: Subject<void> = new Subject<void>();\r\n\r\n    constructor(\r\n        private _changeDetectorRef: ChangeDetectorRef,\r\n        private _cmatNavigationService: CmatNavigationService,\r\n        private _cmatUtilsService: CmatUtilsService\r\n    ) {\r\n        // Set the equivalent of {exact: false} as default for active match options.\r\n        // We are not assigning the item.isActiveMatchOptions directly to the\r\n        // [routerLinkActiveOptions] because if it's \"undefined\" initially, the router\r\n        // will throw an error and stop working.\r\n        this.isActiveMatchOptions = this._cmatUtilsService.subsetMatchOptions;\r\n    }\r\n\r\n    // -----------------------------------------------------------------------------------------------------\r\n    // @ Lifecycle hooks\r\n    // -----------------------------------------------------------------------------------------------------\r\n\r\n    /**\r\n     * On init\r\n     */\r\n    ngOnInit(): void {\r\n        // Set the \"isActiveMatchOptions\" either from item's\r\n        // \"isActiveMatchOptions\" or the equivalent form of\r\n        // item's \"exactMatch\" option\r\n        this.isActiveMatchOptions =\r\n            this.item.isActiveMatchOptions ?? this.item.exactMatch\r\n                ? this._cmatUtilsService.exactMatchOptions\r\n                : this._cmatUtilsService.subsetMatchOptions;\r\n\r\n        // Get the parent navigation component\r\n        this._cmatVerticalNavigationComponent = this._cmatNavigationService.getComponent(this.name);\r\n\r\n        // Mark for check\r\n        this._changeDetectorRef.markForCheck();\r\n\r\n        // Subscribe to onRefreshed on the navigation component\r\n        this._cmatVerticalNavigationComponent.onRefreshed.pipe(\r\n            takeUntil(this._unsubscribeAll)\r\n        ).subscribe(() => {\r\n\r\n            // Mark for check\r\n            this._changeDetectorRef.markForCheck();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * On destroy\r\n     */\r\n    ngOnDestroy(): void {\r\n        // Unsubscribe from all subscriptions\r\n        this._unsubscribeAll.next(void 0);\r\n        this._unsubscribeAll.complete();\r\n    }\r\n\r\n    selectItem(): void {\r\n        this.editSelectedItemChanged.next(this.item);\r\n    }\r\n}\r\n","<!-- Item wrapper -->\n<div class=\"cmat-vertical-navigation-item-wrapper\" [class.cmat-vertical-navigation-item-has-subtitle]=\"!!item.subTitle\"\n  [ngClass]=\"item.classes?.wrapper\">\n\n  @if(editState){\n  <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n    [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n    (click)=\"selectItem()\">\n    <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n  </div>\n  }@else{\n  <!-- Item with an internal link -->\n  @if (item.link && !item.externalLink && !item.function && !item.disabled) {\n  <a class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n    [routerLink]=\"[item.link]\" [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\"\n    [routerLinkActiveOptions]=\"isActiveMatchOptions\" [matTooltip]=\"item.tooltip || ''\">\n    <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n  </a>\n  }\n\n  <!-- Item with an external link -->\n  @if (item.link && item.externalLink && !item.function && !item.disabled) {\n  <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n    [matTooltip]=\"item.tooltip || ''\">\n    <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n  </a>\n  }\n\n  <!-- Item with a function -->\n  @if (!item.link && item.function && !item.disabled) {\n  <div class=\"cmat-vertical-navigation-item\" role=\"presentation\"\n    [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\" [matTooltip]=\"item.tooltip || ''\"\n    (click)=\"item.function(item)\">\n    <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n  </div>\n  }\n\n  <!-- Item with an internal link and function -->\n  @if (item.link && !item.externalLink && item.function && !item.disabled) {\n  <a class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n    [routerLink]=\"[item.link]\" [routerLinkActive]=\"'cmat-vertical-navigation-item-active'\"\n    [routerLinkActiveOptions]=\"isActiveMatchOptions\" [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n    <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n  </a>\n  }\n\n  <!-- Item with an external link and function -->\n  @if (item.link && item.externalLink && item.function && !item.disabled) {\n  <a class=\"cmat-vertical-navigation-item\" [href]=\"item.link\" [target]=\"item.target || '_blank'\"\n    [matTooltip]=\"item.tooltip || ''\" (click)=\"item.function(item)\">\n    <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n  </a>\n  }\n\n  <!-- Item with a no link and no function -->\n  @if (!item.link && !item.function && !item.disabled) {\n  <div class=\"cmat-vertical-navigation-item\" [ngClass]=\"{'cmat-vertical-navigation-item-active-forced': item.active}\"\n    [matTooltip]=\"item.tooltip || ''\">\n    <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n  </div>\n  }\n\n  <!-- Item is disabled -->\n  @if (item.disabled) {\n  <div class=\"cmat-vertical-navigation-item cmat-vertical-navigation-item-disabled\" [matTooltip]=\"item.tooltip || ''\">\n    <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n  </div>\n  }\n  }\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n\n  <!-- Icon -->\n  @if (item.icon) {\n  <mat-icon class=\"cmat-vertical-navigation-item-icon\" [ngClass]=\"item.classes?.icon\" [svgIcon]=\"item.icon\">\n  </mat-icon>\n  }\n\n  <!-- Title & Subtitle -->\n  <div class=\"cmat-vertical-navigation-item-title-wrapper\">\n    <div class=\"cmat-vertical-navigation-item-title\">\n      <span [ngClass]=\"item.classes?.title\">\n        {{item.title}}\n      </span>\n    </div>\n    @if (item.subTitle) {\n    <div class=\"cmat-vertical-navigation-item-subtitle\">\n      <span [ngClass]=\"item.classes?.subtitle\">\n        {{item.subTitle}}\n      </span>\n    </div>\n    }\n  </div>\n\n  <!-- Badge -->\n  @if (item.badge) {\n  <div class=\"cmat-vertical-navigation-item-badge\">\n    <div class=\"cmat-vertical-navigation-item-badge-content\" [ngClass]=\"item.badge.classes\">\n      {{item.badge.title}}\n    </div>\n  </div>\n  }\n</ng-template>"]}