@recursyve/nice-ui-kit.v2 14.0.0-beta.125 → 14.0.0-beta.127

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 (34) hide show
  1. package/esm2020/lib/components/alert/alert.component.mjs +3 -3
  2. package/esm2020/lib/components/async-typeahead/async-typeahead.component.mjs +6 -2
  3. package/esm2020/lib/components/async-typeahead/providers/async-typeahead.provider.mjs +1 -1
  4. package/esm2020/lib/components/async-typeahead/providers/async-typeahead.service.mjs +73 -63
  5. package/esm2020/lib/components/form-error/control-status.directive.mjs +9 -2
  6. package/esm2020/lib/components/form-error/form-error.component.mjs +1 -1
  7. package/esm2020/lib/components/navigation/horizontal/components/basic/basic.component.mjs +11 -4
  8. package/esm2020/lib/components/navigation/horizontal/components/branch/branch.component.mjs +9 -3
  9. package/esm2020/lib/components/navigation/horizontal/horizontal.component.mjs +9 -3
  10. package/esm2020/lib/components/navigation/navigation.types.mjs +1 -1
  11. package/esm2020/lib/components/navigation/vertical/components/aside/aside.component.mjs +9 -3
  12. package/esm2020/lib/components/navigation/vertical/components/basic/basic.component.mjs +13 -6
  13. package/esm2020/lib/components/navigation/vertical/components/collapsable/collapsable.component.mjs +9 -3
  14. package/esm2020/lib/components/navigation/vertical/components/group/group.component.mjs +9 -3
  15. package/esm2020/lib/components/navigation/vertical/vertical.component.mjs +9 -3
  16. package/fesm2015/recursyve-nice-ui-kit.v2.mjs +134 -62
  17. package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +1 -1
  18. package/fesm2020/recursyve-nice-ui-kit.v2.mjs +153 -86
  19. package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +1 -1
  20. package/lib/components/async-typeahead/providers/async-typeahead.provider.d.ts +2 -1
  21. package/lib/components/async-typeahead/providers/async-typeahead.service.d.ts +13 -2
  22. package/lib/components/form-error/control-status.directive.d.ts +4 -2
  23. package/lib/components/form-error/form-error.component.d.ts +1 -1
  24. package/lib/components/navigation/horizontal/components/basic/basic.component.d.ts +4 -1
  25. package/lib/components/navigation/horizontal/components/branch/branch.component.d.ts +4 -1
  26. package/lib/components/navigation/horizontal/horizontal.component.d.ts +4 -1
  27. package/lib/components/navigation/navigation.types.d.ts +1 -0
  28. package/lib/components/navigation/vertical/components/aside/aside.component.d.ts +4 -1
  29. package/lib/components/navigation/vertical/components/basic/basic.component.d.ts +4 -1
  30. package/lib/components/navigation/vertical/components/collapsable/collapsable.component.d.ts +4 -1
  31. package/lib/components/navigation/vertical/components/group/group.component.d.ts +4 -1
  32. package/lib/components/navigation/vertical/vertical.component.d.ts +4 -1
  33. package/package.json +1 -1
  34. package/src/lib/components/navigation/vertical/vertical.theme.scss +11 -0
@@ -1,6 +1,7 @@
1
1
  import { Inject, Injectable, Optional } from "@angular/core";
2
- import { BehaviorSubject, firstValueFrom, from, isObservable, mergeMap } from "rxjs";
3
- import { map } from "rxjs/operators";
2
+ import { BehaviorSubject, catchError, defer, distinctUntilChanged, EMPTY, firstValueFrom, from, isObservable, mergeMap, Subject, switchMap } from "rxjs";
3
+ import { fromPromise } from "rxjs/internal/observable/innerFrom";
4
+ import { finalize, map } from "rxjs/operators";
4
5
  import { NICE_ASYNC_TYPEAHEAD_PROVIDER } from "../async-typeahead.constant";
5
6
  import * as i0 from "@angular/core";
6
7
  export class AsyncTypeaheadState {
@@ -19,15 +20,22 @@ export class NiceAsyncTypeaheadService {
19
20
  isLastPage: false,
20
21
  excludedIds: []
21
22
  });
22
- this.loading$ = this.state$.pipe(map(x => x.loading));
23
- this.loadingPage$ = this.state$.pipe(map(x => x.loadingPage));
24
- this.active$ = this.state$.pipe(map(x => x.active));
25
- this.items$ = this.state$.pipe(map(x => x.items));
26
- this.filteredItems$ = this.state$.pipe(map(x => x.items.filter(item => !x.excludedIds.includes(item.id))));
23
+ this.loading$ = this.state$.pipe(map(x => x.loading), distinctUntilChanged());
24
+ this.loadingPage$ = this.state$.pipe(map(x => x.loadingPage), distinctUntilChanged());
25
+ this.active$ = this.state$.pipe(map(x => x.active), distinctUntilChanged());
26
+ this.items$ = this.state$.pipe(map(x => x.items), distinctUntilChanged());
27
+ this.filteredItems$ = this.state$.pipe(map(x => x.items.filter(item => !x.excludedIds.includes(item.id))), distinctUntilChanged());
28
+ this.requests$ = new Subject();
27
29
  if (!this.apis) {
28
30
  this.apis = [];
29
31
  }
30
32
  }
33
+ listenForRequest() {
34
+ this.requestsSubscription$ = this.requests$.pipe(switchMap((request) => this.sendRequest(request))).subscribe();
35
+ }
36
+ closeRequestSubscription() {
37
+ this.requestsSubscription$?.unsubscribe();
38
+ }
31
39
  async initialize(resource, options) {
32
40
  const { initialized } = this.state$.getValue();
33
41
  if (initialized) {
@@ -35,74 +43,76 @@ export class NiceAsyncTypeaheadService {
35
43
  }
36
44
  return this.search(resource, "", options);
37
45
  }
38
- async search(resource, searchQuery, options) {
39
- const { active, initialized } = this.state$.getValue();
40
- if (active && !initialized) {
41
- this.state$.next({
42
- ...this.state$.value,
43
- initialized: true
44
- });
45
- return;
46
- }
47
- const api = this.apis.find(x => x.resource === resource);
48
- if (!api) {
49
- return;
50
- }
51
- try {
52
- this.state$.next({
53
- ...this.state$.value,
54
- loading: true,
55
- initialized: true,
56
- page: 0,
57
- isLastPage: false,
58
- searchQuery
59
- });
60
- const result = await api.search(searchQuery, 0, options);
46
+ sendRequest(request) {
47
+ return defer(() => {
48
+ const { active, initialized } = this.state$.getValue();
49
+ if (active && !initialized) {
50
+ this.state$.next({
51
+ ...this.state$.value,
52
+ initialized: true
53
+ });
54
+ return EMPTY;
55
+ }
56
+ const api = this.apis.find(x => x.resource === request.resource);
57
+ if (!api) {
58
+ return EMPTY;
59
+ }
60
+ if (request.page === 0) {
61
+ this.state$.next({
62
+ ...this.state$.value,
63
+ loading: true,
64
+ initialized: true,
65
+ page: request.page,
66
+ isLastPage: false,
67
+ searchQuery: request.searchQuery
68
+ });
69
+ }
70
+ else {
71
+ this.state$.next({
72
+ ...this.state$.value,
73
+ loadingPage: true
74
+ });
75
+ }
76
+ const result = api.search(request.searchQuery, request.page, request.searchOptions);
77
+ if (isObservable(result)) {
78
+ return result;
79
+ }
80
+ return fromPromise(result);
81
+ }).pipe(map((result) => {
61
82
  this.state$.next({
62
83
  ...this.state$.value,
63
- items: result.items,
84
+ items: request.page === 0 ? result.items : [...(this.state$.value.items ?? []), ...result.items],
64
85
  page: result.nextPage ? result.nextPage : this.state$.value.page,
65
86
  isLastPage: !result.nextPage
66
87
  });
67
- }
68
- catch { }
69
- finally {
88
+ }), catchError(() => EMPTY), finalize(() => {
70
89
  this.state$.next({
71
90
  ...this.state$.value,
72
- loading: false
91
+ loading: false,
92
+ loadingPage: false
73
93
  });
74
- }
94
+ }));
95
+ }
96
+ search(resource, searchQuery, options) {
97
+ this.requests$.next({
98
+ resource,
99
+ searchQuery,
100
+ searchOptions: options,
101
+ page: 0
102
+ });
75
103
  }
76
- async loadMore(resource, options) {
104
+ loadMore(resource, options) {
77
105
  const { loadingPage, isLastPage } = this.state$.getValue();
78
106
  if (loadingPage || isLastPage) {
79
107
  return;
80
108
  }
81
- const api = this.apis.find(x => x.resource === resource);
82
- if (!api) {
83
- return;
84
- }
85
- try {
86
- this.state$.next({
87
- ...this.state$.value,
88
- loadingPage: true
89
- });
90
- const { searchQuery, page, items } = this.state$.getValue();
91
- const result = await api.search(searchQuery, page, options);
92
- this.state$.next({
93
- ...this.state$.value,
94
- items: [...items, ...result.items],
95
- page: result.nextPage ? result.nextPage : this.state$.value.page,
96
- isLastPage: !result.nextPage
97
- });
98
- }
99
- catch { }
100
- finally {
101
- this.state$.next({
102
- ...this.state$.value,
103
- loadingPage: false
104
- });
105
- }
109
+ const { searchQuery, page } = this.state$.getValue();
110
+ this.requests$.next({
111
+ resource,
112
+ page,
113
+ searchQuery,
114
+ searchOptions: options,
115
+ });
106
116
  }
107
117
  getActive() {
108
118
  return this.state$.value.active;
@@ -196,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
196
206
  type: Inject,
197
207
  args: [NICE_ASYNC_TYPEAHEAD_PROVIDER]
198
208
  }] }]; } });
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-typeahead.service.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/async-typeahead/providers/async-typeahead.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional } from \"@angular/core\";\nimport { BehaviorSubject, firstValueFrom, from, isObservable, mergeMap, Observable } from \"rxjs\";\nimport { map } from \"rxjs/operators\";\nimport { NICE_ASYNC_TYPEAHEAD_PROVIDER } from \"../async-typeahead.constant\";\nimport { NiceAsyncTypeaheadProvider } from \"./async-typeahead.provider\";\n\nexport class AsyncTypeaheadState {\n    items: any[];\n    active: any;\n    loading: boolean;\n    loadingPage: boolean;\n    initialized: boolean;\n    page: number;\n    isLastPage: boolean;\n    searchQuery?: string;\n    excludedIds: any[];\n}\n\n@Injectable()\nexport class NiceAsyncTypeaheadService {\n    private state$: BehaviorSubject<AsyncTypeaheadState> = new BehaviorSubject({\n        items: [],\n        active: null,\n        loading: false,\n        loadingPage: false,\n        initialized: false,\n        searchQuery: null,\n        page: 0,\n        isLastPage: false,\n        excludedIds: []\n    });\n\n    public loading$ = this.state$.pipe(map(x => x.loading));\n    public loadingPage$ = this.state$.pipe(map(x => x.loadingPage));\n    public active$ = this.state$.pipe(map(x => x.active));\n    public items$ = this.state$.pipe(map(x => x.items));\n    public filteredItems$ = this.state$.pipe(map(x => x.items.filter(item => !x.excludedIds.includes(item.id))));\n\n    constructor(@Optional() @Inject(NICE_ASYNC_TYPEAHEAD_PROVIDER) private readonly apis: NiceAsyncTypeaheadProvider<any>[]) {\n        if (!this.apis) {\n            this.apis = [];\n        }\n    }\n\n    public async initialize(resource: string, options?: any): Promise<void> {\n        const { initialized } = this.state$.getValue();\n        if (initialized) {\n            return;\n        }\n\n        return this.search(resource, \"\", options);\n    }\n\n    public async search(resource: string, searchQuery: string, options?: any): Promise<void> {\n        const { active, initialized } = this.state$.getValue();\n\n        if (active && !initialized) {\n            this.state$.next({\n                ...this.state$.value,\n                initialized: true\n            });\n            return;\n        }\n\n        const api = this.apis.find(x => x.resource === resource);\n        if (!api) {\n            return;\n        }\n\n        try {\n            this.state$.next({\n                ...this.state$.value,\n                loading: true,\n                initialized: true,\n                page: 0,\n                isLastPage: false,\n                searchQuery\n            });\n\n            const result = await api.search(searchQuery, 0, options);\n            this.state$.next({\n                ...this.state$.value,\n                items: result.items,\n                page: result.nextPage ? result.nextPage : this.state$.value.page,\n                isLastPage: !result.nextPage\n            });\n        } catch {} finally {\n            this.state$.next({\n                ...this.state$.value,\n                loading: false\n            });\n        }\n    }\n\n    public async loadMore(resource: string, options?: any): Promise<void> {\n        const { loadingPage, isLastPage } = this.state$.getValue();\n        if (loadingPage || isLastPage) {\n            return;\n        }\n\n        const api = this.apis.find(x => x.resource === resource);\n        if (!api) {\n            return;\n        }\n\n        try {\n            this.state$.next({\n                ...this.state$.value,\n                loadingPage: true\n            });\n\n            const { searchQuery, page, items } = this.state$.getValue();\n            const result = await api.search(searchQuery, page, options);\n            this.state$.next({\n                ...this.state$.value,\n                items: [...items, ...result.items],\n                page: result.nextPage ? result.nextPage : this.state$.value.page,\n                isLastPage: !result.nextPage\n            });\n        } catch {} finally {\n            this.state$.next({\n                ...this.state$.value,\n                loadingPage: false\n            });\n        }\n    }\n\n    public getActive(): any {\n        return this.state$.value.active;\n    }\n\n    public getInitialized(): boolean {\n        return this.state$.value.initialized;\n    }\n\n    public setActive(entity: any | undefined): void {\n        this.state$.next({\n            ...this.state$.value,\n            active: entity ?? null\n        });\n    }\n\n    public async setActiveId(resource: string, id: any, options?: any): Promise<void> {\n        if (!id) {\n            return;\n        }\n\n        const api = this.apis.find(x => x.resource === resource);\n        if (!api) {\n            return;\n        }\n\n        try {\n            this.state$.next({\n                ...this.state$.value,\n                loading: true\n            });\n\n            const localItem = this.state$.value.items.find((item) => item.id === id);\n            if (localItem) {\n                this.state$.next({\n                    ...this.state$.value,\n                    items: [localItem],\n                    active: localItem,\n                    page: 0,\n                    isLastPage: false\n                });\n                return;\n            }\n\n            const entity = await api.getById(id, options);\n            if (!entity) {\n                return;\n            }\n\n            this.state$.next({\n                ...this.state$.value,\n                items: [entity],\n                active: entity,\n                page: 0,\n                isLastPage: false\n            });\n        } catch {} finally {\n            this.state$.next({\n                ...this.state$.value,\n                loading: false\n            });\n        }\n    }\n\n    public reloadActive(resource: string, options?: any): Promise<void> {\n        return this.setActiveId(resource, this.state$.value.active?.id, options);\n    }\n\n    public reloadFilteredItems(): void {\n        // TODO: Use a better way to trigger the items$ observable\n        this.state$.next({\n            ...this.state$.value\n        });\n    }\n\n    public setFilterFn(filterFn: (value: any) => boolean | Promise<boolean> | Observable<boolean>): void {\n        this.filteredItems$ = this.items$.pipe(mergeMap(items => {\n                    return from(Promise.all(items.map(async item => {\n                        const result = filterFn(item);\n\n                        const unwrappedResult = isObservable(result) ? await firstValueFrom(result) : await result;\n\n                        return [item, unwrappedResult];\n                    })));\n                }\n            ),\n            map(items => items.filter(([item, keep]) => keep).map(([item, keep]) => item))\n        );\n    }\n\n    public format(resource: string, item: string): string {\n        const api = this.apis.find(x => x.resource === resource);\n        if (!api) {\n            return \"\";\n        }\n\n        return api.format(item);\n    }\n}\n"]}
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-typeahead.service.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/async-typeahead/providers/async-typeahead.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional } from \"@angular/core\";\nimport {\n    BehaviorSubject, catchError,\n    defer, distinctUntilChanged,\n    EMPTY,\n    firstValueFrom,\n    from,\n    isObservable,\n    mergeMap,\n    Observable,\n    Subject,\n    Subscription,\n    switchMap\n} from \"rxjs\";\nimport { fromPromise } from \"rxjs/internal/observable/innerFrom\";\nimport { finalize, map } from \"rxjs/operators\";\nimport { NICE_ASYNC_TYPEAHEAD_PROVIDER } from \"../async-typeahead.constant\";\nimport { NiceAsyncTypeaheadProvider, NiceAsyncTypeaheadSearchResult } from \"./async-typeahead.provider\";\n\nexport class AsyncTypeaheadState {\n    items: any[];\n    active: any;\n    loading: boolean;\n    loadingPage: boolean;\n    initialized: boolean;\n    page: number;\n    isLastPage: boolean;\n    searchQuery?: string;\n    excludedIds: any[];\n}\n\nexport type AsyncTypeaheadRequests = {\n    resource: string;\n    page: number;\n    searchQuery?: string;\n    searchOptions?: any;\n};\n\n@Injectable()\nexport class NiceAsyncTypeaheadService {\n    private state$: BehaviorSubject<AsyncTypeaheadState> = new BehaviorSubject({\n        items: [],\n        active: null,\n        loading: false,\n        loadingPage: false,\n        initialized: false,\n        searchQuery: null,\n        page: 0,\n        isLastPage: false,\n        excludedIds: []\n    });\n\n    public loading$ = this.state$.pipe(map(x => x.loading), distinctUntilChanged());\n    public loadingPage$ = this.state$.pipe(map(x => x.loadingPage), distinctUntilChanged());\n    public active$ = this.state$.pipe(map(x => x.active), distinctUntilChanged());\n    public items$ = this.state$.pipe(map(x => x.items), distinctUntilChanged());\n    public filteredItems$ = this.state$.pipe(map(x => x.items.filter(item => !x.excludedIds.includes(item.id))), distinctUntilChanged());\n\n    private requests$ = new Subject<AsyncTypeaheadRequests>();\n    private requestsSubscription$: Subscription;\n\n    constructor(@Optional() @Inject(NICE_ASYNC_TYPEAHEAD_PROVIDER) private readonly apis: NiceAsyncTypeaheadProvider<any>[]) {\n        if (!this.apis) {\n            this.apis = [];\n        }\n    }\n\n    public listenForRequest(): void {\n        this.requestsSubscription$ = this.requests$.pipe(\n            switchMap((request) => this.sendRequest(request))\n        ).subscribe();\n    }\n\n    public closeRequestSubscription(): void {\n        this.requestsSubscription$?.unsubscribe();\n    }\n\n    public async initialize(resource: string, options?: any): Promise<void> {\n        const { initialized } = this.state$.getValue();\n        if (initialized) {\n            return;\n        }\n\n        return this.search(resource, \"\", options);\n    }\n\n    public sendRequest(request: AsyncTypeaheadRequests): Observable<void> {\n        return defer(() => {\n            const { active, initialized } = this.state$.getValue();\n\n            if (active && !initialized) {\n                this.state$.next({\n                    ...this.state$.value,\n                    initialized: true\n                });\n                return EMPTY;\n            }\n\n            const api = this.apis.find(x => x.resource === request.resource);\n            if (!api) {\n                return EMPTY;\n            }\n\n            if (request.page === 0) {\n                this.state$.next({\n                    ...this.state$.value,\n                    loading: true,\n                    initialized: true,\n                    page: request.page,\n                    isLastPage: false,\n                    searchQuery: request.searchQuery\n                });\n            } else {\n                this.state$.next({\n                    ...this.state$.value,\n                    loadingPage: true\n                });\n            }\n\n            const result = api.search(request.searchQuery, request.page, request.searchOptions);\n            if (isObservable(result)) {\n                return result;\n            }\n\n            return fromPromise(result);\n        }).pipe(\n            map((result) => {\n                this.state$.next({\n                    ...this.state$.value,\n                    items: request.page === 0 ? result.items : [...(this.state$.value.items ?? []), ...result.items],\n                    page: result.nextPage ? result.nextPage : this.state$.value.page,\n                    isLastPage: !result.nextPage\n                });\n            }),\n            catchError(() => EMPTY),\n            finalize(() => {\n                this.state$.next({\n                    ...this.state$.value,\n                    loading: false,\n                    loadingPage: false\n                });\n            })\n        );\n    }\n\n    public search(resource: string, searchQuery: string, options?: any): void {\n        this.requests$.next({\n            resource,\n            searchQuery,\n            searchOptions: options,\n            page: 0\n        });\n    }\n\n    public loadMore(resource: string, options?: any): void {\n        const { loadingPage, isLastPage } = this.state$.getValue();\n        if (loadingPage || isLastPage) {\n            return;\n        }\n\n        const { searchQuery, page } = this.state$.getValue();\n        this.requests$.next({\n            resource,\n            page,\n            searchQuery,\n            searchOptions: options,\n        });\n    }\n\n    public getActive(): any {\n        return this.state$.value.active;\n    }\n\n    public getInitialized(): boolean {\n        return this.state$.value.initialized;\n    }\n\n    public setActive(entity: any | undefined): void {\n        this.state$.next({\n            ...this.state$.value,\n            active: entity ?? null\n        });\n    }\n\n    public async setActiveId(resource: string, id: any, options?: any): Promise<void> {\n        if (!id) {\n            return;\n        }\n\n        const api = this.apis.find(x => x.resource === resource);\n        if (!api) {\n            return;\n        }\n\n        try {\n            this.state$.next({\n                ...this.state$.value,\n                loading: true\n            });\n\n            const localItem = this.state$.value.items.find((item) => item.id === id);\n            if (localItem) {\n                this.state$.next({\n                    ...this.state$.value,\n                    items: [localItem],\n                    active: localItem,\n                    page: 0,\n                    isLastPage: false\n                });\n                return;\n            }\n\n            const entity = await api.getById(id, options);\n            if (!entity) {\n                return;\n            }\n\n            this.state$.next({\n                ...this.state$.value,\n                items: [entity],\n                active: entity,\n                page: 0,\n                isLastPage: false\n            });\n        } catch {} finally {\n            this.state$.next({\n                ...this.state$.value,\n                loading: false\n            });\n        }\n    }\n\n    public reloadActive(resource: string, options?: any): Promise<void> {\n        return this.setActiveId(resource, this.state$.value.active?.id, options);\n    }\n\n    public reloadFilteredItems(): void {\n        // TODO: Use a better way to trigger the items$ observable\n        this.state$.next({\n            ...this.state$.value\n        });\n    }\n\n    public setFilterFn(filterFn: (value: any) => boolean | Promise<boolean> | Observable<boolean>): void {\n        this.filteredItems$ = this.items$.pipe(mergeMap(items => {\n                    return from(Promise.all(items.map(async item => {\n                        const result = filterFn(item);\n\n                        const unwrappedResult = isObservable(result) ? await firstValueFrom(result) : await result;\n\n                        return [item, unwrappedResult];\n                    })));\n                }\n            ),\n            map(items => items.filter(([item, keep]) => keep).map(([item, keep]) => item))\n        );\n    }\n\n    public format(resource: string, item: string): string {\n        const api = this.apis.find(x => x.resource === resource);\n        if (!api) {\n            return \"\";\n        }\n\n        return api.format(item);\n    }\n}\n"]}
@@ -2,6 +2,8 @@ import { Directive, ElementRef, ViewContainerRef } from "@angular/core";
2
2
  import { MatFormField } from "@angular/material/form-field";
3
3
  import { TranslateService } from "@ngx-translate/core";
4
4
  import { NiceFormErrorComponent } from "./form-error.component";
5
+ import { Subject } from "rxjs";
6
+ import { takeUntil } from "rxjs/operators";
5
7
  import * as i0 from "@angular/core";
6
8
  import * as i1 from "@angular/material/form-field";
7
9
  import * as i2 from "@ngx-translate/core";
@@ -11,10 +13,15 @@ export class NiceControlStatusDirective {
11
13
  this.vcr = vcr;
12
14
  this.formField = formField;
13
15
  this.translateService = translateService;
16
+ this.unsubscribeAll$ = new Subject();
14
17
  }
15
18
  ngAfterViewInit() {
16
19
  this.control = this.formField._control.ngControl;
17
- this.control.statusChanges.subscribe(() => this.onChange());
20
+ this.control.statusChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(() => this.onChange());
21
+ }
22
+ ngOnDestroy() {
23
+ this.unsubscribeAll$.next();
24
+ this.unsubscribeAll$.complete();
18
25
  }
19
26
  onChange() {
20
27
  if (this.control.pending) {
@@ -81,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
81
88
  type: Directive,
82
89
  args: [{ selector: "[niceControlStatus]" }]
83
90
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i1.MatFormField }, { type: i2.TranslateService }]; } });
84
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control-status.directive.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/components/form-error/control-status.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ComponentRef, Directive, ElementRef, ViewContainerRef } from \"@angular/core\";\nimport { NgControl } from \"@angular/forms\";\nimport { MatFormField } from \"@angular/material/form-field\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { NiceFormErrorComponent } from \"./form-error.component\";\n\n@Directive({ selector: \"[niceControlStatus]\" })\nexport class NiceControlStatusDirective implements AfterViewInit {\n    private ref: ComponentRef<NiceFormErrorComponent>;\n    private control: NgControl;\n\n    constructor(\n        private el: ElementRef<HTMLElement>,\n        private vcr: ViewContainerRef,\n        private formField: MatFormField,\n        private translateService: TranslateService\n    ) {}\n\n    public ngAfterViewInit() {\n        this.control = this.formField._control.ngControl as NgControl;\n        this.control.statusChanges.subscribe(() => this.onChange());\n    }\n\n    public onChange(): void {\n        if (this.control.pending) {\n            return;\n        }\n\n        if (this.control.invalid && this.control.touched) {\n            for (const error in this.control.errors) {\n                if (this.control.errors.hasOwnProperty(error)) {\n                    if (this.control.errors[error]) {\n                        let lastErrorKey = error;\n                        let param: any;\n                        if (error === \"pattern\") {\n                            lastErrorKey = this.control.errors[error].requiredPattern;\n                        }\n                        if (error === \"mask\") {\n                            lastErrorKey = this.control.errors[error].requiredMask;\n                        }\n                        if (error === \"minlength\" || error === \"maxlength\") {\n                            param = {\n                                value: this.control.errors[error].requiredLength\n                            };\n                        }\n                        if (error === \"min\") {\n                            param = {\n                                min: this.control.errors[error].min,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n                        if (error === \"max\") {\n                            param = {\n                                max: this.control.errors[error].max,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n\n                        if (typeof this.control.errors[error] === \"object\" && !param) {\n                            param = this.control.errors[error];\n                        }\n\n                        this.setError(this.translateService.instant(`errors.${lastErrorKey}`, param));\n                        break;\n                    }\n                }\n            }\n        } else {\n            this.setError(\"\");\n        }\n    }\n\n    public setError(text: string): void {\n        if (!this.ref) {\n            this.ref = this.vcr.createComponent(NiceFormErrorComponent);\n            this.el.nativeElement\n                .getElementsByClassName(\"mat-form-field-wrapper\")\n                .item(0)\n                .getElementsByClassName(\"mat-form-field-subscript-wrapper\")\n                .item(0)\n                .appendChild(this.ref.location.nativeElement);\n        }\n        this.ref.instance.error = text;\n    }\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control-status.directive.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/components/form-error/control-status.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ComponentRef, Directive, ElementRef, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { NgControl } from \"@angular/forms\";\nimport { MatFormField } from \"@angular/material/form-field\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { NiceFormErrorComponent } from \"./form-error.component\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\n@Directive({ selector: \"[niceControlStatus]\" })\nexport class NiceControlStatusDirective implements AfterViewInit, OnDestroy {\n    private ref: ComponentRef<NiceFormErrorComponent>;\n    private control: NgControl;\n\n    private unsubscribeAll$ = new Subject<void>();\n\n    constructor(\n        private el: ElementRef<HTMLElement>,\n        private vcr: ViewContainerRef,\n        private formField: MatFormField,\n        private translateService: TranslateService\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this.control = this.formField._control.ngControl as NgControl;\n        this.control.statusChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(() => this.onChange());\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n\n    public onChange(): void {\n        if (this.control.pending) {\n            return;\n        }\n\n        if (this.control.invalid && this.control.touched) {\n            for (const error in this.control.errors) {\n                if (this.control.errors.hasOwnProperty(error)) {\n                    if (this.control.errors[error]) {\n                        let lastErrorKey = error;\n                        let param: any;\n                        if (error === \"pattern\") {\n                            lastErrorKey = this.control.errors[error].requiredPattern;\n                        }\n                        if (error === \"mask\") {\n                            lastErrorKey = this.control.errors[error].requiredMask;\n                        }\n                        if (error === \"minlength\" || error === \"maxlength\") {\n                            param = {\n                                value: this.control.errors[error].requiredLength\n                            };\n                        }\n                        if (error === \"min\") {\n                            param = {\n                                min: this.control.errors[error].min,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n                        if (error === \"max\") {\n                            param = {\n                                max: this.control.errors[error].max,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n\n                        if (typeof this.control.errors[error] === \"object\" && !param) {\n                            param = this.control.errors[error];\n                        }\n\n                        this.setError(this.translateService.instant(`errors.${lastErrorKey}`, param));\n                        break;\n                    }\n                }\n            }\n        } else {\n            this.setError(\"\");\n        }\n    }\n\n    public setError(text: string): void {\n        if (!this.ref) {\n            this.ref = this.vcr.createComponent(NiceFormErrorComponent);\n            this.el.nativeElement\n                .getElementsByClassName(\"mat-form-field-wrapper\")\n                .item(0)\n                .getElementsByClassName(\"mat-form-field-subscript-wrapper\")\n                .item(0)\n                .appendChild(this.ref.location.nativeElement);\n        }\n        this.ref.instance.error = text;\n    }\n}\n"]}
@@ -59,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImpor
59
59
  }], propDecorators: { error: [{
60
60
  type: Input
61
61
  }] } });
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1lcnJvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLXVpLWtpdC12Mi9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS1lcnJvci9mb3JtLWVycm9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7Ozs7QUF1QjFFLE1BQU0sT0FBTyxzQkFBc0I7SUFyQm5DO1FBdUJXLGNBQVMsR0FBRyxDQUFDLENBQUM7S0FXeEI7SUFURyxJQUNXLEtBQUssQ0FBQyxLQUFLO1FBQ2xCLElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLEtBQUssRUFBRTtnQkFDeEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO2FBQ3BCO1NBQ0o7UUFDRCxJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUN6QixDQUFDOzttSEFaUSxzQkFBc0I7dUdBQXRCLHNCQUFzQixnRkFsQnJCOzs7Ozs7S0FNVCxtT0FDVztRQUNSLE9BQU8sQ0FBQyxXQUFXLEVBQUU7WUFDakIsVUFBVSxDQUFDLFlBQVksRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxlQUFlLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2xHLFVBQVUsQ0FBQyxRQUFRLEVBQUU7Z0JBQ2pCLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsU0FBUyxFQUFFLG1CQUFtQixFQUFFLENBQUM7Z0JBQ3JELE9BQU8sQ0FBQyxlQUFlLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLENBQUMsQ0FBQzthQUM5RSxDQUFDO1lBQ0YsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLFNBQVMsRUFBRSxtQkFBbUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQzNHLENBQUM7S0FDTDsyRkFFUSxzQkFBc0I7a0JBckJsQyxTQUFTO21CQUFDO29CQUNQLGtFQUFrRTtvQkFDbEUsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFFBQVEsRUFBRTs7Ozs7O0tBTVQ7b0JBQ0QsVUFBVSxFQUFFO3dCQUNSLE9BQU8sQ0FBQyxXQUFXLEVBQUU7NEJBQ2pCLFVBQVUsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxPQUFPLENBQUMsZUFBZSxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzs0QkFDbEcsVUFBVSxDQUFDLFFBQVEsRUFBRTtnQ0FDakIsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsbUJBQW1CLEVBQUUsQ0FBQztnQ0FDckQsT0FBTyxDQUFDLGVBQWUsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLFNBQVMsRUFBRSxlQUFlLEVBQUUsQ0FBQyxDQUFDOzZCQUM5RSxDQUFDOzRCQUNGLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDM0csQ0FBQztxQkFDTDtpQkFDSjs4QkFNYyxLQUFLO3NCQURmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IGFuaW1hdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyIH0gZnJvbSBcIkBhbmd1bGFyL2FuaW1hdGlvbnNcIjtcblxuQENvbXBvbmVudCh7XG4gICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOmNvbXBvbmVudHMtc2VsZWN0b3IgY29tcG9uZW50LXNlbGVjdG9yXG4gICAgc2VsZWN0b3I6IFwiW2Zvcm0tZXJyb3JdXCIsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPGRpdiBbQGFuaW1hdGlvbl09XCJpbmNyZW1lbnRcIiAqbmdJZj1cIm1lc3NhZ2VcIj5cbiAgICAgICAgICAgIDxtYXQtZXJyb3I+XG4gICAgICAgICAgICAgICAge3sgbWVzc2FnZSB9fVxuICAgICAgICAgICAgPC9tYXQtZXJyb3I+XG4gICAgICAgIDwvZGl2PlxuICAgIGAsXG4gICAgYW5pbWF0aW9uczogW1xuICAgICAgICB0cmlnZ2VyKFwiYW5pbWF0aW9uXCIsIFtcbiAgICAgICAgICAgIHRyYW5zaXRpb24oXCI6aW5jcmVtZW50XCIsIFtzdHlsZSh7IG9wYWNpdHk6IDAgfSksIGFuaW1hdGUoXCIyMDBtcyBlYXNlLWluXCIsIHN0eWxlKHsgb3BhY2l0eTogMSB9KSldKSxcbiAgICAgICAgICAgIHRyYW5zaXRpb24oXCI6ZW50ZXJcIiwgW1xuICAgICAgICAgICAgICAgIHN0eWxlKHsgb3BhY2l0eTogMCwgdHJhbnNmb3JtOiBcInRyYW5zbGF0ZVkoLTFyZW0pXCIgfSksXG4gICAgICAgICAgICAgICAgYW5pbWF0ZShcIjIwMG1zIGVhc2UtaW5cIiwgc3R5bGUoeyBvcGFjaXR5OiAxLCB0cmFuc2Zvcm06IFwidHJhbnNsYXRlWSgwKVwiIH0pKVxuICAgICAgICAgICAgXSksXG4gICAgICAgICAgICB0cmFuc2l0aW9uKFwiOmxlYXZlXCIsIFthbmltYXRlKFwiMjAwbXMgZWFzZS1vdXRcIiwgc3R5bGUoeyBvcGFjaXR5OiAwLCB0cmFuc2Zvcm06IFwidHJhbnNsYXRlWSgtMXJlbSlcIiB9KSldKVxuICAgICAgICBdKVxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgTmljZUZvcm1FcnJvckNvbXBvbmVudCB7XG4gICAgcHVibGljIG1lc3NhZ2U6IHN0cmluZztcbiAgICBwdWJsaWMgaW5jcmVtZW50ID0gMDtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNldCBlcnJvcih2YWx1ZSkge1xuICAgICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLm1lc3NhZ2UgIT09IHZhbHVlKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5pbmNyZW1lbnQrKztcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICB0aGlzLm1lc3NhZ2UgPSB2YWx1ZTtcbiAgICB9XG59XG4iXX0=
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1lcnJvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLXVpLWtpdC12Mi9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS1lcnJvci9mb3JtLWVycm9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7Ozs7QUF1QjFFLE1BQU0sT0FBTyxzQkFBc0I7SUFyQm5DO1FBdUJXLGNBQVMsR0FBRyxDQUFDLENBQUM7S0FXeEI7SUFURyxJQUNXLEtBQUssQ0FBQyxLQUFhO1FBQzFCLElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLEtBQUssRUFBRTtnQkFDeEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO2FBQ3BCO1NBQ0o7UUFDRCxJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUN6QixDQUFDOzttSEFaUSxzQkFBc0I7dUdBQXRCLHNCQUFzQixnRkFsQnJCOzs7Ozs7S0FNVCxtT0FDVztRQUNSLE9BQU8sQ0FBQyxXQUFXLEVBQUU7WUFDakIsVUFBVSxDQUFDLFlBQVksRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxlQUFlLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2xHLFVBQVUsQ0FBQyxRQUFRLEVBQUU7Z0JBQ2pCLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsU0FBUyxFQUFFLG1CQUFtQixFQUFFLENBQUM7Z0JBQ3JELE9BQU8sQ0FBQyxlQUFlLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLENBQUMsQ0FBQzthQUM5RSxDQUFDO1lBQ0YsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLFNBQVMsRUFBRSxtQkFBbUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQzNHLENBQUM7S0FDTDsyRkFFUSxzQkFBc0I7a0JBckJsQyxTQUFTO21CQUFDO29CQUNQLGtFQUFrRTtvQkFDbEUsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFFBQVEsRUFBRTs7Ozs7O0tBTVQ7b0JBQ0QsVUFBVSxFQUFFO3dCQUNSLE9BQU8sQ0FBQyxXQUFXLEVBQUU7NEJBQ2pCLFVBQVUsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxPQUFPLENBQUMsZUFBZSxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzs0QkFDbEcsVUFBVSxDQUFDLFFBQVEsRUFBRTtnQ0FDakIsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsbUJBQW1CLEVBQUUsQ0FBQztnQ0FDckQsT0FBTyxDQUFDLGVBQWUsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLFNBQVMsRUFBRSxlQUFlLEVBQUUsQ0FBQyxDQUFDOzZCQUM5RSxDQUFDOzRCQUNGLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsbUJBQW1CLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQzt5QkFDM0csQ0FBQztxQkFDTDtpQkFDSjs4QkFNYyxLQUFLO3NCQURmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IGFuaW1hdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyIH0gZnJvbSBcIkBhbmd1bGFyL2FuaW1hdGlvbnNcIjtcblxuQENvbXBvbmVudCh7XG4gICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOmNvbXBvbmVudHMtc2VsZWN0b3IgY29tcG9uZW50LXNlbGVjdG9yXG4gICAgc2VsZWN0b3I6IFwiW2Zvcm0tZXJyb3JdXCIsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPGRpdiBbQGFuaW1hdGlvbl09XCJpbmNyZW1lbnRcIiAqbmdJZj1cIm1lc3NhZ2VcIj5cbiAgICAgICAgICAgIDxtYXQtZXJyb3I+XG4gICAgICAgICAgICAgICAge3sgbWVzc2FnZSB9fVxuICAgICAgICAgICAgPC9tYXQtZXJyb3I+XG4gICAgICAgIDwvZGl2PlxuICAgIGAsXG4gICAgYW5pbWF0aW9uczogW1xuICAgICAgICB0cmlnZ2VyKFwiYW5pbWF0aW9uXCIsIFtcbiAgICAgICAgICAgIHRyYW5zaXRpb24oXCI6aW5jcmVtZW50XCIsIFtzdHlsZSh7IG9wYWNpdHk6IDAgfSksIGFuaW1hdGUoXCIyMDBtcyBlYXNlLWluXCIsIHN0eWxlKHsgb3BhY2l0eTogMSB9KSldKSxcbiAgICAgICAgICAgIHRyYW5zaXRpb24oXCI6ZW50ZXJcIiwgW1xuICAgICAgICAgICAgICAgIHN0eWxlKHsgb3BhY2l0eTogMCwgdHJhbnNmb3JtOiBcInRyYW5zbGF0ZVkoLTFyZW0pXCIgfSksXG4gICAgICAgICAgICAgICAgYW5pbWF0ZShcIjIwMG1zIGVhc2UtaW5cIiwgc3R5bGUoeyBvcGFjaXR5OiAxLCB0cmFuc2Zvcm06IFwidHJhbnNsYXRlWSgwKVwiIH0pKVxuICAgICAgICAgICAgXSksXG4gICAgICAgICAgICB0cmFuc2l0aW9uKFwiOmxlYXZlXCIsIFthbmltYXRlKFwiMjAwbXMgZWFzZS1vdXRcIiwgc3R5bGUoeyBvcGFjaXR5OiAwLCB0cmFuc2Zvcm06IFwidHJhbnNsYXRlWSgtMXJlbSlcIiB9KSldKVxuICAgICAgICBdKVxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgTmljZUZvcm1FcnJvckNvbXBvbmVudCB7XG4gICAgcHVibGljIG1lc3NhZ2U6IHN0cmluZztcbiAgICBwdWJsaWMgaW5jcmVtZW50ID0gMDtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNldCBlcnJvcih2YWx1ZTogc3RyaW5nKSB7XG4gICAgICAgIGlmICh2YWx1ZSkge1xuICAgICAgICAgICAgaWYgKHRoaXMubWVzc2FnZSAhPT0gdmFsdWUpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmluY3JlbWVudCsrO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHRoaXMubWVzc2FnZSA9IHZhbHVlO1xuICAgIH1cbn1cbiJdfQ==
@@ -8,7 +8,8 @@ import * as i2 from "@angular/common";
8
8
  import * as i3 from "@angular/router";
9
9
  import * as i4 from "@angular/material/icon";
10
10
  import * as i5 from "@angular/material/menu";
11
- import * as i6 from "@ngx-translate/core";
11
+ import * as i6 from "@angular/material/tooltip";
12
+ import * as i7 from "@ngx-translate/core";
12
13
  export class NiceHorizontalNavigationBasicItemComponent {
13
14
  /**
14
15
  * Constructor
@@ -17,6 +18,8 @@ export class NiceHorizontalNavigationBasicItemComponent {
17
18
  this._changeDetectorRef = _changeDetectorRef;
18
19
  this._niceNavigationService = _niceNavigationService;
19
20
  this._unsubscribeAll = new Subject();
21
+ this.showTooltips = false;
22
+ this.tooltipPosition = "after";
20
23
  }
21
24
  // -----------------------------------------------------------------------------------------------------
22
25
  // @ Lifecycle hooks
@@ -43,13 +46,17 @@ export class NiceHorizontalNavigationBasicItemComponent {
43
46
  }
44
47
  }
45
48
  NiceHorizontalNavigationBasicItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceHorizontalNavigationBasicItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NiceNavigationService }], target: i0.ɵɵFactoryTarget.Component });
46
- NiceHorizontalNavigationBasicItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.3", type: NiceHorizontalNavigationBasicItemComponent, selector: "nice-horizontal-navigation-basic-item", inputs: { item: "item", name: "name" }, ngImport: i0, template: "<!-- Item wrapper -->\n<div\n class=\"nice-horizontal-navigation-item-wrapper\"\n [class.nice-horizontal-navigation-item-has-subtitle]=\"!!item.subtitle\"\n [ngClass]=\"item.classes?.wrapper\"\n>\n <!-- Item with an internal link -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n [queryParams]=\"item?.queryParams\"\n [state]=\"item?.state\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an external link -->\n <a\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && item.externalLink && !item.function && !item.disabled\"\n [href]=\"item.link\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n\n <!-- Item with a function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"!item.link && item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an internal link and function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && !item.externalLink && item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n [queryParams]=\"item?.queryParams\"\n [state]=\"item?.state\"\n (click)=\"item.function(item)\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an external link and function -->\n <a\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && item.externalLink && item.function && !item.disabled\"\n [href]=\"item.link\"\n (click)=\"item.function(item)\"\n mat-menu-item\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n\n <!-- Item with a no link and no function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"!item.link && !item.function && !item.disabled\"\n [ngClass]=\"{'nice-horizontal-navigation-item-active-forced': item.active}\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item is disabled -->\n <div\n class=\"nice-horizontal-navigation-item nice-horizontal-navigation-item-disabled\"\n *ngIf=\"item.disabled\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n <!-- Icon -->\n <mat-icon\n class=\"nice-vertical-navigation-item-icon\"\n [ngClass]=\"item.classes?.icon\"\n *ngIf=\"item.icon && item.iconType === 'material'\"\n >\n {{ item.icon }}\n </mat-icon>\n\n <span class=\"nice-vertical-navigation-item-icon\" [ngClass]=\"item.icon\" *ngIf=\"item.icon && item.iconType == 'fontawesome'\"></span>\n\n <mat-icon\n class=\"nice-vertical-navigation-item-icon\"\n [ngClass]=\"item.classes?.icon\"\n [svgIcon]=\"item.icon\"\n *ngIf=\"item.icon && item.iconType === 'svg'\"\n ></mat-icon>\n\n <!-- Title & Subtitle -->\n <div class=\"nice-horizontal-navigation-item-title-wrapper\">\n <div class=\"nice-horizontal-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{ item.title | translate }}\n </span>\n </div>\n <div\n class=\"nice-horizontal-navigation-item-subtitle text-hint\"\n *ngIf=\"item.subtitle\"\n >\n <span [ngClass]=\"item.classes?.subtitle\">\n {{ item.subtitle | translate }}\n </span>\n </div>\n </div>\n\n <!-- Badge -->\n <div\n class=\"nice-horizontal-navigation-item-badge\"\n *ngIf=\"item.badge\"\n >\n <div\n class=\"nice-horizontal-navigation-item-badge-content\"\n [ngClass]=\"item.badge.classes\">\n {{ item.badge.title | translate }}\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.RouterLink, selector: ":not(a):not(area)[routerLink]", inputs: ["queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
49
+ NiceHorizontalNavigationBasicItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.3", type: NiceHorizontalNavigationBasicItemComponent, selector: "nice-horizontal-navigation-basic-item", inputs: { item: "item", name: "name", showTooltips: "showTooltips", tooltipPosition: "tooltipPosition" }, ngImport: i0, template: "<!-- Item wrapper -->\n<div\n class=\"nice-horizontal-navigation-item-wrapper\"\n [class.nice-horizontal-navigation-item-has-subtitle]=\"!!item.subtitle\"\n [ngClass]=\"item.classes?.wrapper\"\n [matTooltip]=\"item.tooltip | translate\"\n [matTooltipDisabled]=\"!showTooltips\"\n [matTooltipPosition]=\"tooltipPosition\"\n>\n <!-- Item with an internal link -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n [queryParams]=\"item?.queryParams\"\n [state]=\"item?.state\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an external link -->\n <a\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && item.externalLink && !item.function && !item.disabled\"\n [href]=\"item.link\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n\n <!-- Item with a function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"!item.link && item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an internal link and function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && !item.externalLink && item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n [queryParams]=\"item?.queryParams\"\n [state]=\"item?.state\"\n (click)=\"item.function(item)\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an external link and function -->\n <a\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && item.externalLink && item.function && !item.disabled\"\n [href]=\"item.link\"\n (click)=\"item.function(item)\"\n mat-menu-item\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n\n <!-- Item with a no link and no function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"!item.link && !item.function && !item.disabled\"\n [ngClass]=\"{'nice-horizontal-navigation-item-active-forced': item.active}\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item is disabled -->\n <div\n class=\"nice-horizontal-navigation-item nice-horizontal-navigation-item-disabled\"\n *ngIf=\"item.disabled\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n <!-- Icon -->\n <mat-icon\n class=\"nice-vertical-navigation-item-icon\"\n [ngClass]=\"item.classes?.icon\"\n *ngIf=\"item.icon && item.iconType === 'material'\"\n >\n {{ item.icon }}\n </mat-icon>\n\n <span class=\"nice-vertical-navigation-item-icon\" [ngClass]=\"item.icon\" *ngIf=\"item.icon && item.iconType == 'fontawesome'\"></span>\n\n <mat-icon\n class=\"nice-vertical-navigation-item-icon\"\n [ngClass]=\"item.classes?.icon\"\n [svgIcon]=\"item.icon\"\n *ngIf=\"item.icon && item.iconType === 'svg'\"\n ></mat-icon>\n\n <!-- Title & Subtitle -->\n <div class=\"nice-horizontal-navigation-item-title-wrapper\">\n <div class=\"nice-horizontal-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{ item.title | translate }}\n </span>\n </div>\n <div\n class=\"nice-horizontal-navigation-item-subtitle text-hint\"\n *ngIf=\"item.subtitle\"\n >\n <span [ngClass]=\"item.classes?.subtitle\">\n {{ item.subtitle | translate }}\n </span>\n </div>\n </div>\n\n <!-- Badge -->\n <div\n class=\"nice-horizontal-navigation-item-badge\"\n *ngIf=\"item.badge\"\n >\n <div\n class=\"nice-horizontal-navigation-item-badge-content\"\n [ngClass]=\"item.badge.classes\">\n {{ item.badge.title | translate }}\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.RouterLink, selector: ":not(a):not(area)[routerLink]", inputs: ["queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
47
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.3", ngImport: i0, type: NiceHorizontalNavigationBasicItemComponent, decorators: [{
48
51
  type: Component,
49
- args: [{ selector: "nice-horizontal-navigation-basic-item", changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Item wrapper -->\n<div\n class=\"nice-horizontal-navigation-item-wrapper\"\n [class.nice-horizontal-navigation-item-has-subtitle]=\"!!item.subtitle\"\n [ngClass]=\"item.classes?.wrapper\"\n>\n <!-- Item with an internal link -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n [queryParams]=\"item?.queryParams\"\n [state]=\"item?.state\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an external link -->\n <a\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && item.externalLink && !item.function && !item.disabled\"\n [href]=\"item.link\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n\n <!-- Item with a function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"!item.link && item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an internal link and function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && !item.externalLink && item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n [queryParams]=\"item?.queryParams\"\n [state]=\"item?.state\"\n (click)=\"item.function(item)\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an external link and function -->\n <a\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && item.externalLink && item.function && !item.disabled\"\n [href]=\"item.link\"\n (click)=\"item.function(item)\"\n mat-menu-item\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n\n <!-- Item with a no link and no function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"!item.link && !item.function && !item.disabled\"\n [ngClass]=\"{'nice-horizontal-navigation-item-active-forced': item.active}\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item is disabled -->\n <div\n class=\"nice-horizontal-navigation-item nice-horizontal-navigation-item-disabled\"\n *ngIf=\"item.disabled\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n <!-- Icon -->\n <mat-icon\n class=\"nice-vertical-navigation-item-icon\"\n [ngClass]=\"item.classes?.icon\"\n *ngIf=\"item.icon && item.iconType === 'material'\"\n >\n {{ item.icon }}\n </mat-icon>\n\n <span class=\"nice-vertical-navigation-item-icon\" [ngClass]=\"item.icon\" *ngIf=\"item.icon && item.iconType == 'fontawesome'\"></span>\n\n <mat-icon\n class=\"nice-vertical-navigation-item-icon\"\n [ngClass]=\"item.classes?.icon\"\n [svgIcon]=\"item.icon\"\n *ngIf=\"item.icon && item.iconType === 'svg'\"\n ></mat-icon>\n\n <!-- Title & Subtitle -->\n <div class=\"nice-horizontal-navigation-item-title-wrapper\">\n <div class=\"nice-horizontal-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{ item.title | translate }}\n </span>\n </div>\n <div\n class=\"nice-horizontal-navigation-item-subtitle text-hint\"\n *ngIf=\"item.subtitle\"\n >\n <span [ngClass]=\"item.classes?.subtitle\">\n {{ item.subtitle | translate }}\n </span>\n </div>\n </div>\n\n <!-- Badge -->\n <div\n class=\"nice-horizontal-navigation-item-badge\"\n *ngIf=\"item.badge\"\n >\n <div\n class=\"nice-horizontal-navigation-item-badge-content\"\n [ngClass]=\"item.badge.classes\">\n {{ item.badge.title | translate }}\n </div>\n </div>\n</ng-template>\n" }]
52
+ args: [{ selector: "nice-horizontal-navigation-basic-item", changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Item wrapper -->\n<div\n class=\"nice-horizontal-navigation-item-wrapper\"\n [class.nice-horizontal-navigation-item-has-subtitle]=\"!!item.subtitle\"\n [ngClass]=\"item.classes?.wrapper\"\n [matTooltip]=\"item.tooltip | translate\"\n [matTooltipDisabled]=\"!showTooltips\"\n [matTooltipPosition]=\"tooltipPosition\"\n>\n <!-- Item with an internal link -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n [queryParams]=\"item?.queryParams\"\n [state]=\"item?.state\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an external link -->\n <a\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && item.externalLink && !item.function && !item.disabled\"\n [href]=\"item.link\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n\n <!-- Item with a function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"!item.link && item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n (click)=\"item.function(item)\">\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an internal link and function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && !item.externalLink && item.function && !item.disabled\"\n [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n [routerLink]=\"[item.link]\"\n [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n [queryParams]=\"item?.queryParams\"\n [state]=\"item?.state\"\n (click)=\"item.function(item)\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item with an external link and function -->\n <a\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"item.link && item.externalLink && item.function && !item.disabled\"\n [href]=\"item.link\"\n (click)=\"item.function(item)\"\n mat-menu-item\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </a>\n\n <!-- Item with a no link and no function -->\n <div\n class=\"nice-horizontal-navigation-item\"\n *ngIf=\"!item.link && !item.function && !item.disabled\"\n [ngClass]=\"{'nice-horizontal-navigation-item-active-forced': item.active}\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n\n <!-- Item is disabled -->\n <div\n class=\"nice-horizontal-navigation-item nice-horizontal-navigation-item-disabled\"\n *ngIf=\"item.disabled\"\n >\n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n </div>\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n <!-- Icon -->\n <mat-icon\n class=\"nice-vertical-navigation-item-icon\"\n [ngClass]=\"item.classes?.icon\"\n *ngIf=\"item.icon && item.iconType === 'material'\"\n >\n {{ item.icon }}\n </mat-icon>\n\n <span class=\"nice-vertical-navigation-item-icon\" [ngClass]=\"item.icon\" *ngIf=\"item.icon && item.iconType == 'fontawesome'\"></span>\n\n <mat-icon\n class=\"nice-vertical-navigation-item-icon\"\n [ngClass]=\"item.classes?.icon\"\n [svgIcon]=\"item.icon\"\n *ngIf=\"item.icon && item.iconType === 'svg'\"\n ></mat-icon>\n\n <!-- Title & Subtitle -->\n <div class=\"nice-horizontal-navigation-item-title-wrapper\">\n <div class=\"nice-horizontal-navigation-item-title\">\n <span [ngClass]=\"item.classes?.title\">\n {{ item.title | translate }}\n </span>\n </div>\n <div\n class=\"nice-horizontal-navigation-item-subtitle text-hint\"\n *ngIf=\"item.subtitle\"\n >\n <span [ngClass]=\"item.classes?.subtitle\">\n {{ item.subtitle | translate }}\n </span>\n </div>\n </div>\n\n <!-- Badge -->\n <div\n class=\"nice-horizontal-navigation-item-badge\"\n *ngIf=\"item.badge\"\n >\n <div\n class=\"nice-horizontal-navigation-item-badge-content\"\n [ngClass]=\"item.badge.classes\">\n {{ item.badge.title | translate }}\n </div>\n </div>\n</ng-template>\n" }]
50
53
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.NiceNavigationService }]; }, propDecorators: { item: [{
51
54
  type: Input
52
55
  }], name: [{
53
56
  type: Input
57
+ }], showTooltips: [{
58
+ type: Input
59
+ }], tooltipPosition: [{
60
+ type: Input
54
61
  }] } });
55
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/horizontal/components/basic/basic.component.ts","../../../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/horizontal/components/basic/basic.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAChH,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;;;;;;;;AASpE,MAAM,OAAO,0CAA0C;IAUnD;;OAEG;IACH,YACY,kBAAqC,EACrC,sBAA6C;QAD7C,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,2BAAsB,GAAtB,sBAAsB,CAAuB;QAbjD,oBAAe,GAAG,IAAI,OAAO,EAAO,CAAC;IAe7C,CAAC;IAED,wGAAwG;IACxG,oBAAoB;IACpB,wGAAwG;IAExG;;OAEG;IACI,QAAQ;QACX,sCAAsC;QACtC,IAAI,CAAC,kCAAkC,GAAG,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE9F,uDAAuD;QACvD,IAAI,CAAC,kCAAkC,CAAC,WAAW,CAAC,IAAI,CACpD,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAClC,CAAC,SAAS,CAAC,GAAG,EAAE;YACb,iBAAiB;YACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QAC3C,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACI,WAAW;QACd,qCAAqC;QACrC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;;uIA9CQ,0CAA0C;2HAA1C,0CAA0C,qHCZvD,yvJAmIA;2FDvHa,0CAA0C;kBANtD,SAAS;+BACI,uCAAuC,mBAGhC,uBAAuB,CAAC,MAAM;4IAOxC,IAAI;sBADV,KAAK;gBAIC,IAAI;sBADV,KAAK","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnDestroy, OnInit } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport { NiceNavigationService } from \"../../../navigation.service\";\nimport { NiceNavigationItem } from \"../../../navigation.types\";\n\n@Component({\n    selector: \"nice-horizontal-navigation-basic-item\",\n    templateUrl: \"./basic.component.html\",\n    styles: [],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NiceHorizontalNavigationBasicItemComponent implements OnInit, OnDestroy {\n    private _niceHorizontalNavigationComponent;\n    private _unsubscribeAll = new Subject<any>();\n\n    @Input()\n    public item: NiceNavigationItem;\n\n    @Input()\n    public name: string;\n\n    /**\n     * Constructor\n     */\n    constructor(\n        private _changeDetectorRef: ChangeDetectorRef,\n        private _niceNavigationService: NiceNavigationService\n    ) {\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Lifecycle hooks\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * On init\n     */\n    public ngOnInit(): void {\n        // Get the parent navigation component\n        this._niceHorizontalNavigationComponent = this._niceNavigationService.getComponent(this.name);\n\n        // Subscribe to onRefreshed on the navigation component\n        this._niceHorizontalNavigationComponent.onRefreshed.pipe(\n            takeUntil(this._unsubscribeAll)\n        ).subscribe(() => {\n            // Mark for check\n            this._changeDetectorRef.markForCheck();\n        });\n    }\n\n    /**\n     * On destroy\n     */\n    public ngOnDestroy(): void {\n        // Unsubscribe from all subscriptions\n        this._unsubscribeAll.next(null);\n        this._unsubscribeAll.complete();\n    }\n}\n","<!-- Item wrapper -->\n<div\n    class=\"nice-horizontal-navigation-item-wrapper\"\n    [class.nice-horizontal-navigation-item-has-subtitle]=\"!!item.subtitle\"\n    [ngClass]=\"item.classes?.wrapper\"\n>\n    <!-- Item with an internal link -->\n    <div\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\"\n        [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n        [routerLink]=\"[item.link]\"\n        [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n        [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n        [queryParams]=\"item?.queryParams\"\n        [state]=\"item?.state\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n\n    <!-- Item with an external link -->\n    <a\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"item.link && item.externalLink && !item.function && !item.disabled\"\n        [href]=\"item.link\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </a>\n\n    <!-- Item with a function -->\n    <div\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"!item.link && item.function && !item.disabled\"\n        [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n        (click)=\"item.function(item)\">\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n\n    <!-- Item with an internal link and function -->\n    <div\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"item.link && !item.externalLink && item.function && !item.disabled\"\n        [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n        [routerLink]=\"[item.link]\"\n        [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n        [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n        [queryParams]=\"item?.queryParams\"\n        [state]=\"item?.state\"\n        (click)=\"item.function(item)\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n\n    <!-- Item with an external link and function -->\n    <a\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"item.link && item.externalLink && item.function && !item.disabled\"\n        [href]=\"item.link\"\n        (click)=\"item.function(item)\"\n        mat-menu-item\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </a>\n\n    <!-- Item with a no link and no function -->\n    <div\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"!item.link && !item.function && !item.disabled\"\n        [ngClass]=\"{'nice-horizontal-navigation-item-active-forced': item.active}\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n\n    <!-- Item is disabled -->\n    <div\n        class=\"nice-horizontal-navigation-item nice-horizontal-navigation-item-disabled\"\n        *ngIf=\"item.disabled\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n    <!-- Icon -->\n    <mat-icon\n            class=\"nice-vertical-navigation-item-icon\"\n            [ngClass]=\"item.classes?.icon\"\n            *ngIf=\"item.icon && item.iconType === 'material'\"\n    >\n        {{ item.icon }}\n    </mat-icon>\n\n    <span class=\"nice-vertical-navigation-item-icon\" [ngClass]=\"item.icon\" *ngIf=\"item.icon && item.iconType == 'fontawesome'\"></span>\n\n    <mat-icon\n            class=\"nice-vertical-navigation-item-icon\"\n            [ngClass]=\"item.classes?.icon\"\n            [svgIcon]=\"item.icon\"\n            *ngIf=\"item.icon && item.iconType === 'svg'\"\n    ></mat-icon>\n\n    <!-- Title & Subtitle -->\n    <div class=\"nice-horizontal-navigation-item-title-wrapper\">\n        <div class=\"nice-horizontal-navigation-item-title\">\n            <span [ngClass]=\"item.classes?.title\">\n                {{ item.title | translate }}\n            </span>\n        </div>\n        <div\n            class=\"nice-horizontal-navigation-item-subtitle text-hint\"\n            *ngIf=\"item.subtitle\"\n        >\n            <span [ngClass]=\"item.classes?.subtitle\">\n                {{ item.subtitle | translate }}\n            </span>\n        </div>\n    </div>\n\n    <!-- Badge -->\n    <div\n        class=\"nice-horizontal-navigation-item-badge\"\n        *ngIf=\"item.badge\"\n    >\n        <div\n            class=\"nice-horizontal-navigation-item-badge-content\"\n            [ngClass]=\"item.badge.classes\">\n            {{ item.badge.title | translate }}\n        </div>\n    </div>\n</ng-template>\n"]}
62
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/horizontal/components/basic/basic.component.ts","../../../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/horizontal/components/basic/basic.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAEhH,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;;;;;;;;;AASpE,MAAM,OAAO,0CAA0C;IAgBnD;;OAEG;IACH,YACY,kBAAqC,EACrC,sBAA6C;QAD7C,uBAAkB,GAAlB,kBAAkB,CAAmB;QACrC,2BAAsB,GAAtB,sBAAsB,CAAuB;QAnBjD,oBAAe,GAAG,IAAI,OAAO,EAAO,CAAC;QAStC,iBAAY,GAAG,KAAK,CAAC;QAGrB,oBAAe,GAAoB,OAAO,CAAC;IASlD,CAAC;IAED,wGAAwG;IACxG,oBAAoB;IACpB,wGAAwG;IAExG;;OAEG;IACI,QAAQ;QACX,sCAAsC;QACtC,IAAI,CAAC,kCAAkC,GAAG,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE9F,uDAAuD;QACvD,IAAI,CAAC,kCAAkC,CAAC,WAAW,CAAC,IAAI,CACpD,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAClC,CAAC,SAAS,CAAC,GAAG,EAAE;YACb,iBAAiB;YACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QAC3C,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACI,WAAW;QACd,qCAAqC;QACrC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;;uIApDQ,0CAA0C;2HAA1C,0CAA0C,uLCbvD,k4JAsIA;2FDzHa,0CAA0C;kBANtD,SAAS;+BACI,uCAAuC,mBAGhC,uBAAuB,CAAC,MAAM;4IAOxC,IAAI;sBADV,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,YAAY;sBADlB,KAAK;gBAIC,eAAe;sBADrB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnDestroy, OnInit } from \"@angular/core\";\nimport { TooltipPosition } from \"@angular/material/tooltip\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport { NiceNavigationService } from \"../../../navigation.service\";\nimport { NiceNavigationItem } from \"../../../navigation.types\";\n\n@Component({\n    selector: \"nice-horizontal-navigation-basic-item\",\n    templateUrl: \"./basic.component.html\",\n    styles: [],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NiceHorizontalNavigationBasicItemComponent implements OnInit, OnDestroy {\n    private _niceHorizontalNavigationComponent;\n    private _unsubscribeAll = new Subject<any>();\n\n    @Input()\n    public item: NiceNavigationItem;\n\n    @Input()\n    public name: string;\n\n    @Input()\n    public showTooltips = false;\n\n    @Input()\n    public tooltipPosition: TooltipPosition = \"after\";\n\n    /**\n     * Constructor\n     */\n    constructor(\n        private _changeDetectorRef: ChangeDetectorRef,\n        private _niceNavigationService: NiceNavigationService\n    ) {\n    }\n\n    // -----------------------------------------------------------------------------------------------------\n    // @ Lifecycle hooks\n    // -----------------------------------------------------------------------------------------------------\n\n    /**\n     * On init\n     */\n    public ngOnInit(): void {\n        // Get the parent navigation component\n        this._niceHorizontalNavigationComponent = this._niceNavigationService.getComponent(this.name);\n\n        // Subscribe to onRefreshed on the navigation component\n        this._niceHorizontalNavigationComponent.onRefreshed.pipe(\n            takeUntil(this._unsubscribeAll)\n        ).subscribe(() => {\n            // Mark for check\n            this._changeDetectorRef.markForCheck();\n        });\n    }\n\n    /**\n     * On destroy\n     */\n    public ngOnDestroy(): void {\n        // Unsubscribe from all subscriptions\n        this._unsubscribeAll.next(null);\n        this._unsubscribeAll.complete();\n    }\n}\n","<!-- Item wrapper -->\n<div\n    class=\"nice-horizontal-navigation-item-wrapper\"\n    [class.nice-horizontal-navigation-item-has-subtitle]=\"!!item.subtitle\"\n    [ngClass]=\"item.classes?.wrapper\"\n    [matTooltip]=\"item.tooltip | translate\"\n    [matTooltipDisabled]=\"!showTooltips\"\n    [matTooltipPosition]=\"tooltipPosition\"\n>\n    <!-- Item with an internal link -->\n    <div\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"item.link && !item.externalLink && !item.function && !item.disabled\"\n        [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n        [routerLink]=\"[item.link]\"\n        [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n        [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n        [queryParams]=\"item?.queryParams\"\n        [state]=\"item?.state\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n\n    <!-- Item with an external link -->\n    <a\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"item.link && item.externalLink && !item.function && !item.disabled\"\n        [href]=\"item.link\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </a>\n\n    <!-- Item with a function -->\n    <div\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"!item.link && item.function && !item.disabled\"\n        [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n        (click)=\"item.function(item)\">\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n\n    <!-- Item with an internal link and function -->\n    <div\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"item.link && !item.externalLink && item.function && !item.disabled\"\n        [ngClass]=\"{ 'nice-horizontal-navigation-item-active-forced': item.active }\"\n        [routerLink]=\"[item.link]\"\n        [routerLinkActive]=\"'nice-horizontal-navigation-item-active'\"\n        [routerLinkActiveOptions]=\"{ exact: item.exactMatch || false }\"\n        [queryParams]=\"item?.queryParams\"\n        [state]=\"item?.state\"\n        (click)=\"item.function(item)\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n\n    <!-- Item with an external link and function -->\n    <a\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"item.link && item.externalLink && item.function && !item.disabled\"\n        [href]=\"item.link\"\n        (click)=\"item.function(item)\"\n        mat-menu-item\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </a>\n\n    <!-- Item with a no link and no function -->\n    <div\n        class=\"nice-horizontal-navigation-item\"\n        *ngIf=\"!item.link && !item.function && !item.disabled\"\n        [ngClass]=\"{'nice-horizontal-navigation-item-active-forced': item.active}\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n\n    <!-- Item is disabled -->\n    <div\n        class=\"nice-horizontal-navigation-item nice-horizontal-navigation-item-disabled\"\n        *ngIf=\"item.disabled\"\n    >\n        <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n    </div>\n</div>\n\n<!-- Item template -->\n<ng-template #itemTemplate>\n    <!-- Icon -->\n    <mat-icon\n            class=\"nice-vertical-navigation-item-icon\"\n            [ngClass]=\"item.classes?.icon\"\n            *ngIf=\"item.icon && item.iconType === 'material'\"\n    >\n        {{ item.icon }}\n    </mat-icon>\n\n    <span class=\"nice-vertical-navigation-item-icon\" [ngClass]=\"item.icon\" *ngIf=\"item.icon && item.iconType == 'fontawesome'\"></span>\n\n    <mat-icon\n            class=\"nice-vertical-navigation-item-icon\"\n            [ngClass]=\"item.classes?.icon\"\n            [svgIcon]=\"item.icon\"\n            *ngIf=\"item.icon && item.iconType === 'svg'\"\n    ></mat-icon>\n\n    <!-- Title & Subtitle -->\n    <div class=\"nice-horizontal-navigation-item-title-wrapper\">\n        <div class=\"nice-horizontal-navigation-item-title\">\n            <span [ngClass]=\"item.classes?.title\">\n                {{ item.title | translate }}\n            </span>\n        </div>\n        <div\n            class=\"nice-horizontal-navigation-item-subtitle text-hint\"\n            *ngIf=\"item.subtitle\"\n        >\n            <span [ngClass]=\"item.classes?.subtitle\">\n                {{ item.subtitle | translate }}\n            </span>\n        </div>\n    </div>\n\n    <!-- Badge -->\n    <div\n        class=\"nice-horizontal-navigation-item-badge\"\n        *ngIf=\"item.badge\"\n    >\n        <div\n            class=\"nice-horizontal-navigation-item-badge-content\"\n            [ngClass]=\"item.badge.classes\">\n            {{ item.badge.title | translate }}\n        </div>\n    </div>\n</ng-template>\n"]}