cmat 0.0.4 → 0.0.6

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 (25) hide show
  1. package/components/chip-input/chip-input.component.d.ts +3 -1
  2. package/components/navigation/vertical/components/aside/aside.component.d.ts +5 -2
  3. package/components/navigation/vertical/components/basic/basic.component.d.ts +5 -2
  4. package/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +5 -2
  5. package/components/navigation/vertical/components/divider/divider.component.d.ts +5 -2
  6. package/components/navigation/vertical/components/group/group.component.d.ts +5 -2
  7. package/components/navigation/vertical/components/spacer/spacer.component.d.ts +5 -2
  8. package/components/navigation/vertical/vertical.component.d.ts +4 -1
  9. package/esm2022/components/chip-input/chip-input.component.mjs +10 -4
  10. package/esm2022/components/navigation/vertical/components/aside/aside.component.mjs +13 -4
  11. package/esm2022/components/navigation/vertical/components/basic/basic.component.mjs +13 -4
  12. package/esm2022/components/navigation/vertical/components/collapsable/collapsable.component.mjs +13 -4
  13. package/esm2022/components/navigation/vertical/components/divider/divider.component.mjs +13 -4
  14. package/esm2022/components/navigation/vertical/components/group/group.component.mjs +13 -4
  15. package/esm2022/components/navigation/vertical/components/spacer/spacer.component.mjs +13 -4
  16. package/esm2022/components/navigation/vertical/vertical.component.mjs +12 -3
  17. package/esm2022/services/config/urlStateConfig.service.mjs +2 -2
  18. package/fesm2022/cmat-components-chip-input.mjs +9 -3
  19. package/fesm2022/cmat-components-chip-input.mjs.map +1 -1
  20. package/fesm2022/cmat-components-navigation.mjs +78 -15
  21. package/fesm2022/cmat-components-navigation.mjs.map +1 -1
  22. package/fesm2022/cmat-services-config.mjs +1 -1
  23. package/fesm2022/cmat-services-config.mjs.map +1 -1
  24. package/package.json +72 -72
  25. package/services/config/urlStateConfig.service.d.ts +1 -1
@@ -11,6 +11,8 @@ export declare class CmatChipInputComponent implements ControlValueAccessor, OnD
11
11
  hasAutocomplete: boolean;
12
12
  outputIsString: boolean;
13
13
  separatorKey: string;
14
+ hasPrefixIcon: boolean;
15
+ prefixIcon: string;
14
16
  inputControl: FormControl<string | null>;
15
17
  filteredOptions$: Observable<string[] | null>;
16
18
  selectedOptions$: BehaviorSubject<any>;
@@ -30,5 +32,5 @@ export declare class CmatChipInputComponent implements ControlValueAccessor, OnD
30
32
  private _onTouchedChange;
31
33
  private _filter;
32
34
  static ɵfac: i0.ɵɵFactoryDeclaration<CmatChipInputComponent, never>;
33
- static ɵcmp: i0.ɵɵComponentDeclaration<CmatChipInputComponent, "cmat-chip-input", ["cmatChipInput"], { "label": { "alias": "label"; "required": false; }; "selectableOptions": { "alias": "selectableOptions"; "required": false; }; "hasAutocomplete": { "alias": "hasAutocomplete"; "required": false; }; "outputIsString": { "alias": "outputIsString"; "required": false; }; "separatorKey": { "alias": "separatorKey"; "required": false; }; }, {}, never, never, true, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<CmatChipInputComponent, "cmat-chip-input", ["cmatChipInput"], { "label": { "alias": "label"; "required": false; }; "selectableOptions": { "alias": "selectableOptions"; "required": false; }; "hasAutocomplete": { "alias": "hasAutocomplete"; "required": false; }; "outputIsString": { "alias": "outputIsString"; "required": false; }; "separatorKey": { "alias": "separatorKey"; "required": false; }; "hasPrefixIcon": { "alias": "hasPrefixIcon"; "required": false; }; "prefixIcon": { "alias": "prefixIcon"; "required": false; }; }, {}, never, never, true, never>;
34
36
  }
@@ -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
  }
@@ -22,6 +22,8 @@ export class CmatChipInputComponent {
22
22
  this.hasAutocomplete = false;
23
23
  this.outputIsString = false;
24
24
  this.separatorKey = ',';
25
+ this.hasPrefixIcon = false;
26
+ this.prefixIcon = 'heroicons_solid:pencil-square';
25
27
  this.inputControl = new FormControl();
26
28
  this.selectedOptions$ = new BehaviorSubject([]);
27
29
  this.separatorKeysCodes = [ENTER, COMMA];
@@ -110,13 +112,13 @@ export class CmatChipInputComponent {
110
112
  return this.selectableOptions.filter(v => v.toLowerCase().includes(filterValue));
111
113
  }
112
114
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatChipInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
113
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatChipInputComponent, isStandalone: true, selector: "cmat-chip-input", inputs: { label: "label", selectableOptions: "selectableOptions", hasAutocomplete: "hasAutocomplete", outputIsString: "outputIsString", separatorKey: "separatorKey" }, providers: [
115
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.4", type: CmatChipInputComponent, isStandalone: true, selector: "cmat-chip-input", inputs: { label: "label", selectableOptions: "selectableOptions", hasAutocomplete: "hasAutocomplete", outputIsString: "outputIsString", separatorKey: "separatorKey", hasPrefixIcon: "hasPrefixIcon", prefixIcon: "prefixIcon" }, providers: [
114
116
  {
115
117
  provide: NG_VALUE_ACCESSOR,
116
118
  useExisting: forwardRef(() => CmatChipInputComponent),
117
119
  multi: true
118
120
  }
119
- ], viewQueries: [{ propertyName: "inputElementRef", first: true, predicate: ["input"], descendants: true }], exportAs: ["cmatChipInput"], ngImport: i0, template: "<mat-form-field subscriptSizing=\"dynamic\" class=\"w-full\">\n <mat-label>{{label}}</mat-label>\n <mat-chip-grid #chipList class=\"items-center\">\n @for (option of selectedOptions$ | async; track trackByFn($index)) {\n <mat-chip-row selectable (removed)=\"onRemove(option)\">\n {{ option }}\n <button matChipRemove>\n <mat-icon class=\"icon-size-5\" [svgIcon]=\"'mat_solid:cancel'\"></mat-icon>\n </button>\n </mat-chip-row>\n }\n\n @if (hasAutocomplete) {\n <input #input matInput [formControl]=\"inputControl\" [placeholder]=\"'\u5F00\u59CB\u9009\u62E9...'\"\n [matAutocomplete]=\"autoComplete\" [matChipInputFor]=\"chipList\"\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n <mat-autocomplete #autoComplete=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\">\n @for (option of filteredOptions$ | async; track trackByFn($index)) {\n <mat-option [value]=\"option\">\n {{ option }}\n </mat-option>\n }\n </mat-autocomplete>\n } @else {\n <input #input [formControl]=\"inputControl\" [placeholder]=\"'\u5F00\u59CB\u586B\u5199...'\" [matChipInputFor]=\"chipList\"\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n }\n </mat-chip-grid>\n\n </mat-form-field>\n\n", dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "ngmodule", type: MatChipsModule }, { kind: "component", type: i2.MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i2.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i2.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i2.MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["editable"], outputs: ["edited"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i4.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i4.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
121
+ ], viewQueries: [{ propertyName: "inputElementRef", first: true, predicate: ["input"], descendants: true }], exportAs: ["cmatChipInput"], ngImport: i0, template: "<mat-form-field subscriptSizing=\"dynamic\" class=\"w-full\">\n <mat-label>{{label}}</mat-label>\n @if(hasPrefixIcon){\n <mat-icon matPrefix class=\"hidden sm:flex icon-size-5\" [svgIcon]=\"prefixIcon\">\n </mat-icon>\n }\n <mat-chip-grid #chipList class=\"items-center\">\n @for (option of selectedOptions$ | async; track trackByFn($index)) {\n <mat-chip-row selectable (removed)=\"onRemove(option)\">\n {{ option }}\n <button matChipRemove>\n <mat-icon class=\"icon-size-5\" [svgIcon]=\"'mat_solid:cancel'\"></mat-icon>\n </button>\n </mat-chip-row>\n }\n\n @if (hasAutocomplete) {\n <input #input matInput [formControl]=\"inputControl\" [placeholder]=\"'\u5F00\u59CB\u9009\u62E9...'\" [matAutocomplete]=\"autoComplete\"\n [matChipInputFor]=\"chipList\" [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\n (matChipInputTokenEnd)=\"onAdd($event)\" />\n <mat-autocomplete #autoComplete=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\">\n @for (option of filteredOptions$ | async; track trackByFn($index)) {\n <mat-option [value]=\"option\">\n {{ option }}\n </mat-option>\n }\n </mat-autocomplete>\n } @else {\n <input #input [formControl]=\"inputControl\" [placeholder]=\"'\u5F00\u59CB\u586B\u5199...'\" [matChipInputFor]=\"chipList\"\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n }\n </mat-chip-grid>\n\n</mat-form-field>", dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "ngmodule", type: MatChipsModule }, { kind: "component", type: i2.MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i2.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i2.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i2.MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["editable"], outputs: ["edited"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "component", type: i4.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i4.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
120
122
  }
121
123
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: CmatChipInputComponent, decorators: [{
122
124
  type: Component,
@@ -126,7 +128,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
126
128
  useExisting: forwardRef(() => CmatChipInputComponent),
127
129
  multi: true
128
130
  }
129
- ], exportAs: 'cmatChipInput', imports: [MatFormFieldModule, MatChipsModule, AsyncPipe, MatInputModule, MatAutocompleteModule, MatIconModule, FormsModule, ReactiveFormsModule], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-form-field subscriptSizing=\"dynamic\" class=\"w-full\">\n <mat-label>{{label}}</mat-label>\n <mat-chip-grid #chipList class=\"items-center\">\n @for (option of selectedOptions$ | async; track trackByFn($index)) {\n <mat-chip-row selectable (removed)=\"onRemove(option)\">\n {{ option }}\n <button matChipRemove>\n <mat-icon class=\"icon-size-5\" [svgIcon]=\"'mat_solid:cancel'\"></mat-icon>\n </button>\n </mat-chip-row>\n }\n\n @if (hasAutocomplete) {\n <input #input matInput [formControl]=\"inputControl\" [placeholder]=\"'\u5F00\u59CB\u9009\u62E9...'\"\n [matAutocomplete]=\"autoComplete\" [matChipInputFor]=\"chipList\"\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n <mat-autocomplete #autoComplete=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\">\n @for (option of filteredOptions$ | async; track trackByFn($index)) {\n <mat-option [value]=\"option\">\n {{ option }}\n </mat-option>\n }\n </mat-autocomplete>\n } @else {\n <input #input [formControl]=\"inputControl\" [placeholder]=\"'\u5F00\u59CB\u586B\u5199...'\" [matChipInputFor]=\"chipList\"\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n }\n </mat-chip-grid>\n\n </mat-form-field>\n\n" }]
131
+ ], exportAs: 'cmatChipInput', imports: [MatFormFieldModule, MatChipsModule, AsyncPipe, MatInputModule, MatAutocompleteModule, MatIconModule, FormsModule, ReactiveFormsModule], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-form-field subscriptSizing=\"dynamic\" class=\"w-full\">\n <mat-label>{{label}}</mat-label>\n @if(hasPrefixIcon){\n <mat-icon matPrefix class=\"hidden sm:flex icon-size-5\" [svgIcon]=\"prefixIcon\">\n </mat-icon>\n }\n <mat-chip-grid #chipList class=\"items-center\">\n @for (option of selectedOptions$ | async; track trackByFn($index)) {\n <mat-chip-row selectable (removed)=\"onRemove(option)\">\n {{ option }}\n <button matChipRemove>\n <mat-icon class=\"icon-size-5\" [svgIcon]=\"'mat_solid:cancel'\"></mat-icon>\n </button>\n </mat-chip-row>\n }\n\n @if (hasAutocomplete) {\n <input #input matInput [formControl]=\"inputControl\" [placeholder]=\"'\u5F00\u59CB\u9009\u62E9...'\" [matAutocomplete]=\"autoComplete\"\n [matChipInputFor]=\"chipList\" [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\n (matChipInputTokenEnd)=\"onAdd($event)\" />\n <mat-autocomplete #autoComplete=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\">\n @for (option of filteredOptions$ | async; track trackByFn($index)) {\n <mat-option [value]=\"option\">\n {{ option }}\n </mat-option>\n }\n </mat-autocomplete>\n } @else {\n <input #input [formControl]=\"inputControl\" [placeholder]=\"'\u5F00\u59CB\u586B\u5199...'\" [matChipInputFor]=\"chipList\"\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n }\n </mat-chip-grid>\n\n</mat-form-field>" }]
130
132
  }], ctorParameters: () => [], propDecorators: { inputElementRef: [{
131
133
  type: ViewChild,
132
134
  args: ['input']
@@ -140,5 +142,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
140
142
  type: Input
141
143
  }], separatorKey: [{
142
144
  type: Input
145
+ }], hasPrefixIcon: [{
146
+ type: Input
147
+ }], prefixIcon: [{
148
+ type: Input
143
149
  }] } });
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip-input.component.js","sourceRoot":"","sources":["../../../../../projects/cmat/components/chip-input/chip-input.component.ts","../../../../../projects/cmat/components/chip-input/chip-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, Input, OnDestroy, ViewChild, ViewEncapsulation, forwardRef } from '@angular/core';\r\nimport { ControlValueAccessor, FormControl, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { BehaviorSubject, Observable, Subject, debounceTime, map, startWith, takeUntil } from 'rxjs';\r\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\r\nimport { MatAutocompleteModule, MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { MatChipInputEvent, MatChipsModule } from '@angular/material/chips';\r\nimport { isArray, isEmpty, isNil } from 'lodash';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\n\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'cmat-chip-input',\r\n    templateUrl: './chip-input.component.html',\r\n    standalone: true,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => CmatChipInputComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    exportAs: 'cmatChipInput',\r\n    imports: [MatFormFieldModule, MatChipsModule,AsyncPipe, MatInputModule, MatAutocompleteModule, MatIconModule, FormsModule, ReactiveFormsModule],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class CmatChipInputComponent implements ControlValueAccessor, OnDestroy {\r\n    @ViewChild('input') inputElementRef: ElementRef<HTMLInputElement>;\r\n    @Input() label: string;\r\n    @Input() selectableOptions: string[];\r\n    @Input() hasAutocomplete: boolean = false;\r\n    @Input() outputIsString: boolean = false;\r\n    @Input() separatorKey: string = ',';\r\n\r\n    inputControl: FormControl<string | null> = new FormControl();\r\n    filteredOptions$: Observable<string[] | null>;\r\n    selectedOptions$: BehaviorSubject<any> = new BehaviorSubject<any>([]);\r\n    separatorKeysCodes: number[] = [ENTER, COMMA];\r\n\r\n    private readonly _maxFilteredItems = 50;\r\n    private _unsubscribeAll: Subject<any> = new Subject<any>();\r\n\r\n    constructor() {\r\n        this.filteredOptions$ = this.inputControl.valueChanges.pipe(\r\n            startWith(null),\r\n            takeUntil(this._unsubscribeAll),\r\n            debounceTime(100),\r\n            map((value: string | null) => {\r\n                if (this.hasAutocomplete) {\r\n                    const selectable = (value ? this._filter(value) : this.selectableOptions.slice());\r\n                    const notSelected = !isNil(this.selectedOptions$.value) ? selectable.filter(option => !this.selectedOptions$.value.includes(option)) : selectable;\r\n\r\n                    return notSelected.slice(0, this._maxFilteredItems);\r\n                }\r\n\r\n                return null;\r\n            }),\r\n        );\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._unsubscribeAll.next(void 0);\r\n        this._unsubscribeAll.complete();\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this._onModelChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this._onTouchedChange = fn;\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        if (isArray(value) || isNil(value))\r\n            this.selectedOptions$.next(value);\r\n        else if (isEmpty(value)) {\r\n            this.selectedOptions$.next([]);\r\n        }\r\n        else {\r\n            this.selectedOptions$.next((value as string).split(this.separatorKey));\r\n        }\r\n\r\n        this.inputControl.setValue(null);\r\n    }\r\n\r\n    onAdd(event: MatChipInputEvent): void {\r\n        const value = (event.value || '').trim();\r\n\r\n        if (value && (!this.hasAutocomplete || this.selectableOptions.includes(value))) {\r\n            const newValue = isNil(this.selectedOptions$.value) ? [value] : [...this.selectedOptions$.value, value];\r\n            this.selectedOptions$.next(newValue);\r\n\r\n            if (this.outputIsString) {\r\n                this._onModelChange(newValue.join(this.separatorKey));\r\n            } else {\r\n                this._onModelChange(newValue);\r\n            }\r\n        }\r\n\r\n        event.chipInput!.clear();\r\n\r\n        this.inputControl.setValue(null);\r\n    }\r\n\r\n    onRemove(option: string): void {\r\n        const index: number = this.selectedOptions$.value.indexOf(option);\r\n        if (index >= 0) {\r\n            let newOptions = [...this.selectedOptions$.value];\r\n            newOptions.splice(index, 1);\r\n            newOptions = newOptions.length > 0 ? newOptions : [];\r\n\r\n            this.selectedOptions$.next(newOptions);\r\n\r\n            if (this.outputIsString && !isNil(newOptions)) {\r\n                this._onModelChange(newOptions.join(this.separatorKey));\r\n            } else {\r\n                this._onModelChange(newOptions);\r\n            }\r\n\r\n            this.inputControl.setValue(null);\r\n        }\r\n    }\r\n\r\n    onSelected(event: MatAutocompleteSelectedEvent): void {\r\n        const newValue = isNil(this.selectedOptions$.value) ? [event.option.viewValue] : [...this.selectedOptions$.value, event.option.viewValue];\r\n        this.selectedOptions$.next(newValue);\r\n\r\n        if (this.outputIsString) {\r\n            this._onModelChange(newValue.join(this.separatorKey));\r\n        } else {\r\n            this._onModelChange(newValue);\r\n        }\r\n\r\n        this.inputElementRef.nativeElement.value = '';\r\n        this.inputControl.setValue(null);\r\n    }\r\n\r\n    trackByFn(index: number): any {\r\n        return index;\r\n    }\r\n\r\n    private _onModelChange: (value: any) => void = () => { };\r\n    private _onTouchedChange: () => any = () => { };\r\n\r\n    private _filter(value: string): string[] {\r\n        const filterValue = value.toLowerCase();\r\n\r\n        return this.selectableOptions.filter(v => v.toLowerCase().includes(filterValue));\r\n    }\r\n}","<mat-form-field subscriptSizing=\"dynamic\" class=\"w-full\">\n  <mat-label>{{label}}</mat-label>\n  <mat-chip-grid #chipList class=\"items-center\">\n    @for (option of selectedOptions$ | async; track trackByFn($index)) {\n      <mat-chip-row selectable (removed)=\"onRemove(option)\">\n        {{ option }}\n        <button matChipRemove>\n          <mat-icon class=\"icon-size-5\"  [svgIcon]=\"'mat_solid:cancel'\"></mat-icon>\n        </button>\n      </mat-chip-row>\n    }\n\n    @if (hasAutocomplete) {\n      <input #input matInput [formControl]=\"inputControl\" [placeholder]=\"'开始选择...'\"\n        [matAutocomplete]=\"autoComplete\" [matChipInputFor]=\"chipList\"\n        [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n        <mat-autocomplete #autoComplete=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\">\n          @for (option of filteredOptions$ | async; track trackByFn($index)) {\n            <mat-option [value]=\"option\">\n              {{ option }}\n            </mat-option>\n          }\n        </mat-autocomplete>\n      } @else {\n        <input #input [formControl]=\"inputControl\" [placeholder]=\"'开始填写...'\" [matChipInputFor]=\"chipList\"\n          [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n        }\n      </mat-chip-grid>\n\n    </mat-form-field>\n\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip-input.component.js","sourceRoot":"","sources":["../../../../../projects/cmat/components/chip-input/chip-input.component.ts","../../../../../projects/cmat/components/chip-input/chip-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, Input, OnDestroy, ViewChild, ViewEncapsulation, forwardRef } from '@angular/core';\r\nimport { ControlValueAccessor, FormControl, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { BehaviorSubject, Observable, Subject, debounceTime, map, startWith, takeUntil } from 'rxjs';\r\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\r\nimport { MatAutocompleteModule, MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { MatChipInputEvent, MatChipsModule } from '@angular/material/chips';\r\nimport { isArray, isEmpty, isNil } from 'lodash';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\n\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'cmat-chip-input',\r\n    templateUrl: './chip-input.component.html',\r\n    standalone: true,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => CmatChipInputComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    exportAs: 'cmatChipInput',\r\n    imports: [MatFormFieldModule, MatChipsModule,AsyncPipe, MatInputModule, MatAutocompleteModule, MatIconModule, FormsModule, ReactiveFormsModule],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class CmatChipInputComponent implements ControlValueAccessor, OnDestroy {\r\n    @ViewChild('input') inputElementRef: ElementRef<HTMLInputElement>;\r\n    @Input() label: string;\r\n    @Input() selectableOptions: string[];\r\n    @Input() hasAutocomplete: boolean = false;\r\n    @Input() outputIsString: boolean = false;\r\n    @Input() separatorKey: string = ',';\r\n    @Input() hasPrefixIcon:boolean=false;\r\n    @Input() prefixIcon:string='heroicons_solid:pencil-square';\r\n\r\n    inputControl: FormControl<string | null> = new FormControl();\r\n    filteredOptions$: Observable<string[] | null>;\r\n    selectedOptions$: BehaviorSubject<any> = new BehaviorSubject<any>([]);\r\n    separatorKeysCodes: number[] = [ENTER, COMMA];\r\n\r\n    private readonly _maxFilteredItems = 50;\r\n    private _unsubscribeAll: Subject<any> = new Subject<any>();\r\n\r\n    constructor() {\r\n        this.filteredOptions$ = this.inputControl.valueChanges.pipe(\r\n            startWith(null),\r\n            takeUntil(this._unsubscribeAll),\r\n            debounceTime(100),\r\n            map((value: string | null) => {\r\n                if (this.hasAutocomplete) {\r\n                    const selectable = (value ? this._filter(value) : this.selectableOptions.slice());\r\n                    const notSelected = !isNil(this.selectedOptions$.value) ? selectable.filter(option => !this.selectedOptions$.value.includes(option)) : selectable;\r\n\r\n                    return notSelected.slice(0, this._maxFilteredItems);\r\n                }\r\n\r\n                return null;\r\n            }),\r\n        );\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._unsubscribeAll.next(void 0);\r\n        this._unsubscribeAll.complete();\r\n    }\r\n\r\n    registerOnChange(fn: any): void {\r\n        this._onModelChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any): void {\r\n        this._onTouchedChange = fn;\r\n    }\r\n\r\n    writeValue(value: any): void {\r\n        if (isArray(value) || isNil(value))\r\n            this.selectedOptions$.next(value);\r\n        else if (isEmpty(value)) {\r\n            this.selectedOptions$.next([]);\r\n        }\r\n        else {\r\n            this.selectedOptions$.next((value as string).split(this.separatorKey));\r\n        }\r\n\r\n        this.inputControl.setValue(null);\r\n    }\r\n\r\n    onAdd(event: MatChipInputEvent): void {\r\n        const value = (event.value || '').trim();\r\n\r\n        if (value && (!this.hasAutocomplete || this.selectableOptions.includes(value))) {\r\n            const newValue = isNil(this.selectedOptions$.value) ? [value] : [...this.selectedOptions$.value, value];\r\n            this.selectedOptions$.next(newValue);\r\n\r\n            if (this.outputIsString) {\r\n                this._onModelChange(newValue.join(this.separatorKey));\r\n            } else {\r\n                this._onModelChange(newValue);\r\n            }\r\n        }\r\n\r\n        event.chipInput!.clear();\r\n\r\n        this.inputControl.setValue(null);\r\n    }\r\n\r\n    onRemove(option: string): void {\r\n        const index: number = this.selectedOptions$.value.indexOf(option);\r\n        if (index >= 0) {\r\n            let newOptions = [...this.selectedOptions$.value];\r\n            newOptions.splice(index, 1);\r\n            newOptions = newOptions.length > 0 ? newOptions : [];\r\n\r\n            this.selectedOptions$.next(newOptions);\r\n\r\n            if (this.outputIsString && !isNil(newOptions)) {\r\n                this._onModelChange(newOptions.join(this.separatorKey));\r\n            } else {\r\n                this._onModelChange(newOptions);\r\n            }\r\n\r\n            this.inputControl.setValue(null);\r\n        }\r\n    }\r\n\r\n    onSelected(event: MatAutocompleteSelectedEvent): void {\r\n        const newValue = isNil(this.selectedOptions$.value) ? [event.option.viewValue] : [...this.selectedOptions$.value, event.option.viewValue];\r\n        this.selectedOptions$.next(newValue);\r\n\r\n        if (this.outputIsString) {\r\n            this._onModelChange(newValue.join(this.separatorKey));\r\n        } else {\r\n            this._onModelChange(newValue);\r\n        }\r\n\r\n        this.inputElementRef.nativeElement.value = '';\r\n        this.inputControl.setValue(null);\r\n    }\r\n\r\n    trackByFn(index: number): any {\r\n        return index;\r\n    }\r\n\r\n    private _onModelChange: (value: any) => void = () => { };\r\n    private _onTouchedChange: () => any = () => { };\r\n\r\n    private _filter(value: string): string[] {\r\n        const filterValue = value.toLowerCase();\r\n\r\n        return this.selectableOptions.filter(v => v.toLowerCase().includes(filterValue));\r\n    }\r\n}","<mat-form-field subscriptSizing=\"dynamic\" class=\"w-full\">\n  <mat-label>{{label}}</mat-label>\n  @if(hasPrefixIcon){\n  <mat-icon matPrefix class=\"hidden sm:flex icon-size-5\" [svgIcon]=\"prefixIcon\">\n  </mat-icon>\n  }\n  <mat-chip-grid #chipList class=\"items-center\">\n    @for (option of selectedOptions$ | async; track trackByFn($index)) {\n    <mat-chip-row selectable (removed)=\"onRemove(option)\">\n      {{ option }}\n      <button matChipRemove>\n        <mat-icon class=\"icon-size-5\" [svgIcon]=\"'mat_solid:cancel'\"></mat-icon>\n      </button>\n    </mat-chip-row>\n    }\n\n    @if (hasAutocomplete) {\n    <input #input matInput [formControl]=\"inputControl\" [placeholder]=\"'开始选择...'\" [matAutocomplete]=\"autoComplete\"\n      [matChipInputFor]=\"chipList\" [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\n      (matChipInputTokenEnd)=\"onAdd($event)\" />\n    <mat-autocomplete #autoComplete=\"matAutocomplete\" (optionSelected)=\"onSelected($event)\">\n      @for (option of filteredOptions$ | async; track trackByFn($index)) {\n      <mat-option [value]=\"option\">\n        {{ option }}\n      </mat-option>\n      }\n    </mat-autocomplete>\n    } @else {\n    <input #input [formControl]=\"inputControl\" [placeholder]=\"'开始填写...'\" [matChipInputFor]=\"chipList\"\n      [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\" (matChipInputTokenEnd)=\"onAdd($event)\" />\n    }\n  </mat-chip-grid>\n\n</mat-form-field>"]}
@@ -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":"AAAA,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAgC,MAAM,EAAiB,MAAM,eAAe,CAAC;AAChK,OAAO,EAAE,aAAa,EAAU,MAAM,iBAAiB,CAAC;AAExD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAInD,OAAO,EAAE,yCAAyC,EAAE,MAAM,4BAA4B,CAAC;AACvF,OAAO,EAAE,wCAAwC,EAAE,MAAM,0BAA0B,CAAC;AACpF,OAAO,EAAE,0CAA0C,EAAE,MAAM,8BAA8B,CAAC;AAC1F,OAAO,EAAE,8CAA8C,EAAE,MAAM,sCAAsC,CAAC;AACtG,OAAO,EAAE,wCAAwC,EAAE,MAAM,0BAA0B,CAAC;AACpF,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;;;;;;AAY1C,MAAM,OAAO,wCAAwC;IAkBjD,YACY,kBAAqC,EACrC,OAAe,EACf,sBAA6C;QAF7C,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,YAAO,GAAP,OAAO,CAAQ;QACf,2BAAsB,GAAtB,sBAAsB,CAAuB;QAVhD,cAAS,GAAY,KAAK,CAAC;QACjB,4BAAuB,GAAqC,IAAI,YAAY,EAAsB,CAAC;QAEtH,WAAM,GAAY,KAAK,CAAC;QAEhB,oBAAe,GAAkB,IAAI,OAAO,EAAQ,CAAC;IAO7D,CAAC;IAED,wGAAwG;IACxG,oBAAoB;IACpB,wGAAwG;IAExG;;;;OAIG;IACH,WAAW,CAAC,OAAsB;QAC9B,iBAAiB;QACjB,IAAI,cAAc,IAAI,OAAO,EAAE;YAC3B,iBAAiB;YACjB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;SACxC;IACL,CAAC;IAED;;OAEG;IACH,QAAQ;QACJ,iBAAiB;QACjB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAErC,+CAA+C;QAC/C,IAAI,CAAC,OAAO,CAAC,MAAM;aACd,IAAI,CACD,MAAM,CAAC,CAAC,KAAK,EAA0B,EAAE,CAAC,KAAK,YAAY,aAAa,CAAC,EACzE,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAClC;aACA,SAAS,CAAC,CAAC,KAAoB,EAAE,EAAE;YAEhC,iBAAiB;YACjB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;QAEP,sCAAsC;QACtC,IAAI,CAAC,gCAAgC,GAAG,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE5F,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,wGAAwG;IACxG,mBAAmB;IACnB,wGAAwG;IAExG;;;;;OAKG;IACH,SAAS,CAAC,KAAa,EAAE,IAAS;QAC9B,OAAO,IAAI,CAAC,EAAE,IAAI,KAAK,CAAC;IAC5B,CAAC;IAED,UAAU,CAAC,IAAwB;QAC/B,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC;IACD,wGAAwG;IACxG,oBAAoB;IACpB,wGAAwG;IAExG;;;;;;;OAOG;IACK,eAAe,CAAC,IAAwB,EAAE,UAAkB;QAChE,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE/B,IAAI,CAAC,QAAQ,EAAE;YACX,OAAO,KAAK,CAAC;SAChB;QAED,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE;YAC1B,IAAI,KAAK,CAAC,QAAQ,EAAE;gBAChB,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,UAAU,CAAC,EAAE;oBACzC,OAAO,IAAI,CAAC;iBACf;aACJ;YAED,gCAAgC;YAChC,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;gBACxB,SAAS;aACZ;YAED,8CAA8C;YAC9C,IAAI,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE;gBAChD,KAAK,EAAE,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ;gBACrD,WAAW,EAAE,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS;aAC5G,CAAC,EAAE;gBACA,OAAO,IAAI,CAAC;aACf;SACJ;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAED;;;;OAIG;IACK,aAAa,CAAC,UAAkB;QACpC,sDAAsD;QACtD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,KAAK,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAEjD,8CAA8C;QAC9C,2BAA2B;QAC3B,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC,EAAE;YAC7C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACtB;QAED,iBAAiB;QACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IAC3C,CAAC;8GAhKQ,wCAAwC;kGAAxC,wCAAwC,+UC3BrD,ksGA2EC,4CDpDa,OAAO,mFAAE,gBAAgB,4TAAE,aAAa,oLAAE,wCAAwC,6JACvF,8CAA8C,mLAAE,0CAA0C,+JAC1F,wCAAwC,6KAAE,yCAAyC;;2FAE/E,wCAAwC;kBAVpD,SAAS;+BACI,qCAAqC,mBAG9B,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,wCAAwC;wBACvF,8CAA8C,EAAE,0CAA0C;wBAC1F,wCAAwC,EAAE,yCAAyC,CAAC;+IAQhF,YAAY;sBAApB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACa,uBAAuB;sBAAzC,MAAM","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}"]}