common-header-lib 0.0.1
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/README.md +24 -0
- package/assets/.gitkeep +0 -0
- package/assets/i18n/ar.json +83 -0
- package/assets/i18n/de.json +83 -0
- package/assets/i18n/en.json +83 -0
- package/assets/i18n/es.json +83 -0
- package/assets/i18n/fr.json +83 -0
- package/assets/i18n/hi.json +83 -0
- package/assets/i18n/ja.json +83 -0
- package/assets/i18n/ko.json +83 -0
- package/assets/images/APP019.svg +6 -0
- package/assets/images/APP020.svg +4 -0
- package/assets/images/APP021.svg +6 -0
- package/assets/images/APP022.svg +6 -0
- package/assets/images/APP023.svg +11 -0
- package/assets/images/APP024.svg +9 -0
- package/assets/images/APP025.svg +8 -0
- package/assets/images/APP026.svg +4 -0
- package/assets/images/APP027.svg +5 -0
- package/assets/images/APP028.svg +6 -0
- package/assets/images/APP029.svg +12 -0
- package/assets/images/APP030.svg +20 -0
- package/assets/images/APP031.svg +14 -0
- package/assets/images/APP032.svg +17 -0
- package/assets/images/Frame.svg +104 -0
- package/assets/images/apps-1.svg +22 -0
- package/assets/images/bell-icon.svg +3 -0
- package/assets/images/check_circle.svg +3 -0
- package/assets/images/close copy.svg +5 -0
- package/assets/images/close.svg +5 -0
- package/assets/images/copy-img.svg +3 -0
- package/assets/images/cross-search.svg +4 -0
- package/assets/images/domain_img.svg +3 -0
- package/assets/images/east.svg +3 -0
- package/assets/images/error.svg +3 -0
- package/assets/images/filepath.svg +8 -0
- package/assets/images/flag1.svg +3 -0
- package/assets/images/gc-mail.svg +3 -0
- package/assets/images/grey-arrow.svg +3 -0
- package/assets/images/info.svg +3 -0
- package/assets/images/local.svg +3 -0
- package/assets/images/lock-pass.svg +3 -0
- package/assets/images/lock1.svg +3 -0
- package/assets/images/login-bg/default_bg.svg +448 -0
- package/assets/images/login-bg/visibility.svg +3 -0
- package/assets/images/login-bg/visibility_off.svg +3 -0
- package/assets/images/logo.png +0 -0
- package/assets/images/logout.svg +3 -0
- package/assets/images/mail-icon.svg +3 -0
- package/assets/images/marker-pin.svg +4 -0
- package/assets/images/noti_ticket.svg +3 -0
- package/assets/images/pass-img.svg +3 -0
- package/assets/images/refresh-1.svg +3 -0
- package/assets/images/schedule.svg +1 -0
- package/assets/images/search-filter.svg +3 -0
- package/assets/images/search-icon.svg +3 -0
- package/assets/images/settings.svg +3 -0
- package/assets/images/successful.svg +10 -0
- package/assets/images/user-name.svg +3 -0
- package/assets/scss/_sidebar.scss +267 -0
- package/assets/scss/styles.scss +577 -0
- package/esm2020/common-header-lib.mjs +5 -0
- package/esm2020/lib/Validators/noSpaceAllowed.mjs +16 -0
- package/esm2020/lib/common-header-lib.component.mjs +612 -0
- package/esm2020/lib/common-header-lib.module.mjs +208 -0
- package/esm2020/lib/common-header-lib.service.mjs +200 -0
- package/esm2020/lib/components/confirm-dialog/confirm-dialog.component.mjs +49 -0
- package/esm2020/lib/components/general-configuration/general-configuration.component.mjs +402 -0
- package/esm2020/lib/components/general-configuration/landingpg-config/landingpg-config.component.mjs +124 -0
- package/esm2020/lib/components/general-configuration/timezone-configuration/timezone-configuration.component.mjs +138 -0
- package/esm2020/lib/components/grid-pagination/grid-pagination.component.mjs +39 -0
- package/esm2020/lib/components/ng-translation/ng-translation.component.mjs +65 -0
- package/esm2020/lib/components/no-service-my-access-pg/no-service-my-access-pg.component.mjs +19 -0
- package/esm2020/lib/components/notification-sidebar/notification-sidebar.component.mjs +40 -0
- package/esm2020/lib/components/side-popup/side-popup.component.mjs +34 -0
- package/esm2020/lib/components/user-mailbox/user-mailbox.component.mjs +173 -0
- package/esm2020/lib/components/user-sidebar/user-sidebar.component.mjs +279 -0
- package/esm2020/lib/components/viewpassword-popup/viewpassword-popup.component.mjs +196 -0
- package/esm2020/lib/model/data_model.mjs +217 -0
- package/esm2020/lib/pipes/custome-dateformat.pipe.mjs +27 -0
- package/esm2020/lib/pipes/date-diff.pipe.mjs +56 -0
- package/esm2020/lib/pipes/slice-to-two.pipe.mjs +34 -0
- package/esm2020/lib/services/EncrypDecryp_RSA.service.mjs +100 -0
- package/esm2020/lib/services/async-passwordcheck.service.mjs +72 -0
- package/esm2020/lib/services/cookie-storage-manager.service.mjs +78 -0
- package/esm2020/lib/services/encrpdata.service.mjs +55 -0
- package/esm2020/lib/services/encrydecrydata.service.mjs +207 -0
- package/esm2020/lib/services/event.service.mjs +133 -0
- package/esm2020/lib/services/http/http-common.service.mjs +216 -0
- package/esm2020/lib/services/http/http-general-config.service.mjs +84 -0
- package/esm2020/lib/services/rest-login-form.service.mjs +296 -0
- package/esm2020/lib/services/rest-signalr.service.mjs +100 -0
- package/esm2020/lib/services/storage.service.mjs +33 -0
- package/esm2020/lib/services/toast-msg.service.mjs +95 -0
- package/esm2020/lib/services/vapt-validation.service.mjs +31 -0
- package/esm2020/public-api.mjs +13 -0
- package/fesm2015/common-header-lib.mjs +4165 -0
- package/fesm2015/common-header-lib.mjs.map +1 -0
- package/fesm2020/common-header-lib.mjs +4146 -0
- package/fesm2020/common-header-lib.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/Validators/noSpaceAllowed.d.ts +2 -0
- package/lib/common-header-lib.component.d.ts +148 -0
- package/lib/common-header-lib.module.d.ts +43 -0
- package/lib/common-header-lib.service.d.ts +25 -0
- package/lib/components/confirm-dialog/confirm-dialog.component.d.ts +13 -0
- package/lib/components/general-configuration/general-configuration.component.d.ts +86 -0
- package/lib/components/general-configuration/landingpg-config/landingpg-config.component.d.ts +37 -0
- package/lib/components/general-configuration/timezone-configuration/timezone-configuration.component.d.ts +38 -0
- package/lib/components/grid-pagination/grid-pagination.component.d.ts +20 -0
- package/lib/components/ng-translation/ng-translation.component.d.ts +22 -0
- package/lib/components/no-service-my-access-pg/no-service-my-access-pg.component.d.ts +8 -0
- package/lib/components/notification-sidebar/notification-sidebar.component.d.ts +16 -0
- package/lib/components/side-popup/side-popup.component.d.ts +14 -0
- package/lib/components/user-mailbox/user-mailbox.component.d.ts +40 -0
- package/lib/components/user-sidebar/user-sidebar.component.d.ts +61 -0
- package/lib/components/viewpassword-popup/viewpassword-popup.component.d.ts +47 -0
- package/lib/model/data_model.d.ts +184 -0
- package/lib/pipes/custome-dateformat.pipe.d.ts +8 -0
- package/lib/pipes/date-diff.pipe.d.ts +9 -0
- package/lib/pipes/slice-to-two.pipe.d.ts +7 -0
- package/lib/services/EncrypDecryp_RSA.service.d.ts +15 -0
- package/lib/services/async-passwordcheck.service.d.ts +18 -0
- package/lib/services/cookie-storage-manager.service.d.ts +16 -0
- package/lib/services/encrpdata.service.d.ts +12 -0
- package/lib/services/encrydecrydata.service.d.ts +33 -0
- package/lib/services/event.service.d.ts +30 -0
- package/lib/services/http/http-common.service.d.ts +30 -0
- package/lib/services/http/http-general-config.service.d.ts +15 -0
- package/lib/services/rest-login-form.service.d.ts +39 -0
- package/lib/services/rest-signalr.service.d.ts +23 -0
- package/lib/services/storage.service.d.ts +11 -0
- package/lib/services/toast-msg.service.d.ts +21 -0
- package/lib/services/vapt-validation.service.d.ts +7 -0
- package/package.json +49 -0
- package/public-api.d.ts +8 -0
- package/src/assets/i18n/ar.json +83 -0
- package/src/assets/i18n/de.json +83 -0
- package/src/assets/i18n/en.json +83 -0
- package/src/assets/i18n/es.json +83 -0
- package/src/assets/i18n/fr.json +83 -0
- package/src/assets/i18n/hi.json +83 -0
- package/src/assets/i18n/ja.json +83 -0
- package/src/assets/i18n/ko.json +83 -0
- package/src/assets/images/APP019.svg +6 -0
- package/src/assets/images/APP020.svg +4 -0
- package/src/assets/images/APP021.svg +6 -0
- package/src/assets/images/APP022.svg +6 -0
- package/src/assets/images/APP023.svg +11 -0
- package/src/assets/images/APP024.svg +9 -0
- package/src/assets/images/APP025.svg +8 -0
- package/src/assets/images/APP026.svg +4 -0
- package/src/assets/images/APP027.svg +5 -0
- package/src/assets/images/APP028.svg +6 -0
- package/src/assets/images/APP029.svg +12 -0
- package/src/assets/images/APP030.svg +20 -0
- package/src/assets/images/APP031.svg +14 -0
- package/src/assets/images/APP032.svg +17 -0
- package/src/assets/images/Frame.svg +104 -0
- package/src/assets/images/apps-1.svg +22 -0
- package/src/assets/images/bell-icon.svg +3 -0
- package/src/assets/images/check_circle.svg +3 -0
- package/src/assets/images/close copy.svg +5 -0
- package/src/assets/images/close.svg +5 -0
- package/src/assets/images/copy-img.svg +3 -0
- package/src/assets/images/cross-search.svg +4 -0
- package/src/assets/images/domain_img.svg +3 -0
- package/src/assets/images/east.svg +3 -0
- package/src/assets/images/error.svg +3 -0
- package/src/assets/images/filepath.svg +8 -0
- package/src/assets/images/flag1.svg +3 -0
- package/src/assets/images/gc-mail.svg +3 -0
- package/src/assets/images/grey-arrow.svg +3 -0
- package/src/assets/images/info.svg +3 -0
- package/src/assets/images/local.svg +3 -0
- package/src/assets/images/lock-pass.svg +3 -0
- package/src/assets/images/lock1.svg +3 -0
- package/src/assets/images/login-bg/default_bg.svg +448 -0
- package/src/assets/images/login-bg/visibility.svg +3 -0
- package/src/assets/images/login-bg/visibility_off.svg +3 -0
- package/src/assets/images/logo.png +0 -0
- package/src/assets/images/logout.svg +3 -0
- package/src/assets/images/mail-icon.svg +3 -0
- package/src/assets/images/marker-pin.svg +4 -0
- package/src/assets/images/noti_ticket.svg +3 -0
- package/src/assets/images/pass-img.svg +3 -0
- package/src/assets/images/refresh-1.svg +3 -0
- package/src/assets/images/schedule.svg +1 -0
- package/src/assets/images/search-filter.svg +3 -0
- package/src/assets/images/search-icon.svg +3 -0
- package/src/assets/images/settings.svg +3 -0
- package/src/assets/images/successful.svg +10 -0
- package/src/assets/images/user-name.svg +3 -0
- package/src/assets/scss/_sidebar.scss +267 -0
- package/src/assets/scss/styles.scss +577 -0
|
@@ -0,0 +1,612 @@
|
|
|
1
|
+
import { ConfirmDialogComponent } from './components/confirm-dialog/confirm-dialog.component';
|
|
2
|
+
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { CommonHeaderLibService } from './common-header-lib.service';
|
|
4
|
+
import { catchError, finalize, map, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { OverlayPanel } from 'primeng/overlaypanel';
|
|
6
|
+
import { Subject, forkJoin, of } from 'rxjs';
|
|
7
|
+
import { GlobalConstants } from './model/data_model';
|
|
8
|
+
import { RestSignalRService } from './services/rest-signalr.service';
|
|
9
|
+
import { EventService } from './services/event.service';
|
|
10
|
+
import { TranslateService } from '@ngx-translate/core';
|
|
11
|
+
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
|
|
12
|
+
import { HttpCommonService } from './services/http/http-common.service';
|
|
13
|
+
import { ToastMsgService } from './services/toast-msg.service';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "./common-header-lib.service";
|
|
16
|
+
import * as i2 from "./services/rest-signalr.service";
|
|
17
|
+
import * as i3 from "./services/event.service";
|
|
18
|
+
import * as i4 from "@ngx-translate/core";
|
|
19
|
+
import * as i5 from "@ng-bootstrap/ng-bootstrap";
|
|
20
|
+
import * as i6 from "./services/http/http-common.service";
|
|
21
|
+
import * as i7 from "./services/toast-msg.service";
|
|
22
|
+
import * as i8 from "@angular/common";
|
|
23
|
+
import * as i9 from "@angular/forms";
|
|
24
|
+
import * as i10 from "primeng/dropdown";
|
|
25
|
+
import * as i11 from "primeng/api";
|
|
26
|
+
import * as i12 from "primeng/overlaypanel";
|
|
27
|
+
import * as i13 from "primeng/badge";
|
|
28
|
+
import * as i14 from "primeng/skeleton";
|
|
29
|
+
import * as i15 from "./components/user-sidebar/user-sidebar.component";
|
|
30
|
+
import * as i16 from "./components/side-popup/side-popup.component";
|
|
31
|
+
import * as i17 from "./components/user-mailbox/user-mailbox.component";
|
|
32
|
+
import * as i18 from "./components/no-service-my-access-pg/no-service-my-access-pg.component";
|
|
33
|
+
import * as i19 from "./components/confirm-dialog/confirm-dialog.component";
|
|
34
|
+
import * as i20 from "./pipes/slice-to-two.pipe";
|
|
35
|
+
export class CommonHeaderLibComponent {
|
|
36
|
+
constructor(libService, cdRef, _signalRService, _eventService, translate, modalService, translateService, httpCommonService, msgService) {
|
|
37
|
+
this.libService = libService;
|
|
38
|
+
this.cdRef = cdRef;
|
|
39
|
+
this._signalRService = _signalRService;
|
|
40
|
+
this._eventService = _eventService;
|
|
41
|
+
this.translate = translate;
|
|
42
|
+
this.modalService = modalService;
|
|
43
|
+
this.translateService = translateService;
|
|
44
|
+
this.httpCommonService = httpCommonService;
|
|
45
|
+
this.msgService = msgService;
|
|
46
|
+
// @Input() apiURL: string = '';
|
|
47
|
+
this.EnableLogo = true;
|
|
48
|
+
this.moduleName = '';
|
|
49
|
+
this.EnableTimeZone = true;
|
|
50
|
+
this.EnableLOB = true;
|
|
51
|
+
this.EnableMail = true;
|
|
52
|
+
this.EnableNotifications = true;
|
|
53
|
+
this.EnableMoreApps = true;
|
|
54
|
+
this.EnableProfile = true;
|
|
55
|
+
this.lobSelected = new EventEmitter();
|
|
56
|
+
this.langChange = new EventEmitter();
|
|
57
|
+
this.overlayStateChange = new EventEmitter();
|
|
58
|
+
this.userTimeZoneAbbreviations = '';
|
|
59
|
+
this.userTimeZoneFullForm = '';
|
|
60
|
+
this.userLOBList = [];
|
|
61
|
+
this.showLobLoader = true;
|
|
62
|
+
this.totalEmails = '';
|
|
63
|
+
this.userNotificationCount = '';
|
|
64
|
+
this.ListOfUserPrivillegedApp = [];
|
|
65
|
+
this.userdisplayName = '';
|
|
66
|
+
this.userDetailsInfo = [];
|
|
67
|
+
this.isOpenSidePopup = false;
|
|
68
|
+
this.showUserDetails = false;
|
|
69
|
+
this.userAppLoaderLoadder = true;
|
|
70
|
+
this.repeatLoader = new Array(12).fill(0);
|
|
71
|
+
this.showMailboxScreenflag = false;
|
|
72
|
+
this.isErrorFound = false;
|
|
73
|
+
this.userNotificationCountObj = {};
|
|
74
|
+
this.eventwiseNotificationCount = [];
|
|
75
|
+
this.notificationLoadder = true;
|
|
76
|
+
this.unsubscribeAPIEventListenerData = new Subject();
|
|
77
|
+
this.unsubscribeSidebarListenerData = new Subject();
|
|
78
|
+
this.userId = '';
|
|
79
|
+
this.assetCategoryMenuList = [];
|
|
80
|
+
this.showbusinessFileds = false;
|
|
81
|
+
this.showInfraFileds = false;
|
|
82
|
+
this.showfiltersearch = true;
|
|
83
|
+
this.clickInside = false;
|
|
84
|
+
this.isLobContentLoaded = false;
|
|
85
|
+
this.isHeaderContentLoaded = false;
|
|
86
|
+
this.requestTypeId = 1;
|
|
87
|
+
this.accessTypes = [
|
|
88
|
+
{ id: 1, name: 'Permanent' },
|
|
89
|
+
{ id: 2, name: 'OneTime' },
|
|
90
|
+
{ id: 3, name: 'TimeBased' },
|
|
91
|
+
];
|
|
92
|
+
this.selectedAssetName = {
|
|
93
|
+
assetId: -100,
|
|
94
|
+
assetName: 'All',
|
|
95
|
+
};
|
|
96
|
+
this.assetName = '';
|
|
97
|
+
this.assetId = 0;
|
|
98
|
+
this.allCategory = {
|
|
99
|
+
assetTypeId: -100,
|
|
100
|
+
assetTypeValue: 'All Section',
|
|
101
|
+
assetList: [
|
|
102
|
+
{
|
|
103
|
+
assetId: -100,
|
|
104
|
+
assetName: 'All',
|
|
105
|
+
},
|
|
106
|
+
],
|
|
107
|
+
};
|
|
108
|
+
this.translateName = [
|
|
109
|
+
'Generic_lib.Permanent',
|
|
110
|
+
'Generic_lib.OneTime',
|
|
111
|
+
'Generic_lib.TimeBased',
|
|
112
|
+
];
|
|
113
|
+
this.appPanel = OverlayPanel;
|
|
114
|
+
this.isErrorOccured = false;
|
|
115
|
+
// @Output() public refreshNotification = new EventEmitter<boolean>();
|
|
116
|
+
this.repeatLoader1 = new Array(9).fill(0);
|
|
117
|
+
}
|
|
118
|
+
ngOnInit() {
|
|
119
|
+
this.headerLogo = '';
|
|
120
|
+
this.overlayStateChange.emit(false);
|
|
121
|
+
this.setWebAPIURL();
|
|
122
|
+
if (this.EnableLogo)
|
|
123
|
+
this.loadHeaderLogo();
|
|
124
|
+
if (this.EnableLOB)
|
|
125
|
+
this.getListofLOB();
|
|
126
|
+
this.onLoadMethod();
|
|
127
|
+
}
|
|
128
|
+
onLoadMethod() {
|
|
129
|
+
this.onDemandActions();
|
|
130
|
+
if (this.EnableNotifications)
|
|
131
|
+
this.getEventwiseNotificationCount();
|
|
132
|
+
this.getUserActivityDetails();
|
|
133
|
+
}
|
|
134
|
+
//* on click of Mail icon
|
|
135
|
+
showMailBoxScreen() {
|
|
136
|
+
this.showMailboxScreenflag = true;
|
|
137
|
+
this.overlayStateChange.emit(true);
|
|
138
|
+
}
|
|
139
|
+
hideMailBoxScreen() {
|
|
140
|
+
this.showMailboxScreenflag = false;
|
|
141
|
+
this.overlayStateChange.emit(false);
|
|
142
|
+
}
|
|
143
|
+
//* Main language change emitter
|
|
144
|
+
languageChange(event) {
|
|
145
|
+
if (!event)
|
|
146
|
+
return;
|
|
147
|
+
this.langChange.emit(event);
|
|
148
|
+
}
|
|
149
|
+
showUserAppsPanel(event) {
|
|
150
|
+
this.appPanel.toggle(event);
|
|
151
|
+
if (this.ListOfUserPrivillegedApp.length === 0) {
|
|
152
|
+
this.getUserAssignedApp();
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
showUserDetailsPanel() {
|
|
156
|
+
this.openSidePopup();
|
|
157
|
+
this.showUserDetails = true;
|
|
158
|
+
}
|
|
159
|
+
closeSidePopup() {
|
|
160
|
+
this.showUserDetails = false;
|
|
161
|
+
this.isOpenSidePopup = false;
|
|
162
|
+
}
|
|
163
|
+
openSidePopup() {
|
|
164
|
+
this.isOpenSidePopup = true;
|
|
165
|
+
}
|
|
166
|
+
//Method: Take Connection of Application
|
|
167
|
+
getConnectionofApplication(appCode) {
|
|
168
|
+
console.log('appcode', appCode);
|
|
169
|
+
const url = GlobalConstants.baseURL + '/xauth/api/Token/AppOAuth?appcode=' + appCode;
|
|
170
|
+
window.open(url, '_blank');
|
|
171
|
+
}
|
|
172
|
+
async getConnectToSingalRhub() {
|
|
173
|
+
try {
|
|
174
|
+
await this._signalRService.initializeSignalRConnection();
|
|
175
|
+
}
|
|
176
|
+
catch (error) {
|
|
177
|
+
console.error('All SignalR hub connections failed.', error);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
ngAfterViewInit() {
|
|
181
|
+
this.ListenToTranslateEvent();
|
|
182
|
+
// Initialize modal instance when DOM is ready
|
|
183
|
+
this.bsModalInstance = new bootstrap.Modal(this.notifyModal.nativeElement);
|
|
184
|
+
}
|
|
185
|
+
/*Method : Listen to the Other component event
|
|
186
|
+
Action : It used to listen diff. component command on basis of perform some actions */
|
|
187
|
+
onDemandActions() {
|
|
188
|
+
//Listen the Event Emit by Sidebar
|
|
189
|
+
this._eventService
|
|
190
|
+
.listenerAssetTypeEvent()
|
|
191
|
+
.pipe(takeUntil(this.unsubscribeSidebarListenerData))
|
|
192
|
+
.subscribe((data) => {
|
|
193
|
+
if (data && data['component'] === 'assetMenu') {
|
|
194
|
+
this.assetCategoryMenuList = [];
|
|
195
|
+
this.assetCategoryMenuList = data['aseetTypeList'];
|
|
196
|
+
//Note: Add Filter Fileds of Business/Infra Asset and there RequestID
|
|
197
|
+
//For Business Asset
|
|
198
|
+
if (data?.['assetCategoryId'] == 1) {
|
|
199
|
+
this.showbusinessFileds = true;
|
|
200
|
+
this.showInfraFileds = false;
|
|
201
|
+
this.requestTypeId = 1;
|
|
202
|
+
this.selectedAssetName = this.assetCategoryMenuList[0]; //Set index 0 By Default
|
|
203
|
+
this.assetName = this.selectedAssetName['assetTypeValue'];
|
|
204
|
+
this.assetId = this.selectedAssetName['assetTypeId'];
|
|
205
|
+
//For Infra Asset
|
|
206
|
+
}
|
|
207
|
+
else if (data?.['assetCategoryId'] == 2) {
|
|
208
|
+
this.showInfraFileds = true;
|
|
209
|
+
this.showbusinessFileds = false;
|
|
210
|
+
this.requestTypeId = 2;
|
|
211
|
+
this.selectedAssetName =
|
|
212
|
+
this.assetCategoryMenuList[0]['assetList'][0]; //Set index 0 By Default
|
|
213
|
+
this.assetName = this.selectedAssetName['assetName'];
|
|
214
|
+
this.assetId = this.selectedAssetName['assetId'];
|
|
215
|
+
}
|
|
216
|
+
//Note: Added Extra Hard coded type in AssetCategory Menu for Infra Asset
|
|
217
|
+
if (this.assetCategoryMenuList.length > 0) {
|
|
218
|
+
if (this.showInfraFileds) {
|
|
219
|
+
this.assetCategoryMenuList.unshift(this.allCategory);
|
|
220
|
+
}
|
|
221
|
+
this.assetCategoryMenuList = this.assetCategoryMenuList.filter((element) => {
|
|
222
|
+
if (!(element.assetTypeValue === 'Favorite' ||
|
|
223
|
+
element.assetTypeValue === 'Bookmark')) {
|
|
224
|
+
return element;
|
|
225
|
+
}
|
|
226
|
+
});
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
});
|
|
230
|
+
//Listen the Event Emit by SignalR Hub
|
|
231
|
+
this._signalRService
|
|
232
|
+
.listenerEventMsg()
|
|
233
|
+
.pipe(takeUntil(this.unsubscribeAPIEventListenerData))
|
|
234
|
+
.subscribe((data) => {
|
|
235
|
+
if (data && data['application'] && data['events']) {
|
|
236
|
+
this.isErrorFound = false;
|
|
237
|
+
this.userNotificationCountObj = data['application'];
|
|
238
|
+
//Note: If Notification count > 99
|
|
239
|
+
if (this.userNotificationCountObj &&
|
|
240
|
+
this.userNotificationCountObj['PendingCount']) {
|
|
241
|
+
if (Number(this.userNotificationCountObj['PendingCount']) > 99) {
|
|
242
|
+
this.userNotificationCount = '99+';
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
this.userNotificationCount = String(this.userNotificationCountObj['PendingCount']);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
else {
|
|
249
|
+
this.userNotificationCount = '';
|
|
250
|
+
}
|
|
251
|
+
this.eventwiseNotificationCount = data['events'];
|
|
252
|
+
}
|
|
253
|
+
});
|
|
254
|
+
this.listenToTimeZoneConfig();
|
|
255
|
+
this.listenToEmailCountEvent();
|
|
256
|
+
}
|
|
257
|
+
//Listen to TimeZone Config
|
|
258
|
+
listenToTimeZoneConfig() {
|
|
259
|
+
this._eventService
|
|
260
|
+
.listenerTimezone()
|
|
261
|
+
.pipe(takeUntil(this.unsubscribeAPIEventListenerData))
|
|
262
|
+
.subscribe((response) => {
|
|
263
|
+
if (response && response['component'] == 'timezone') {
|
|
264
|
+
this.userTimeZoneAbbreviations =
|
|
265
|
+
response['usertimezoneAbbreviations'];
|
|
266
|
+
this.userTimeZoneFullForm = response['userTimeZoneFullForm'];
|
|
267
|
+
}
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
//Listen to Email Count when user Read
|
|
271
|
+
listenToEmailCountEvent() {
|
|
272
|
+
this._eventService
|
|
273
|
+
.listenerUserEmail()
|
|
274
|
+
.pipe(takeUntil(this.unsubscribeAPIEventListenerData))
|
|
275
|
+
.subscribe((data) => {
|
|
276
|
+
if (data && data['component'] === 'email-count') {
|
|
277
|
+
this.totalEmails = data['mailCount'];
|
|
278
|
+
}
|
|
279
|
+
});
|
|
280
|
+
}
|
|
281
|
+
//Method: Convert text one Lang. to another
|
|
282
|
+
ListenToTranslateEvent() {
|
|
283
|
+
this.translate.onLangChange.subscribe((val) => {
|
|
284
|
+
this.getTranslateContent();
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
//Method: Convert text one Lang. to another Event Listener
|
|
288
|
+
getTranslateContent() {
|
|
289
|
+
this.translate.get(this.translateName).subscribe((trans) => {
|
|
290
|
+
this.accessTypes.forEach((item, index) => {
|
|
291
|
+
const key = this.translateName[index];
|
|
292
|
+
item['name'] = trans[key];
|
|
293
|
+
});
|
|
294
|
+
});
|
|
295
|
+
}
|
|
296
|
+
OpenNotificationModal() {
|
|
297
|
+
// const modalRef = this.modalService.open(NotificationSidebarComponent);
|
|
298
|
+
// modalRef.componentInstance.lesson = lesson;
|
|
299
|
+
this.bsModalInstance?.show();
|
|
300
|
+
}
|
|
301
|
+
closeModal() {
|
|
302
|
+
this.bsModalInstance?.hide();
|
|
303
|
+
}
|
|
304
|
+
//Method: Call APi to Fetch New Notification Count
|
|
305
|
+
getEventwiseNotification() {
|
|
306
|
+
// this.refreshNotification.emit(true);
|
|
307
|
+
this.getEventwiseNotificationCount();
|
|
308
|
+
}
|
|
309
|
+
setWebAPIURL() {
|
|
310
|
+
if (GlobalConstants.baseURL == undefined) {
|
|
311
|
+
if (localStorage.getItem('_WAU')) {
|
|
312
|
+
GlobalConstants.baseURL = localStorage.getItem('_WAU') || '';
|
|
313
|
+
}
|
|
314
|
+
else {
|
|
315
|
+
let parsedURL = new URL(window.location.href);
|
|
316
|
+
let WebApiUrl = parsedURL.origin;
|
|
317
|
+
GlobalConstants.baseURL = WebApiUrl;
|
|
318
|
+
localStorage.setItem('_WAU', GlobalConstants.baseURL);
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
getUserActivityDetails() {
|
|
323
|
+
// Reset error state before API calls
|
|
324
|
+
this.isErrorFound = false;
|
|
325
|
+
// Initialize response container for forkJoin
|
|
326
|
+
const responseSet = {};
|
|
327
|
+
// Build payload once for notification API
|
|
328
|
+
const notificationPayload = {
|
|
329
|
+
ApplicationName: GlobalConstants.applicationName,
|
|
330
|
+
UserId: String(this.userId),
|
|
331
|
+
};
|
|
332
|
+
// Add notification API if enabled
|
|
333
|
+
if (this.EnableNotifications) {
|
|
334
|
+
responseSet.notifications = this.httpCommonService
|
|
335
|
+
.getWorkFlowTicketCount(notificationPayload)
|
|
336
|
+
.pipe(
|
|
337
|
+
// Extract valid notification data
|
|
338
|
+
map((response) => response),
|
|
339
|
+
// Handle API error without breaking forkJoin
|
|
340
|
+
catchError(() => {
|
|
341
|
+
this.isErrorFound = true;
|
|
342
|
+
return of(null);
|
|
343
|
+
}));
|
|
344
|
+
}
|
|
345
|
+
// Add user profile API if enabled
|
|
346
|
+
if (this.EnableProfile) {
|
|
347
|
+
responseSet.userinfo = this.httpCommonService.getLoggedInUserDetails();
|
|
348
|
+
}
|
|
349
|
+
// Add timezone API if enabled
|
|
350
|
+
if (this.EnableTimeZone) {
|
|
351
|
+
responseSet.timeZone = this.httpCommonService.getGlobalTimeZone();
|
|
352
|
+
}
|
|
353
|
+
// Add unread email count API if enabled
|
|
354
|
+
if (this.EnableMail) {
|
|
355
|
+
responseSet.emailCount =
|
|
356
|
+
this.httpCommonService.getUnreadUserEmailsCount();
|
|
357
|
+
}
|
|
358
|
+
// Execute all enabled APIs together
|
|
359
|
+
forkJoin(responseSet)
|
|
360
|
+
.pipe(
|
|
361
|
+
// Mark header loading as completed
|
|
362
|
+
finalize(() => {
|
|
363
|
+
this.isHeaderContentLoaded = true;
|
|
364
|
+
}))
|
|
365
|
+
.subscribe((response) => {
|
|
366
|
+
// Process notification data
|
|
367
|
+
if (response.notifications) {
|
|
368
|
+
this.getTotalNotificationCounts(response.notifications);
|
|
369
|
+
}
|
|
370
|
+
// Process user profile data
|
|
371
|
+
if (response.userinfo) {
|
|
372
|
+
this.getLoggedInUserDetails(response.userinfo);
|
|
373
|
+
}
|
|
374
|
+
// Process timezone list
|
|
375
|
+
if (response.timeZone) {
|
|
376
|
+
this.getListOfTimeZones(response.timeZone);
|
|
377
|
+
}
|
|
378
|
+
// Process unread email count
|
|
379
|
+
if (response.emailCount) {
|
|
380
|
+
this.getUserEmailCount(response.emailCount);
|
|
381
|
+
}
|
|
382
|
+
});
|
|
383
|
+
}
|
|
384
|
+
getTotalNotificationCounts(data) {
|
|
385
|
+
// this.isErrorFound = false;
|
|
386
|
+
this.userNotificationCountObj = data || {};
|
|
387
|
+
if (this.userNotificationCountObj &&
|
|
388
|
+
this.userNotificationCountObj['PendingCount']) {
|
|
389
|
+
if (Number(this.userNotificationCountObj['PendingCount']) > 99) {
|
|
390
|
+
this.userNotificationCount = '99+';
|
|
391
|
+
}
|
|
392
|
+
else {
|
|
393
|
+
this.userNotificationCount = String(this.userNotificationCountObj['PendingCount']);
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
else {
|
|
397
|
+
this.userNotificationCount = '';
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
/*Method : Retrieves details of the currently logged-in user*/
|
|
401
|
+
getLoggedInUserDetails(response) {
|
|
402
|
+
if (response && response['success'] && response['result']) {
|
|
403
|
+
this.userDetails = response['result'];
|
|
404
|
+
this.userdisplayName = this.userDetails['userDisplayName'];
|
|
405
|
+
}
|
|
406
|
+
}
|
|
407
|
+
/*Method : GET
|
|
408
|
+
Action : Get List of Time Zone*/
|
|
409
|
+
getListOfTimeZones(result) {
|
|
410
|
+
if (result && result['abbreviations']) {
|
|
411
|
+
this.userTimeZoneAbbreviations = result['abbreviations'];
|
|
412
|
+
this.userTimeZoneFullForm = result['userTimeZone'];
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
/*Method : GET
|
|
416
|
+
Action : Transformation fo Count */
|
|
417
|
+
getUserEmailCount(count) {
|
|
418
|
+
if (count <= 0) {
|
|
419
|
+
this.totalEmails = '';
|
|
420
|
+
}
|
|
421
|
+
else if (count > 99) {
|
|
422
|
+
this.totalEmails = '99+';
|
|
423
|
+
}
|
|
424
|
+
else {
|
|
425
|
+
this.totalEmails = String(count);
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
/** API to get the header LOGO */
|
|
429
|
+
loadHeaderLogo() {
|
|
430
|
+
this.httpCommonService.getLogo().subscribe((img) => {
|
|
431
|
+
this.headerLogo = 'data:image/png;base64,' + img['logoImg'];
|
|
432
|
+
});
|
|
433
|
+
}
|
|
434
|
+
/** API to get the timezone */
|
|
435
|
+
// getUserPreferredTimezone() {
|
|
436
|
+
// this.httpCommonService.getGlobalTimeZone().subscribe((res: any) => {
|
|
437
|
+
// if (res?.abbreviations) {
|
|
438
|
+
// this.userTimeZoneAbbreviations = res.abbreviations;
|
|
439
|
+
// this.userTimeZoneFullForm = res?.userTimeZone;
|
|
440
|
+
// }
|
|
441
|
+
// });
|
|
442
|
+
// }
|
|
443
|
+
//* get Lob AI call and initial LOB emitter
|
|
444
|
+
getListofLOB() {
|
|
445
|
+
this.showLobLoader = true;
|
|
446
|
+
this.httpCommonService.getLOBList().subscribe((res) => {
|
|
447
|
+
this.showLobLoader = false;
|
|
448
|
+
this.userLOBList = res.result;
|
|
449
|
+
let initialLobSelected = this.getLobById(this.userLOBList, this.userLOBList[0]?.lobId);
|
|
450
|
+
const preSelectedLob = JSON.parse(localStorage.getItem('XOB') || 'null');
|
|
451
|
+
let isPreSelectedLobExistsInList = this.userLOBList.some((lob) => Number(lob.lobId) == Number(preSelectedLob?.LOBId));
|
|
452
|
+
if (preSelectedLob &&
|
|
453
|
+
Number(preSelectedLob.LOBId) &&
|
|
454
|
+
isPreSelectedLobExistsInList) {
|
|
455
|
+
//* Emitting 1st LOB for LOB List as LOb details available in localstorega
|
|
456
|
+
this.selectedLOBId = preSelectedLob?.LOBId;
|
|
457
|
+
this.tempSelectedLOBId = preSelectedLob?.LOBId;
|
|
458
|
+
initialLobSelected = this.getLobById(this.userLOBList, this.selectedLOBId);
|
|
459
|
+
}
|
|
460
|
+
else {
|
|
461
|
+
//* Emitting 1st LOB for LOB List if localstorage have null LOB details
|
|
462
|
+
this.selectedLOBId = this.userLOBList[0]?.lobId;
|
|
463
|
+
this.tempSelectedLOBId = this.userLOBList[0]?.lobId;
|
|
464
|
+
localStorage.setItem('XOB', JSON.stringify(initialLobSelected));
|
|
465
|
+
}
|
|
466
|
+
this.lobSelected.emit(initialLobSelected);
|
|
467
|
+
this.cdRef.detectChanges();
|
|
468
|
+
});
|
|
469
|
+
}
|
|
470
|
+
//* Selected LOB emitter
|
|
471
|
+
onLobChangeEvent(event) {
|
|
472
|
+
this.selectedLOBId = event.value;
|
|
473
|
+
this.openConfirm(event);
|
|
474
|
+
}
|
|
475
|
+
openConfirm(event) {
|
|
476
|
+
this.confirmDialog.openConfirmModal(event);
|
|
477
|
+
}
|
|
478
|
+
lobChangeConfirmation(event) {
|
|
479
|
+
if (event) {
|
|
480
|
+
this.tempSelectedLOBId = this.selectedLOBId;
|
|
481
|
+
let selectedLob = this.getLobById(this.userLOBList, this.tempSelectedLOBId);
|
|
482
|
+
localStorage.setItem('XOB', JSON.stringify(selectedLob));
|
|
483
|
+
this.lobSelected.emit(selectedLob);
|
|
484
|
+
}
|
|
485
|
+
else {
|
|
486
|
+
this.selectedLOBId = this.tempSelectedLOBId;
|
|
487
|
+
}
|
|
488
|
+
}
|
|
489
|
+
setCustomLobId(lobId) {
|
|
490
|
+
if (this.userLOBList) {
|
|
491
|
+
let filteredLobs = this.getLobById(this.userLOBList, lobId);
|
|
492
|
+
if (Object.keys(filteredLobs).length > 0) {
|
|
493
|
+
this.selectedLOBId = lobId;
|
|
494
|
+
//* If the LOB is forcefully set from the parent module, CustomLOBSetByParent is set to true; otherwise, it is set to false.
|
|
495
|
+
filteredLobs['CustomLOBSetByParent'] = true;
|
|
496
|
+
this.lobSelected.emit(filteredLobs);
|
|
497
|
+
localStorage.setItem('XOB', JSON.stringify(filteredLobs));
|
|
498
|
+
}
|
|
499
|
+
else {
|
|
500
|
+
this.msgService.error('The LOB you are trying to set is not available.');
|
|
501
|
+
}
|
|
502
|
+
}
|
|
503
|
+
}
|
|
504
|
+
//* Helper function to get selected LOB Object by LobId
|
|
505
|
+
getLobById(list, id) {
|
|
506
|
+
const item = list.find((x) => x.lobId === id);
|
|
507
|
+
if (!item)
|
|
508
|
+
return {};
|
|
509
|
+
return {
|
|
510
|
+
LOBId: item.lobId,
|
|
511
|
+
LOBName: item.lobName,
|
|
512
|
+
CustomLOBSetByParent: false,
|
|
513
|
+
};
|
|
514
|
+
}
|
|
515
|
+
//* get the Mail count
|
|
516
|
+
// getMailCount() {
|
|
517
|
+
// this.httpCommonService
|
|
518
|
+
// .getUnreadUserEmailsCount()
|
|
519
|
+
// .pipe(takeUntil(this.unsubscribeAPIEventListenerData))
|
|
520
|
+
// .subscribe((result) => {
|
|
521
|
+
// this.totalEmails = result;
|
|
522
|
+
// });
|
|
523
|
+
// }
|
|
524
|
+
//Action: Used to Get Total Eventwise User Notification Count */
|
|
525
|
+
getEventwiseNotificationCount() {
|
|
526
|
+
let payload = {
|
|
527
|
+
ApplicationName: GlobalConstants.applicationName,
|
|
528
|
+
UserId: String(this.userId),
|
|
529
|
+
};
|
|
530
|
+
this.notificationLoadder = true;
|
|
531
|
+
this.httpCommonService
|
|
532
|
+
.getWorkFlowTicketEventwiseCount(payload)
|
|
533
|
+
.pipe(takeUntil(this.unsubscribeAPIEventListenerData), finalize(() => (this.notificationLoadder = false)))
|
|
534
|
+
.subscribe({
|
|
535
|
+
next: (data) => {
|
|
536
|
+
this.isErrorFound = data.length == 0;
|
|
537
|
+
this.eventwiseNotificationCount = data;
|
|
538
|
+
},
|
|
539
|
+
error: () => {
|
|
540
|
+
this.isErrorFound = true;
|
|
541
|
+
},
|
|
542
|
+
});
|
|
543
|
+
}
|
|
544
|
+
//* Get Module privilege list
|
|
545
|
+
getUserAssignedApp() {
|
|
546
|
+
this.ListOfUserPrivillegedApp = [];
|
|
547
|
+
this.userAppLoaderLoadder = true;
|
|
548
|
+
this.httpCommonService
|
|
549
|
+
.getUserAssignedApps()
|
|
550
|
+
.pipe(takeUntil(this.unsubscribeAPIEventListenerData))
|
|
551
|
+
.subscribe((result) => {
|
|
552
|
+
this.userAppLoaderLoadder = false;
|
|
553
|
+
this.ListOfUserPrivillegedApp = result;
|
|
554
|
+
});
|
|
555
|
+
}
|
|
556
|
+
//* Get User details
|
|
557
|
+
getLoggedInuserDetails() {
|
|
558
|
+
this.httpCommonService.getLoggedInUserDetails().subscribe((result) => {
|
|
559
|
+
this.userDetailsInfo = result.result;
|
|
560
|
+
this.userdisplayName = this.userDetailsInfo['userDisplayName'];
|
|
561
|
+
});
|
|
562
|
+
}
|
|
563
|
+
ngOnDestroy() {
|
|
564
|
+
this.unsubscribeAPIEventListenerData.next(true);
|
|
565
|
+
this.unsubscribeAPIEventListenerData.complete();
|
|
566
|
+
this.unsubscribeSidebarListenerData.next(true);
|
|
567
|
+
this.unsubscribeSidebarListenerData.complete();
|
|
568
|
+
}
|
|
569
|
+
}
|
|
570
|
+
CommonHeaderLibComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CommonHeaderLibComponent, deps: [{ token: i1.CommonHeaderLibService }, { token: i0.ChangeDetectorRef }, { token: i2.RestSignalRService }, { token: i3.EventService }, { token: i4.TranslateService }, { token: i5.NgbModal }, { token: i4.TranslateService }, { token: i6.HttpCommonService }, { token: i7.ToastMsgService }], target: i0.ɵɵFactoryTarget.Component });
|
|
571
|
+
CommonHeaderLibComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CommonHeaderLibComponent, selector: "lib-common-header-lib", inputs: { EnableLogo: "EnableLogo", moduleName: "moduleName", EnableTimeZone: "EnableTimeZone", EnableLOB: "EnableLOB", EnableMail: "EnableMail", EnableNotifications: "EnableNotifications", EnableMoreApps: "EnableMoreApps", EnableProfile: "EnableProfile", selectedLOBId: "selectedLOBId" }, outputs: { lobSelected: "lobSelected", langChange: "langChange", overlayStateChange: "overlayStateChange" }, viewQueries: [{ propertyName: "confirmDialog", first: true, predicate: ["confirmDialog"], descendants: true }, { propertyName: "appPanel", first: true, predicate: ["App"], descendants: true }, { propertyName: "notifyModalRef", first: true, predicate: ["notifyModal"], descendants: true }, { propertyName: "notifyModal", first: true, predicate: ["notifyModal"], descendants: true }], ngImport: i0, template: "<header class=\"app-header ext\">\r\n <div class=\"d-flex justify-content-between align-items-center\">\r\n <div class=\"d-flex\">\r\n <div class=\"logo gap-4\">\r\n <img\r\n *ngIf=\"EnableLogo && headerLogo\"\r\n class=\"logo-size\"\r\n title=\"Logo\"\r\n alt=\"Logo\"\r\n [src]=\"headerLogo\"\r\n loading=\"lazy\"\r\n />\r\n <p-skeleton\r\n *ngIf=\"!headerLogo\"\r\n height=\"1.5rem\"\r\n width=\"5rem\"\r\n ></p-skeleton>\r\n </div>\r\n </div>\r\n <div class=\"projName\">\r\n <h1 class=\"modname\">{{ moduleName }}</h1>\r\n </div>\r\n\r\n <div class=\"d-flex justify-content-end align-items-center\">\r\n <!--timezone-->\r\n <ng-container *ngIf=\"EnableTimeZone && userTimeZoneAbbreviations\">\r\n <div class=\"timezone\">\r\n <img\r\n src=\"../assets/common-header-lib/images/schedule.svg\"\r\n class=\"mb-1\"\r\n alt=\"Icon\"\r\n />\r\n <span class=\"timezone-text\"\r\n >{{ \"Generic_lib.PreferredTimezone\" | translate }} :\r\n </span>\r\n <span\r\n *ngIf=\"userTimeZoneAbbreviations\"\r\n class=\"user-tz\"\r\n [title]=\"userTimeZoneFullForm\"\r\n >{{ userTimeZoneAbbreviations }}</span\r\n >\r\n </div>\r\n </ng-container>\r\n\r\n <!--lob-->\r\n <ng-container\r\n *ngIf=\"EnableLOB && !showLobLoader; else LobLodderAnimation\"\r\n >\r\n <div class=\"main-left d-flex\">\r\n <img\r\n src=\"../assets/common-header-lib/images/marker-pin.svg\"\r\n alt=\"pen Icon\"\r\n />\r\n <p-dropdown\r\n filterPlaceholder=\"{{ 'Generic_lib.Search' | translate }}\"\r\n [options]=\"userLOBList\"\r\n (onChange)=\"onLobChangeEvent($event)\"\r\n optionLabel=\"lobName\"\r\n optionValue=\"lobId\"\r\n [(ngModel)]=\"selectedLOBId\"\r\n [filter]=\"true\"\r\n filterBy=\"lobName\"\r\n [showClear]=\"false\"\r\n [style]=\"{ width: '150px', height: '30px' }\"\r\n [resetFilterOnHide]=\"true\"\r\n [virtualScroll]=\"true\"\r\n [lazy]=\"false\"\r\n name=\"lob\"\r\n [itemSize]=\"30\"\r\n class=\"loblist-drpdwn\"\r\n panelStyleClass=\"loblist-drpdwn-panel\"\r\n >\r\n <ng-template let-loblist pTemplate=\"item\">\r\n <div class=\"flex align-items-center gap-2\">\r\n <div title=\"{{ loblist.lobName }}\" class=\"header-drpdwn\">\r\n {{ loblist.lobName }}\r\n </div>\r\n </div>\r\n </ng-template>\r\n </p-dropdown>\r\n </div>\r\n </ng-container>\r\n <ng-template #LobLodderAnimation>\r\n <p-skeleton height=\"1.5rem\" width=\"10rem\"></p-skeleton>\r\n </ng-template>\r\n\r\n <!--mailbox-->\r\n <ng-container *ngIf=\"isHeaderContentLoaded; else HeaderLoading\">\r\n <div *ngIf=\"EnableMail\" class=\"header-left-icon\">\r\n <img\r\n src=\"../assets/common-header-lib/images/mail-icon.svg\"\r\n alt=\"mail Icon\"\r\n class=\"headeright-icon\"\r\n (click)=\"showMailBoxScreen()\"\r\n />\r\n </div>\r\n <ng-container *ngIf=\"EnableMail && totalEmails.length > 0\">\r\n <!-- <ng-container> -->\r\n <div class=\"badge-notify\">\r\n <div pBadge [value]=\"totalEmails\"></div>\r\n </div>\r\n </ng-container>\r\n\r\n <!--notification-->\r\n <div class=\"header-left-icon\" *ngIf=\"EnableNotifications\">\r\n <img\r\n src=\"../assets/common-header-lib/images/bell-icon.svg\"\r\n alt=\"mail Icon\"\r\n class=\"headeright-icon\"\r\n (click)=\"OpenNotificationModal()\"\r\n />\r\n </div>\r\n\r\n <ng-container\r\n *ngIf=\"EnableNotifications && userNotificationCount.length > 0\"\r\n >\r\n <div class=\"badge-notify\">\r\n <div pBadge [value]=\"userNotificationCount\"></div>\r\n </div>\r\n </ng-container>\r\n\r\n <!--9 Dots -->\r\n <div\r\n *ngIf=\"EnableMoreApps\"\r\n class=\"header-left-icon\"\r\n title=\"Control Center\"\r\n alt=\"bell Icon\"\r\n (click)=\"showUserAppsPanel($event)\"\r\n >\r\n <img\r\n src=\"../assets/common-header-lib/images/apps-1.svg\"\r\n class=\"apps-icon\"\r\n />\r\n </div>\r\n\r\n <!--user display name -->\r\n <div\r\n *ngIf=\"EnableProfile\"\r\n class=\"main-right\"\r\n (click)=\"showUserDetailsPanel()\"\r\n >\r\n <ng-container>\r\n <div class=\"initial-text mx-1\">\r\n {{ userdisplayName | sliceToTwo }}\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-template #HeaderLoading>\r\n <p-skeleton shape=\"circle\" size=\"1.3rem\" styleClass=\"mx-2\"></p-skeleton>\r\n <p-skeleton shape=\"circle\" size=\"1.3rem\" styleClass=\"mx-2\"></p-skeleton>\r\n <p-skeleton size=\"1.5rem\" styleClass=\"mx-2\"></p-skeleton>\r\n <p-skeleton shape=\"circle\" size=\"2rem\" styleClass=\"mx-2\"></p-skeleton>\r\n </ng-template>\r\n </div>\r\n </div>\r\n</header>\r\n\r\n<!--List of Application : 9 dots -->\r\n<p-overlayPanel #App class=\"pt-0\" styleClass=\"app-panel\">\r\n <ng-container *ngIf=\"!userAppLoaderLoadder; else LoadingTemplate\">\r\n <div class=\"custom-popover-content\">\r\n <div class=\"waffle-align\">\r\n <div\r\n class=\"waffle-popup\"\r\n [title]=\"appDetails['applicationName']\"\r\n *ngFor=\"let appDetails of ListOfUserPrivillegedApp\"\r\n (click)=\"getConnectionofApplication(appDetails['appCode'])\"\r\n >\r\n <img\r\n *ngIf=\"appDetails?.appCode\"\r\n src=\"../assets/common-header-lib/images/{{\r\n appDetails.appCode\r\n }}.svg\"\r\n alt=\"App icon\"\r\n />\r\n\r\n <div class=\"waffle-text\">{{ appDetails[\"applicationName\"] }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-template #LoadingTemplate>\r\n <div class=\"custom-popover-content skeleton-popover\">\r\n <ng-container *ngFor=\"let item of repeatLoader\">\r\n <div\r\n class=\"d-flex flex-column align-items-center justify-content-center gap-2\"\r\n >\r\n <p-skeleton size=\"3rem\"></p-skeleton>\r\n <p-skeleton height=\".3rem\" width=\"35px\"></p-skeleton>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n</p-overlayPanel>\r\n\r\n<!--mailbox details-->\r\n<ng-container *ngIf=\"showMailboxScreenflag\">\r\n <div class=\"changingContent\">\r\n <app-user-mailbox\r\n (closeMailDialogBox)=\"hideMailBoxScreen()\"\r\n ></app-user-mailbox>\r\n </div>\r\n</ng-container>\r\n\r\n<!-- Userdetails profile pop up -->\r\n<div class=\"profile-sidebar\">\r\n <app-side-popup\r\n *ngIf=\"isOpenSidePopup\"\r\n [visible]=\"true\"\r\n [position]=\"'right'\"\r\n (closeDialogBox)=\"closeSidePopup()\"\r\n >\r\n <app-user-sidebar\r\n *ngIf=\"showUserDetails\"\r\n (closeDialogBox)=\"closeSidePopup()\"\r\n ></app-user-sidebar>\r\n </app-side-popup>\r\n</div>\r\n\r\n<!-- Notification side popup -->\r\n<div\r\n class=\"modal fade common-alert-modal\"\r\n #notifyModal\r\n id=\"Notify_SidebarModal\"\r\n tabindex=\"-1\"\r\n aria-hidden=\"true\"\r\n>\r\n <div class=\"modal-dialog sidebar-outer white-bg\">\r\n <div class=\"modal-content\">\r\n <div class=\"sidebar-container white-bg\">\r\n <!-- keep everything inside this content -->\r\n\r\n <!-- Sidebar Header -->\r\n <div class=\"sidebar-header grey-background\">\r\n <div class=\"sh-top\">\r\n <div class=\"sh-top-left d-flex align-items-center\">\r\n <div class=\"mx-2 log-text\">\r\n {{ \"Generic_lib.Notification\" | translate }}\r\n </div>\r\n </div>\r\n <div class=\"sh-top-right\">\r\n <button\r\n type=\"button\"\r\n class=\"common-bn tertiary-btn\"\r\n aria-label=\"Close\"\r\n (click)=\"closeModal()\"\r\n >\r\n <img\r\n src=\"assets/common-header-lib/images/close.svg\"\r\n alt=\"Close\"\r\n class=\"imgs mb-1\"\r\n />\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Sidebar Body -->\r\n <div class=\"sidebar-body\">\r\n <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n <div class=\"noti-text\">\r\n {{\r\n \"Generic_lib.YouHaveNNotifications\"\r\n | translate: { count: userNotificationCount }\r\n }}\r\n </div>\r\n <div\r\n class=\"d-flex align-items-center gap-1 refresh-icon\"\r\n (click)=\"getEventwiseNotification()\"\r\n >\r\n <img\r\n src=\"assets/common-header-lib/images/refresh-1.svg\"\r\n alt=\"Refresh\"\r\n />\r\n <div class=\"refresh-text\">\r\n {{ \"Generic_lib.Refresh\" | translate }}\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mt-3\">\r\n <ng-container\r\n *ngIf=\"\r\n !isErrorFound && !notificationLoadder;\r\n else Noti_LoadingTemplate\r\n \"\r\n >\r\n <div\r\n class=\"notify-border\"\r\n *ngFor=\"let event of eventwiseNotificationCount\"\r\n >\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <div class=\"initial-text initial-text-1 mx-1\">\r\n <img\r\n src=\"assets/common-header-lib/images/noti_ticket.svg\"\r\n alt=\"Icon\"\r\n />\r\n </div>\r\n <div>\r\n <div>\r\n <span class=\"service-count\"\r\n >{{ event[\"PendingCount\"] }} New </span\r\n ><span class=\"service-request\"\r\n >{{ event[\"EventName\"] }} Event requests</span\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"grey-borders mt-2\"></div>\r\n </div>\r\n </ng-container>\r\n <ng-template #Noti_LoadingTemplate>\r\n <ng-container *ngIf=\"notificationLoadder; else errorTemplate\">\r\n <ng-container *ngFor=\"let item of repeatLoader1\">\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <p-skeleton\r\n shape=\"circle\"\r\n size=\"60px\"\r\n styleClass=\"my-2\"\r\n ></p-skeleton>\r\n <div class=\"ms-1\">\r\n <p-skeleton width=\"200%\" styleClass=\"mb-2\"></p-skeleton>\r\n <p-skeleton width=\"150px\" height=\"1rem\"></p-skeleton>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-template>\r\n\r\n <ng-template #errorTemplate>\r\n <app-no-service-my-access-pg\r\n heading=\"{{ 'Generic_lib.CommonError' | translate }}\"\r\n ></app-no-service-my-access-pg>\r\n </ng-template>\r\n </div>\r\n <!-- Notification content & loaders remain here -->\r\n </div>\r\n </div>\r\n <!-- end of sidebar-container -->\r\n </div>\r\n <!-- end of modal-content -->\r\n </div>\r\n <!-- end of modal-dialog -->\r\n</div>\r\n\r\n<!-- Common Conirmation Modal -->\r\n<confirm-dialog\r\n class=\"rm-invalid-border\"\r\n #confirmDialog\r\n header=\"{{ 'Generic_lib.ChangeLOB' | translate }}\"\r\n message=\"{{ 'Generic_lib.DoYouWantToChangeTheCurrentLOB' | translate }}\"\r\n (result)=\"lobChangeConfirmation($event)\"\r\n></confirm-dialog>\r\n\r\n<!--* Need to use component based notification UI as below -->\r\n<!-- Notification-Sidebar Started -->\r\n<!-- <app-notification-sidebar [isErrorOccured]=\"isErrorFound\" [userNotificationCount]=\"userNotificationCount\"\r\n [userNotificationCountObj]=\"userNotificationCountObj\" [eventwiseNotificationCount]=\"eventwiseNotificationCount\"\r\n (refreshNotification)=\"getEventwiseNotificationCount()\"\r\n [notificationLoadder]=\"notificationLoadder\"></app-notification-sidebar> -->\r\n<!-- Notification-Sidebar Ended -->\r\n", styles: [".app-header{padding:4px 10px 10px;height:42px;border-bottom:1px solid #d0d4e4}.logo{display:flex;align-items:center}.main-right{display:flex;align-items:center;cursor:pointer}.logo-icon{width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;position:relative}.logo-icon:after{width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;position:absolute;content:\"\";top:7px;left:-7px}p{font-size:25px!important}.p-inputtext.p-inputtext-sm{padding:4px 5px 4px 33px!important}.pi-search:before{font-size:13px;position:absolute;top:2px}.overlay-text{font-size:13px;line-height:18px;color:#676879;font-weight:400}.main-left .p-dropdown{border:none;border-radius:0;width:140px!important}.main-left .p-dropdown-panel .p-dropdown-items{padding:0!important;max-height:110px}.main-left :focus-visible{outline:none}.main-left .p-scroller{overflow-x:hidden;height:120px!important}.header-drpdwn{width:120px!important;font-size:11px!important;text-overflow:ellipsis;overflow:hidden}.logs{gap:70px;margin-top:5px}.head-search{position:fixed;top:4px;left:275px}.head-search input{width:calc(30vw - 40px)!important;border:1px solid #c3c6d4;background-color:#f6f7fb;height:32px;border-radius:0 4px 4px 0;border-left:none;font-size:13px!important;padding-left:30px!important;padding-right:54px}.head-search.active{position:fixed;top:4px;left:275px}.head-search.active input{width:555px!important}@media screen and (min-width: 1920px){.head-search.active{position:fixed;top:4px;left:275px}.head-search.active input{width:900px!important}}.header-left-icon{height:32px;width:32px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .5s;border-radius:50%;margin-right:4px;position:relative}.header-left-icon:hover{background:#dcdfec}.header-left-icon img:hover{filter:invert(0%) sepia(4%) saturate(0%) hue-rotate(324deg) brightness(55%) contrast(105%)}.apps-icon{width:21px}.logo-img{width:80px}.initial-text{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:11px;border-radius:50%;color:#fff;background-color:#8e562e}.initial-text-1{background-color:#f2edfa}.lob-img{padding-bottom:4px}.session-app:hover{background:#dcdfec;border-radius:10px}.app-col{cursor:pointer;padding:8px 0}.app-text{font-size:12px;color:#676879;white-space:nowrap;padding-top:8px;text-align:center;text-overflow:ellipsis;overflow:hidden;width:100px}.filter-search{position:relative;right:50px;bottom:2px;cursor:pointer}.filter-search .cross-search{width:23px}.filter-search .search-filter{width:19px}.headeright-icon{width:17px;height:17px;filter:invert(44%) sepia(3%) saturate(1698%) hue-rotate(199deg) brightness(92%) contrast(93%)}.pl-0{padding-left:0}.form-control-sm{border:none;border-bottom:1px solid #c3c6d4;border-radius:0}.overlay-footer .common-btn{width:110px;height:32px;padding:11px 12px;border-radius:4px;font-size:13px;cursor:pointer;background:#fff}.overlay-footer .primary-btn{padding:8px 12px 11px 14px;border-radius:4px;height:32px;width:65px;font-size:13px;cursor:pointer}.filter-popup{position:relative;left:10px}.form-group{margin-bottom:5px}.waffle-text{font-size:11px;text-align:center;width:70px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;margin-top:-3px}.waffle-align{display:grid;grid-template-columns:auto auto auto}.waffle{cursor:pointer;margin-right:16px}.waffle-popup{width:89px!important;margin-top:0;padding:8px 0 4px;display:flex;align-items:center;justify-content:center;flex-direction:column;cursor:pointer}.waffle-popup:hover{background:#d3e6ff;border-radius:10px}.waffle-popup img{height:40px}.custom-popover-content{padding:10px;right:-5px;top:0;position:absolute;background:white;border-radius:8px;box-shadow:0 0 6px #9d9d9d}.custom-popover-content.skeleton-popover{width:313px;display:grid;grid-template-columns:auto auto auto;gap:10px}.timezone{margin-right:12px}.timezone-icon{font-size:16px}.timezone-text{padding-left:6px;font-size:13px;color:#495057;font-weight:400}.user-tz{font-size:13px;color:#757575;font-weight:400;text-overflow:ellipsis;overflow:hidden;width:30px;white-space:normal}.profile-sidebar .p-dialog .p-dialog-content{padding:0}.profile-sidebar .p-dialog-header{display:none}.modname{font-size:18px;margin-bottom:0}.changingContent{overflow:hidden;width:100%}.changingContent .intro-text{background-image:linear-gradient(145deg,#f1eaec,#f8e3e7,#f7e1f8,#ebeeff,#e8eef3);position:relative;height:135px}.changingContent .inner-garient{padding:50px 20px 115px 30px}.changingContent .table-heading{padding:0 20px 1px 30px}.changingContent .table-selection{padding:3px 20px 0 30px}.grey-background{background-color:#f6f7fb}.white-bg{background:#ffffff;overflow:hidden}.imgs{width:20px}.p-dropdown .p-dropdown-label{background:transparent;border:0 none;display:flex;align-items:center}.p-dropdown .p-dropdown-trigger{width:32px!important}.pi-chevron-down:before{content:\"\\e902\";font-size:11px}.sidebar-outer{height:100vh}.lang-dropdown .p-dropdown{border:1px solid #dee2e6!important;height:26px!important;border-radius:4px!important;min-width:calc(40vh - 92px)!important;padding:0 4px 0 12px!important;display:flex!important;align-items:center!important;justify-content:space-between!important}.lang-dropdown .p-dropdown .pi{position:relative;bottom:2px;left:7px}.lang-dropdown .p-dropdown-panel{background:#ffffff!important;color:#495057!important;border:0px!important;box-shadow:0 2px 12px #0000001a!important}.lang-dropdown .p-dropdown-header{padding:5px 10px!important;border-bottom:1px solid #dee2e6!important;background:#f8f9fa!important;color:#343a40!important;margin:0!important}.lang-dropdown .p-dropdown-items-wrapper{max-height:140px!important}.lang-dropdown .p-dropdown-panel .p-dropdown-header{padding:4px 8px!important;border-radius:0!important}.p-dropdown-panel .p-dropdown-header{padding:.75rem 1.25rem;border-bottom:1px solid #dee2e6;color:#343a40;background:#f8f9fa;margin:0;border-top-right-radius:6px;border-top-left-radius:6px}.lang-dropdown .p-dropdown .p-dropdown-header .p-dropdown-filter{height:26px;border-radius:4px;font-size:12px;border:1px solid #ced4da!important;padding-left:12px!important}.lang-dropdown .p-inputtext{margin:0;text-align:start;font-size:13px;padding:0!important}.lang-dropdown .p-dropdown-panel .p-dropdown-header .p-dropdown-filter-icon{position:relative;bottom:13px;font-size:13px}.sidebar-outer .sidebar-body .sb-list ul li span{margin-right:12px}.p-dropdown-panel .p-dropdown-header .p-dropdown-filter-icon{left:6px;color:#6c757d}.lang-dropdown .p-dropdown-items-wrapper ::-webkit-scrollbar{width:6px!important}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:#c1c1c1;border-radius:6px}::-webkit-scrollbar-thumb:hover{background-color:#a8a8a8}.sidebar-outer .sidebar-body .sb-list ul{float:left;width:100%;list-style:none;padding-left:0}.lang-dropdown .p-dropdown-panel .p-dropdown-items{font-size:12px;padding:0!important}.p-dropdown-panel .p-dropdown-items .p-dropdown-item.p-highlight{color:#1d4ed8;background:#eff6ff}.lang-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-item{padding:2px 14px;font-size:12px}.sidebar-outer .sidebar-body .sb-list ul li{display:flex;padding:8px 2px;cursor:pointer}.modal-dialog{margin-right:0;margin-top:0;margin-bottom:0}.loblist-drpdwn-panel .p-dropdown-header{padding:5px 10px}.loblist-drpdwn-panel .p-inputtext{background:#ffffff;padding:6px}.loblist-drpdwn .p-inputtext{font-size:13px}.loblist-drpdwn-panel .p-dropdown-header .p-dropdown-filter{height:28px;border-radius:4px;font-size:12px}.loblist-drpdwn-panel .p-dropdown-items .p-dropdown-item{margin-bottom:1px;padding:6px 16px;border:0;color:#495057;background:transparent;transition:box-shadow .2s;border-radius:0;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loblist-drpdwn-panel .p-dropdown-header .p-dropdown-filter-icon{position:absolute;left:82%;top:50%;transform:translateY(-50%);color:#6c757d}.loblist-drpdwn-panel .p-dropdown-items .p-dropdown-empty-message{padding:6px 12px;color:#495057!important;background:transparent!important;font-size:12px}.logo-size{max-height:32px;max-width:92px}.logo-size-1{width:80px;height:30px}.sidebar-body{overflow:auto;height:calc(100vh - 70px);width:100%}.sidebar-body .refresh-icon{cursor:pointer}.sidebar-body .notify-border{padding:8px 8px 0 6px;cursor:pointer}.sidebar-body .notify-border:hover{background-color:#dcdfec;border-radius:8px}.sidebar-body .notify-border .initial-text{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:11px;border-radius:50%;color:#fff;background-color:#f2edfa}.sidebar-body .notify-border .service-count{color:#323238;font-weight:600;font-size:13px}.sidebar-body .notify-border .service-request{color:#676879;font-size:12px;font-weight:500}.sidebar-body .notify-border .time-text{color:#676879;font-size:12px}.sidebar-body .notify-border .grey-borders{border-bottom:1px solid #d0d4e4}.mail-table{height:calc(100vh - 155px);overflow:auto}.mail-table .p-datatable .p-datatable-thead>tr{border:1px solid #dee2e6;border-radius:24px}.mail-table .p-datatable .p-datatable-thead>tr th{padding:0 8px;height:36px;font-size:13px;color:var(--primary-text);font-weight:600;background:#fff}.mail-table .p-datatable .p-datatable-tbody>tr{border:1px solid #dee2e6;border-radius:24px}.mail-table .p-datatable .p-datatable-tbody>tr td{padding:0 25px 0 8px;height:38px;font-size:13px;color:var(--secondary-text);white-space:nowrap}.mail-table .p-checkbox{height:18px;width:18px}.mail-table .p-checkbox .p-checkbox-box{height:16px;width:16px;border-radius:4px;border:1px solid var(--ui-border)}.mail-table .p-checkbox .p-checkbox-box:hover{border:1px solid var(--ui-border)!important}.mail-table .p-checkbox .p-checkbox-icon{font-size:10px!important}.mail-table .p-datatable .p-sortable-column:hover{background-color:#fff!important;color:#000!important}.mail-table .p-datatable .p-sortable-column:focus{box-shadow:none!important}.mail-table .p-datatable .p-sortable-column .p-sortable-column-icon{font-size:12px}.mail-table .p-dropdown-panel .p-dropdown-items{padding:0}.mail-table .p-dropdown-panel .p-dropdown-items .p-dropdown-item{font-size:13px!important;padding:10px 15px}.mail-table .p-paginator{justify-content:flex-start!important;position:fixed;bottom:0;padding-left:0!important}.mail-table .p-paginator .p-paginator-current{font-size:12px;height:1rem!important}.mail-table .p-paginator .p-paginator-pages .p-paginator-page{min-width:30px!important;height:30px!important;font-size:12px}.mail-table .p-paginator .p-dropdown{height:30px!important;margin-top:0;border:0px}.mail-table .p-paginator .p-dropdown .p-dropdown-label{padding:4px 5px 0 10px!important;font-size:14px}.mail-table .p-paginator .p-dropdown .p-dropdown-trigger{width:1.5rem!important}.mail-table .p-paginator .p-dropdown .p-dropdown-trigger .pi{font-size:13px!important}.mail-pagination .p-paginator{justify-content:flex-start!important;position:fixed;bottom:0;padding-left:0}.mail-pagination .p-paginator .p-paginator-current{font-size:12px;height:1rem!important;padding-left:0}.mail-pagination .p-paginator .p-paginator-pages .p-paginator-page{min-width:30px!important;height:30px!important;font-size:12px}.mail-pagination .p-paginator .p-dropdown{height:30px!important;margin-top:0;border:0px}.mail-pagination .p-paginator .p-dropdown .p-dropdown-label{padding:4px 5px 0 10px!important;font-size:14px}.mail-pagination .p-paginator .p-dropdown .p-dropdown-trigger{width:1.5rem!important}.mail-pagination .p-paginator .p-dropdown .p-dropdown-trigger .pi{font-size:13px!important}.rm-invalid-border .card{border:0px}.view-pass-details{width:600px!important}.view-pass-details .p-dialog-header{background:#ffffff!important;border-radius:4px 4px 0 0!important;border-bottom:1px solid #d0d4e4!important}.view-pass-details .p-dialog-content:last-of-type{border-bottom-right-radius:4px!important;border-bottom-left-radius:4px!important;padding:0}.confirmtion-modal .p-dialog-content{padding-top:24px;padding-right:100px;font-size:15px}.confirmtion-modal .p-confirm-dialog-message{margin-left:0!important}.confirmtion-modal .p-button{font-size:15px;padding:6px 28px}.ngx-toastr{width:400px!important;margin-top:10px!important}.toast-success{background-color:#fff!important;border-bottom:3px solid #258750;border-radius:4px!important;background-image:url(../assets/common-header-lib/images/check_circle.svg)!important;background-repeat:no-repeat}.toast-success .toast-message{padding-top:2px;color:#258750!important;font-size:14px!important}.toast-error{background-color:#fff!important;border-bottom:3px solid #d83a52;border-radius:4px!important;background-image:url(../assets/common-header-lib/images/error.svg)!important;background-repeat:no-repeat}.toast-error .toast-message{padding-top:2px;color:#d83a52!important;font-size:14px!important}.toast-info{background-color:#fff!important;border-bottom:3px solid #0073ea;border-radius:4px!important;background-image:url(../assets/common-header-lib/images/info.svg)!important;background-repeat:no-repeat}.toast-info .toast-message{padding-top:3px;color:#0073ea!important;font-size:14px!important}.toast-warning{background-color:#fff!important;border-bottom:3px solid #fdab3d;border-radius:4px!important;background-image:url(../assets/common-header-lib/images/check_circle.svg)!important;background-repeat:no-repeat}.toast-warning .toast-message{padding-top:3px;color:#fdab3d!important;font-size:14px!important}.toast-close-button{right:10px!important;font-size:20px;font-weight:700;text-shadow:0 1px 0 #ffffff;background-color:transparent;border:0px;color:#676879;position:absolute;top:10px;cursor:pointer}.toast-container{position:absolute;z-index:2147483647!important}.toast-container .ngx-toastr{position:relative;overflow:hidden;margin:0 0 6px;padding:15px 40px 15px 50px;width:300px;border-radius:3px;background-position:15px center;background-repeat:no-repeat;background-size:24px;box-shadow:0 0 12px #999;color:#fff}.toast-top-center{top:0;right:0;width:100%}.toast-container.toast-top-center .ngx-toastr,.toast-container.toast-bottom-center .ngx-toastr{margin-left:auto;margin-right:auto}.badge-notify:hover{border-radius:50%;background:#dcdfec}.badge-notify .p-badge{min-width:16px;height:16px;line-height:15px}.badge-notify .p-overlay-badge .p-badge{position:absolute;top:-7px;right:12px;font-size:9px;padding:0 2px;cursor:pointer}.madontary-icon{color:#d4231d;font-weight:500;padding:5px 0 0 5px}.img-lock{width:12px;margin-bottom:1px}.img-lock.ext{width:16px;margin-bottom:0}.img-lock.ext2{width:18px;margin-bottom:0}.form-group .error-msg{position:relative}.submit-btn .p-button{height:30px;font-size:14px;border-radius:4px}.submit-btn .p-button .p-button-label{font-weight:400;font-size:13px}.p-dialog.general-configuration{width:100%;height:100vh;max-height:100vh}.general-configuration .p-dialog-header{border-bottom:1px solid #d0d4e4!important;background:#ffffff!important}.p-dialog .p-dialog-header{padding:10px 21px!important;background:#f6f7fb!important;border-top-right-radius:0!important;border-top-left-radius:0!important;height:54px}.assets-dropdown .p-dropdown{height:38px!important;width:100%!important;border-radius:4px!important;align-items:center!important}.assets-dropdown .p-dropdown:hover{border:1px solid #ced4da!important}.p-dropdown-panel .p-dropdown-header .p-dropdown-filter{padding-right:1.75rem;margin-right:-1.75rem}.assets-dropdown .p-inputtext{width:100%;border-radius:4px;height:30px;font-size:13px!important}.assets-dropdown .p-dropdown-panel .p-dropdown-header .p-dropdown-filter-icon{left:96%;color:#6c757d;font-size:13px;top:15px!important}.assets-dropdown .p-dropdown-panel .p-dropdown-header{padding:10px!important}.assets-dropdown .p-dropdown-items-wrapper{max-height:100px!important}.assets-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-item{padding:5px 20px!important;font-size:13px!important;font-weight:400!important}.p-dropdown-panel .p-dropdown-items{padding:0!important}.assets-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-empty-message{font-size:13px!important;padding:8px 20px!important}.p-dropdown-panel .p-dropdown-items .p-dropdown-empty-message{padding:.75rem 1.25rem;color:#495057!important;background:transparent!important}.p-dropdown-filter-container{position:relative}.p-dropdown-filter-container input{border:1px solid #ced4da!important}.input-dropdown .password-checkbox-right{position:absolute;width:24px;right:8px}.timezone-dropdown .p-dropdown{width:100%;border:1px solid #ced4da!important;border-radius:4px;height:38px}.timezone-dropdown .p-dropdown-panel .p-dropdown-header{padding:5px}.timezone-dropdown .p-dropdown:hover{border:1px solid #ced4da!important}.timezone-dropdown .p-inputtext{width:100%;border-radius:4px;height:30px;font-size:13px!important}.timezone-dropdown .p-dropdown-panel .p-dropdown-header .p-dropdown-filter-icon{left:96%;color:#6c757d;font-size:13px;top:15px!important}.timezone-dropdown .p-dropdown-panel .p-dropdown-header{padding:10px!important}.timezone-dropdowntimezone-dropdown .p-dropdown-items-wrapper{max-height:100px!important}.timezone-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-item{padding:5px 20px!important;font-size:13px!important;font-weight:400!important}.timezone-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-empty-message{font-size:13px!important;padding:8px 20px!important}.sidebar-container{width:420px;position:fixed;top:0;height:100vh;max-width:100%;transition:all .3s ease;-webkit-transition:all .3s ease;-moz-transition:all .3s ease;background-color:#fff}.white-bg{background:#ffffff;width:420px;overflow:hidden}.sidebar-outer .sidebar-header{padding:12px 15px}.sidebar-outer .sidebar-header .sh-top{display:flex;align-items:center;justify-content:space-between}.log-text{font-size:16px;color:#292f4c;font-weight:600}.sidebar-outer .sidebar-header .sh-top button{height:24px}.sidebar-outer .sidebar-body{padding:12px 20px;float:left;width:100%;overflow:auto;height:calc(100vh - 70px)}.tertiary-btn{border:none;background-color:transparent}.sidebar-body .noti-text{color:#292f4c;font-size:13px;font-weight:600;line-height:24px}.sidebar-body .refresh-text{color:#676879;font-size:12px;line-height:24px}.error-msg{font-size:12px;font-weight:600;width:100%;position:absolute;bottom:4px;left:0;display:flex;align-items:flex-end;color:#d83a52;font-family:-apple-system,BlinkMacSystemFont,Roboto,Segoe UI,Helvetica,Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",Segoe UI Symbol!important}.error-msg .error-icon{font-size:18px;margin-right:4px;position:relative;top:-1px}\n"], dependencies: [{ kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "component", type: i10.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "overlayDirection", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "directive", type: i11.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i12.OverlayPanel, selector: "p-overlayPanel", inputs: ["dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "directive", type: i13.BadgeDirective, selector: "[pBadge]", inputs: ["iconPos", "badgeDisabled", "value", "severity"] }, { kind: "component", type: i14.Skeleton, selector: "p-skeleton", inputs: ["styleClass", "style", "shape", "animation", "borderRadius", "size", "width", "height"] }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i15.UserSidebarComponent, selector: "app-user-sidebar", outputs: ["closeDialogBox"] }, { kind: "component", type: i16.SidePopupComponent, selector: "app-side-popup", inputs: ["visible", "position", "header"], outputs: ["closeDialogBox"] }, { kind: "component", type: i17.UserMailboxComponent, selector: "app-user-mailbox", inputs: ["apiURL"], outputs: ["closeMailDialogBox"] }, { kind: "component", type: i18.NoServiceMyAccessPgComponent, selector: "app-no-service-my-access-pg", inputs: ["heading", "subHeading"] }, { kind: "component", type: i19.ConfirmDialogComponent, selector: "confirm-dialog", inputs: ["header", "message"], outputs: ["result"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "pipe", type: i20.SliceToTwoPipe, name: "sliceToTwo" }], encapsulation: i0.ViewEncapsulation.None });
|
|
572
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CommonHeaderLibComponent, decorators: [{
|
|
573
|
+
type: Component,
|
|
574
|
+
args: [{ selector: 'lib-common-header-lib', encapsulation: ViewEncapsulation.None, template: "<header class=\"app-header ext\">\r\n <div class=\"d-flex justify-content-between align-items-center\">\r\n <div class=\"d-flex\">\r\n <div class=\"logo gap-4\">\r\n <img\r\n *ngIf=\"EnableLogo && headerLogo\"\r\n class=\"logo-size\"\r\n title=\"Logo\"\r\n alt=\"Logo\"\r\n [src]=\"headerLogo\"\r\n loading=\"lazy\"\r\n />\r\n <p-skeleton\r\n *ngIf=\"!headerLogo\"\r\n height=\"1.5rem\"\r\n width=\"5rem\"\r\n ></p-skeleton>\r\n </div>\r\n </div>\r\n <div class=\"projName\">\r\n <h1 class=\"modname\">{{ moduleName }}</h1>\r\n </div>\r\n\r\n <div class=\"d-flex justify-content-end align-items-center\">\r\n <!--timezone-->\r\n <ng-container *ngIf=\"EnableTimeZone && userTimeZoneAbbreviations\">\r\n <div class=\"timezone\">\r\n <img\r\n src=\"../assets/common-header-lib/images/schedule.svg\"\r\n class=\"mb-1\"\r\n alt=\"Icon\"\r\n />\r\n <span class=\"timezone-text\"\r\n >{{ \"Generic_lib.PreferredTimezone\" | translate }} :\r\n </span>\r\n <span\r\n *ngIf=\"userTimeZoneAbbreviations\"\r\n class=\"user-tz\"\r\n [title]=\"userTimeZoneFullForm\"\r\n >{{ userTimeZoneAbbreviations }}</span\r\n >\r\n </div>\r\n </ng-container>\r\n\r\n <!--lob-->\r\n <ng-container\r\n *ngIf=\"EnableLOB && !showLobLoader; else LobLodderAnimation\"\r\n >\r\n <div class=\"main-left d-flex\">\r\n <img\r\n src=\"../assets/common-header-lib/images/marker-pin.svg\"\r\n alt=\"pen Icon\"\r\n />\r\n <p-dropdown\r\n filterPlaceholder=\"{{ 'Generic_lib.Search' | translate }}\"\r\n [options]=\"userLOBList\"\r\n (onChange)=\"onLobChangeEvent($event)\"\r\n optionLabel=\"lobName\"\r\n optionValue=\"lobId\"\r\n [(ngModel)]=\"selectedLOBId\"\r\n [filter]=\"true\"\r\n filterBy=\"lobName\"\r\n [showClear]=\"false\"\r\n [style]=\"{ width: '150px', height: '30px' }\"\r\n [resetFilterOnHide]=\"true\"\r\n [virtualScroll]=\"true\"\r\n [lazy]=\"false\"\r\n name=\"lob\"\r\n [itemSize]=\"30\"\r\n class=\"loblist-drpdwn\"\r\n panelStyleClass=\"loblist-drpdwn-panel\"\r\n >\r\n <ng-template let-loblist pTemplate=\"item\">\r\n <div class=\"flex align-items-center gap-2\">\r\n <div title=\"{{ loblist.lobName }}\" class=\"header-drpdwn\">\r\n {{ loblist.lobName }}\r\n </div>\r\n </div>\r\n </ng-template>\r\n </p-dropdown>\r\n </div>\r\n </ng-container>\r\n <ng-template #LobLodderAnimation>\r\n <p-skeleton height=\"1.5rem\" width=\"10rem\"></p-skeleton>\r\n </ng-template>\r\n\r\n <!--mailbox-->\r\n <ng-container *ngIf=\"isHeaderContentLoaded; else HeaderLoading\">\r\n <div *ngIf=\"EnableMail\" class=\"header-left-icon\">\r\n <img\r\n src=\"../assets/common-header-lib/images/mail-icon.svg\"\r\n alt=\"mail Icon\"\r\n class=\"headeright-icon\"\r\n (click)=\"showMailBoxScreen()\"\r\n />\r\n </div>\r\n <ng-container *ngIf=\"EnableMail && totalEmails.length > 0\">\r\n <!-- <ng-container> -->\r\n <div class=\"badge-notify\">\r\n <div pBadge [value]=\"totalEmails\"></div>\r\n </div>\r\n </ng-container>\r\n\r\n <!--notification-->\r\n <div class=\"header-left-icon\" *ngIf=\"EnableNotifications\">\r\n <img\r\n src=\"../assets/common-header-lib/images/bell-icon.svg\"\r\n alt=\"mail Icon\"\r\n class=\"headeright-icon\"\r\n (click)=\"OpenNotificationModal()\"\r\n />\r\n </div>\r\n\r\n <ng-container\r\n *ngIf=\"EnableNotifications && userNotificationCount.length > 0\"\r\n >\r\n <div class=\"badge-notify\">\r\n <div pBadge [value]=\"userNotificationCount\"></div>\r\n </div>\r\n </ng-container>\r\n\r\n <!--9 Dots -->\r\n <div\r\n *ngIf=\"EnableMoreApps\"\r\n class=\"header-left-icon\"\r\n title=\"Control Center\"\r\n alt=\"bell Icon\"\r\n (click)=\"showUserAppsPanel($event)\"\r\n >\r\n <img\r\n src=\"../assets/common-header-lib/images/apps-1.svg\"\r\n class=\"apps-icon\"\r\n />\r\n </div>\r\n\r\n <!--user display name -->\r\n <div\r\n *ngIf=\"EnableProfile\"\r\n class=\"main-right\"\r\n (click)=\"showUserDetailsPanel()\"\r\n >\r\n <ng-container>\r\n <div class=\"initial-text mx-1\">\r\n {{ userdisplayName | sliceToTwo }}\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-template #HeaderLoading>\r\n <p-skeleton shape=\"circle\" size=\"1.3rem\" styleClass=\"mx-2\"></p-skeleton>\r\n <p-skeleton shape=\"circle\" size=\"1.3rem\" styleClass=\"mx-2\"></p-skeleton>\r\n <p-skeleton size=\"1.5rem\" styleClass=\"mx-2\"></p-skeleton>\r\n <p-skeleton shape=\"circle\" size=\"2rem\" styleClass=\"mx-2\"></p-skeleton>\r\n </ng-template>\r\n </div>\r\n </div>\r\n</header>\r\n\r\n<!--List of Application : 9 dots -->\r\n<p-overlayPanel #App class=\"pt-0\" styleClass=\"app-panel\">\r\n <ng-container *ngIf=\"!userAppLoaderLoadder; else LoadingTemplate\">\r\n <div class=\"custom-popover-content\">\r\n <div class=\"waffle-align\">\r\n <div\r\n class=\"waffle-popup\"\r\n [title]=\"appDetails['applicationName']\"\r\n *ngFor=\"let appDetails of ListOfUserPrivillegedApp\"\r\n (click)=\"getConnectionofApplication(appDetails['appCode'])\"\r\n >\r\n <img\r\n *ngIf=\"appDetails?.appCode\"\r\n src=\"../assets/common-header-lib/images/{{\r\n appDetails.appCode\r\n }}.svg\"\r\n alt=\"App icon\"\r\n />\r\n\r\n <div class=\"waffle-text\">{{ appDetails[\"applicationName\"] }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-template #LoadingTemplate>\r\n <div class=\"custom-popover-content skeleton-popover\">\r\n <ng-container *ngFor=\"let item of repeatLoader\">\r\n <div\r\n class=\"d-flex flex-column align-items-center justify-content-center gap-2\"\r\n >\r\n <p-skeleton size=\"3rem\"></p-skeleton>\r\n <p-skeleton height=\".3rem\" width=\"35px\"></p-skeleton>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n</p-overlayPanel>\r\n\r\n<!--mailbox details-->\r\n<ng-container *ngIf=\"showMailboxScreenflag\">\r\n <div class=\"changingContent\">\r\n <app-user-mailbox\r\n (closeMailDialogBox)=\"hideMailBoxScreen()\"\r\n ></app-user-mailbox>\r\n </div>\r\n</ng-container>\r\n\r\n<!-- Userdetails profile pop up -->\r\n<div class=\"profile-sidebar\">\r\n <app-side-popup\r\n *ngIf=\"isOpenSidePopup\"\r\n [visible]=\"true\"\r\n [position]=\"'right'\"\r\n (closeDialogBox)=\"closeSidePopup()\"\r\n >\r\n <app-user-sidebar\r\n *ngIf=\"showUserDetails\"\r\n (closeDialogBox)=\"closeSidePopup()\"\r\n ></app-user-sidebar>\r\n </app-side-popup>\r\n</div>\r\n\r\n<!-- Notification side popup -->\r\n<div\r\n class=\"modal fade common-alert-modal\"\r\n #notifyModal\r\n id=\"Notify_SidebarModal\"\r\n tabindex=\"-1\"\r\n aria-hidden=\"true\"\r\n>\r\n <div class=\"modal-dialog sidebar-outer white-bg\">\r\n <div class=\"modal-content\">\r\n <div class=\"sidebar-container white-bg\">\r\n <!-- keep everything inside this content -->\r\n\r\n <!-- Sidebar Header -->\r\n <div class=\"sidebar-header grey-background\">\r\n <div class=\"sh-top\">\r\n <div class=\"sh-top-left d-flex align-items-center\">\r\n <div class=\"mx-2 log-text\">\r\n {{ \"Generic_lib.Notification\" | translate }}\r\n </div>\r\n </div>\r\n <div class=\"sh-top-right\">\r\n <button\r\n type=\"button\"\r\n class=\"common-bn tertiary-btn\"\r\n aria-label=\"Close\"\r\n (click)=\"closeModal()\"\r\n >\r\n <img\r\n src=\"assets/common-header-lib/images/close.svg\"\r\n alt=\"Close\"\r\n class=\"imgs mb-1\"\r\n />\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Sidebar Body -->\r\n <div class=\"sidebar-body\">\r\n <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n <div class=\"noti-text\">\r\n {{\r\n \"Generic_lib.YouHaveNNotifications\"\r\n | translate: { count: userNotificationCount }\r\n }}\r\n </div>\r\n <div\r\n class=\"d-flex align-items-center gap-1 refresh-icon\"\r\n (click)=\"getEventwiseNotification()\"\r\n >\r\n <img\r\n src=\"assets/common-header-lib/images/refresh-1.svg\"\r\n alt=\"Refresh\"\r\n />\r\n <div class=\"refresh-text\">\r\n {{ \"Generic_lib.Refresh\" | translate }}\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"mt-3\">\r\n <ng-container\r\n *ngIf=\"\r\n !isErrorFound && !notificationLoadder;\r\n else Noti_LoadingTemplate\r\n \"\r\n >\r\n <div\r\n class=\"notify-border\"\r\n *ngFor=\"let event of eventwiseNotificationCount\"\r\n >\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <div class=\"initial-text initial-text-1 mx-1\">\r\n <img\r\n src=\"assets/common-header-lib/images/noti_ticket.svg\"\r\n alt=\"Icon\"\r\n />\r\n </div>\r\n <div>\r\n <div>\r\n <span class=\"service-count\"\r\n >{{ event[\"PendingCount\"] }} New </span\r\n ><span class=\"service-request\"\r\n >{{ event[\"EventName\"] }} Event requests</span\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"grey-borders mt-2\"></div>\r\n </div>\r\n </ng-container>\r\n <ng-template #Noti_LoadingTemplate>\r\n <ng-container *ngIf=\"notificationLoadder; else errorTemplate\">\r\n <ng-container *ngFor=\"let item of repeatLoader1\">\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <p-skeleton\r\n shape=\"circle\"\r\n size=\"60px\"\r\n styleClass=\"my-2\"\r\n ></p-skeleton>\r\n <div class=\"ms-1\">\r\n <p-skeleton width=\"200%\" styleClass=\"mb-2\"></p-skeleton>\r\n <p-skeleton width=\"150px\" height=\"1rem\"></p-skeleton>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-template>\r\n\r\n <ng-template #errorTemplate>\r\n <app-no-service-my-access-pg\r\n heading=\"{{ 'Generic_lib.CommonError' | translate }}\"\r\n ></app-no-service-my-access-pg>\r\n </ng-template>\r\n </div>\r\n <!-- Notification content & loaders remain here -->\r\n </div>\r\n </div>\r\n <!-- end of sidebar-container -->\r\n </div>\r\n <!-- end of modal-content -->\r\n </div>\r\n <!-- end of modal-dialog -->\r\n</div>\r\n\r\n<!-- Common Conirmation Modal -->\r\n<confirm-dialog\r\n class=\"rm-invalid-border\"\r\n #confirmDialog\r\n header=\"{{ 'Generic_lib.ChangeLOB' | translate }}\"\r\n message=\"{{ 'Generic_lib.DoYouWantToChangeTheCurrentLOB' | translate }}\"\r\n (result)=\"lobChangeConfirmation($event)\"\r\n></confirm-dialog>\r\n\r\n<!--* Need to use component based notification UI as below -->\r\n<!-- Notification-Sidebar Started -->\r\n<!-- <app-notification-sidebar [isErrorOccured]=\"isErrorFound\" [userNotificationCount]=\"userNotificationCount\"\r\n [userNotificationCountObj]=\"userNotificationCountObj\" [eventwiseNotificationCount]=\"eventwiseNotificationCount\"\r\n (refreshNotification)=\"getEventwiseNotificationCount()\"\r\n [notificationLoadder]=\"notificationLoadder\"></app-notification-sidebar> -->\r\n<!-- Notification-Sidebar Ended -->\r\n", styles: [".app-header{padding:4px 10px 10px;height:42px;border-bottom:1px solid #d0d4e4}.logo{display:flex;align-items:center}.main-right{display:flex;align-items:center;cursor:pointer}.logo-icon{width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;position:relative}.logo-icon:after{width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;position:absolute;content:\"\";top:7px;left:-7px}p{font-size:25px!important}.p-inputtext.p-inputtext-sm{padding:4px 5px 4px 33px!important}.pi-search:before{font-size:13px;position:absolute;top:2px}.overlay-text{font-size:13px;line-height:18px;color:#676879;font-weight:400}.main-left .p-dropdown{border:none;border-radius:0;width:140px!important}.main-left .p-dropdown-panel .p-dropdown-items{padding:0!important;max-height:110px}.main-left :focus-visible{outline:none}.main-left .p-scroller{overflow-x:hidden;height:120px!important}.header-drpdwn{width:120px!important;font-size:11px!important;text-overflow:ellipsis;overflow:hidden}.logs{gap:70px;margin-top:5px}.head-search{position:fixed;top:4px;left:275px}.head-search input{width:calc(30vw - 40px)!important;border:1px solid #c3c6d4;background-color:#f6f7fb;height:32px;border-radius:0 4px 4px 0;border-left:none;font-size:13px!important;padding-left:30px!important;padding-right:54px}.head-search.active{position:fixed;top:4px;left:275px}.head-search.active input{width:555px!important}@media screen and (min-width: 1920px){.head-search.active{position:fixed;top:4px;left:275px}.head-search.active input{width:900px!important}}.header-left-icon{height:32px;width:32px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:all .5s;border-radius:50%;margin-right:4px;position:relative}.header-left-icon:hover{background:#dcdfec}.header-left-icon img:hover{filter:invert(0%) sepia(4%) saturate(0%) hue-rotate(324deg) brightness(55%) contrast(105%)}.apps-icon{width:21px}.logo-img{width:80px}.initial-text{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:11px;border-radius:50%;color:#fff;background-color:#8e562e}.initial-text-1{background-color:#f2edfa}.lob-img{padding-bottom:4px}.session-app:hover{background:#dcdfec;border-radius:10px}.app-col{cursor:pointer;padding:8px 0}.app-text{font-size:12px;color:#676879;white-space:nowrap;padding-top:8px;text-align:center;text-overflow:ellipsis;overflow:hidden;width:100px}.filter-search{position:relative;right:50px;bottom:2px;cursor:pointer}.filter-search .cross-search{width:23px}.filter-search .search-filter{width:19px}.headeright-icon{width:17px;height:17px;filter:invert(44%) sepia(3%) saturate(1698%) hue-rotate(199deg) brightness(92%) contrast(93%)}.pl-0{padding-left:0}.form-control-sm{border:none;border-bottom:1px solid #c3c6d4;border-radius:0}.overlay-footer .common-btn{width:110px;height:32px;padding:11px 12px;border-radius:4px;font-size:13px;cursor:pointer;background:#fff}.overlay-footer .primary-btn{padding:8px 12px 11px 14px;border-radius:4px;height:32px;width:65px;font-size:13px;cursor:pointer}.filter-popup{position:relative;left:10px}.form-group{margin-bottom:5px}.waffle-text{font-size:11px;text-align:center;width:70px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;margin-top:-3px}.waffle-align{display:grid;grid-template-columns:auto auto auto}.waffle{cursor:pointer;margin-right:16px}.waffle-popup{width:89px!important;margin-top:0;padding:8px 0 4px;display:flex;align-items:center;justify-content:center;flex-direction:column;cursor:pointer}.waffle-popup:hover{background:#d3e6ff;border-radius:10px}.waffle-popup img{height:40px}.custom-popover-content{padding:10px;right:-5px;top:0;position:absolute;background:white;border-radius:8px;box-shadow:0 0 6px #9d9d9d}.custom-popover-content.skeleton-popover{width:313px;display:grid;grid-template-columns:auto auto auto;gap:10px}.timezone{margin-right:12px}.timezone-icon{font-size:16px}.timezone-text{padding-left:6px;font-size:13px;color:#495057;font-weight:400}.user-tz{font-size:13px;color:#757575;font-weight:400;text-overflow:ellipsis;overflow:hidden;width:30px;white-space:normal}.profile-sidebar .p-dialog .p-dialog-content{padding:0}.profile-sidebar .p-dialog-header{display:none}.modname{font-size:18px;margin-bottom:0}.changingContent{overflow:hidden;width:100%}.changingContent .intro-text{background-image:linear-gradient(145deg,#f1eaec,#f8e3e7,#f7e1f8,#ebeeff,#e8eef3);position:relative;height:135px}.changingContent .inner-garient{padding:50px 20px 115px 30px}.changingContent .table-heading{padding:0 20px 1px 30px}.changingContent .table-selection{padding:3px 20px 0 30px}.grey-background{background-color:#f6f7fb}.white-bg{background:#ffffff;overflow:hidden}.imgs{width:20px}.p-dropdown .p-dropdown-label{background:transparent;border:0 none;display:flex;align-items:center}.p-dropdown .p-dropdown-trigger{width:32px!important}.pi-chevron-down:before{content:\"\\e902\";font-size:11px}.sidebar-outer{height:100vh}.lang-dropdown .p-dropdown{border:1px solid #dee2e6!important;height:26px!important;border-radius:4px!important;min-width:calc(40vh - 92px)!important;padding:0 4px 0 12px!important;display:flex!important;align-items:center!important;justify-content:space-between!important}.lang-dropdown .p-dropdown .pi{position:relative;bottom:2px;left:7px}.lang-dropdown .p-dropdown-panel{background:#ffffff!important;color:#495057!important;border:0px!important;box-shadow:0 2px 12px #0000001a!important}.lang-dropdown .p-dropdown-header{padding:5px 10px!important;border-bottom:1px solid #dee2e6!important;background:#f8f9fa!important;color:#343a40!important;margin:0!important}.lang-dropdown .p-dropdown-items-wrapper{max-height:140px!important}.lang-dropdown .p-dropdown-panel .p-dropdown-header{padding:4px 8px!important;border-radius:0!important}.p-dropdown-panel .p-dropdown-header{padding:.75rem 1.25rem;border-bottom:1px solid #dee2e6;color:#343a40;background:#f8f9fa;margin:0;border-top-right-radius:6px;border-top-left-radius:6px}.lang-dropdown .p-dropdown .p-dropdown-header .p-dropdown-filter{height:26px;border-radius:4px;font-size:12px;border:1px solid #ced4da!important;padding-left:12px!important}.lang-dropdown .p-inputtext{margin:0;text-align:start;font-size:13px;padding:0!important}.lang-dropdown .p-dropdown-panel .p-dropdown-header .p-dropdown-filter-icon{position:relative;bottom:13px;font-size:13px}.sidebar-outer .sidebar-body .sb-list ul li span{margin-right:12px}.p-dropdown-panel .p-dropdown-header .p-dropdown-filter-icon{left:6px;color:#6c757d}.lang-dropdown .p-dropdown-items-wrapper ::-webkit-scrollbar{width:6px!important}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:#c1c1c1;border-radius:6px}::-webkit-scrollbar-thumb:hover{background-color:#a8a8a8}.sidebar-outer .sidebar-body .sb-list ul{float:left;width:100%;list-style:none;padding-left:0}.lang-dropdown .p-dropdown-panel .p-dropdown-items{font-size:12px;padding:0!important}.p-dropdown-panel .p-dropdown-items .p-dropdown-item.p-highlight{color:#1d4ed8;background:#eff6ff}.lang-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-item{padding:2px 14px;font-size:12px}.sidebar-outer .sidebar-body .sb-list ul li{display:flex;padding:8px 2px;cursor:pointer}.modal-dialog{margin-right:0;margin-top:0;margin-bottom:0}.loblist-drpdwn-panel .p-dropdown-header{padding:5px 10px}.loblist-drpdwn-panel .p-inputtext{background:#ffffff;padding:6px}.loblist-drpdwn .p-inputtext{font-size:13px}.loblist-drpdwn-panel .p-dropdown-header .p-dropdown-filter{height:28px;border-radius:4px;font-size:12px}.loblist-drpdwn-panel .p-dropdown-items .p-dropdown-item{margin-bottom:1px;padding:6px 16px;border:0;color:#495057;background:transparent;transition:box-shadow .2s;border-radius:0;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loblist-drpdwn-panel .p-dropdown-header .p-dropdown-filter-icon{position:absolute;left:82%;top:50%;transform:translateY(-50%);color:#6c757d}.loblist-drpdwn-panel .p-dropdown-items .p-dropdown-empty-message{padding:6px 12px;color:#495057!important;background:transparent!important;font-size:12px}.logo-size{max-height:32px;max-width:92px}.logo-size-1{width:80px;height:30px}.sidebar-body{overflow:auto;height:calc(100vh - 70px);width:100%}.sidebar-body .refresh-icon{cursor:pointer}.sidebar-body .notify-border{padding:8px 8px 0 6px;cursor:pointer}.sidebar-body .notify-border:hover{background-color:#dcdfec;border-radius:8px}.sidebar-body .notify-border .initial-text{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:11px;border-radius:50%;color:#fff;background-color:#f2edfa}.sidebar-body .notify-border .service-count{color:#323238;font-weight:600;font-size:13px}.sidebar-body .notify-border .service-request{color:#676879;font-size:12px;font-weight:500}.sidebar-body .notify-border .time-text{color:#676879;font-size:12px}.sidebar-body .notify-border .grey-borders{border-bottom:1px solid #d0d4e4}.mail-table{height:calc(100vh - 155px);overflow:auto}.mail-table .p-datatable .p-datatable-thead>tr{border:1px solid #dee2e6;border-radius:24px}.mail-table .p-datatable .p-datatable-thead>tr th{padding:0 8px;height:36px;font-size:13px;color:var(--primary-text);font-weight:600;background:#fff}.mail-table .p-datatable .p-datatable-tbody>tr{border:1px solid #dee2e6;border-radius:24px}.mail-table .p-datatable .p-datatable-tbody>tr td{padding:0 25px 0 8px;height:38px;font-size:13px;color:var(--secondary-text);white-space:nowrap}.mail-table .p-checkbox{height:18px;width:18px}.mail-table .p-checkbox .p-checkbox-box{height:16px;width:16px;border-radius:4px;border:1px solid var(--ui-border)}.mail-table .p-checkbox .p-checkbox-box:hover{border:1px solid var(--ui-border)!important}.mail-table .p-checkbox .p-checkbox-icon{font-size:10px!important}.mail-table .p-datatable .p-sortable-column:hover{background-color:#fff!important;color:#000!important}.mail-table .p-datatable .p-sortable-column:focus{box-shadow:none!important}.mail-table .p-datatable .p-sortable-column .p-sortable-column-icon{font-size:12px}.mail-table .p-dropdown-panel .p-dropdown-items{padding:0}.mail-table .p-dropdown-panel .p-dropdown-items .p-dropdown-item{font-size:13px!important;padding:10px 15px}.mail-table .p-paginator{justify-content:flex-start!important;position:fixed;bottom:0;padding-left:0!important}.mail-table .p-paginator .p-paginator-current{font-size:12px;height:1rem!important}.mail-table .p-paginator .p-paginator-pages .p-paginator-page{min-width:30px!important;height:30px!important;font-size:12px}.mail-table .p-paginator .p-dropdown{height:30px!important;margin-top:0;border:0px}.mail-table .p-paginator .p-dropdown .p-dropdown-label{padding:4px 5px 0 10px!important;font-size:14px}.mail-table .p-paginator .p-dropdown .p-dropdown-trigger{width:1.5rem!important}.mail-table .p-paginator .p-dropdown .p-dropdown-trigger .pi{font-size:13px!important}.mail-pagination .p-paginator{justify-content:flex-start!important;position:fixed;bottom:0;padding-left:0}.mail-pagination .p-paginator .p-paginator-current{font-size:12px;height:1rem!important;padding-left:0}.mail-pagination .p-paginator .p-paginator-pages .p-paginator-page{min-width:30px!important;height:30px!important;font-size:12px}.mail-pagination .p-paginator .p-dropdown{height:30px!important;margin-top:0;border:0px}.mail-pagination .p-paginator .p-dropdown .p-dropdown-label{padding:4px 5px 0 10px!important;font-size:14px}.mail-pagination .p-paginator .p-dropdown .p-dropdown-trigger{width:1.5rem!important}.mail-pagination .p-paginator .p-dropdown .p-dropdown-trigger .pi{font-size:13px!important}.rm-invalid-border .card{border:0px}.view-pass-details{width:600px!important}.view-pass-details .p-dialog-header{background:#ffffff!important;border-radius:4px 4px 0 0!important;border-bottom:1px solid #d0d4e4!important}.view-pass-details .p-dialog-content:last-of-type{border-bottom-right-radius:4px!important;border-bottom-left-radius:4px!important;padding:0}.confirmtion-modal .p-dialog-content{padding-top:24px;padding-right:100px;font-size:15px}.confirmtion-modal .p-confirm-dialog-message{margin-left:0!important}.confirmtion-modal .p-button{font-size:15px;padding:6px 28px}.ngx-toastr{width:400px!important;margin-top:10px!important}.toast-success{background-color:#fff!important;border-bottom:3px solid #258750;border-radius:4px!important;background-image:url(../assets/common-header-lib/images/check_circle.svg)!important;background-repeat:no-repeat}.toast-success .toast-message{padding-top:2px;color:#258750!important;font-size:14px!important}.toast-error{background-color:#fff!important;border-bottom:3px solid #d83a52;border-radius:4px!important;background-image:url(../assets/common-header-lib/images/error.svg)!important;background-repeat:no-repeat}.toast-error .toast-message{padding-top:2px;color:#d83a52!important;font-size:14px!important}.toast-info{background-color:#fff!important;border-bottom:3px solid #0073ea;border-radius:4px!important;background-image:url(../assets/common-header-lib/images/info.svg)!important;background-repeat:no-repeat}.toast-info .toast-message{padding-top:3px;color:#0073ea!important;font-size:14px!important}.toast-warning{background-color:#fff!important;border-bottom:3px solid #fdab3d;border-radius:4px!important;background-image:url(../assets/common-header-lib/images/check_circle.svg)!important;background-repeat:no-repeat}.toast-warning .toast-message{padding-top:3px;color:#fdab3d!important;font-size:14px!important}.toast-close-button{right:10px!important;font-size:20px;font-weight:700;text-shadow:0 1px 0 #ffffff;background-color:transparent;border:0px;color:#676879;position:absolute;top:10px;cursor:pointer}.toast-container{position:absolute;z-index:2147483647!important}.toast-container .ngx-toastr{position:relative;overflow:hidden;margin:0 0 6px;padding:15px 40px 15px 50px;width:300px;border-radius:3px;background-position:15px center;background-repeat:no-repeat;background-size:24px;box-shadow:0 0 12px #999;color:#fff}.toast-top-center{top:0;right:0;width:100%}.toast-container.toast-top-center .ngx-toastr,.toast-container.toast-bottom-center .ngx-toastr{margin-left:auto;margin-right:auto}.badge-notify:hover{border-radius:50%;background:#dcdfec}.badge-notify .p-badge{min-width:16px;height:16px;line-height:15px}.badge-notify .p-overlay-badge .p-badge{position:absolute;top:-7px;right:12px;font-size:9px;padding:0 2px;cursor:pointer}.madontary-icon{color:#d4231d;font-weight:500;padding:5px 0 0 5px}.img-lock{width:12px;margin-bottom:1px}.img-lock.ext{width:16px;margin-bottom:0}.img-lock.ext2{width:18px;margin-bottom:0}.form-group .error-msg{position:relative}.submit-btn .p-button{height:30px;font-size:14px;border-radius:4px}.submit-btn .p-button .p-button-label{font-weight:400;font-size:13px}.p-dialog.general-configuration{width:100%;height:100vh;max-height:100vh}.general-configuration .p-dialog-header{border-bottom:1px solid #d0d4e4!important;background:#ffffff!important}.p-dialog .p-dialog-header{padding:10px 21px!important;background:#f6f7fb!important;border-top-right-radius:0!important;border-top-left-radius:0!important;height:54px}.assets-dropdown .p-dropdown{height:38px!important;width:100%!important;border-radius:4px!important;align-items:center!important}.assets-dropdown .p-dropdown:hover{border:1px solid #ced4da!important}.p-dropdown-panel .p-dropdown-header .p-dropdown-filter{padding-right:1.75rem;margin-right:-1.75rem}.assets-dropdown .p-inputtext{width:100%;border-radius:4px;height:30px;font-size:13px!important}.assets-dropdown .p-dropdown-panel .p-dropdown-header .p-dropdown-filter-icon{left:96%;color:#6c757d;font-size:13px;top:15px!important}.assets-dropdown .p-dropdown-panel .p-dropdown-header{padding:10px!important}.assets-dropdown .p-dropdown-items-wrapper{max-height:100px!important}.assets-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-item{padding:5px 20px!important;font-size:13px!important;font-weight:400!important}.p-dropdown-panel .p-dropdown-items{padding:0!important}.assets-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-empty-message{font-size:13px!important;padding:8px 20px!important}.p-dropdown-panel .p-dropdown-items .p-dropdown-empty-message{padding:.75rem 1.25rem;color:#495057!important;background:transparent!important}.p-dropdown-filter-container{position:relative}.p-dropdown-filter-container input{border:1px solid #ced4da!important}.input-dropdown .password-checkbox-right{position:absolute;width:24px;right:8px}.timezone-dropdown .p-dropdown{width:100%;border:1px solid #ced4da!important;border-radius:4px;height:38px}.timezone-dropdown .p-dropdown-panel .p-dropdown-header{padding:5px}.timezone-dropdown .p-dropdown:hover{border:1px solid #ced4da!important}.timezone-dropdown .p-inputtext{width:100%;border-radius:4px;height:30px;font-size:13px!important}.timezone-dropdown .p-dropdown-panel .p-dropdown-header .p-dropdown-filter-icon{left:96%;color:#6c757d;font-size:13px;top:15px!important}.timezone-dropdown .p-dropdown-panel .p-dropdown-header{padding:10px!important}.timezone-dropdowntimezone-dropdown .p-dropdown-items-wrapper{max-height:100px!important}.timezone-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-item{padding:5px 20px!important;font-size:13px!important;font-weight:400!important}.timezone-dropdown .p-dropdown-panel .p-dropdown-items .p-dropdown-empty-message{font-size:13px!important;padding:8px 20px!important}.sidebar-container{width:420px;position:fixed;top:0;height:100vh;max-width:100%;transition:all .3s ease;-webkit-transition:all .3s ease;-moz-transition:all .3s ease;background-color:#fff}.white-bg{background:#ffffff;width:420px;overflow:hidden}.sidebar-outer .sidebar-header{padding:12px 15px}.sidebar-outer .sidebar-header .sh-top{display:flex;align-items:center;justify-content:space-between}.log-text{font-size:16px;color:#292f4c;font-weight:600}.sidebar-outer .sidebar-header .sh-top button{height:24px}.sidebar-outer .sidebar-body{padding:12px 20px;float:left;width:100%;overflow:auto;height:calc(100vh - 70px)}.tertiary-btn{border:none;background-color:transparent}.sidebar-body .noti-text{color:#292f4c;font-size:13px;font-weight:600;line-height:24px}.sidebar-body .refresh-text{color:#676879;font-size:12px;line-height:24px}.error-msg{font-size:12px;font-weight:600;width:100%;position:absolute;bottom:4px;left:0;display:flex;align-items:flex-end;color:#d83a52;font-family:-apple-system,BlinkMacSystemFont,Roboto,Segoe UI,Helvetica,Arial,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",Segoe UI Symbol!important}.error-msg .error-icon{font-size:18px;margin-right:4px;position:relative;top:-1px}\n"] }]
|
|
575
|
+
}], ctorParameters: function () { return [{ type: i1.CommonHeaderLibService }, { type: i0.ChangeDetectorRef }, { type: i2.RestSignalRService }, { type: i3.EventService }, { type: i4.TranslateService }, { type: i5.NgbModal }, { type: i4.TranslateService }, { type: i6.HttpCommonService }, { type: i7.ToastMsgService }]; }, propDecorators: { EnableLogo: [{
|
|
576
|
+
type: Input
|
|
577
|
+
}], moduleName: [{
|
|
578
|
+
type: Input
|
|
579
|
+
}], EnableTimeZone: [{
|
|
580
|
+
type: Input
|
|
581
|
+
}], EnableLOB: [{
|
|
582
|
+
type: Input
|
|
583
|
+
}], EnableMail: [{
|
|
584
|
+
type: Input
|
|
585
|
+
}], EnableNotifications: [{
|
|
586
|
+
type: Input
|
|
587
|
+
}], EnableMoreApps: [{
|
|
588
|
+
type: Input
|
|
589
|
+
}], EnableProfile: [{
|
|
590
|
+
type: Input
|
|
591
|
+
}], selectedLOBId: [{
|
|
592
|
+
type: Input
|
|
593
|
+
}], lobSelected: [{
|
|
594
|
+
type: Output
|
|
595
|
+
}], langChange: [{
|
|
596
|
+
type: Output
|
|
597
|
+
}], overlayStateChange: [{
|
|
598
|
+
type: Output
|
|
599
|
+
}], confirmDialog: [{
|
|
600
|
+
type: ViewChild,
|
|
601
|
+
args: ['confirmDialog']
|
|
602
|
+
}], appPanel: [{
|
|
603
|
+
type: ViewChild,
|
|
604
|
+
args: ['App']
|
|
605
|
+
}], notifyModalRef: [{
|
|
606
|
+
type: ViewChild,
|
|
607
|
+
args: ['notifyModal']
|
|
608
|
+
}], notifyModal: [{
|
|
609
|
+
type: ViewChild,
|
|
610
|
+
args: ['notifyModal']
|
|
611
|
+
}] } });
|
|
612
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-header-lib.component.js","sourceRoot":"","sources":["../../../../projects/common-header-lib/src/lib/common-header-lib.component.ts","../../../../projects/common-header-lib/src/lib/common-header-lib.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConfirmDialogComponent } from './components/confirm-dialog/confirm-dialog.component';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { CommonHeaderLibService } from './common-header-lib.service';\nimport { catchError, finalize, map, takeUntil } from 'rxjs/operators';\nimport { OverlayPanel } from 'primeng/overlaypanel';\nimport { Subject, forkJoin, of } from 'rxjs';\nimport { GlobalConstants } from './model/data_model';\nimport { RestSignalRService } from './services/rest-signalr.service';\nimport { EventService } from './services/event.service';\nimport { TranslateService } from '@ngx-translate/core';\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\nimport { HttpCommonService } from './services/http/http-common.service';\nimport { ToastMsgService } from './services/toast-msg.service';\ndeclare var bootstrap: any; // Bootstrap JS is global (from bundle)\n\ninterface AppDetails {\n  applicationName: string;\n  applicationId: number;\n  appCode: string;\n  privileges: any; // or a more specific type if you know it\n  applicationUrl: string;\n  isAssignedLanding: boolean;\n}\n\ninterface AccessType {\n  id: number;\n  name: string;\n}\n\n@Component({\n  selector: 'lib-common-header-lib',\n  templateUrl: './common-header-lib.component.html',\n  styleUrls: ['./common-header-lib.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class CommonHeaderLibComponent implements OnInit, AfterViewInit {\n  // @Input() apiURL: string = '';\n  @Input() EnableLogo: boolean = true;\n  @Input() moduleName: string = '';\n  @Input() EnableTimeZone: boolean = true;\n  @Input() EnableLOB: boolean = true;\n  @Input() EnableMail: boolean = true;\n  @Input() EnableNotifications: boolean = true;\n  @Input() EnableMoreApps: boolean = true;\n  @Input() EnableProfile: boolean = true;\n  @Input() selectedLOBId: any;\n  @Output() lobSelected = new EventEmitter<any>();\n  @Output() langChange = new EventEmitter<any>();\n  @Output() overlayStateChange = new EventEmitter<boolean>();\n  @ViewChild('confirmDialog')\n  confirmDialog!: ConfirmDialogComponent;\n\n  headerLogo: any;\n  userTimeZoneAbbreviations: string = '';\n  public userTimeZoneFullForm: string = '';\n  userLOBList: any = [];\n  tempSelectedLOBId: any;\n  showLobLoader: boolean = true;\n  public totalEmails: string = '';\n  public userNotificationCount: string = '';\n\n  public userDetails: any;\n\n  ListOfUserPrivillegedApp: AppDetails[] = [];\n  userdisplayName: string = '';\n  userDetailsInfo: any = [];\n  public isOpenSidePopup: boolean = false;\n  public showUserDetails: boolean = false;\n  public userAppLoaderLoadder: boolean = true;\n  public repeatLoader = new Array(12).fill(0);\n  showMailboxScreenflag: boolean = false;\n  public isErrorFound: boolean = false;\n  public userNotificationCountObj: any = {};\n  public eventwiseNotificationCount = [];\n  public notificationLoadder: boolean = true;\n  private unsubscribeAPIEventListenerData: Subject<boolean> =\n    new Subject<boolean>();\n  private unsubscribeSidebarListenerData: Subject<boolean> =\n    new Subject<boolean>();\n  public userId: string = '';\n  public assetCategoryMenuList: any = [];\n  public showbusinessFileds: boolean = false;\n  public showInfraFileds: boolean = false;\n  public showfiltersearch: boolean = true;\n  public clickInside: boolean = false;\n  public isLobContentLoaded: boolean = false;\n  public isHeaderContentLoaded: boolean = false;\n  public requestTypeId: number = 1;\n  public accessTypes: Array<AccessType> = [\n    { id: 1, name: 'Permanent' },\n    { id: 2, name: 'OneTime' },\n    { id: 3, name: 'TimeBased' },\n  ];\n  public selectedAssetName: any = {\n    assetId: -100,\n    assetName: 'All',\n  };\n  public assetName: string = '';\n  public assetId: number = 0;\n  public allCategory = {\n    assetTypeId: -100,\n    assetTypeValue: 'All Section',\n    assetList: [\n      {\n        assetId: -100,\n        assetName: 'All',\n      },\n    ],\n  };\n\n  private translateName = [\n    'Generic_lib.Permanent',\n    'Generic_lib.OneTime',\n    'Generic_lib.TimeBased',\n  ];\n\n  @ViewChild('App') appPanel: any = OverlayPanel;\n  @ViewChild('notifyModal') notifyModalRef!: ElementRef;\n  @ViewChild('notifyModal') notifyModal!: ElementRef;\n  private bsModalInstance: any;\n  public isErrorOccured: boolean = false;\n  // @Output() public refreshNotification = new EventEmitter<boolean>();\n  public repeatLoader1 = new Array(9).fill(0);\n\n  constructor(\n    private readonly libService: CommonHeaderLibService,\n    private readonly cdRef: ChangeDetectorRef,\n    private readonly _signalRService: RestSignalRService,\n    private readonly _eventService: EventService,\n    private translate: TranslateService,\n    private modalService: NgbModal,\n    private translateService: TranslateService,\n    private httpCommonService: HttpCommonService,\n    private readonly msgService: ToastMsgService,\n  ) {}\n  ngOnInit() {\n    this.headerLogo = '';\n    this.overlayStateChange.emit(false);\n    this.setWebAPIURL();\n    if (this.EnableLogo) this.loadHeaderLogo();\n    if (this.EnableLOB) this.getListofLOB();\n    this.onLoadMethod();\n  }\n  onLoadMethod() {\n    this.onDemandActions();\n    if (this.EnableNotifications) this.getEventwiseNotificationCount();\n    this.getUserActivityDetails();\n  }\n\n  //* on click of Mail icon\n  showMailBoxScreen() {\n    this.showMailboxScreenflag = true;\n    this.overlayStateChange.emit(true);\n  }\n\n  hideMailBoxScreen() {\n    this.showMailboxScreenflag = false;\n    this.overlayStateChange.emit(false);\n  }\n\n  //* Main language change emitter\n  languageChange(event: any) {\n    if (!event) return;\n    this.langChange.emit(event);\n  }\n\n  showUserAppsPanel(event: Event) {\n    this.appPanel.toggle(event);\n    if (this.ListOfUserPrivillegedApp.length === 0) {\n      this.getUserAssignedApp();\n    }\n  }\n  showUserDetailsPanel() {\n    this.openSidePopup();\n    this.showUserDetails = true;\n  }\n\n  closeSidePopup() {\n    this.showUserDetails = false;\n    this.isOpenSidePopup = false;\n  }\n  openSidePopup() {\n    this.isOpenSidePopup = true;\n  }\n  //Method: Take Connection of Application\n  getConnectionofApplication(appCode: string) {\n    console.log('appcode', appCode);\n\n    const url =\n      GlobalConstants.baseURL + '/xauth/api/Token/AppOAuth?appcode=' + appCode;\n    window.open(url, '_blank');\n  }\n\n  private async getConnectToSingalRhub() {\n    try {\n      await this._signalRService.initializeSignalRConnection();\n    } catch (error) {\n      console.error('All SignalR hub connections failed.', error);\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.ListenToTranslateEvent();\n    // Initialize modal instance when DOM is ready\n    this.bsModalInstance = new bootstrap.Modal(this.notifyModal.nativeElement);\n  }\n\n  /*Method : Listen to the Other component event\n   Action : It used to listen diff. component command on basis of perform some actions */\n  onDemandActions() {\n    //Listen the Event Emit by Sidebar\n    this._eventService\n      .listenerAssetTypeEvent()\n      .pipe(takeUntil(this.unsubscribeSidebarListenerData))\n      .subscribe((data) => {\n        if (data && data['component'] === 'assetMenu') {\n          this.assetCategoryMenuList = [];\n          this.assetCategoryMenuList = data['aseetTypeList'];\n\n          //Note: Add Filter Fileds of Business/Infra Asset and there RequestID\n          //For Business Asset\n          if (data?.['assetCategoryId'] == 1) {\n            this.showbusinessFileds = true;\n            this.showInfraFileds = false;\n            this.requestTypeId = 1;\n            this.selectedAssetName = this.assetCategoryMenuList[0]; //Set index 0 By Default\n            this.assetName = this.selectedAssetName['assetTypeValue'];\n            this.assetId = this.selectedAssetName['assetTypeId'];\n            //For Infra Asset\n          } else if (data?.['assetCategoryId'] == 2) {\n            this.showInfraFileds = true;\n            this.showbusinessFileds = false;\n            this.requestTypeId = 2;\n            this.selectedAssetName =\n              this.assetCategoryMenuList[0]['assetList'][0]; //Set index 0 By Default\n            this.assetName = this.selectedAssetName['assetName'];\n            this.assetId = this.selectedAssetName['assetId'];\n          }\n\n          //Note: Added Extra Hard coded type in AssetCategory Menu for Infra Asset\n          if (this.assetCategoryMenuList.length > 0) {\n            if (this.showInfraFileds) {\n              this.assetCategoryMenuList.unshift(this.allCategory);\n            }\n            this.assetCategoryMenuList = this.assetCategoryMenuList.filter(\n              (element: any) => {\n                if (\n                  !(\n                    element.assetTypeValue === 'Favorite' ||\n                    element.assetTypeValue === 'Bookmark'\n                  )\n                ) {\n                  return element;\n                }\n              },\n            );\n          }\n        }\n      });\n\n    //Listen the Event Emit by SignalR Hub\n    this._signalRService\n      .listenerEventMsg()\n      .pipe(takeUntil(this.unsubscribeAPIEventListenerData))\n      .subscribe((data) => {\n        if (data && data['application'] && data['events']) {\n          this.isErrorFound = false;\n          this.userNotificationCountObj = data['application'];\n          //Note: If Notification count > 99\n          if (\n            this.userNotificationCountObj &&\n            this.userNotificationCountObj['PendingCount']\n          ) {\n            if (Number(this.userNotificationCountObj['PendingCount']) > 99) {\n              this.userNotificationCount = '99+';\n            } else {\n              this.userNotificationCount = String(\n                this.userNotificationCountObj['PendingCount'],\n              );\n            }\n          } else {\n            this.userNotificationCount = '';\n          }\n          this.eventwiseNotificationCount = data['events'];\n        }\n      });\n\n    this.listenToTimeZoneConfig();\n    this.listenToEmailCountEvent();\n  }\n\n  //Listen to TimeZone Config\n  listenToTimeZoneConfig() {\n    this._eventService\n      .listenerTimezone()\n      .pipe(takeUntil(this.unsubscribeAPIEventListenerData))\n      .subscribe((response) => {\n        if (response && response['component'] == 'timezone') {\n          this.userTimeZoneAbbreviations =\n            response['usertimezoneAbbreviations'];\n          this.userTimeZoneFullForm = response['userTimeZoneFullForm'];\n        }\n      });\n  }\n\n  //Listen to Email Count when user Read\n  listenToEmailCountEvent() {\n    this._eventService\n      .listenerUserEmail()\n      .pipe(takeUntil(this.unsubscribeAPIEventListenerData))\n      .subscribe((data) => {\n        if (data && data['component'] === 'email-count') {\n          this.totalEmails = data['mailCount'];\n        }\n      });\n  }\n\n  //Method: Convert text one Lang. to another\n  private ListenToTranslateEvent() {\n    this.translate.onLangChange.subscribe((val: any) => {\n      this.getTranslateContent();\n    });\n  }\n\n  //Method: Convert text one Lang. to another Event Listener\n  private getTranslateContent() {\n    this.translate.get(this.translateName).subscribe((trans: any) => {\n      this.accessTypes.forEach((item, index) => {\n        const key = this.translateName[index];\n        item['name'] = trans[key];\n      });\n    });\n  }\n\n  OpenNotificationModal() {\n    // const modalRef = this.modalService.open(NotificationSidebarComponent);\n    // modalRef.componentInstance.lesson = lesson;\n    this.bsModalInstance?.show();\n  }\n  closeModal() {\n    this.bsModalInstance?.hide();\n  }\n\n  //Method: Call APi to Fetch New Notification Count\n  getEventwiseNotification() {\n    // this.refreshNotification.emit(true);\n    this.getEventwiseNotificationCount();\n  }\n\n  setWebAPIURL() {\n    if (GlobalConstants.baseURL == undefined) {\n      if (localStorage.getItem('_WAU')) {\n        GlobalConstants.baseURL = localStorage.getItem('_WAU') || '';\n      } else {\n        let parsedURL = new URL(window.location.href);\n        let WebApiUrl = parsedURL.origin;\n        GlobalConstants.baseURL = WebApiUrl;\n        localStorage.setItem('_WAU', GlobalConstants.baseURL);\n      }\n    }\n  }\n\n  private getUserActivityDetails(): void {\n    // Reset error state before API calls\n    this.isErrorFound = false;\n\n    // Initialize response container for forkJoin\n    const responseSet: any = {};\n\n    // Build payload once for notification API\n    const notificationPayload = {\n      ApplicationName: GlobalConstants.applicationName,\n      UserId: String(this.userId),\n    };\n\n    // Add notification API if enabled\n    if (this.EnableNotifications) {\n      responseSet.notifications = this.httpCommonService\n        .getWorkFlowTicketCount(notificationPayload)\n        .pipe(\n          // Extract valid notification data\n          map((response) => response),\n          // Handle API error without breaking forkJoin\n          catchError(() => {\n            this.isErrorFound = true;\n            return of(null);\n          }),\n        );\n    }\n\n    // Add user profile API if enabled\n    if (this.EnableProfile) {\n      responseSet.userinfo = this.httpCommonService.getLoggedInUserDetails();\n    }\n\n    // Add timezone API if enabled\n    if (this.EnableTimeZone) {\n      responseSet.timeZone = this.httpCommonService.getGlobalTimeZone();\n    }\n\n    // Add unread email count API if enabled\n    if (this.EnableMail) {\n      responseSet.emailCount =\n        this.httpCommonService.getUnreadUserEmailsCount();\n    }\n\n    // Execute all enabled APIs together\n    forkJoin(responseSet)\n      .pipe(\n        // Mark header loading as completed\n        finalize(() => {\n          this.isHeaderContentLoaded = true;\n        }),\n      )\n      .subscribe((response: any) => {\n        // Process notification data\n        if (response.notifications) {\n          this.getTotalNotificationCounts(response.notifications);\n        }\n\n        // Process user profile data\n        if (response.userinfo) {\n          this.getLoggedInUserDetails(response.userinfo);\n        }\n\n        // Process timezone list\n        if (response.timeZone) {\n          this.getListOfTimeZones(response.timeZone);\n        }\n\n        // Process unread email count\n        if (response.emailCount) {\n          this.getUserEmailCount(response.emailCount);\n        }\n      });\n  }\n\n  public getTotalNotificationCounts(data: any) {\n    // this.isErrorFound = false;\n    this.userNotificationCountObj = data || {};\n    if (\n      this.userNotificationCountObj &&\n      this.userNotificationCountObj['PendingCount']\n    ) {\n      if (Number(this.userNotificationCountObj['PendingCount']) > 99) {\n        this.userNotificationCount = '99+';\n      } else {\n        this.userNotificationCount = String(\n          this.userNotificationCountObj['PendingCount'],\n        );\n      }\n    } else {\n      this.userNotificationCount = '';\n    }\n  }\n\n  /*Method :  Retrieves details of the currently logged-in user*/\n  public getLoggedInUserDetails(response: any) {\n    if (response && response['success'] && response['result']) {\n      this.userDetails = response['result'];\n      this.userdisplayName = this.userDetails['userDisplayName'];\n    }\n  }\n\n  /*Method : GET\n    Action : Get List of Time Zone*/\n  public getListOfTimeZones(result: any) {\n    if (result && result['abbreviations']) {\n      this.userTimeZoneAbbreviations = result['abbreviations'];\n      this.userTimeZoneFullForm = result['userTimeZone'];\n    }\n  }\n\n  /*Method : GET\n    Action : Transformation fo Count  */\n  private getUserEmailCount(count: number) {\n    if (count <= 0) {\n      this.totalEmails = '';\n    } else if (count > 99) {\n      this.totalEmails = '99+';\n    } else {\n      this.totalEmails = String(count);\n    }\n  }\n\n  /** API to get the header LOGO */\n  loadHeaderLogo() {\n    this.httpCommonService.getLogo().subscribe((img) => {\n      this.headerLogo = 'data:image/png;base64,' + img['logoImg'];\n    });\n  }\n\n  /** API to get the timezone */\n  // getUserPreferredTimezone() {\n  //   this.httpCommonService.getGlobalTimeZone().subscribe((res: any) => {\n  //     if (res?.abbreviations) {\n  //       this.userTimeZoneAbbreviations = res.abbreviations;\n  //       this.userTimeZoneFullForm = res?.userTimeZone;\n  //     }\n  //   });\n  // }\n\n  //* get Lob AI call and initial LOB emitter\n  getListofLOB() {\n    this.showLobLoader = true;\n    this.httpCommonService.getLOBList().subscribe((res: any) => {\n      this.showLobLoader = false;\n      this.userLOBList = res.result;\n      let initialLobSelected = this.getLobById(\n        this.userLOBList,\n        this.userLOBList[0]?.lobId,\n      );\n      const preSelectedLob = JSON.parse(localStorage.getItem('XOB') || 'null');\n      let isPreSelectedLobExistsInList = this.userLOBList.some(\n        (lob: any) => Number(lob.lobId) == Number(preSelectedLob?.LOBId),\n      );\n      if (\n        preSelectedLob &&\n        Number(preSelectedLob.LOBId) &&\n        isPreSelectedLobExistsInList\n      ) {\n        //* Emitting 1st LOB for LOB List as LOb details available in localstorega\n        this.selectedLOBId = preSelectedLob?.LOBId;\n        this.tempSelectedLOBId = preSelectedLob?.LOBId;\n        initialLobSelected = this.getLobById(\n          this.userLOBList,\n          this.selectedLOBId,\n        );\n      } else {\n        //* Emitting 1st LOB for LOB List if localstorage have null LOB details\n        this.selectedLOBId = this.userLOBList[0]?.lobId;\n        this.tempSelectedLOBId = this.userLOBList[0]?.lobId;\n        localStorage.setItem('XOB', JSON.stringify(initialLobSelected));\n      }\n      this.lobSelected.emit(initialLobSelected);\n      this.cdRef.detectChanges();\n    });\n  }\n\n  //* Selected LOB emitter\n  onLobChangeEvent(event: any) {\n    this.selectedLOBId = event.value;\n    this.openConfirm(event);\n  }\n\n  openConfirm(event: Event) {\n    this.confirmDialog.openConfirmModal(event);\n  }\n\n  lobChangeConfirmation(event: any) {\n    if (event) {\n      this.tempSelectedLOBId = this.selectedLOBId;\n      let selectedLob = this.getLobById(\n        this.userLOBList,\n        this.tempSelectedLOBId,\n      );\n      localStorage.setItem('XOB', JSON.stringify(selectedLob));\n      this.lobSelected.emit(selectedLob);\n    } else {\n      this.selectedLOBId = this.tempSelectedLOBId;\n    }\n  }\n\n  setCustomLobId(lobId: any) {\n    if (this.userLOBList) {\n      let filteredLobs = this.getLobById(this.userLOBList, lobId);\n      if (Object.keys(filteredLobs).length > 0) {\n        this.selectedLOBId = lobId;\n        //* If the LOB is forcefully set from the parent module, CustomLOBSetByParent is set to true; otherwise, it is set to false.\n        filteredLobs['CustomLOBSetByParent'] = true;\n        this.lobSelected.emit(filteredLobs);\n        localStorage.setItem('XOB', JSON.stringify(filteredLobs));\n      } else {\n        this.msgService.error(\n          'The LOB you are trying to set is not available.',\n        );\n      }\n    }\n  }\n\n  //* Helper function to get selected LOB Object by LobId\n  getLobById(list: any, id: any) {\n    const item = list.find((x: any) => x.lobId === id);\n    if (!item) return {};\n    return {\n      LOBId: item.lobId,\n      LOBName: item.lobName,\n      CustomLOBSetByParent: false,\n    };\n  }\n\n  //* get the Mail count\n  // getMailCount() {\n  //   this.httpCommonService\n  //     .getUnreadUserEmailsCount()\n  //     .pipe(takeUntil(this.unsubscribeAPIEventListenerData))\n  //     .subscribe((result) => {\n  //       this.totalEmails = result;\n  //     });\n  // }\n\n  //Action: Used to Get Total Eventwise User Notification Count */\n  getEventwiseNotificationCount() {\n    let payload = {\n      ApplicationName: GlobalConstants.applicationName,\n      UserId: String(this.userId),\n    };\n    this.notificationLoadder = true;\n\n    this.httpCommonService\n      .getWorkFlowTicketEventwiseCount(payload)\n      .pipe(\n        takeUntil(this.unsubscribeAPIEventListenerData),\n        finalize(() => (this.notificationLoadder = false)),\n      )\n      .subscribe({\n        next: (data) => {\n          this.isErrorFound = data.length == 0;\n          this.eventwiseNotificationCount = data;\n        },\n        error: () => {\n          this.isErrorFound = true;\n        },\n      });\n  }\n\n  //* Get Module privilege list\n  getUserAssignedApp() {\n    this.ListOfUserPrivillegedApp = [];\n\n    this.userAppLoaderLoadder = true;\n    this.httpCommonService\n      .getUserAssignedApps()\n      .pipe(takeUntil(this.unsubscribeAPIEventListenerData))\n      .subscribe((result) => {\n        this.userAppLoaderLoadder = false;\n        this.ListOfUserPrivillegedApp = result;\n      });\n  }\n\n  //* Get User details\n  getLoggedInuserDetails() {\n    this.httpCommonService.getLoggedInUserDetails().subscribe((result) => {\n      this.userDetailsInfo = result.result;\n      this.userdisplayName = this.userDetailsInfo['userDisplayName'];\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.unsubscribeAPIEventListenerData.next(true);\n    this.unsubscribeAPIEventListenerData.complete();\n\n    this.unsubscribeSidebarListenerData.next(true);\n    this.unsubscribeSidebarListenerData.complete();\n  }\n}\n","<header class=\"app-header ext\">\r\n  <div class=\"d-flex justify-content-between align-items-center\">\r\n    <div class=\"d-flex\">\r\n      <div class=\"logo gap-4\">\r\n        <img\r\n          *ngIf=\"EnableLogo && headerLogo\"\r\n          class=\"logo-size\"\r\n          title=\"Logo\"\r\n          alt=\"Logo\"\r\n          [src]=\"headerLogo\"\r\n          loading=\"lazy\"\r\n        />\r\n        <p-skeleton\r\n          *ngIf=\"!headerLogo\"\r\n          height=\"1.5rem\"\r\n          width=\"5rem\"\r\n        ></p-skeleton>\r\n      </div>\r\n    </div>\r\n    <div class=\"projName\">\r\n      <h1 class=\"modname\">{{ moduleName }}</h1>\r\n    </div>\r\n\r\n    <div class=\"d-flex justify-content-end align-items-center\">\r\n      <!--timezone-->\r\n      <ng-container *ngIf=\"EnableTimeZone && userTimeZoneAbbreviations\">\r\n        <div class=\"timezone\">\r\n          <img\r\n            src=\"../assets/common-header-lib/images/schedule.svg\"\r\n            class=\"mb-1\"\r\n            alt=\"Icon\"\r\n          />\r\n          <span class=\"timezone-text\"\r\n            >{{ \"Generic_lib.PreferredTimezone\" | translate }} :\r\n          </span>\r\n          <span\r\n            *ngIf=\"userTimeZoneAbbreviations\"\r\n            class=\"user-tz\"\r\n            [title]=\"userTimeZoneFullForm\"\r\n            >{{ userTimeZoneAbbreviations }}</span\r\n          >\r\n        </div>\r\n      </ng-container>\r\n\r\n      <!--lob-->\r\n      <ng-container\r\n        *ngIf=\"EnableLOB && !showLobLoader; else LobLodderAnimation\"\r\n      >\r\n        <div class=\"main-left d-flex\">\r\n          <img\r\n            src=\"../assets/common-header-lib/images/marker-pin.svg\"\r\n            alt=\"pen Icon\"\r\n          />\r\n          <p-dropdown\r\n            filterPlaceholder=\"{{ 'Generic_lib.Search' | translate }}\"\r\n            [options]=\"userLOBList\"\r\n            (onChange)=\"onLobChangeEvent($event)\"\r\n            optionLabel=\"lobName\"\r\n            optionValue=\"lobId\"\r\n            [(ngModel)]=\"selectedLOBId\"\r\n            [filter]=\"true\"\r\n            filterBy=\"lobName\"\r\n            [showClear]=\"false\"\r\n            [style]=\"{ width: '150px', height: '30px' }\"\r\n            [resetFilterOnHide]=\"true\"\r\n            [virtualScroll]=\"true\"\r\n            [lazy]=\"false\"\r\n            name=\"lob\"\r\n            [itemSize]=\"30\"\r\n            class=\"loblist-drpdwn\"\r\n            panelStyleClass=\"loblist-drpdwn-panel\"\r\n          >\r\n            <ng-template let-loblist pTemplate=\"item\">\r\n              <div class=\"flex align-items-center gap-2\">\r\n                <div title=\"{{ loblist.lobName }}\" class=\"header-drpdwn\">\r\n                  {{ loblist.lobName }}\r\n                </div>\r\n              </div>\r\n            </ng-template>\r\n          </p-dropdown>\r\n        </div>\r\n      </ng-container>\r\n      <ng-template #LobLodderAnimation>\r\n        <p-skeleton height=\"1.5rem\" width=\"10rem\"></p-skeleton>\r\n      </ng-template>\r\n\r\n      <!--mailbox-->\r\n      <ng-container *ngIf=\"isHeaderContentLoaded; else HeaderLoading\">\r\n        <div *ngIf=\"EnableMail\" class=\"header-left-icon\">\r\n          <img\r\n            src=\"../assets/common-header-lib/images/mail-icon.svg\"\r\n            alt=\"mail Icon\"\r\n            class=\"headeright-icon\"\r\n            (click)=\"showMailBoxScreen()\"\r\n          />\r\n        </div>\r\n        <ng-container *ngIf=\"EnableMail && totalEmails.length > 0\">\r\n          <!-- <ng-container> -->\r\n          <div class=\"badge-notify\">\r\n            <div pBadge [value]=\"totalEmails\"></div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!--notification-->\r\n        <div class=\"header-left-icon\" *ngIf=\"EnableNotifications\">\r\n          <img\r\n            src=\"../assets/common-header-lib/images/bell-icon.svg\"\r\n            alt=\"mail Icon\"\r\n            class=\"headeright-icon\"\r\n            (click)=\"OpenNotificationModal()\"\r\n          />\r\n        </div>\r\n\r\n        <ng-container\r\n          *ngIf=\"EnableNotifications && userNotificationCount.length > 0\"\r\n        >\r\n          <div class=\"badge-notify\">\r\n            <div pBadge [value]=\"userNotificationCount\"></div>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <!--9 Dots -->\r\n        <div\r\n          *ngIf=\"EnableMoreApps\"\r\n          class=\"header-left-icon\"\r\n          title=\"Control Center\"\r\n          alt=\"bell Icon\"\r\n          (click)=\"showUserAppsPanel($event)\"\r\n        >\r\n          <img\r\n            src=\"../assets/common-header-lib/images/apps-1.svg\"\r\n            class=\"apps-icon\"\r\n          />\r\n        </div>\r\n\r\n        <!--user display name -->\r\n        <div\r\n          *ngIf=\"EnableProfile\"\r\n          class=\"main-right\"\r\n          (click)=\"showUserDetailsPanel()\"\r\n        >\r\n          <ng-container>\r\n            <div class=\"initial-text mx-1\">\r\n              {{ userdisplayName | sliceToTwo }}\r\n            </div>\r\n          </ng-container>\r\n        </div>\r\n      </ng-container>\r\n\r\n      <ng-template #HeaderLoading>\r\n        <p-skeleton shape=\"circle\" size=\"1.3rem\" styleClass=\"mx-2\"></p-skeleton>\r\n        <p-skeleton shape=\"circle\" size=\"1.3rem\" styleClass=\"mx-2\"></p-skeleton>\r\n        <p-skeleton size=\"1.5rem\" styleClass=\"mx-2\"></p-skeleton>\r\n        <p-skeleton shape=\"circle\" size=\"2rem\" styleClass=\"mx-2\"></p-skeleton>\r\n      </ng-template>\r\n    </div>\r\n  </div>\r\n</header>\r\n\r\n<!--List of Application : 9 dots -->\r\n<p-overlayPanel #App class=\"pt-0\" styleClass=\"app-panel\">\r\n  <ng-container *ngIf=\"!userAppLoaderLoadder; else LoadingTemplate\">\r\n    <div class=\"custom-popover-content\">\r\n      <div class=\"waffle-align\">\r\n        <div\r\n          class=\"waffle-popup\"\r\n          [title]=\"appDetails['applicationName']\"\r\n          *ngFor=\"let appDetails of ListOfUserPrivillegedApp\"\r\n          (click)=\"getConnectionofApplication(appDetails['appCode'])\"\r\n        >\r\n          <img\r\n            *ngIf=\"appDetails?.appCode\"\r\n            src=\"../assets/common-header-lib/images/{{\r\n              appDetails.appCode\r\n            }}.svg\"\r\n            alt=\"App icon\"\r\n          />\r\n\r\n          <div class=\"waffle-text\">{{ appDetails[\"applicationName\"] }}</div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n  <ng-template #LoadingTemplate>\r\n    <div class=\"custom-popover-content skeleton-popover\">\r\n      <ng-container *ngFor=\"let item of repeatLoader\">\r\n        <div\r\n          class=\"d-flex flex-column align-items-center justify-content-center gap-2\"\r\n        >\r\n          <p-skeleton size=\"3rem\"></p-skeleton>\r\n          <p-skeleton height=\".3rem\" width=\"35px\"></p-skeleton>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </ng-template>\r\n</p-overlayPanel>\r\n\r\n<!--mailbox details-->\r\n<ng-container *ngIf=\"showMailboxScreenflag\">\r\n  <div class=\"changingContent\">\r\n    <app-user-mailbox\r\n      (closeMailDialogBox)=\"hideMailBoxScreen()\"\r\n    ></app-user-mailbox>\r\n  </div>\r\n</ng-container>\r\n\r\n<!-- Userdetails profile pop up -->\r\n<div class=\"profile-sidebar\">\r\n  <app-side-popup\r\n    *ngIf=\"isOpenSidePopup\"\r\n    [visible]=\"true\"\r\n    [position]=\"'right'\"\r\n    (closeDialogBox)=\"closeSidePopup()\"\r\n  >\r\n    <app-user-sidebar\r\n      *ngIf=\"showUserDetails\"\r\n      (closeDialogBox)=\"closeSidePopup()\"\r\n    ></app-user-sidebar>\r\n  </app-side-popup>\r\n</div>\r\n\r\n<!-- Notification side popup  -->\r\n<div\r\n  class=\"modal fade common-alert-modal\"\r\n  #notifyModal\r\n  id=\"Notify_SidebarModal\"\r\n  tabindex=\"-1\"\r\n  aria-hidden=\"true\"\r\n>\r\n  <div class=\"modal-dialog sidebar-outer white-bg\">\r\n    <div class=\"modal-content\">\r\n      <div class=\"sidebar-container white-bg\">\r\n        <!-- keep everything inside this content -->\r\n\r\n        <!-- Sidebar Header -->\r\n        <div class=\"sidebar-header grey-background\">\r\n          <div class=\"sh-top\">\r\n            <div class=\"sh-top-left d-flex align-items-center\">\r\n              <div class=\"mx-2 log-text\">\r\n                {{ \"Generic_lib.Notification\" | translate }}\r\n              </div>\r\n            </div>\r\n            <div class=\"sh-top-right\">\r\n              <button\r\n                type=\"button\"\r\n                class=\"common-bn tertiary-btn\"\r\n                aria-label=\"Close\"\r\n                (click)=\"closeModal()\"\r\n              >\r\n                <img\r\n                  src=\"assets/common-header-lib/images/close.svg\"\r\n                  alt=\"Close\"\r\n                  class=\"imgs mb-1\"\r\n                />\r\n              </button>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Sidebar Body -->\r\n        <div class=\"sidebar-body\">\r\n          <div class=\"d-flex justify-content-between align-items-center mb-2\">\r\n            <div class=\"noti-text\">\r\n              {{\r\n                \"Generic_lib.YouHaveNNotifications\"\r\n                  | translate: { count: userNotificationCount }\r\n              }}\r\n            </div>\r\n            <div\r\n              class=\"d-flex align-items-center gap-1 refresh-icon\"\r\n              (click)=\"getEventwiseNotification()\"\r\n            >\r\n              <img\r\n                src=\"assets/common-header-lib/images/refresh-1.svg\"\r\n                alt=\"Refresh\"\r\n              />\r\n              <div class=\"refresh-text\">\r\n                {{ \"Generic_lib.Refresh\" | translate }}\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"mt-3\">\r\n            <ng-container\r\n              *ngIf=\"\r\n                !isErrorFound && !notificationLoadder;\r\n                else Noti_LoadingTemplate\r\n              \"\r\n            >\r\n              <div\r\n                class=\"notify-border\"\r\n                *ngFor=\"let event of eventwiseNotificationCount\"\r\n              >\r\n                <div class=\"d-flex align-items-center gap-3\">\r\n                  <div class=\"initial-text initial-text-1 mx-1\">\r\n                    <img\r\n                      src=\"assets/common-header-lib/images/noti_ticket.svg\"\r\n                      alt=\"Icon\"\r\n                    />\r\n                  </div>\r\n                  <div>\r\n                    <div>\r\n                      <span class=\"service-count\"\r\n                        >{{ event[\"PendingCount\"] }} New </span\r\n                      ><span class=\"service-request\"\r\n                        >{{ event[\"EventName\"] }} Event requests</span\r\n                      >\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n                <div class=\"grey-borders mt-2\"></div>\r\n              </div>\r\n            </ng-container>\r\n            <ng-template #Noti_LoadingTemplate>\r\n              <ng-container *ngIf=\"notificationLoadder; else errorTemplate\">\r\n                <ng-container *ngFor=\"let item of repeatLoader1\">\r\n                  <div class=\"d-flex align-items-center gap-3\">\r\n                    <p-skeleton\r\n                      shape=\"circle\"\r\n                      size=\"60px\"\r\n                      styleClass=\"my-2\"\r\n                    ></p-skeleton>\r\n                    <div class=\"ms-1\">\r\n                      <p-skeleton width=\"200%\" styleClass=\"mb-2\"></p-skeleton>\r\n                      <p-skeleton width=\"150px\" height=\"1rem\"></p-skeleton>\r\n                    </div>\r\n                  </div>\r\n                </ng-container>\r\n              </ng-container>\r\n            </ng-template>\r\n\r\n            <ng-template #errorTemplate>\r\n              <app-no-service-my-access-pg\r\n                heading=\"{{ 'Generic_lib.CommonError' | translate }}\"\r\n              ></app-no-service-my-access-pg>\r\n            </ng-template>\r\n          </div>\r\n          <!-- Notification content & loaders remain here -->\r\n        </div>\r\n      </div>\r\n      <!-- end of sidebar-container -->\r\n    </div>\r\n    <!-- end of modal-content -->\r\n  </div>\r\n  <!-- end of modal-dialog -->\r\n</div>\r\n\r\n<!-- Common Conirmation Modal  -->\r\n<confirm-dialog\r\n  class=\"rm-invalid-border\"\r\n  #confirmDialog\r\n  header=\"{{ 'Generic_lib.ChangeLOB' | translate }}\"\r\n  message=\"{{ 'Generic_lib.DoYouWantToChangeTheCurrentLOB' | translate }}\"\r\n  (result)=\"lobChangeConfirmation($event)\"\r\n></confirm-dialog>\r\n\r\n<!--* Need to use component based notification UI as below -->\r\n<!-- Notification-Sidebar Started -->\r\n<!-- <app-notification-sidebar [isErrorOccured]=\"isErrorFound\" [userNotificationCount]=\"userNotificationCount\"\r\n  [userNotificationCountObj]=\"userNotificationCountObj\" [eventwiseNotificationCount]=\"eventwiseNotificationCount\"\r\n  (refreshNotification)=\"getEventwiseNotificationCount()\"\r\n  [notificationLoadder]=\"notificationLoadder\"></app-notification-sidebar> -->\r\n<!-- Notification-Sidebar Ended -->\r\n"]}
|