aril 1.1.22 → 1.1.24
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.
- package/esm2022/theme/layout/app/general-search/general-search.component.mjs +75 -0
- package/esm2022/theme/layout/app/general-search/helpers.mjs +92 -0
- package/esm2022/theme/layout/app/general-search/models.mjs +50 -0
- package/esm2022/theme/layout/app/topbar/app.topbar.component.mjs +56 -46
- package/esm2022/theme/layout/service/search.service.mjs +25 -0
- package/esm2022/ui/table/index.mjs +9 -4
- package/esm2022/ui/table/src/export-overlay-panel.component.mjs +321 -0
- package/esm2022/ui/table/src/interfaces.mjs +1 -1
- package/esm2022/ui/table/src/table.component.mjs +30 -164
- package/fesm2022/aril-theme-layout.mjs +300 -73
- package/fesm2022/aril-theme-layout.mjs.map +1 -1
- package/fesm2022/aril-ui-table.mjs +328 -156
- package/fesm2022/aril-ui-table.mjs.map +1 -1
- package/package.json +124 -124
- package/theme/layout/app/general-search/general-search.component.d.ts +22 -0
- package/theme/layout/app/general-search/general-search.component.html +57 -0
- package/theme/layout/app/general-search/general-search.component.scss +27 -0
- package/theme/layout/app/general-search/general-search.component.ts +93 -0
- package/theme/layout/app/general-search/helpers.d.ts +7 -0
- package/theme/layout/app/general-search/helpers.spec.ts +527 -0
- package/theme/layout/app/general-search/helpers.ts +106 -0
- package/theme/layout/app/general-search/models.d.ts +131 -0
- package/theme/layout/app/general-search/models.ts +142 -0
- package/theme/layout/app/topbar/app.topbar.component.d.ts +4 -2
- package/theme/layout/app/topbar/app.topbar.component.html +3 -9
- package/theme/layout/app/topbar/app.topbar.component.scss +0 -4
- package/theme/layout/app/topbar/app.topbar.component.ts +53 -43
- package/theme/layout/service/search.service.d.ts +11 -0
- package/theme/layout/service/search.service.ts +22 -0
- package/theme/styles/theme/base/components/input/_chips.scss +2 -0
- package/theme/styles/theme/dark/_variables.scss +27 -18
- package/ui/table/index.d.ts +3 -1
- package/ui/table/src/export-overlay-panel.component.d.ts +39 -0
- package/ui/table/src/interfaces.d.ts +1 -1
- package/ui/table/src/table.component.d.ts +5 -22
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, effect, signal } from '@angular/core';
|
|
3
|
+
import { toObservable, toSignal } from '@angular/core/rxjs-interop';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import { AutoCompleteModule } from 'primeng/autocomplete';
|
|
6
|
+
import { TranslocoModule } from '@ngneat/transloco';
|
|
7
|
+
import { of, startWith } from 'rxjs';
|
|
8
|
+
import { catchError, distinctUntilChanged, filter, map, switchMap } from 'rxjs/operators';
|
|
9
|
+
import { Apps } from 'aril/boot/config/apps';
|
|
10
|
+
import { getPresentableData } from './helpers';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "@angular/router";
|
|
13
|
+
import * as i2 from "../../service/search.service";
|
|
14
|
+
import * as i3 from "@angular/common";
|
|
15
|
+
import * as i4 from "@angular/forms";
|
|
16
|
+
import * as i5 from "@ngneat/transloco";
|
|
17
|
+
import * as i6 from "primeng/autocomplete";
|
|
18
|
+
import * as i7 from "primeng/api";
|
|
19
|
+
export class GeneralSearchComponent {
|
|
20
|
+
constructor(router, searchService) {
|
|
21
|
+
this.router = router;
|
|
22
|
+
this.searchService = searchService;
|
|
23
|
+
this.query = '';
|
|
24
|
+
this.activeTab = 'all';
|
|
25
|
+
this.data = {};
|
|
26
|
+
this.presentableData = [];
|
|
27
|
+
this.querySig = signal('');
|
|
28
|
+
this.resultsSig = toSignal(toObservable(this.querySig).pipe(map((q) => q.trim()), filter((q) => q.length > 2), distinctUntilChanged(), switchMap((q) => {
|
|
29
|
+
const payload = {
|
|
30
|
+
searchText: q,
|
|
31
|
+
assetDefinitionCodes: [],
|
|
32
|
+
pager: { pageSize: 5, pageNumber: 1 }
|
|
33
|
+
};
|
|
34
|
+
return this.searchService.searchForAssets(payload).pipe(map((res) => res.response), catchError(() => {
|
|
35
|
+
return of({});
|
|
36
|
+
}), startWith(null));
|
|
37
|
+
})), { initialValue: null });
|
|
38
|
+
effect(() => {
|
|
39
|
+
const results = this.resultsSig();
|
|
40
|
+
if (results) {
|
|
41
|
+
this.data = results;
|
|
42
|
+
this.presentableData = getPresentableData(results, this.activeTab);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
search(query) {
|
|
47
|
+
this.query = (query ?? '').trim();
|
|
48
|
+
this.querySig.set(this.query);
|
|
49
|
+
}
|
|
50
|
+
setTab(tab) {
|
|
51
|
+
this.activeTab = tab;
|
|
52
|
+
this.presentableData = getPresentableData(this.data, tab);
|
|
53
|
+
}
|
|
54
|
+
goToDetail(item) {
|
|
55
|
+
const isHostYeap = globalThis.activeHost === Apps.YEAP;
|
|
56
|
+
if (isHostYeap) {
|
|
57
|
+
this.router.navigate(['mng/master-data/view-md-data'], {
|
|
58
|
+
queryParams: { assetId: item.assetId }
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
this.router.navigate([item.url]);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
onResultClick(item) {
|
|
66
|
+
this.goToDetail(item.value);
|
|
67
|
+
}
|
|
68
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: GeneralSearchComponent, deps: [{ token: i1.Router }, { token: i2.SearchService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
69
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: GeneralSearchComponent, isStandalone: true, selector: "app-general-search", ngImport: i0, template: "<ng-container *transloco=\"let g\">\r\n\t<ng-container *transloco=\"let t; read: 'generalSearch'\">\r\n\t\t<div class=\"global-search\">\r\n\t\t\t<p-autoComplete\r\n\t\t\t\t[(ngModel)]=\"query\"\r\n\t\t\t\toptionLabel=\"title\"\r\n\t\t\t\tminLength=\"3\"\r\n\t\t\t\t[delay]=\"500\"\r\n\t\t\t\t(completeMethod)=\"search($event.query)\"\r\n\t\t\t\t[suggestions]=\"presentableData\"\r\n\t\t\t\t[placeholder]=\"t('placeholder')\"\r\n\t\t\t\t(onSelect)=\"onResultClick($event)\">\r\n\t\t\t\t<ng-template pTemplate=\"empty\">\r\n\t\t\t\t\t<div class=\"px-3\">\r\n\t\t\t\t\t\t{{ t('noResults') }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template pTemplate=\"header\">\r\n\t\t\t\t\t<div class=\"tabs flex gap-2 overflow-x-auto white-space-nowrap p-2 border-bottom-1 border-gray-200\">\r\n\t\t\t\t\t\t<span (click)=\"setTab('all')\" class=\"cursor-pointer py-1 px-2\" [class.active]=\"activeTab === 'all'\">\r\n\t\t\t\t\t\t\t{{ t('all') }}\r\n\t\t\t\t\t\t</span>\r\n\r\n\t\t\t\t\t\t@for (tab of data | keyvalue; track tab) {\r\n\t\t\t\t\t\t\t<span (click)=\"setTab(tab.key)\" class=\"cursor-pointer py-1 px-2\" [class.active]=\"activeTab === tab.key\">\r\n\t\t\t\t\t\t\t\t{{ data[tab.key].result[0].assetDefinitionName }}\r\n\t\t\t\t\t\t\t</span>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template let-result pTemplate=\"item\">\r\n\t\t\t\t\t<div class=\"flex items-center gap-2\">\r\n\t\t\t\t\t\t<div class=\"result-icon\">\r\n\t\t\t\t\t\t\t<i class=\"pi {{ result.icon }}\"></i>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<div class=\"result-text\">\r\n\t\t\t\t\t\t\t<div class=\"title mb-2\">{{ result.title }}</div>\r\n\t\t\t\t\t\t\t@if (result.subtitle) {\r\n\t\t\t\t\t\t\t\t<div class=\"subtitle\">{{ result.subtitle }}</div>\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t@if (result.url) {\r\n\t\t\t\t\t\t\t<div class=\"open-btn ml-auto align-self-center\">\r\n\t\t\t\t\t\t\t\t<i class=\"pi pi-chevron-right\"></i>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template pTemplate=\"footer\">\r\n\t\t\t\t\t<div class=\"px-3 py-3 border-top-1 border-gray-200\">\r\n\t\t\t\t\t\t<span>{{ presentableData.length }} {{ t('results') }}</span>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</p-autoComplete>\r\n\t\t</div>\r\n\t</ng-container>\r\n</ng-container>\r\n", styles: ["::ng-deep .p-autocomplete,::ng-deep .p-autocomplete-input{width:100%;max-width:100%}::ng-deep .p-overlay{width:100%!important;max-width:100%!important}::ng-deep .p-autocomplete-item.p-focus{background:var(--gray-100)}::ng-deep .tabs span.active{font-weight:700;border-bottom:2px solid var(--gray-900)}.global-search{position:relative}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i3.KeyValuePipe, name: "keyvalue" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: TranslocoModule }, { kind: "directive", type: i5.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoLang", "translocoLoadingTpl"] }, { kind: "ngmodule", type: AutoCompleteModule }, { kind: "component", type: i6.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "disabled", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "type", "autoZIndex", "baseZIndex", "ariaLabel", "dropdownAriaLabel", "ariaLabelledBy", "dropdownIcon", "unique", "group", "completeOnFocus", "showClear", "field", "dropdown", "showEmptyMessage", "dropdownMode", "multiple", "tabindex", "dataKey", "emptyMessage", "showTransitionOptions", "hideTransitionOptions", "autofocus", "autocomplete", "optionGroupChildren", "optionGroupLabel", "overlayOptions", "suggestions", "itemSize", "optionLabel", "optionValue", "id", "searchMessage", "emptySelectionMessage", "selectionMessage", "autoOptionFocus", "selectOnFocus", "searchLocale", "optionDisabled", "focusOnHover", "variant"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide", "onLazyLoad"] }, { kind: "directive", type: i7.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }] }); }
|
|
70
|
+
}
|
|
71
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: GeneralSearchComponent, decorators: [{
|
|
72
|
+
type: Component,
|
|
73
|
+
args: [{ selector: 'app-general-search', standalone: true, imports: [CommonModule, FormsModule, TranslocoModule, AutoCompleteModule], template: "<ng-container *transloco=\"let g\">\r\n\t<ng-container *transloco=\"let t; read: 'generalSearch'\">\r\n\t\t<div class=\"global-search\">\r\n\t\t\t<p-autoComplete\r\n\t\t\t\t[(ngModel)]=\"query\"\r\n\t\t\t\toptionLabel=\"title\"\r\n\t\t\t\tminLength=\"3\"\r\n\t\t\t\t[delay]=\"500\"\r\n\t\t\t\t(completeMethod)=\"search($event.query)\"\r\n\t\t\t\t[suggestions]=\"presentableData\"\r\n\t\t\t\t[placeholder]=\"t('placeholder')\"\r\n\t\t\t\t(onSelect)=\"onResultClick($event)\">\r\n\t\t\t\t<ng-template pTemplate=\"empty\">\r\n\t\t\t\t\t<div class=\"px-3\">\r\n\t\t\t\t\t\t{{ t('noResults') }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template pTemplate=\"header\">\r\n\t\t\t\t\t<div class=\"tabs flex gap-2 overflow-x-auto white-space-nowrap p-2 border-bottom-1 border-gray-200\">\r\n\t\t\t\t\t\t<span (click)=\"setTab('all')\" class=\"cursor-pointer py-1 px-2\" [class.active]=\"activeTab === 'all'\">\r\n\t\t\t\t\t\t\t{{ t('all') }}\r\n\t\t\t\t\t\t</span>\r\n\r\n\t\t\t\t\t\t@for (tab of data | keyvalue; track tab) {\r\n\t\t\t\t\t\t\t<span (click)=\"setTab(tab.key)\" class=\"cursor-pointer py-1 px-2\" [class.active]=\"activeTab === tab.key\">\r\n\t\t\t\t\t\t\t\t{{ data[tab.key].result[0].assetDefinitionName }}\r\n\t\t\t\t\t\t\t</span>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template let-result pTemplate=\"item\">\r\n\t\t\t\t\t<div class=\"flex items-center gap-2\">\r\n\t\t\t\t\t\t<div class=\"result-icon\">\r\n\t\t\t\t\t\t\t<i class=\"pi {{ result.icon }}\"></i>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<div class=\"result-text\">\r\n\t\t\t\t\t\t\t<div class=\"title mb-2\">{{ result.title }}</div>\r\n\t\t\t\t\t\t\t@if (result.subtitle) {\r\n\t\t\t\t\t\t\t\t<div class=\"subtitle\">{{ result.subtitle }}</div>\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t@if (result.url) {\r\n\t\t\t\t\t\t\t<div class=\"open-btn ml-auto align-self-center\">\r\n\t\t\t\t\t\t\t\t<i class=\"pi pi-chevron-right\"></i>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template pTemplate=\"footer\">\r\n\t\t\t\t\t<div class=\"px-3 py-3 border-top-1 border-gray-200\">\r\n\t\t\t\t\t\t<span>{{ presentableData.length }} {{ t('results') }}</span>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</p-autoComplete>\r\n\t\t</div>\r\n\t</ng-container>\r\n</ng-container>\r\n", styles: ["::ng-deep .p-autocomplete,::ng-deep .p-autocomplete-input{width:100%;max-width:100%}::ng-deep .p-overlay{width:100%!important;max-width:100%!important}::ng-deep .p-autocomplete-item.p-focus{background:var(--gray-100)}::ng-deep .tabs span.active{font-weight:700;border-bottom:2px solid var(--gray-900)}.global-search{position:relative}\n"] }]
|
|
74
|
+
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.SearchService }] });
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general-search.component.js","sourceRoot":"","sources":["../../../../../../projects/aril/theme/layout/app/general-search/general-search.component.ts","../../../../../../projects/aril/theme/layout/app/general-search/general-search.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, effect, signal } from '@angular/core';\r\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { Router } from '@angular/router';\r\n\r\nimport { AutoCompleteModule, AutoCompleteSelectEvent } from 'primeng/autocomplete';\r\n\r\nimport { TranslocoModule } from '@ngneat/transloco';\r\nimport { of, startWith } from 'rxjs';\r\nimport { catchError, distinctUntilChanged, filter, map, switchMap } from 'rxjs/operators';\r\n\r\nimport { Apps } from 'aril/boot/config/apps';\r\n\r\nimport { SearchService } from '../../service/search.service';\r\nimport { getPresentableData } from './helpers';\r\nimport { CacheSearchRequestDTO, DefaultSearchAggregateAssetAggregate, PresentableData } from './models';\r\n\r\n@Component({\r\n\tselector: 'app-general-search',\r\n\tstandalone: true,\r\n\timports: [CommonModule, FormsModule, TranslocoModule, AutoCompleteModule],\r\n\ttemplateUrl: './general-search.component.html',\r\n\tstyleUrls: ['./general-search.component.scss']\r\n})\r\nexport class GeneralSearchComponent {\r\n\tquery = '';\r\n\tactiveTab = 'all';\r\n\tdata: DefaultSearchAggregateAssetAggregate = {};\r\n\tpresentableData: PresentableData[] = [];\r\n\tquerySig = signal<string>('');\r\n\tresultsSig = toSignal<DefaultSearchAggregateAssetAggregate | null>(\r\n\t\ttoObservable(this.querySig).pipe(\r\n\t\t\tmap((q) => q.trim()),\r\n\t\t\tfilter((q) => q.length > 2),\r\n\t\t\tdistinctUntilChanged(),\r\n\t\t\tswitchMap((q) => {\r\n\t\t\t\tconst payload: CacheSearchRequestDTO = {\r\n\t\t\t\t\tsearchText: q,\r\n\t\t\t\t\tassetDefinitionCodes: [],\r\n\t\t\t\t\tpager: { pageSize: 5, pageNumber: 1 }\r\n\t\t\t\t};\r\n\t\t\t\treturn this.searchService.searchForAssets(payload).pipe(\r\n\t\t\t\t\tmap((res) => res.response),\r\n\t\t\t\t\tcatchError(() => {\r\n\t\t\t\t\t\treturn of({} as DefaultSearchAggregateAssetAggregate);\r\n\t\t\t\t\t}),\r\n\t\t\t\t\tstartWith(null)\r\n\t\t\t\t);\r\n\t\t\t})\r\n\t\t),\r\n\t\t{ initialValue: null }\r\n\t);\r\n\r\n\tconstructor(\r\n\t\tprivate readonly router: Router,\r\n\t\tprivate readonly searchService: SearchService\r\n\t) {\r\n\t\teffect(() => {\r\n\t\t\tconst results = this.resultsSig();\r\n\t\t\tif (results) {\r\n\t\t\t\tthis.data = results;\r\n\t\t\t\tthis.presentableData = getPresentableData(results, this.activeTab);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tsearch(query: string) {\r\n\t\tthis.query = (query ?? '').trim();\r\n\t\tthis.querySig.set(this.query);\r\n\t}\r\n\r\n\tsetTab(tab: string) {\r\n\t\tthis.activeTab = tab;\r\n\t\tthis.presentableData = getPresentableData(this.data, tab);\r\n\t}\r\n\r\n\tgoToDetail(item: PresentableData) {\r\n\t\tconst isHostYeap = (<any>globalThis).activeHost === Apps.YEAP;\r\n\r\n\t\tif (isHostYeap) {\r\n\t\t\tthis.router.navigate(['mng/master-data/view-md-data'], {\r\n\t\t\t\tqueryParams: { assetId: item.assetId }\r\n\t\t\t});\r\n\t\t} else {\r\n\t\t\tthis.router.navigate([item.url]);\r\n\t\t}\r\n\t}\r\n\r\n\tonResultClick(item: AutoCompleteSelectEvent) {\r\n\t\tthis.goToDetail(item.value);\r\n\t}\r\n}\r\n","<ng-container *transloco=\"let g\">\r\n\t<ng-container *transloco=\"let t; read: 'generalSearch'\">\r\n\t\t<div class=\"global-search\">\r\n\t\t\t<p-autoComplete\r\n\t\t\t\t[(ngModel)]=\"query\"\r\n\t\t\t\toptionLabel=\"title\"\r\n\t\t\t\tminLength=\"3\"\r\n\t\t\t\t[delay]=\"500\"\r\n\t\t\t\t(completeMethod)=\"search($event.query)\"\r\n\t\t\t\t[suggestions]=\"presentableData\"\r\n\t\t\t\t[placeholder]=\"t('placeholder')\"\r\n\t\t\t\t(onSelect)=\"onResultClick($event)\">\r\n\t\t\t\t<ng-template pTemplate=\"empty\">\r\n\t\t\t\t\t<div class=\"px-3\">\r\n\t\t\t\t\t\t{{ t('noResults') }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template pTemplate=\"header\">\r\n\t\t\t\t\t<div class=\"tabs flex gap-2 overflow-x-auto white-space-nowrap p-2 border-bottom-1 border-gray-200\">\r\n\t\t\t\t\t\t<span (click)=\"setTab('all')\" class=\"cursor-pointer py-1 px-2\" [class.active]=\"activeTab === 'all'\">\r\n\t\t\t\t\t\t\t{{ t('all') }}\r\n\t\t\t\t\t\t</span>\r\n\r\n\t\t\t\t\t\t@for (tab of data | keyvalue; track tab) {\r\n\t\t\t\t\t\t\t<span (click)=\"setTab(tab.key)\" class=\"cursor-pointer py-1 px-2\" [class.active]=\"activeTab === tab.key\">\r\n\t\t\t\t\t\t\t\t{{ data[tab.key].result[0].assetDefinitionName }}\r\n\t\t\t\t\t\t\t</span>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template let-result pTemplate=\"item\">\r\n\t\t\t\t\t<div class=\"flex items-center gap-2\">\r\n\t\t\t\t\t\t<div class=\"result-icon\">\r\n\t\t\t\t\t\t\t<i class=\"pi {{ result.icon }}\"></i>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<div class=\"result-text\">\r\n\t\t\t\t\t\t\t<div class=\"title mb-2\">{{ result.title }}</div>\r\n\t\t\t\t\t\t\t@if (result.subtitle) {\r\n\t\t\t\t\t\t\t\t<div class=\"subtitle\">{{ result.subtitle }}</div>\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t@if (result.url) {\r\n\t\t\t\t\t\t\t<div class=\"open-btn ml-auto align-self-center\">\r\n\t\t\t\t\t\t\t\t<i class=\"pi pi-chevron-right\"></i>\r\n\t\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template pTemplate=\"footer\">\r\n\t\t\t\t\t<div class=\"px-3 py-3 border-top-1 border-gray-200\">\r\n\t\t\t\t\t\t<span>{{ presentableData.length }} {{ t('results') }}</span>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</p-autoComplete>\r\n\t\t</div>\r\n\t</ng-container>\r\n</ng-container>\r\n"]}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { AssetCodes } from './models';
|
|
2
|
+
import { PrimeIcons } from 'primeng/api';
|
|
3
|
+
export function getIcon(key) {
|
|
4
|
+
switch (key) {
|
|
5
|
+
case AssetCodes.Account:
|
|
6
|
+
return PrimeIcons.USER;
|
|
7
|
+
case AssetCodes.HumanBusinessPartner:
|
|
8
|
+
return PrimeIcons.USER;
|
|
9
|
+
case AssetCodes.Contract:
|
|
10
|
+
return PrimeIcons.FILE_EDIT;
|
|
11
|
+
case AssetCodes.ConnectionPoint:
|
|
12
|
+
return PrimeIcons.BUILDING;
|
|
13
|
+
case AssetCodes.Warehouse:
|
|
14
|
+
return PrimeIcons.LIST;
|
|
15
|
+
case AssetCodes.Team:
|
|
16
|
+
return PrimeIcons.LIST;
|
|
17
|
+
case AssetCodes.Premise:
|
|
18
|
+
return PrimeIcons.BUILDING;
|
|
19
|
+
case AssetCodes.PowerTransformer:
|
|
20
|
+
return PrimeIcons.BOLT;
|
|
21
|
+
case AssetCodes.Gateway:
|
|
22
|
+
return PrimeIcons.SERVER;
|
|
23
|
+
case AssetCodes.Seal:
|
|
24
|
+
return PrimeIcons.TICKET;
|
|
25
|
+
case AssetCodes.Meter:
|
|
26
|
+
return PrimeIcons.COMPASS;
|
|
27
|
+
case AssetCodes.SimCard:
|
|
28
|
+
return PrimeIcons.LIST;
|
|
29
|
+
case AssetCodes.MeasurementTransformer:
|
|
30
|
+
return PrimeIcons.LIST;
|
|
31
|
+
case AssetCodes.MaterialClass:
|
|
32
|
+
return PrimeIcons.LIST;
|
|
33
|
+
case AssetCodes.GatewayMaterialClass:
|
|
34
|
+
return PrimeIcons.LIST;
|
|
35
|
+
case AssetCodes.MeterMaterialClass:
|
|
36
|
+
return PrimeIcons.LIST;
|
|
37
|
+
case AssetCodes.PowerTransformerMaterialClass:
|
|
38
|
+
return PrimeIcons.LIST;
|
|
39
|
+
case AssetCodes.MeasurementTransformerMaterialClass:
|
|
40
|
+
return PrimeIcons.LIST;
|
|
41
|
+
case AssetCodes.BusinessPartner:
|
|
42
|
+
return PrimeIcons.USER;
|
|
43
|
+
case AssetCodes.LegalEntityBusinessPartner:
|
|
44
|
+
return PrimeIcons.BUILDING;
|
|
45
|
+
case AssetCodes.Organization:
|
|
46
|
+
return PrimeIcons.LIST;
|
|
47
|
+
case AssetCodes.FieldStaff:
|
|
48
|
+
return PrimeIcons.LIST;
|
|
49
|
+
case AssetCodes.SSB:
|
|
50
|
+
return PrimeIcons.LIST;
|
|
51
|
+
case AssetCodes.ServicePoint:
|
|
52
|
+
return PrimeIcons.COG;
|
|
53
|
+
case AssetCodes.ServicePointGroup:
|
|
54
|
+
return PrimeIcons.SITEMAP;
|
|
55
|
+
case AssetCodes.Device:
|
|
56
|
+
return PrimeIcons.PHONE;
|
|
57
|
+
default:
|
|
58
|
+
return PrimeIcons.LIST;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
export const getPresentableData = (items, key) => {
|
|
62
|
+
const transformToPresentableDataFor = (k) => (item) => {
|
|
63
|
+
const attributes = item?.attributes ?? [];
|
|
64
|
+
const assetNumberAttr = attributes.find((a) => a?.attribute?.attributeCode === 'AssetNumber');
|
|
65
|
+
const assetNameAttr = attributes.find((a) => a?.attribute?.attributeCode === 'AssetDefinitionName');
|
|
66
|
+
const number = assetNumberAttr?.valueDesc ?? 'N/A';
|
|
67
|
+
const subtitle = attributes
|
|
68
|
+
.filter((a) => a?.attribute?.attributeCode !== 'AssetNumber')
|
|
69
|
+
.map((a) => a?.valueDesc)
|
|
70
|
+
.filter((v) => v != null && v !== '')
|
|
71
|
+
.map(String)
|
|
72
|
+
.join(' - ');
|
|
73
|
+
const assetIdAttr = attributes.find((a) => a?.attribute?.attributeCode === 'AssetId');
|
|
74
|
+
const id = assetIdAttr?.valueDesc ?? '';
|
|
75
|
+
const icon = getIcon(k);
|
|
76
|
+
const url = assetNumberAttr?.attribute?.referringAsset?.detailPageUrl ?
|
|
77
|
+
`${assetNumberAttr.attribute.referringAsset.detailPageUrl}/${id}`
|
|
78
|
+
: '';
|
|
79
|
+
return {
|
|
80
|
+
title: `${assetNameAttr?.valueDesc ?? 'N/A'} #${number}`,
|
|
81
|
+
subtitle,
|
|
82
|
+
icon,
|
|
83
|
+
url: url,
|
|
84
|
+
assetId: id
|
|
85
|
+
};
|
|
86
|
+
};
|
|
87
|
+
if (key === 'all') {
|
|
88
|
+
return Object.keys(items).flatMap((k) => (items[k]?.result ?? []).map(transformToPresentableDataFor(k)));
|
|
89
|
+
}
|
|
90
|
+
return (items[key]?.result ?? []).map(transformToPresentableDataFor(key));
|
|
91
|
+
};
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../../../../projects/aril/theme/layout/app/general-search/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,UAAU,EAAmB,MAAM,UAAU,CAAC;AAIvE,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAIzC,MAAM,UAAU,OAAO,CAAC,GAAW;IAClC,QAAQ,GAAG,EAAE,CAAC;QACb,KAAK,UAAU,CAAC,OAAO;YACtB,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,oBAAoB;YACnC,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,QAAQ;YACvB,OAAO,UAAU,CAAC,SAAS,CAAC;QAC7B,KAAK,UAAU,CAAC,eAAe;YAC9B,OAAO,UAAU,CAAC,QAAQ,CAAC;QAC5B,KAAK,UAAU,CAAC,SAAS;YACxB,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,IAAI;YACnB,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,OAAO;YACtB,OAAO,UAAU,CAAC,QAAQ,CAAC;QAC5B,KAAK,UAAU,CAAC,gBAAgB;YAC/B,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,OAAO;YACtB,OAAO,UAAU,CAAC,MAAM,CAAC;QAC1B,KAAK,UAAU,CAAC,IAAI;YACnB,OAAO,UAAU,CAAC,MAAM,CAAC;QAC1B,KAAK,UAAU,CAAC,KAAK;YACpB,OAAO,UAAU,CAAC,OAAO,CAAC;QAC3B,KAAK,UAAU,CAAC,OAAO;YACtB,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,sBAAsB;YACrC,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,aAAa;YAC5B,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,oBAAoB;YACnC,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,kBAAkB;YACjC,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,6BAA6B;YAC5C,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,mCAAmC;YAClD,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,eAAe;YAC9B,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,0BAA0B;YACzC,OAAO,UAAU,CAAC,QAAQ,CAAC;QAC5B,KAAK,UAAU,CAAC,YAAY;YAC3B,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,UAAU;YACzB,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,GAAG;YAClB,OAAO,UAAU,CAAC,IAAI,CAAC;QACxB,KAAK,UAAU,CAAC,YAAY;YAC3B,OAAO,UAAU,CAAC,GAAG,CAAC;QACvB,KAAK,UAAU,CAAC,iBAAiB;YAChC,OAAO,UAAU,CAAC,OAAO,CAAC;QAC3B,KAAK,UAAU,CAAC,MAAM;YACrB,OAAO,UAAU,CAAC,KAAK,CAAC;QACzB;YACC,OAAO,UAAU,CAAC,IAAI,CAAC;IACzB,CAAC;AACF,CAAC;AAED,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,KAA2C,EAAE,GAAW,EAAqB,EAAE;IACjH,MAAM,6BAA6B,GAAG,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,IAAoB,EAAE,EAAE;QAC7E,MAAM,UAAU,GAAG,IAAI,EAAE,UAAU,IAAI,EAAE,CAAC;QAE1C,MAAM,eAAe,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,aAAa,KAAK,aAAa,CAAC,CAAC;QAC9F,MAAM,aAAa,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,aAAa,KAAK,qBAAqB,CAAC,CAAC;QAEpG,MAAM,MAAM,GAAG,eAAe,EAAE,SAAS,IAAI,KAAK,CAAC;QAEnD,MAAM,QAAQ,GAAG,UAAU;aACzB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,aAAa,KAAK,aAAa,CAAC;aAC5D,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,SAAS,CAAC;aACxB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;aACpC,GAAG,CAAC,MAAM,CAAC;aACX,IAAI,CAAC,KAAK,CAAC,CAAC;QAEd,MAAM,WAAW,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,aAAa,KAAK,SAAS,CAAC,CAAC;QACtF,MAAM,EAAE,GAAG,WAAW,EAAE,SAAS,IAAI,EAAE,CAAC;QACxC,MAAM,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QACxB,MAAM,GAAG,GACR,eAAe,EAAE,SAAS,EAAE,cAAc,EAAE,aAAa,CAAC,CAAC;YAC1D,GAAG,eAAe,CAAC,SAAS,CAAC,cAAc,CAAC,aAAa,IAAI,EAAE,EAAE;YAClE,CAAC,CAAC,EAAE,CAAC;QAEN,OAAO;YACN,KAAK,EAAE,GAAG,aAAa,EAAE,SAAS,IAAI,KAAK,KAAK,MAAM,EAAE;YACxD,QAAQ;YACR,IAAI;YACJ,GAAG,EAAE,GAAG;YACR,OAAO,EAAE,EAAE;SACX,CAAC;IACH,CAAC,CAAC;IAEF,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;QACnB,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1G,CAAC;IAED,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,MAAM,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,6BAA6B,CAAC,GAAG,CAAC,CAAC,CAAC;AAC3E,CAAC,CAAC","sourcesContent":["import { AssetAggregate, AssetCodes, PresentableData } from './models';\r\n\r\nimport { DefaultSearchAggregateAssetAggregate } from './models';\r\n\r\nimport { PrimeIcons } from 'primeng/api';\r\n\r\ntype MappedIcon = PrimeIcons;\r\n\r\nexport function getIcon(key: string): MappedIcon {\r\n\tswitch (key) {\r\n\t\tcase AssetCodes.Account:\r\n\t\t\treturn PrimeIcons.USER;\r\n\t\tcase AssetCodes.HumanBusinessPartner:\r\n\t\t\treturn PrimeIcons.USER;\r\n\t\tcase AssetCodes.Contract:\r\n\t\t\treturn PrimeIcons.FILE_EDIT;\r\n\t\tcase AssetCodes.ConnectionPoint:\r\n\t\t\treturn PrimeIcons.BUILDING;\r\n\t\tcase AssetCodes.Warehouse:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.Team:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.Premise:\r\n\t\t\treturn PrimeIcons.BUILDING;\r\n\t\tcase AssetCodes.PowerTransformer:\r\n\t\t\treturn PrimeIcons.BOLT;\r\n\t\tcase AssetCodes.Gateway:\r\n\t\t\treturn PrimeIcons.SERVER;\r\n\t\tcase AssetCodes.Seal:\r\n\t\t\treturn PrimeIcons.TICKET;\r\n\t\tcase AssetCodes.Meter:\r\n\t\t\treturn PrimeIcons.COMPASS;\r\n\t\tcase AssetCodes.SimCard:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.MeasurementTransformer:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.MaterialClass:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.GatewayMaterialClass:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.MeterMaterialClass:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.PowerTransformerMaterialClass:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.MeasurementTransformerMaterialClass:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.BusinessPartner:\r\n\t\t\treturn PrimeIcons.USER;\r\n\t\tcase AssetCodes.LegalEntityBusinessPartner:\r\n\t\t\treturn PrimeIcons.BUILDING;\r\n\t\tcase AssetCodes.Organization:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.FieldStaff:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.SSB:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t\tcase AssetCodes.ServicePoint:\r\n\t\t\treturn PrimeIcons.COG;\r\n\t\tcase AssetCodes.ServicePointGroup:\r\n\t\t\treturn PrimeIcons.SITEMAP;\r\n\t\tcase AssetCodes.Device:\r\n\t\t\treturn PrimeIcons.PHONE;\r\n\t\tdefault:\r\n\t\t\treturn PrimeIcons.LIST;\r\n\t}\r\n}\r\n\r\nexport const getPresentableData = (items: DefaultSearchAggregateAssetAggregate, key: string): PresentableData[] => {\r\n\tconst transformToPresentableDataFor = (k: string) => (item: AssetAggregate) => {\r\n\t\tconst attributes = item?.attributes ?? [];\r\n\r\n\t\tconst assetNumberAttr = attributes.find((a) => a?.attribute?.attributeCode === 'AssetNumber');\r\n\t\tconst assetNameAttr = attributes.find((a) => a?.attribute?.attributeCode === 'AssetDefinitionName');\r\n\r\n\t\tconst number = assetNumberAttr?.valueDesc ?? 'N/A';\r\n\r\n\t\tconst subtitle = attributes\r\n\t\t\t.filter((a) => a?.attribute?.attributeCode !== 'AssetNumber')\r\n\t\t\t.map((a) => a?.valueDesc)\r\n\t\t\t.filter((v) => v != null && v !== '')\r\n\t\t\t.map(String)\r\n\t\t\t.join(' - ');\r\n\r\n\t\tconst assetIdAttr = attributes.find((a) => a?.attribute?.attributeCode === 'AssetId');\r\n\t\tconst id = assetIdAttr?.valueDesc ?? '';\r\n\t\tconst icon = getIcon(k);\r\n\t\tconst url =\r\n\t\t\tassetNumberAttr?.attribute?.referringAsset?.detailPageUrl ?\r\n\t\t\t\t`${assetNumberAttr.attribute.referringAsset.detailPageUrl}/${id}`\r\n\t\t\t:\t'';\r\n\r\n\t\treturn {\r\n\t\t\ttitle: `${assetNameAttr?.valueDesc ?? 'N/A'} #${number}`,\r\n\t\t\tsubtitle,\r\n\t\t\ticon,\r\n\t\t\turl: url,\r\n\t\t\tassetId: id\r\n\t\t};\r\n\t};\r\n\r\n\tif (key === 'all') {\r\n\t\treturn Object.keys(items).flatMap((k) => (items[k]?.result ?? []).map(transformToPresentableDataFor(k)));\r\n\t}\r\n\r\n\treturn (items[key]?.result ?? []).map(transformToPresentableDataFor(key));\r\n};\r\n"]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
export var AssetCodes;
|
|
2
|
+
(function (AssetCodes) {
|
|
3
|
+
AssetCodes["MasterData"] = "MasterData";
|
|
4
|
+
AssetCodes["LightingFacility"] = "LightingFacility";
|
|
5
|
+
AssetCodes["ConnectionPoint"] = "ConnectionPoint";
|
|
6
|
+
AssetCodes["Premise"] = "Premise";
|
|
7
|
+
AssetCodes["ServicePoint"] = "ServicePoint";
|
|
8
|
+
AssetCodes["ServicePointGroup"] = "ServicePointGroup";
|
|
9
|
+
AssetCodes["DistributionConnectionAgreement"] = "DistributionConnectionAgreement";
|
|
10
|
+
AssetCodes["Contract"] = "Contract";
|
|
11
|
+
AssetCodes["BusinessPartner"] = "BusinessPartner";
|
|
12
|
+
AssetCodes["Account"] = "Account";
|
|
13
|
+
AssetCodes["Warehouse"] = "Warehouse";
|
|
14
|
+
AssetCodes["Team"] = "Team";
|
|
15
|
+
AssetCodes["Device"] = "Device";
|
|
16
|
+
AssetCodes["Location"] = "Location";
|
|
17
|
+
AssetCodes["Material"] = "Material";
|
|
18
|
+
AssetCodes["SerializedMaterial"] = "SerializedMaterial";
|
|
19
|
+
AssetCodes["LegalEntityBusinessPartner"] = "LegalEntityBusinessPartner";
|
|
20
|
+
AssetCodes["Organization"] = "Organization";
|
|
21
|
+
AssetCodes["FieldStaff"] = "FieldStaff";
|
|
22
|
+
AssetCodes["SSB"] = "SSB";
|
|
23
|
+
AssetCodes["ProducerServicePoint"] = "ProducerServicePoint";
|
|
24
|
+
AssetCodes["UnlicensedProducerServicePoint"] = "UnlicensedProducerServicePoint";
|
|
25
|
+
AssetCodes["LicensedProducerServicePoint"] = "LicensedProducerServicePoint";
|
|
26
|
+
AssetCodes["GeneralLightingServicePoint"] = "GeneralLightingServicePoint";
|
|
27
|
+
AssetCodes["ConsumerServicePoint"] = "ConsumerServicePoint";
|
|
28
|
+
AssetCodes["GeneralLightingContract"] = "GeneralLightingContract";
|
|
29
|
+
AssetCodes["UnmeteredContract"] = "UnmeteredContract";
|
|
30
|
+
AssetCodes["ProducerContract"] = "ProducerContract";
|
|
31
|
+
AssetCodes["UnlicensedProducerContract"] = "UnlicensedProducerContract";
|
|
32
|
+
AssetCodes["LicensedProducerContract"] = "LicensedProducerContract";
|
|
33
|
+
AssetCodes["ConsumerContract"] = "ConsumerContract";
|
|
34
|
+
AssetCodes["HumanBusinessPartner"] = "HumanBusinessPartner";
|
|
35
|
+
AssetCodes["Meter"] = "Meter";
|
|
36
|
+
AssetCodes["Seal"] = "Seal";
|
|
37
|
+
AssetCodes["SimCard"] = "SimCard";
|
|
38
|
+
AssetCodes["Transformer"] = "Transformer";
|
|
39
|
+
AssetCodes["MeasurementTransformer"] = "MeasurementTransformer";
|
|
40
|
+
AssetCodes["PowerTransformer"] = "PowerTransformer";
|
|
41
|
+
AssetCodes["Gateway"] = "Gateway";
|
|
42
|
+
AssetCodes["NonSerializedMaterial"] = "NonSerializedMaterial";
|
|
43
|
+
AssetCodes["MaterialClass"] = "MaterialClass";
|
|
44
|
+
AssetCodes["GatewayMaterialClass"] = "GatewayMaterialClass";
|
|
45
|
+
AssetCodes["MeterMaterialClass"] = "MeterMaterialClass";
|
|
46
|
+
AssetCodes["TransformerMaterialClass"] = "TransformerMaterialClass";
|
|
47
|
+
AssetCodes["PowerTransformerMaterialClass"] = "PowerTransformerMaterialClass";
|
|
48
|
+
AssetCodes["MeasurementTransformerMaterialClass"] = "MeasurementTransformerMaterialClass";
|
|
49
|
+
})(AssetCodes || (AssetCodes = {}));
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXJpbC90aGVtZS9sYXlvdXQvYXBwL2dlbmVyYWwtc2VhcmNoL21vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzRkEsTUFBTSxDQUFOLElBQVksVUErQ1g7QUEvQ0QsV0FBWSxVQUFVO0lBQ3JCLHVDQUF5QixDQUFBO0lBQ3pCLG1EQUFxQyxDQUFBO0lBQ3JDLGlEQUFtQyxDQUFBO0lBQ25DLGlDQUFtQixDQUFBO0lBQ25CLDJDQUE2QixDQUFBO0lBQzdCLHFEQUF1QyxDQUFBO0lBQ3ZDLGlGQUFtRSxDQUFBO0lBQ25FLG1DQUFxQixDQUFBO0lBQ3JCLGlEQUFtQyxDQUFBO0lBQ25DLGlDQUFtQixDQUFBO0lBQ25CLHFDQUF1QixDQUFBO0lBQ3ZCLDJCQUFhLENBQUE7SUFDYiwrQkFBaUIsQ0FBQTtJQUNqQixtQ0FBcUIsQ0FBQTtJQUNyQixtQ0FBcUIsQ0FBQTtJQUNyQix1REFBeUMsQ0FBQTtJQUN6Qyx1RUFBeUQsQ0FBQTtJQUN6RCwyQ0FBNkIsQ0FBQTtJQUM3Qix1Q0FBeUIsQ0FBQTtJQUN6Qix5QkFBVyxDQUFBO0lBQ1gsMkRBQTZDLENBQUE7SUFDN0MsK0VBQWlFLENBQUE7SUFDakUsMkVBQTZELENBQUE7SUFDN0QseUVBQTJELENBQUE7SUFDM0QsMkRBQTZDLENBQUE7SUFDN0MsaUVBQW1ELENBQUE7SUFDbkQscURBQXVDLENBQUE7SUFDdkMsbURBQXFDLENBQUE7SUFDckMsdUVBQXlELENBQUE7SUFDekQsbUVBQXFELENBQUE7SUFDckQsbURBQXFDLENBQUE7SUFDckMsMkRBQTZDLENBQUE7SUFDN0MsNkJBQWUsQ0FBQTtJQUNmLDJCQUFhLENBQUE7SUFDYixpQ0FBbUIsQ0FBQTtJQUNuQix5Q0FBMkIsQ0FBQTtJQUMzQiwrREFBaUQsQ0FBQTtJQUNqRCxtREFBcUMsQ0FBQTtJQUNyQyxpQ0FBbUIsQ0FBQTtJQUNuQiw2REFBK0MsQ0FBQTtJQUMvQyw2Q0FBK0IsQ0FBQTtJQUMvQiwyREFBNkMsQ0FBQTtJQUM3Qyx1REFBeUMsQ0FBQTtJQUN6QyxtRUFBcUQsQ0FBQTtJQUNyRCw2RUFBK0QsQ0FBQTtJQUMvRCx5RkFBMkUsQ0FBQTtBQUM1RSxDQUFDLEVBL0NXLFVBQVUsS0FBVixVQUFVLFFBK0NyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByaW1lSWNvbnMgfSBmcm9tICdwcmltZW5nL2FwaSc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFN1Z2dlc3Rpb25zR3JvdXBEVE8ge1xyXG5cdGtleTogbnVtYmVyIHwgc3RyaW5nIHwgbnVsbDtcclxuXHR0ZXh0OiBzdHJpbmc7XHJcblx0YXR0cmlidXRlcz86IEF0dHJpYnV0ZUVsZW1lbnRbXTtcclxuXHRhc3NldERlZmluaXRpb25Db2RlPzogc3RyaW5nO1xyXG5cdGl0ZW1zOiBTdWdnZXN0aW9uc0RUT1tdO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgU3VnZ2VzdGlvbnNEVE8ge1xyXG5cdGtleTogbnVtYmVyIHwgc3RyaW5nIHwgbnVsbDtcclxuXHR0ZXh0OiBzdHJpbmc7XHJcblx0YXR0cmlidXRlcz86IEF0dHJpYnV0ZUVsZW1lbnRbXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBEZWZhdWx0U2VhcmNoQWdncmVnYXRlQXNzZXRBZ2dyZWdhdGUge1xyXG5cdFtrZXk6IHN0cmluZ106IEFkZGl0aW9uYWxQcm9wO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFkZGl0aW9uYWxQcm9wIHtcclxuXHRyZXN1bHRJbmZvOiBSZXN1bHRJbmZvO1xyXG5cdHJlc3VsdDogQXNzZXRBZ2dyZWdhdGVbXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBSZXN1bHRJbmZvIHtcclxuXHR0b3RhbFBhZ2U6IG51bWJlcjtcclxuXHR0b3RhbEl0ZW06IG51bWJlcjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBc3NldEFnZ3JlZ2F0ZSB7XHJcblx0aWQ6IG51bWJlcjtcclxuXHRhc3NldERlZmluaXRpb25JZDogbnVtYmVyO1xyXG5cdGFzc2V0RGVmaW5pdGlvbkNvZGU6IHN0cmluZztcclxuXHRhc3NldERlZmluaXRpb25OYW1lOiBzdHJpbmc7XHJcblx0dW5pcXVlSWRlbnRpZmllcjogc3RyaW5nO1xyXG5cdGF1dGhvcml0eUdyb3VwOiBzdHJpbmc7XHJcblx0Y3JlYXRlRGF0ZTogbnVtYmVyO1xyXG5cdHVwZGF0ZURhdGU6IG51bWJlcjtcclxuXHR1cGRhdGVVc2VyOiBzdHJpbmc7XHJcblx0Y3JlYXRlVXNlcjogc3RyaW5nO1xyXG5cdGFzc2V0czogQXNzZXRbXTtcclxuXHRhdHRyaWJ1dGVzOiBBdHRyaWJ1dGVFbGVtZW50W107XHJcblx0a2V5PzogbnVtYmVyO1xyXG5cdHRleHQ/OiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQXNzZXQge1xyXG5cdGFsaWFzOiBzdHJpbmc7XHJcblx0YXNzZXREZWZpbml0aW9uSUQ6IG51bWJlcjtcclxuXHRhc3NldERlZmluaXRpb25Db2RlOiBzdHJpbmc7XHJcblx0YXNzZXREZWZpbml0aW9uTmFtZTogc3RyaW5nO1xyXG5cdGFzc2V0SWQ6IG51bWJlcjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBdHRyaWJ1dGVFbGVtZW50IHtcclxuXHRpZDogbnVtYmVyO1xyXG5cdGF0dHJpYnV0ZTogQXR0cmlidXRlQXR0cmlidXRlO1xyXG5cdHZhbHVlOiBWYWx1ZTtcclxuXHRzdGFydERhdGU6IG51bWJlcjtcclxuXHR2YWx1ZURlc2M6IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBdHRyaWJ1dGVBdHRyaWJ1dGUge1xyXG5cdGFsaWFzOiBzdHJpbmc7XHJcblx0YXR0cmlidXRlQ29kZTogc3RyaW5nO1xyXG5cdGF0dHJpYnV0ZU5hbWU6IHN0cmluZztcclxuXHRhdHRyaWJ1dGVJZDogbnVtYmVyO1xyXG5cdGF0dHJpYnV0ZVR5cGU6IHN0cmluZztcclxuXHRyZWZlcnJpbmdBc3NldD86IHtcclxuXHRcdGRldGFpbFBhZ2VVcmw/OiBzdHJpbmc7XHJcblx0fTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZSB7fVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYWdlckRUTyB7XHJcblx0cGFnZVNpemU6IG51bWJlcjtcclxuXHRwYWdlTnVtYmVyOiBudW1iZXI7XHJcbn1cclxuZXhwb3J0IGludGVyZmFjZSBDYWNoZVNlYXJjaFJlcXVlc3REVE8ge1xyXG5cdGFzc2V0RGVmaW5pdGlvbkNvZGVzOiBzdHJpbmdbXTtcclxuXHRzZWFyY2hUZXh0Pzogc3RyaW5nO1xyXG5cdG1xbD86IHN0cmluZztcclxuXHRwYWdlcjogUGFnZXJEVE87XHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIEFzc2V0Q29kZXMge1xyXG5cdE1hc3RlckRhdGEgPSAnTWFzdGVyRGF0YScsXHJcblx0TGlnaHRpbmdGYWNpbGl0eSA9ICdMaWdodGluZ0ZhY2lsaXR5JyxcclxuXHRDb25uZWN0aW9uUG9pbnQgPSAnQ29ubmVjdGlvblBvaW50JyxcclxuXHRQcmVtaXNlID0gJ1ByZW1pc2UnLFxyXG5cdFNlcnZpY2VQb2ludCA9ICdTZXJ2aWNlUG9pbnQnLFxyXG5cdFNlcnZpY2VQb2ludEdyb3VwID0gJ1NlcnZpY2VQb2ludEdyb3VwJyxcclxuXHREaXN0cmlidXRpb25Db25uZWN0aW9uQWdyZWVtZW50ID0gJ0Rpc3RyaWJ1dGlvbkNvbm5lY3Rpb25BZ3JlZW1lbnQnLFxyXG5cdENvbnRyYWN0ID0gJ0NvbnRyYWN0JyxcclxuXHRCdXNpbmVzc1BhcnRuZXIgPSAnQnVzaW5lc3NQYXJ0bmVyJyxcclxuXHRBY2NvdW50ID0gJ0FjY291bnQnLFxyXG5cdFdhcmVob3VzZSA9ICdXYXJlaG91c2UnLFxyXG5cdFRlYW0gPSAnVGVhbScsXHJcblx0RGV2aWNlID0gJ0RldmljZScsXHJcblx0TG9jYXRpb24gPSAnTG9jYXRpb24nLFxyXG5cdE1hdGVyaWFsID0gJ01hdGVyaWFsJyxcclxuXHRTZXJpYWxpemVkTWF0ZXJpYWwgPSAnU2VyaWFsaXplZE1hdGVyaWFsJyxcclxuXHRMZWdhbEVudGl0eUJ1c2luZXNzUGFydG5lciA9ICdMZWdhbEVudGl0eUJ1c2luZXNzUGFydG5lcicsXHJcblx0T3JnYW5pemF0aW9uID0gJ09yZ2FuaXphdGlvbicsXHJcblx0RmllbGRTdGFmZiA9ICdGaWVsZFN0YWZmJyxcclxuXHRTU0IgPSAnU1NCJyxcclxuXHRQcm9kdWNlclNlcnZpY2VQb2ludCA9ICdQcm9kdWNlclNlcnZpY2VQb2ludCcsXHJcblx0VW5saWNlbnNlZFByb2R1Y2VyU2VydmljZVBvaW50ID0gJ1VubGljZW5zZWRQcm9kdWNlclNlcnZpY2VQb2ludCcsXHJcblx0TGljZW5zZWRQcm9kdWNlclNlcnZpY2VQb2ludCA9ICdMaWNlbnNlZFByb2R1Y2VyU2VydmljZVBvaW50JyxcclxuXHRHZW5lcmFsTGlnaHRpbmdTZXJ2aWNlUG9pbnQgPSAnR2VuZXJhbExpZ2h0aW5nU2VydmljZVBvaW50JyxcclxuXHRDb25zdW1lclNlcnZpY2VQb2ludCA9ICdDb25zdW1lclNlcnZpY2VQb2ludCcsXHJcblx0R2VuZXJhbExpZ2h0aW5nQ29udHJhY3QgPSAnR2VuZXJhbExpZ2h0aW5nQ29udHJhY3QnLFxyXG5cdFVubWV0ZXJlZENvbnRyYWN0ID0gJ1VubWV0ZXJlZENvbnRyYWN0JyxcclxuXHRQcm9kdWNlckNvbnRyYWN0ID0gJ1Byb2R1Y2VyQ29udHJhY3QnLFxyXG5cdFVubGljZW5zZWRQcm9kdWNlckNvbnRyYWN0ID0gJ1VubGljZW5zZWRQcm9kdWNlckNvbnRyYWN0JyxcclxuXHRMaWNlbnNlZFByb2R1Y2VyQ29udHJhY3QgPSAnTGljZW5zZWRQcm9kdWNlckNvbnRyYWN0JyxcclxuXHRDb25zdW1lckNvbnRyYWN0ID0gJ0NvbnN1bWVyQ29udHJhY3QnLFxyXG5cdEh1bWFuQnVzaW5lc3NQYXJ0bmVyID0gJ0h1bWFuQnVzaW5lc3NQYXJ0bmVyJyxcclxuXHRNZXRlciA9ICdNZXRlcicsXHJcblx0U2VhbCA9ICdTZWFsJyxcclxuXHRTaW1DYXJkID0gJ1NpbUNhcmQnLFxyXG5cdFRyYW5zZm9ybWVyID0gJ1RyYW5zZm9ybWVyJyxcclxuXHRNZWFzdXJlbWVudFRyYW5zZm9ybWVyID0gJ01lYXN1cmVtZW50VHJhbnNmb3JtZXInLFxyXG5cdFBvd2VyVHJhbnNmb3JtZXIgPSAnUG93ZXJUcmFuc2Zvcm1lcicsXHJcblx0R2F0ZXdheSA9ICdHYXRld2F5JyxcclxuXHROb25TZXJpYWxpemVkTWF0ZXJpYWwgPSAnTm9uU2VyaWFsaXplZE1hdGVyaWFsJyxcclxuXHRNYXRlcmlhbENsYXNzID0gJ01hdGVyaWFsQ2xhc3MnLFxyXG5cdEdhdGV3YXlNYXRlcmlhbENsYXNzID0gJ0dhdGV3YXlNYXRlcmlhbENsYXNzJyxcclxuXHRNZXRlck1hdGVyaWFsQ2xhc3MgPSAnTWV0ZXJNYXRlcmlhbENsYXNzJyxcclxuXHRUcmFuc2Zvcm1lck1hdGVyaWFsQ2xhc3MgPSAnVHJhbnNmb3JtZXJNYXRlcmlhbENsYXNzJyxcclxuXHRQb3dlclRyYW5zZm9ybWVyTWF0ZXJpYWxDbGFzcyA9ICdQb3dlclRyYW5zZm9ybWVyTWF0ZXJpYWxDbGFzcycsXHJcblx0TWVhc3VyZW1lbnRUcmFuc2Zvcm1lck1hdGVyaWFsQ2xhc3MgPSAnTWVhc3VyZW1lbnRUcmFuc2Zvcm1lck1hdGVyaWFsQ2xhc3MnXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFByZXNlbnRhYmxlRGF0YSA9IHtcclxuXHR0aXRsZTogc3RyaW5nO1xyXG5cdGljb246IFByaW1lSWNvbnM7XHJcblx0c3VidGl0bGU6IHN0cmluZztcclxuXHRhc3NldElkOiBzdHJpbmc7XHJcblx0dXJsOiBzdHJpbmc7XHJcbn07XHJcbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { UpperCasePipe } from '@angular/common';
|
|
2
|
-
import { Component, ViewChild, inject
|
|
2
|
+
import { Component, ViewChild, inject } from '@angular/core';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
4
|
import { BadgeModule } from 'primeng/badge';
|
|
5
5
|
import { ButtonModule } from 'primeng/button';
|
|
@@ -10,6 +10,7 @@ import { TranslocoModule } from '@ngneat/transloco';
|
|
|
10
10
|
import { Apps } from 'aril/boot/config/apps';
|
|
11
11
|
import { LayoutService } from '../../service/app.layout.service';
|
|
12
12
|
import { LanguageCode } from '../../service/interfaces/enum';
|
|
13
|
+
import { GeneralSearchComponent } from '../general-search/general-search.component';
|
|
13
14
|
import * as i0 from "@angular/core";
|
|
14
15
|
import * as i1 from "@ngneat/transloco";
|
|
15
16
|
import * as i2 from "aril/util/pub-sub";
|
|
@@ -27,7 +28,8 @@ export class AppTopbarComponent {
|
|
|
27
28
|
this.keycloak = keycloak;
|
|
28
29
|
this.layoutService = inject(LayoutService);
|
|
29
30
|
this.search = '';
|
|
30
|
-
this.
|
|
31
|
+
this.logoPath = '';
|
|
32
|
+
this.currentFlagPath = '';
|
|
31
33
|
this.currentLang = localStorage.getItem('lang') || LanguageCode.TR;
|
|
32
34
|
this.languages = [
|
|
33
35
|
{ name: 'TR', code: LanguageCode.TR, flag: 'assets/images/flags/tr.svg' },
|
|
@@ -35,42 +37,8 @@ export class AppTopbarComponent {
|
|
|
35
37
|
];
|
|
36
38
|
this.translocoService.setActiveLang(this.currentLang);
|
|
37
39
|
this.publishLanguageChange(this.currentLang);
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
case Apps.YEAP:
|
|
41
|
-
this.filePath.update(() => 'assets/images/yeap-logo-dark.png');
|
|
42
|
-
break;
|
|
43
|
-
case Apps.THOR:
|
|
44
|
-
this.filePath.update(() => 'assets/images/thor-logo-dark.png');
|
|
45
|
-
break;
|
|
46
|
-
case Apps.LENA:
|
|
47
|
-
this.filePath.update(() => 'assets/images/lena-logo-dark.png');
|
|
48
|
-
break;
|
|
49
|
-
default:
|
|
50
|
-
this.filePath.update(() => 'assets/images/yeap-logo-dark.png');
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
else {
|
|
54
|
-
switch (globalThis.activeMF) {
|
|
55
|
-
case Apps.HES:
|
|
56
|
-
case Apps.CTS:
|
|
57
|
-
case Apps.SIS:
|
|
58
|
-
this.filePath.update(() => 'assets/images/lena-logo.png');
|
|
59
|
-
break;
|
|
60
|
-
case Apps.CRM:
|
|
61
|
-
case Apps.BILLING:
|
|
62
|
-
case Apps.PAYMENT:
|
|
63
|
-
case Apps.WDM:
|
|
64
|
-
case Apps.MNG:
|
|
65
|
-
this.filePath.update(() => 'assets/images/thor-logo.png');
|
|
66
|
-
break;
|
|
67
|
-
case Apps.MW:
|
|
68
|
-
this.filePath.update(() => 'assets/images/yeap-logo.png');
|
|
69
|
-
break;
|
|
70
|
-
default:
|
|
71
|
-
this.filePath.update(() => 'assets/images/yeap-logo.png');
|
|
72
|
-
}
|
|
73
|
-
}
|
|
40
|
+
this.setFlagPath(this.currentLang);
|
|
41
|
+
this.setLogoPath();
|
|
74
42
|
this.username = this.keycloak.getUsername();
|
|
75
43
|
}
|
|
76
44
|
get unreadCount() {
|
|
@@ -112,18 +80,59 @@ export class AppTopbarComponent {
|
|
|
112
80
|
};
|
|
113
81
|
this.pubSubService.publish(event);
|
|
114
82
|
}
|
|
115
|
-
|
|
83
|
+
setFlagPath(lang) {
|
|
116
84
|
switch (lang) {
|
|
117
85
|
case LanguageCode.TR:
|
|
118
|
-
|
|
86
|
+
this.currentFlagPath = 'assets/images/flags/tr.svg';
|
|
87
|
+
break;
|
|
119
88
|
case LanguageCode.EN:
|
|
120
|
-
|
|
89
|
+
this.currentFlagPath = 'assets/images/flags/gb.svg';
|
|
90
|
+
break;
|
|
121
91
|
default:
|
|
122
|
-
|
|
92
|
+
this.currentFlagPath = 'assets/images/flags/tr.svg';
|
|
93
|
+
break;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
setLogoPath() {
|
|
97
|
+
if (globalThis.activeHost) {
|
|
98
|
+
switch (globalThis.activeHost) {
|
|
99
|
+
case Apps.YEAP:
|
|
100
|
+
this.logoPath = 'assets/images/yeap-logo-dark.png';
|
|
101
|
+
break;
|
|
102
|
+
case Apps.THOR:
|
|
103
|
+
this.logoPath = 'assets/images/thor-logo-dark.png';
|
|
104
|
+
break;
|
|
105
|
+
case Apps.LENA:
|
|
106
|
+
this.logoPath = 'assets/images/lena-logo-dark.png';
|
|
107
|
+
break;
|
|
108
|
+
default:
|
|
109
|
+
this.logoPath = 'assets/images/yeap-logo-dark.png';
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
switch (globalThis.activeMF) {
|
|
114
|
+
case Apps.HES:
|
|
115
|
+
case Apps.CTS:
|
|
116
|
+
case Apps.SIS:
|
|
117
|
+
this.logoPath = 'assets/images/lena-logo.png';
|
|
118
|
+
break;
|
|
119
|
+
case Apps.CRM:
|
|
120
|
+
case Apps.BILLING:
|
|
121
|
+
case Apps.PAYMENT:
|
|
122
|
+
case Apps.WDM:
|
|
123
|
+
case Apps.MNG:
|
|
124
|
+
this.logoPath = 'assets/images/thor-logo.png';
|
|
125
|
+
break;
|
|
126
|
+
case Apps.MW:
|
|
127
|
+
this.logoPath = 'assets/images/yeap-logo.png';
|
|
128
|
+
break;
|
|
129
|
+
default:
|
|
130
|
+
this.logoPath = 'assets/images/yeap-logo.png';
|
|
131
|
+
}
|
|
123
132
|
}
|
|
124
133
|
}
|
|
125
134
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AppTopbarComponent, deps: [{ token: i1.TranslocoService }, { token: i2.PubSubService }, { token: i3.KeycloakService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
126
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AppTopbarComponent, isStandalone: true, selector: "app-topbar", viewQueries: [{ propertyName: "menuButton", first: true, predicate: ["menubutton"], descendants: true }], ngImport: i0, template: "<div class=\"layout-topbar\">\r\n\t<div class=\"topbar-start\">\r\n\t\t<button #menubutton type=\"button\" class=\"topbar-menubutton p-link p-trigger\" (click)=\"onMenuButtonClick()\">\r\n\t\t\t<i class=\"pi pi-bars\"></i>\r\n\t\t</button>\r\n\t\t<img [src]=\"
|
|
135
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AppTopbarComponent, isStandalone: true, selector: "app-topbar", viewQueries: [{ propertyName: "menuButton", first: true, predicate: ["menubutton"], descendants: true }], ngImport: i0, template: "<div class=\"layout-topbar\">\r\n\t<div class=\"topbar-start\">\r\n\t\t<button #menubutton type=\"button\" class=\"topbar-menubutton p-link p-trigger\" (click)=\"onMenuButtonClick()\">\r\n\t\t\t<i class=\"pi pi-bars\"></i>\r\n\t\t</button>\r\n\t\t<img [src]=\"logoPath\" class=\"topbar-logo\" alt=\"logo\" />\r\n\t</div>\r\n\r\n\t<div class=\"topbar-search\" *transloco=\"let t; read: ''\">\r\n\t\t<span class=\"p-input-icon-left\">\r\n\t\t\t<i class=\"pi pi-search\"></i>\r\n\t\t\t<app-general-search></app-general-search>\r\n\t\t</span>\r\n\t</div>\r\n\r\n\t<div class=\"topbar-end mr-2\">\r\n\t\t<ul class=\"topbar-menu\">\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-sitemap\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onSiteMapButtonClick()\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-history\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onHistoryButtonClick()\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-heart\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onFavoritePagesButtonClick()\" />\r\n\t\t\t</li>\r\n\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" (click)=\"onProfileButtonClick()\">\r\n\t\t\t\t\t{{ username[0] | uppercase }}\r\n\t\t\t\t</p-button>\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-divider layout=\"vertical\" styleClass=\"h-1rem border-500 m-0\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<i\r\n\t\t\t\t\tclass=\"pi pi-bell notification-icon\"\r\n\t\t\t\t\tpBadge\r\n\t\t\t\t\t[value]=\"unreadCount > 0 ? unreadCount.toString() : '0'\"\r\n\t\t\t\t\t(click)=\"onNotificationsButtonClick()\"></i>\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-dropdown\r\n\t\t\t\t\t[options]=\"languages\"\r\n\t\t\t\t\t[(ngModel)]=\"currentLang\"\r\n\t\t\t\t\t(onChange)=\"onLanguageChange()\"\r\n\t\t\t\t\toptionLabel=\"name\"\r\n\t\t\t\t\toptionValue=\"code\"\r\n\t\t\t\t\t[showClear]=\"false\"\r\n\t\t\t\t\tclass=\"custom-dropdown ml-3\">\r\n\t\t\t\t\t<ng-template pTemplate=\"selectedItem\">\r\n\t\t\t\t\t\t<div class=\"flex align-items-center gap-2\">\r\n\t\t\t\t\t\t\t<img [src]=\"currentFlagPath\" class=\"flag-icon\" alt=\"flag\" />\r\n\t\t\t\t\t\t\t<span class=\"language-text\">{{ currentLang | uppercase }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t<ng-template pTemplate=\"item\" let-item>\r\n\t\t\t\t\t\t<div class=\"flex align-items-center gap-2\">\r\n\t\t\t\t\t\t\t<img [src]=\"item.flag\" class=\"flag-icon\" alt=\"flag\" />\r\n\t\t\t\t\t\t\t<span>{{ item.name }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t</p-dropdown>\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</div>\r\n</div>\r\n\r\n<!-- <app-breadcrumb class=\"topbar-breadcrumb\"></app-breadcrumb> -->\r\n", styles: [".layout-topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:.5rem;padding:0 1rem;box-shadow:0 1px 2px #00000013}@media (max-width: 768px){.layout-topbar{padding:0 .5rem;gap:.25rem}}.topbar-start{display:flex}.topbar-logo{height:36px;width:auto}@media (max-width: 768px){.topbar-logo{display:none}}.topbar-search{flex:1;max-width:50rem;margin:0 1rem}@media (max-width: 1024px){.topbar-search{max-width:30rem}}@media (max-width: 768px){.topbar-search{max-width:20rem;margin:0 .5rem}}@media (max-width: 480px){.topbar-search{max-width:15rem;margin:0 .25rem}}.topbar-search .p-input-icon-left{width:100%}.topbar-end{flex-shrink:0}.topbar-menu{display:flex;align-items:center;gap:.5rem;margin:0;padding:0;list-style:none}@media (max-width: 768px){.topbar-menu{gap:.25rem}}@media (max-width: 480px){.topbar-menu{gap:.1rem}}.topbar-menu-item{display:flex;align-items:center}@media (max-width: 1024px){.desktop-only{display:none!important}}.mobile-only{display:none!important}@media (max-width: 1024px){.mobile-only{display:flex!important}}.custom-dropdown .p-dropdown{border-radius:50px;padding:.5rem 1rem;border:1px solid #c8c8c8;background-color:#f4f4f4}@media (max-width: 768px){.custom-dropdown .p-dropdown{padding:.4rem .8rem}}@media (max-width: 480px){.custom-dropdown .p-dropdown{padding:.3rem .6rem}}.custom-dropdown .p-dropdown-label{padding:0;line-height:1.5}.custom-dropdown .p-dropdown-trigger{border-radius:50px}.flag-icon{width:18px;height:18px;display:inline-block;vertical-align:middle}@media (max-width: 768px){.flag-icon{width:16px;height:16px}}@media (max-width: 480px){.language-text{display:none}}@media (max-width: 768px){.topbar-menubutton{padding:.4rem!important}}@media (max-width: 480px){.topbar-menubutton{padding:.3rem!important}}@media (max-width: 768px){.topbar-menu-item p-button{min-width:auto}.topbar-menu-item p-button .p-button-icon{margin:0}.topbar-menu-item p-button .p-button-label{font-size:.9rem}}@media (max-width: 480px){.topbar-menu-item p-button .p-button-label{font-size:.8rem}.topbar-menu-item p-divider{display:none}}.notification-icon{cursor:pointer;padding:.2rem;border-radius:50%;transition:background-color .2s}.notification-icon:hover{background-color:var(--surface-hover)}@media (max-width: 480px){.notification-icon{font-size:.9rem;padding:.4rem}}\n"], dependencies: [{ kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: i5.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: DividerModule }, { kind: "component", type: i7.Divider, selector: "p-divider", inputs: ["style", "styleClass", "layout", "type", "align"] }, { kind: "ngmodule", type: BadgeModule }, { kind: "directive", type: i8.BadgeDirective, selector: "[pBadge]", inputs: ["badgeDisabled", "badgeSize", "size", "severity", "value", "badgeStyle", "badgeStyleClass"] }, { kind: "ngmodule", type: MenubarModule }, { kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i9.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "variant", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "ngmodule", type: TranslocoModule }, { kind: "directive", type: i1.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: GeneralSearchComponent, selector: "app-general-search" }] }); }
|
|
127
136
|
}
|
|
128
137
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AppTopbarComponent, decorators: [{
|
|
129
138
|
type: Component,
|
|
@@ -135,10 +144,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
135
144
|
BadgeModule,
|
|
136
145
|
MenubarModule,
|
|
137
146
|
DropdownModule,
|
|
138
|
-
TranslocoModule
|
|
139
|
-
|
|
147
|
+
TranslocoModule,
|
|
148
|
+
GeneralSearchComponent
|
|
149
|
+
], template: "<div class=\"layout-topbar\">\r\n\t<div class=\"topbar-start\">\r\n\t\t<button #menubutton type=\"button\" class=\"topbar-menubutton p-link p-trigger\" (click)=\"onMenuButtonClick()\">\r\n\t\t\t<i class=\"pi pi-bars\"></i>\r\n\t\t</button>\r\n\t\t<img [src]=\"logoPath\" class=\"topbar-logo\" alt=\"logo\" />\r\n\t</div>\r\n\r\n\t<div class=\"topbar-search\" *transloco=\"let t; read: ''\">\r\n\t\t<span class=\"p-input-icon-left\">\r\n\t\t\t<i class=\"pi pi-search\"></i>\r\n\t\t\t<app-general-search></app-general-search>\r\n\t\t</span>\r\n\t</div>\r\n\r\n\t<div class=\"topbar-end mr-2\">\r\n\t\t<ul class=\"topbar-menu\">\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-sitemap\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onSiteMapButtonClick()\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-history\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onHistoryButtonClick()\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-heart\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onFavoritePagesButtonClick()\" />\r\n\t\t\t</li>\r\n\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" (click)=\"onProfileButtonClick()\">\r\n\t\t\t\t\t{{ username[0] | uppercase }}\r\n\t\t\t\t</p-button>\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-divider layout=\"vertical\" styleClass=\"h-1rem border-500 m-0\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<i\r\n\t\t\t\t\tclass=\"pi pi-bell notification-icon\"\r\n\t\t\t\t\tpBadge\r\n\t\t\t\t\t[value]=\"unreadCount > 0 ? unreadCount.toString() : '0'\"\r\n\t\t\t\t\t(click)=\"onNotificationsButtonClick()\"></i>\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-dropdown\r\n\t\t\t\t\t[options]=\"languages\"\r\n\t\t\t\t\t[(ngModel)]=\"currentLang\"\r\n\t\t\t\t\t(onChange)=\"onLanguageChange()\"\r\n\t\t\t\t\toptionLabel=\"name\"\r\n\t\t\t\t\toptionValue=\"code\"\r\n\t\t\t\t\t[showClear]=\"false\"\r\n\t\t\t\t\tclass=\"custom-dropdown ml-3\">\r\n\t\t\t\t\t<ng-template pTemplate=\"selectedItem\">\r\n\t\t\t\t\t\t<div class=\"flex align-items-center gap-2\">\r\n\t\t\t\t\t\t\t<img [src]=\"currentFlagPath\" class=\"flag-icon\" alt=\"flag\" />\r\n\t\t\t\t\t\t\t<span class=\"language-text\">{{ currentLang | uppercase }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t<ng-template pTemplate=\"item\" let-item>\r\n\t\t\t\t\t\t<div class=\"flex align-items-center gap-2\">\r\n\t\t\t\t\t\t\t<img [src]=\"item.flag\" class=\"flag-icon\" alt=\"flag\" />\r\n\t\t\t\t\t\t\t<span>{{ item.name }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t</p-dropdown>\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</div>\r\n</div>\r\n\r\n<!-- <app-breadcrumb class=\"topbar-breadcrumb\"></app-breadcrumb> -->\r\n", styles: [".layout-topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:.5rem;padding:0 1rem;box-shadow:0 1px 2px #00000013}@media (max-width: 768px){.layout-topbar{padding:0 .5rem;gap:.25rem}}.topbar-start{display:flex}.topbar-logo{height:36px;width:auto}@media (max-width: 768px){.topbar-logo{display:none}}.topbar-search{flex:1;max-width:50rem;margin:0 1rem}@media (max-width: 1024px){.topbar-search{max-width:30rem}}@media (max-width: 768px){.topbar-search{max-width:20rem;margin:0 .5rem}}@media (max-width: 480px){.topbar-search{max-width:15rem;margin:0 .25rem}}.topbar-search .p-input-icon-left{width:100%}.topbar-end{flex-shrink:0}.topbar-menu{display:flex;align-items:center;gap:.5rem;margin:0;padding:0;list-style:none}@media (max-width: 768px){.topbar-menu{gap:.25rem}}@media (max-width: 480px){.topbar-menu{gap:.1rem}}.topbar-menu-item{display:flex;align-items:center}@media (max-width: 1024px){.desktop-only{display:none!important}}.mobile-only{display:none!important}@media (max-width: 1024px){.mobile-only{display:flex!important}}.custom-dropdown .p-dropdown{border-radius:50px;padding:.5rem 1rem;border:1px solid #c8c8c8;background-color:#f4f4f4}@media (max-width: 768px){.custom-dropdown .p-dropdown{padding:.4rem .8rem}}@media (max-width: 480px){.custom-dropdown .p-dropdown{padding:.3rem .6rem}}.custom-dropdown .p-dropdown-label{padding:0;line-height:1.5}.custom-dropdown .p-dropdown-trigger{border-radius:50px}.flag-icon{width:18px;height:18px;display:inline-block;vertical-align:middle}@media (max-width: 768px){.flag-icon{width:16px;height:16px}}@media (max-width: 480px){.language-text{display:none}}@media (max-width: 768px){.topbar-menubutton{padding:.4rem!important}}@media (max-width: 480px){.topbar-menubutton{padding:.3rem!important}}@media (max-width: 768px){.topbar-menu-item p-button{min-width:auto}.topbar-menu-item p-button .p-button-icon{margin:0}.topbar-menu-item p-button .p-button-label{font-size:.9rem}}@media (max-width: 480px){.topbar-menu-item p-button .p-button-label{font-size:.8rem}.topbar-menu-item p-divider{display:none}}.notification-icon{cursor:pointer;padding:.2rem;border-radius:50%;transition:background-color .2s}.notification-icon:hover{background-color:var(--surface-hover)}@media (max-width: 480px){.notification-icon{font-size:.9rem;padding:.4rem}}\n"] }]
|
|
140
150
|
}], ctorParameters: () => [{ type: i1.TranslocoService }, { type: i2.PubSubService }, { type: i3.KeycloakService }], propDecorators: { menuButton: [{
|
|
141
151
|
type: ViewChild,
|
|
142
152
|
args: ['menubutton']
|
|
143
153
|
}] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.topbar.component.js","sourceRoot":"","sources":["../../../../../../projects/aril/theme/layout/app/topbar/app.topbar.component.ts","../../../../../../projects/aril/theme/layout/app/topbar/app.topbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { UpperCasePipe } from '@angular/common';\r\nimport { Component, ElementRef, ViewChild, inject, signal } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\nimport { BadgeModule } from 'primeng/badge';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { DividerModule } from 'primeng/divider';\r\nimport { DropdownModule } from 'primeng/dropdown';\r\nimport { MenubarModule } from 'primeng/menubar';\r\n\r\nimport { TranslocoModule, TranslocoService } from '@ngneat/transloco';\r\nimport { KeycloakService } from 'keycloak-angular';\r\n\r\nimport { Apps } from 'aril/boot/config/apps';\r\nimport { PubSubService } from 'aril/util/pub-sub';\r\n\r\nimport { LayoutService } from '../../service/app.layout.service';\r\nimport { LanguageCode } from '../../service/interfaces/enum';\r\nimport { Language, LanguageChangeEvent } from '../../service/interfaces/interfaces';\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'app-topbar',\r\n\timports: [\r\n\t\tButtonModule,\r\n\t\tUpperCasePipe,\r\n\t\tFormsModule,\r\n\t\tDividerModule,\r\n\t\tBadgeModule,\r\n\t\tMenubarModule,\r\n\t\tDropdownModule,\r\n\t\tTranslocoModule\r\n\t],\r\n\ttemplateUrl: './app.topbar.component.html',\r\n\tstyleUrls: ['./app.topbar.component.scss']\r\n})\r\nexport class AppTopbarComponent {\r\n\t@ViewChild('menubutton') menuButton!: ElementRef;\r\n\r\n\tusername!: string;\r\n\tlayoutService = inject(LayoutService);\r\n\tsearch: string = '';\r\n\r\n\tfilePath = signal<string>('');\r\n\tcurrentLang: LanguageCode = (localStorage.getItem('lang') as LanguageCode) || LanguageCode.TR;\r\n\r\n\tlanguages: Language[] = [\r\n\t\t{ name: 'TR', code: LanguageCode.TR, flag: 'assets/images/flags/tr.svg' },\r\n\t\t{ name: 'EN', code: LanguageCode.EN, flag: 'assets/images/flags/gb.svg' }\r\n\t];\r\n\r\n\tconstructor(\r\n\t\tprivate readonly translocoService: TranslocoService,\r\n\t\tprivate readonly pubSubService: PubSubService,\r\n\t\tprivate readonly keycloak: KeycloakService\r\n\t) {\r\n\t\tthis.translocoService.setActiveLang(this.currentLang);\r\n\t\tthis.publishLanguageChange(this.currentLang);\r\n\r\n\t\tif ((<any>globalThis).activeHost) {\r\n\t\t\tswitch ((<any>globalThis).activeHost) {\r\n\t\t\t\tcase Apps.YEAP:\r\n\t\t\t\t\tthis.filePath.update(() => 'assets/images/yeap-logo-dark.png');\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase Apps.THOR:\r\n\t\t\t\t\tthis.filePath.update(() => 'assets/images/thor-logo-dark.png');\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase Apps.LENA:\r\n\t\t\t\t\tthis.filePath.update(() => 'assets/images/lena-logo-dark.png');\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthis.filePath.update(() => 'assets/images/yeap-logo-dark.png');\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tswitch ((<any>globalThis).activeMF) {\r\n\t\t\t\tcase Apps.HES:\r\n\t\t\t\tcase Apps.CTS:\r\n\t\t\t\tcase Apps.SIS:\r\n\t\t\t\t\tthis.filePath.update(() => 'assets/images/lena-logo.png');\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase Apps.CRM:\r\n\t\t\t\tcase Apps.BILLING:\r\n\t\t\t\tcase Apps.PAYMENT:\r\n\t\t\t\tcase Apps.WDM:\r\n\t\t\t\tcase Apps.MNG:\r\n\t\t\t\t\tthis.filePath.update(() => 'assets/images/thor-logo.png');\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase Apps.MW:\r\n\t\t\t\t\tthis.filePath.update(() => 'assets/images/yeap-logo.png');\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthis.filePath.update(() => 'assets/images/yeap-logo.png');\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tthis.username = this.keycloak.getUsername();\r\n\t}\r\n\r\n\tget unreadCount(): number {\r\n\t\treturn this.layoutService.getUnreadNotificationCount();\r\n\t}\r\n\r\n\tonMenuButtonClick(): void {\r\n\t\tthis.layoutService.onMenuToggle();\r\n\t}\r\n\r\n\tonProfileButtonClick(): void {\r\n\t\tthis.layoutService.showProfileSidebar();\r\n\t}\r\n\r\n\tonHistoryButtonClick(): void {\r\n\t\tthis.layoutService.showHistorySidebar();\r\n\t}\r\n\r\n\tonSiteMapButtonClick(): void {\r\n\t\tthis.layoutService.showSiteMapSidebar();\r\n\t}\r\n\r\n\tonFavoritePagesButtonClick(): void {\r\n\t\tthis.layoutService.showFavoritePagesSidebar();\r\n\t}\r\n\r\n\tonNotificationsButtonClick(): void {\r\n\t\tthis.layoutService.showNotificationsSidebar();\r\n\t}\r\n\r\n\tonLanguageChange(): void {\r\n\t\tlocalStorage.setItem('lang', this.currentLang);\r\n\r\n\t\tthis.translocoService.setActiveLang(this.currentLang);\r\n\r\n\t\twindow.location.reload();\r\n\r\n\t\tthis.publishLanguageChange(this.currentLang);\r\n\t}\r\n\r\n\tprivate publishLanguageChange(language: LanguageCode): void {\r\n\t\tconst event: LanguageChangeEvent = {\r\n\t\t\tname: 'languageChanged',\r\n\t\t\tdata: {\r\n\t\t\t\tpath: '',\r\n\t\t\t\tcustom: {\r\n\t\t\t\t\tlanguage\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t};\r\n\r\n\t\tthis.pubSubService.publish(event);\r\n\t}\r\n\r\n\tgetFlagPath(lang: LanguageCode): string {\r\n\t\tswitch (lang) {\r\n\t\t\tcase LanguageCode.TR:\r\n\t\t\t\treturn 'assets/images/flags/tr.svg';\r\n\t\t\tcase LanguageCode.EN:\r\n\t\t\t\treturn 'assets/images/flags/gb.svg';\r\n\t\t\tdefault:\r\n\t\t\t\treturn 'assets/images/flags/tr.svg';\r\n\t\t}\r\n\t}\r\n}\r\n","<div class=\"layout-topbar\">\r\n\t<div class=\"topbar-start\">\r\n\t\t<button #menubutton type=\"button\" class=\"topbar-menubutton p-link p-trigger\" (click)=\"onMenuButtonClick()\">\r\n\t\t\t<i class=\"pi pi-bars\"></i>\r\n\t\t</button>\r\n\t\t<img [src]=\"filePath()\" class=\"topbar-logo\" alt=\"logo\" />\r\n\t</div>\r\n\r\n\t<div class=\"topbar-search\" *transloco=\"let t; read: ''\">\r\n\t\t<span class=\"p-input-icon-left\">\r\n\t\t\t<i class=\"pi pi-search\"></i>\r\n\t\t\t<input\r\n\t\t\t\ttype=\"text\"\r\n\t\t\t\tpInputText\r\n\t\t\t\tvariant=\"filled\"\r\n\t\t\t\t[placeholder]=\"t('searchGeneral')\"\r\n\t\t\t\tstyle=\"background: #f8fafc; border-color: #e2e8f0; height: 32px\"\r\n\t\t\t\tclass=\"p-inputtext p-component p-element topbar-search-input\" />\r\n\t\t</span>\r\n\t</div>\r\n\r\n\t<div class=\"topbar-end mr-2\">\r\n\t\t<ul class=\"topbar-menu\">\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-sitemap\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onSiteMapButtonClick()\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-history\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onHistoryButtonClick()\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-heart\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onFavoritePagesButtonClick()\" />\r\n\t\t\t</li>\r\n\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" (click)=\"onProfileButtonClick()\">\r\n\t\t\t\t\t{{ username[0] | uppercase }}\r\n\t\t\t\t</p-button>\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-divider layout=\"vertical\" styleClass=\"h-1rem border-500 m-0\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<i\r\n\t\t\t\t\tclass=\"pi pi-bell notification-icon\"\r\n\t\t\t\t\tpBadge\r\n\t\t\t\t\t[value]=\"unreadCount > 0 ? unreadCount.toString() : '0'\"\r\n\t\t\t\t\t(click)=\"onNotificationsButtonClick()\"></i>\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-dropdown\r\n\t\t\t\t\t[options]=\"languages\"\r\n\t\t\t\t\t[(ngModel)]=\"currentLang\"\r\n\t\t\t\t\t(onChange)=\"onLanguageChange()\"\r\n\t\t\t\t\toptionLabel=\"name\"\r\n\t\t\t\t\toptionValue=\"code\"\r\n\t\t\t\t\t[showClear]=\"false\"\r\n\t\t\t\t\tclass=\"custom-dropdown ml-3\">\r\n\t\t\t\t\t<ng-template pTemplate=\"selectedItem\">\r\n\t\t\t\t\t\t<div class=\"flex align-items-center gap-2\">\r\n\t\t\t\t\t\t\t<img [src]=\"getFlagPath(currentLang)\" class=\"flag-icon\" alt=\"flag\" />\r\n\t\t\t\t\t\t\t<span class=\"language-text\">{{ currentLang | uppercase }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t<ng-template pTemplate=\"item\" let-item>\r\n\t\t\t\t\t\t<div class=\"flex align-items-center gap-2\">\r\n\t\t\t\t\t\t\t<img [src]=\"item.flag\" class=\"flag-icon\" alt=\"flag\" />\r\n\t\t\t\t\t\t\t<span>{{ item.name }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t</p-dropdown>\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</div>\r\n</div>\r\n\r\n<!-- <app-breadcrumb class=\"topbar-breadcrumb\"></app-breadcrumb> -->\r\n"]}
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app.topbar.component.js","sourceRoot":"","sources":["../../../../../../projects/aril/theme/layout/app/topbar/app.topbar.component.ts","../../../../../../projects/aril/theme/layout/app/topbar/app.topbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAc,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD,OAAO,EAAE,eAAe,EAAoB,MAAM,mBAAmB,CAAC;AAGtE,OAAO,EAAE,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAG7C,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAE7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;;;;;;;;;;;AAmBpF,MAAM,OAAO,kBAAkB;IAgB9B,YACkB,gBAAkC,EAClC,aAA4B,EAC5B,QAAyB;QAFzB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,kBAAa,GAAb,aAAa,CAAe;QAC5B,aAAQ,GAAR,QAAQ,CAAiB;QAf3C,kBAAa,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QACtC,WAAM,GAAW,EAAE,CAAC;QAEpB,aAAQ,GAAW,EAAE,CAAC;QACtB,oBAAe,GAAW,EAAE,CAAC;QAC7B,gBAAW,GAAkB,YAAY,CAAC,OAAO,CAAC,MAAM,CAAkB,IAAI,YAAY,CAAC,EAAE,CAAC;QAE9F,cAAS,GAAe;YACvB,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,CAAC,EAAE,EAAE,IAAI,EAAE,4BAA4B,EAAE;YACzE,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,CAAC,EAAE,EAAE,IAAI,EAAE,4BAA4B,EAAE;SACzE,CAAC;QAOD,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACtD,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC7C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACnC,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAC7C,CAAC;IAED,IAAI,WAAW;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,0BAA0B,EAAE,CAAC;IACxD,CAAC;IAED,iBAAiB;QAChB,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;IACnC,CAAC;IAED,oBAAoB;QACnB,IAAI,CAAC,aAAa,CAAC,kBAAkB,EAAE,CAAC;IACzC,CAAC;IAED,oBAAoB;QACnB,IAAI,CAAC,aAAa,CAAC,kBAAkB,EAAE,CAAC;IACzC,CAAC;IAED,oBAAoB;QACnB,IAAI,CAAC,aAAa,CAAC,kBAAkB,EAAE,CAAC;IACzC,CAAC;IAED,0BAA0B;QACzB,IAAI,CAAC,aAAa,CAAC,wBAAwB,EAAE,CAAC;IAC/C,CAAC;IAED,0BAA0B;QACzB,IAAI,CAAC,aAAa,CAAC,wBAAwB,EAAE,CAAC;IAC/C,CAAC;IAED,gBAAgB;QACf,YAAY,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAE/C,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAEtD,MAAM,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QAEzB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC9C,CAAC;IAEO,qBAAqB,CAAC,QAAsB;QACnD,MAAM,KAAK,GAAwB;YAClC,IAAI,EAAE,iBAAiB;YACvB,IAAI,EAAE;gBACL,IAAI,EAAE,EAAE;gBACR,MAAM,EAAE;oBACP,QAAQ;iBACR;aACD;SACD,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,WAAW,CAAC,IAAkB;QAC7B,QAAQ,IAAI,EAAE,CAAC;YACd,KAAK,YAAY,CAAC,EAAE;gBACnB,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC;gBACpD,MAAM;YACP,KAAK,YAAY,CAAC,EAAE;gBACnB,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC;gBACpD,MAAM;YACP;gBACC,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC;gBACpD,MAAM;QACR,CAAC;IACF,CAAC;IAED,WAAW;QACV,IAAU,UAAW,CAAC,UAAU,EAAE,CAAC;YAClC,QAAc,UAAW,CAAC,UAAU,EAAE,CAAC;gBACtC,KAAK,IAAI,CAAC,IAAI;oBACb,IAAI,CAAC,QAAQ,GAAG,kCAAkC,CAAC;oBACnD,MAAM;gBACP,KAAK,IAAI,CAAC,IAAI;oBACb,IAAI,CAAC,QAAQ,GAAG,kCAAkC,CAAC;oBACnD,MAAM;gBACP,KAAK,IAAI,CAAC,IAAI;oBACb,IAAI,CAAC,QAAQ,GAAG,kCAAkC,CAAC;oBACnD,MAAM;gBACP;oBACC,IAAI,CAAC,QAAQ,GAAG,kCAAkC,CAAC;YACrD,CAAC;QACF,CAAC;aAAM,CAAC;YACP,QAAc,UAAW,CAAC,QAAQ,EAAE,CAAC;gBACpC,KAAK,IAAI,CAAC,GAAG,CAAC;gBACd,KAAK,IAAI,CAAC,GAAG,CAAC;gBACd,KAAK,IAAI,CAAC,GAAG;oBACZ,IAAI,CAAC,QAAQ,GAAG,6BAA6B,CAAC;oBAC9C,MAAM;gBACP,KAAK,IAAI,CAAC,GAAG,CAAC;gBACd,KAAK,IAAI,CAAC,OAAO,CAAC;gBAClB,KAAK,IAAI,CAAC,OAAO,CAAC;gBAClB,KAAK,IAAI,CAAC,GAAG,CAAC;gBACd,KAAK,IAAI,CAAC,GAAG;oBACZ,IAAI,CAAC,QAAQ,GAAG,6BAA6B,CAAC;oBAC9C,MAAM;gBACP,KAAK,IAAI,CAAC,EAAE;oBACX,IAAI,CAAC,QAAQ,GAAG,6BAA6B,CAAC;oBAC9C,MAAM;gBACP;oBACC,IAAI,CAAC,QAAQ,GAAG,6BAA6B,CAAC;YAChD,CAAC;QACF,CAAC;IACF,CAAC;8GAnIW,kBAAkB;kGAAlB,kBAAkB,gLCtC/B,+mGAqFA,u1ED5DE,YAAY,geACZ,aAAa,iDACb,WAAW,8VACX,aAAa,0JACb,WAAW,0MACX,aAAa,8BACb,cAAc,2qCACd,eAAe,iOACf,sBAAsB;;2FAKX,kBAAkB;kBAjB9B,SAAS;iCACG,IAAI,YACN,YAAY,WACb;wBACR,YAAY;wBACZ,aAAa;wBACb,WAAW;wBACX,aAAa;wBACb,WAAW;wBACX,aAAa;wBACb,cAAc;wBACd,eAAe;wBACf,sBAAsB;qBACtB;+IAKwB,UAAU;sBAAlC,SAAS;uBAAC,YAAY","sourcesContent":["import { UpperCasePipe } from '@angular/common';\r\nimport { Component, ElementRef, ViewChild, inject } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\nimport { BadgeModule } from 'primeng/badge';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { DividerModule } from 'primeng/divider';\r\nimport { DropdownModule } from 'primeng/dropdown';\r\nimport { MenubarModule } from 'primeng/menubar';\r\n\r\nimport { TranslocoModule, TranslocoService } from '@ngneat/transloco';\r\nimport { KeycloakService } from 'keycloak-angular';\r\n\r\nimport { Apps } from 'aril/boot/config/apps';\r\nimport { PubSubService } from 'aril/util/pub-sub';\r\n\r\nimport { LayoutService } from '../../service/app.layout.service';\r\nimport { LanguageCode } from '../../service/interfaces/enum';\r\nimport { Language, LanguageChangeEvent } from '../../service/interfaces/interfaces';\r\nimport { GeneralSearchComponent } from '../general-search/general-search.component';\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'app-topbar',\r\n\timports: [\r\n\t\tButtonModule,\r\n\t\tUpperCasePipe,\r\n\t\tFormsModule,\r\n\t\tDividerModule,\r\n\t\tBadgeModule,\r\n\t\tMenubarModule,\r\n\t\tDropdownModule,\r\n\t\tTranslocoModule,\r\n\t\tGeneralSearchComponent\r\n\t],\r\n\ttemplateUrl: './app.topbar.component.html',\r\n\tstyleUrls: ['./app.topbar.component.scss']\r\n})\r\nexport class AppTopbarComponent {\r\n\t@ViewChild('menubutton') menuButton!: ElementRef;\r\n\r\n\tusername!: string;\r\n\tlayoutService = inject(LayoutService);\r\n\tsearch: string = '';\r\n\r\n\tlogoPath: string = '';\r\n\tcurrentFlagPath: string = '';\r\n\tcurrentLang: LanguageCode = (localStorage.getItem('lang') as LanguageCode) || LanguageCode.TR;\r\n\r\n\tlanguages: Language[] = [\r\n\t\t{ name: 'TR', code: LanguageCode.TR, flag: 'assets/images/flags/tr.svg' },\r\n\t\t{ name: 'EN', code: LanguageCode.EN, flag: 'assets/images/flags/gb.svg' }\r\n\t];\r\n\r\n\tconstructor(\r\n\t\tprivate readonly translocoService: TranslocoService,\r\n\t\tprivate readonly pubSubService: PubSubService,\r\n\t\tprivate readonly keycloak: KeycloakService\r\n\t) {\r\n\t\tthis.translocoService.setActiveLang(this.currentLang);\r\n\t\tthis.publishLanguageChange(this.currentLang);\r\n\t\tthis.setFlagPath(this.currentLang);\r\n\t\tthis.setLogoPath();\r\n\r\n\t\tthis.username = this.keycloak.getUsername();\r\n\t}\r\n\r\n\tget unreadCount(): number {\r\n\t\treturn this.layoutService.getUnreadNotificationCount();\r\n\t}\r\n\r\n\tonMenuButtonClick(): void {\r\n\t\tthis.layoutService.onMenuToggle();\r\n\t}\r\n\r\n\tonProfileButtonClick(): void {\r\n\t\tthis.layoutService.showProfileSidebar();\r\n\t}\r\n\r\n\tonHistoryButtonClick(): void {\r\n\t\tthis.layoutService.showHistorySidebar();\r\n\t}\r\n\r\n\tonSiteMapButtonClick(): void {\r\n\t\tthis.layoutService.showSiteMapSidebar();\r\n\t}\r\n\r\n\tonFavoritePagesButtonClick(): void {\r\n\t\tthis.layoutService.showFavoritePagesSidebar();\r\n\t}\r\n\r\n\tonNotificationsButtonClick(): void {\r\n\t\tthis.layoutService.showNotificationsSidebar();\r\n\t}\r\n\r\n\tonLanguageChange(): void {\r\n\t\tlocalStorage.setItem('lang', this.currentLang);\r\n\r\n\t\tthis.translocoService.setActiveLang(this.currentLang);\r\n\r\n\t\twindow.location.reload();\r\n\r\n\t\tthis.publishLanguageChange(this.currentLang);\r\n\t}\r\n\r\n\tprivate publishLanguageChange(language: LanguageCode): void {\r\n\t\tconst event: LanguageChangeEvent = {\r\n\t\t\tname: 'languageChanged',\r\n\t\t\tdata: {\r\n\t\t\t\tpath: '',\r\n\t\t\t\tcustom: {\r\n\t\t\t\t\tlanguage\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t};\r\n\r\n\t\tthis.pubSubService.publish(event);\r\n\t}\r\n\r\n\tsetFlagPath(lang: LanguageCode) {\r\n\t\tswitch (lang) {\r\n\t\t\tcase LanguageCode.TR:\r\n\t\t\t\tthis.currentFlagPath = 'assets/images/flags/tr.svg';\r\n\t\t\t\tbreak;\r\n\t\t\tcase LanguageCode.EN:\r\n\t\t\t\tthis.currentFlagPath = 'assets/images/flags/gb.svg';\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\tthis.currentFlagPath = 'assets/images/flags/tr.svg';\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n\r\n\tsetLogoPath() {\r\n\t\tif ((<any>globalThis).activeHost) {\r\n\t\t\tswitch ((<any>globalThis).activeHost) {\r\n\t\t\t\tcase Apps.YEAP:\r\n\t\t\t\t\tthis.logoPath = 'assets/images/yeap-logo-dark.png';\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase Apps.THOR:\r\n\t\t\t\t\tthis.logoPath = 'assets/images/thor-logo-dark.png';\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase Apps.LENA:\r\n\t\t\t\t\tthis.logoPath = 'assets/images/lena-logo-dark.png';\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthis.logoPath = 'assets/images/yeap-logo-dark.png';\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tswitch ((<any>globalThis).activeMF) {\r\n\t\t\t\tcase Apps.HES:\r\n\t\t\t\tcase Apps.CTS:\r\n\t\t\t\tcase Apps.SIS:\r\n\t\t\t\t\tthis.logoPath = 'assets/images/lena-logo.png';\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase Apps.CRM:\r\n\t\t\t\tcase Apps.BILLING:\r\n\t\t\t\tcase Apps.PAYMENT:\r\n\t\t\t\tcase Apps.WDM:\r\n\t\t\t\tcase Apps.MNG:\r\n\t\t\t\t\tthis.logoPath = 'assets/images/thor-logo.png';\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase Apps.MW:\r\n\t\t\t\t\tthis.logoPath = 'assets/images/yeap-logo.png';\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthis.logoPath = 'assets/images/yeap-logo.png';\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n","<div class=\"layout-topbar\">\r\n\t<div class=\"topbar-start\">\r\n\t\t<button #menubutton type=\"button\" class=\"topbar-menubutton p-link p-trigger\" (click)=\"onMenuButtonClick()\">\r\n\t\t\t<i class=\"pi pi-bars\"></i>\r\n\t\t</button>\r\n\t\t<img [src]=\"logoPath\" class=\"topbar-logo\" alt=\"logo\" />\r\n\t</div>\r\n\r\n\t<div class=\"topbar-search\" *transloco=\"let t; read: ''\">\r\n\t\t<span class=\"p-input-icon-left\">\r\n\t\t\t<i class=\"pi pi-search\"></i>\r\n\t\t\t<app-general-search></app-general-search>\r\n\t\t</span>\r\n\t</div>\r\n\r\n\t<div class=\"topbar-end mr-2\">\r\n\t\t<ul class=\"topbar-menu\">\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-sitemap\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onSiteMapButtonClick()\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-history\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onHistoryButtonClick()\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button\r\n\t\t\t\t\ticon=\"pi pi-heart\"\r\n\t\t\t\t\tseverity=\"secondary\"\r\n\t\t\t\t\t[text]=\"true\"\r\n\t\t\t\t\t[rounded]=\"true\"\r\n\t\t\t\t\t(click)=\"onFavoritePagesButtonClick()\" />\r\n\t\t\t</li>\r\n\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-button severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" (click)=\"onProfileButtonClick()\">\r\n\t\t\t\t\t{{ username[0] | uppercase }}\r\n\t\t\t\t</p-button>\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-divider layout=\"vertical\" styleClass=\"h-1rem border-500 m-0\" />\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<i\r\n\t\t\t\t\tclass=\"pi pi-bell notification-icon\"\r\n\t\t\t\t\tpBadge\r\n\t\t\t\t\t[value]=\"unreadCount > 0 ? unreadCount.toString() : '0'\"\r\n\t\t\t\t\t(click)=\"onNotificationsButtonClick()\"></i>\r\n\t\t\t</li>\r\n\t\t\t<li class=\"topbar-menu-item\">\r\n\t\t\t\t<p-dropdown\r\n\t\t\t\t\t[options]=\"languages\"\r\n\t\t\t\t\t[(ngModel)]=\"currentLang\"\r\n\t\t\t\t\t(onChange)=\"onLanguageChange()\"\r\n\t\t\t\t\toptionLabel=\"name\"\r\n\t\t\t\t\toptionValue=\"code\"\r\n\t\t\t\t\t[showClear]=\"false\"\r\n\t\t\t\t\tclass=\"custom-dropdown ml-3\">\r\n\t\t\t\t\t<ng-template pTemplate=\"selectedItem\">\r\n\t\t\t\t\t\t<div class=\"flex align-items-center gap-2\">\r\n\t\t\t\t\t\t\t<img [src]=\"currentFlagPath\" class=\"flag-icon\" alt=\"flag\" />\r\n\t\t\t\t\t\t\t<span class=\"language-text\">{{ currentLang | uppercase }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t<ng-template pTemplate=\"item\" let-item>\r\n\t\t\t\t\t\t<div class=\"flex align-items-center gap-2\">\r\n\t\t\t\t\t\t\t<img [src]=\"item.flag\" class=\"flag-icon\" alt=\"flag\" />\r\n\t\t\t\t\t\t\t<span>{{ item.name }}</span>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t</p-dropdown>\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</div>\r\n</div>\r\n\r\n<!-- <app-breadcrumb class=\"topbar-breadcrumb\"></app-breadcrumb> -->\r\n"]}
|