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,133 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { CookieService } from 'ngx-cookie-service';
|
|
3
|
+
import { BehaviorSubject, Subject } from 'rxjs';
|
|
4
|
+
import { COOKIECONSTANT } from '../model/data_model';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "ngx-cookie-service";
|
|
7
|
+
export class EventService {
|
|
8
|
+
constructor(_cookie) {
|
|
9
|
+
this._cookie = _cookie;
|
|
10
|
+
this.getUserLOB = new BehaviorSubject({});
|
|
11
|
+
this.getAssetType = new BehaviorSubject({});
|
|
12
|
+
this.refreshSidebar = new BehaviorSubject({});
|
|
13
|
+
this.filterRecords = new Subject();
|
|
14
|
+
this.AuthMethods = new BehaviorSubject([]);
|
|
15
|
+
this.refreshEmails = new BehaviorSubject({});
|
|
16
|
+
this.timeZone = new BehaviorSubject({});
|
|
17
|
+
}
|
|
18
|
+
emitLOBEvent(data) {
|
|
19
|
+
this.getUserLOB.next(data);
|
|
20
|
+
}
|
|
21
|
+
listenerLOBEvent() {
|
|
22
|
+
return this.getUserLOB.asObservable();
|
|
23
|
+
}
|
|
24
|
+
emitAssetTypeEvent(data) {
|
|
25
|
+
this.getAssetType.next(data);
|
|
26
|
+
}
|
|
27
|
+
listenerAssetTypeEvent() {
|
|
28
|
+
return this.getAssetType.asObservable();
|
|
29
|
+
}
|
|
30
|
+
emitrefreshSidebar(data) {
|
|
31
|
+
this.refreshSidebar.next(data);
|
|
32
|
+
}
|
|
33
|
+
listenerrefreshSidebar() {
|
|
34
|
+
return this.refreshSidebar.asObservable();
|
|
35
|
+
}
|
|
36
|
+
emitFilterRecords(data) {
|
|
37
|
+
this.filterRecords.next(data);
|
|
38
|
+
}
|
|
39
|
+
listenerFilterEvent() {
|
|
40
|
+
return this.filterRecords.asObservable();
|
|
41
|
+
}
|
|
42
|
+
emitAuthMethod(data) {
|
|
43
|
+
this.AuthMethods.next(data);
|
|
44
|
+
}
|
|
45
|
+
listenerAuthMethod() {
|
|
46
|
+
return this.AuthMethods.asObservable();
|
|
47
|
+
}
|
|
48
|
+
emitUserEmail(data) {
|
|
49
|
+
this.refreshEmails.next(data);
|
|
50
|
+
}
|
|
51
|
+
listenerUserEmail() {
|
|
52
|
+
return this.refreshEmails.asObservable();
|
|
53
|
+
}
|
|
54
|
+
emitTimezone(data) {
|
|
55
|
+
this.timeZone.next(data);
|
|
56
|
+
}
|
|
57
|
+
listenerTimezone() {
|
|
58
|
+
return this.timeZone.asObservable();
|
|
59
|
+
}
|
|
60
|
+
// checkMFAv1(mfaUrl: string) {
|
|
61
|
+
// return new Promise((resolve, reject) => {
|
|
62
|
+
// const params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,
|
|
63
|
+
// width=600,height=500,left=350,top=150`;
|
|
64
|
+
// const mfaWindow = open(mfaUrl, 'CI Authentication', params);
|
|
65
|
+
// //setInterval to check cookie every second
|
|
66
|
+
// const interval = setInterval(() => {
|
|
67
|
+
// if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECK)) {
|
|
68
|
+
// clearInterval(interval);
|
|
69
|
+
// // clearTimeout(timeout);
|
|
70
|
+
// mfaWindow.close();
|
|
71
|
+
// resolve(true);
|
|
72
|
+
// }
|
|
73
|
+
// else if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECKFAIL)) {
|
|
74
|
+
// clearInterval(interval);
|
|
75
|
+
// mfaWindow.close();
|
|
76
|
+
// reject(false);
|
|
77
|
+
// }
|
|
78
|
+
// }, 1000);
|
|
79
|
+
// //when use close window manually
|
|
80
|
+
// let flag = false;
|
|
81
|
+
// mfaWindow.onunload = () => {
|
|
82
|
+
// if (flag) {
|
|
83
|
+
// console.log("window closed manually");
|
|
84
|
+
// clearInterval(interval);
|
|
85
|
+
// // clearTimeout(timeout);
|
|
86
|
+
// reject(false);
|
|
87
|
+
// }
|
|
88
|
+
// flag = true;
|
|
89
|
+
// }
|
|
90
|
+
// })
|
|
91
|
+
// }
|
|
92
|
+
checkMFA(mfaUrl) {
|
|
93
|
+
return new Promise((resolve, reject) => {
|
|
94
|
+
const params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,
|
|
95
|
+
width=600,height=500,left=350,top=150`;
|
|
96
|
+
const mfaWindow = window.open(mfaUrl, 'CI Authentication', params);
|
|
97
|
+
if (!mfaWindow) {
|
|
98
|
+
reject(new Error("Failed to open MFA window. Popup blocked?"));
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
// Polling interval to check cookie every second
|
|
102
|
+
const interval = setInterval(() => {
|
|
103
|
+
if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECK)) {
|
|
104
|
+
clearInterval(interval);
|
|
105
|
+
mfaWindow.close();
|
|
106
|
+
resolve(true);
|
|
107
|
+
}
|
|
108
|
+
else if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECKFAIL)) {
|
|
109
|
+
clearInterval(interval);
|
|
110
|
+
mfaWindow.close();
|
|
111
|
+
reject(false);
|
|
112
|
+
}
|
|
113
|
+
}, 1000);
|
|
114
|
+
// Detect manual close of popup window
|
|
115
|
+
const checkPopupClosed = setInterval(() => {
|
|
116
|
+
if (mfaWindow.closed) {
|
|
117
|
+
clearInterval(interval);
|
|
118
|
+
clearInterval(checkPopupClosed);
|
|
119
|
+
reject(false);
|
|
120
|
+
}
|
|
121
|
+
}, 500);
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
EventService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EventService, deps: [{ token: i1.CookieService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
126
|
+
EventService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EventService, providedIn: 'root' });
|
|
127
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EventService, decorators: [{
|
|
128
|
+
type: Injectable,
|
|
129
|
+
args: [{
|
|
130
|
+
providedIn: 'root',
|
|
131
|
+
}]
|
|
132
|
+
}], ctorParameters: function () { return [{ type: i1.CookieService }]; } });
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event.service.js","sourceRoot":"","sources":["../../../../../projects/common-header-lib/src/lib/services/event.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { CookieService } from 'ngx-cookie-service';\r\nimport { BehaviorSubject, Subject } from 'rxjs';\r\nimport { COOKIECONSTANT } from '../model/data_model';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class EventService {\r\n  private getUserLOB = new BehaviorSubject<any>({});\r\n  private getAssetType = new BehaviorSubject<any>({});\r\n  private refreshSidebar = new BehaviorSubject<any>({});\r\n  private filterRecords = new Subject<any>();\r\n  private AuthMethods = new BehaviorSubject<any>([]);\r\n  private refreshEmails = new BehaviorSubject<any>({});\r\n  private timeZone = new BehaviorSubject<any>({});\r\n\r\n  constructor(private _cookie : CookieService) { }\r\n\r\n  emitLOBEvent(data: any) {\r\n    this.getUserLOB.next(data);\r\n  }\r\n\r\n  listenerLOBEvent() {\r\n    return this.getUserLOB.asObservable();\r\n  }\r\n\r\n  emitAssetTypeEvent(data: any) {\r\n    this.getAssetType.next(data);\r\n  }\r\n\r\n  listenerAssetTypeEvent() {\r\n    return this.getAssetType.asObservable();\r\n  }\r\n\r\n  emitrefreshSidebar(data: any) {\r\n    this.refreshSidebar.next(data);\r\n  }\r\n\r\n  listenerrefreshSidebar() {\r\n    return this.refreshSidebar.asObservable();\r\n  }\r\n\r\n  emitFilterRecords(data: any) {\r\n    this.filterRecords.next(data);\r\n  }\r\n\r\n  listenerFilterEvent() {\r\n    return this.filterRecords.asObservable();\r\n  }\r\n\r\n  emitAuthMethod(data: any) {\r\n    this.AuthMethods.next(data);\r\n  }\r\n\r\n  listenerAuthMethod() {\r\n    return this.AuthMethods.asObservable();\r\n  }\r\n\r\n  emitUserEmail(data: any) {\r\n    this.refreshEmails.next(data);\r\n  }\r\n\r\n  listenerUserEmail() {\r\n    return this.refreshEmails.asObservable();\r\n  }\r\n\r\n  emitTimezone(data: any) {\r\n    this.timeZone.next(data);\r\n  }\r\n\r\n  listenerTimezone() {\r\n    return this.timeZone.asObservable();\r\n  }\r\n\r\n  // checkMFAv1(mfaUrl: string) {\r\n  //   return new Promise((resolve, reject) => {\r\n  //     const params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,\r\n  //     width=600,height=500,left=350,top=150`;\r\n  //     const mfaWindow = open(mfaUrl, 'CI Authentication', params);\r\n      \r\n\r\n  //     //setInterval to check cookie every second\r\n  //     const interval = setInterval(() => {\r\n  //       if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECK)) {\r\n  //         clearInterval(interval);\r\n  //         // clearTimeout(timeout);\r\n  //         mfaWindow.close();\r\n  //         resolve(true);\r\n  //       }\r\n  //       else if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECKFAIL)) {\r\n  //         clearInterval(interval);\r\n  //         mfaWindow.close();\r\n  //         reject(false);\r\n  //       }\r\n  //     }, 1000);\r\n\r\n  //     //when use close window manually\r\n  //     let flag = false;\r\n  //     mfaWindow.onunload = () => {\r\n  //       if (flag) {\r\n  //         console.log(\"window closed manually\");\r\n  //         clearInterval(interval);\r\n  //         // clearTimeout(timeout);\r\n  //         reject(false);\r\n  //       }\r\n  //       flag = true;\r\n  //     }\r\n  //   })\r\n  // }\r\n  checkMFA(mfaUrl: string) {\r\n  return new Promise<boolean>((resolve, reject) => {\r\n    const params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,\r\n      width=600,height=500,left=350,top=150`;\r\n\r\n    const mfaWindow = window.open(mfaUrl, 'CI Authentication', params);\r\n\r\n    if (!mfaWindow) {\r\n      reject(new Error(\"Failed to open MFA window. Popup blocked?\"));\r\n      return;\r\n    }\r\n\r\n    // Polling interval to check cookie every second\r\n    const interval = setInterval(() => {\r\n      if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECK)) {\r\n        clearInterval(interval);\r\n        mfaWindow.close();\r\n        resolve(true);\r\n      } else if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECKFAIL)) {\r\n        clearInterval(interval);\r\n        mfaWindow.close();\r\n        reject(false);\r\n      }\r\n    }, 1000);\r\n\r\n    // Detect manual close of popup window\r\n    const checkPopupClosed = setInterval(() => {\r\n      if (mfaWindow.closed) {\r\n        clearInterval(interval);\r\n        clearInterval(checkPopupClosed);\r\n        reject(false);\r\n      }\r\n    }, 500);\r\n  });\r\n}\r\n\r\n}\r\n"]}
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
import { HttpClient, HttpParams } from '@angular/common/http';
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { catchError, map, throwError } from 'rxjs';
|
|
4
|
+
import { GlobalConstants } from '../../model/data_model';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common/http";
|
|
7
|
+
export class HttpCommonService {
|
|
8
|
+
constructor(http) {
|
|
9
|
+
this.http = http;
|
|
10
|
+
this.xAccessAPIUrl = '/xaccess/api/SecureAccess/';
|
|
11
|
+
this.metaAPIUrl = '/meta/api/metadata/';
|
|
12
|
+
this.metaAPIUrl1 = '/meta/api/Metadata/';
|
|
13
|
+
this.xServiceAPIUrl = '/xservice/api/CIInfraAsset/';
|
|
14
|
+
this.workflowAPIUrl = '/workflow/api/Workflow/Workflow/';
|
|
15
|
+
}
|
|
16
|
+
getLogo() {
|
|
17
|
+
return this.http
|
|
18
|
+
.get(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}BackgroundLogo`)
|
|
19
|
+
.pipe(map((response) => {
|
|
20
|
+
return response['result'];
|
|
21
|
+
}));
|
|
22
|
+
}
|
|
23
|
+
getGlobalTimeZone() {
|
|
24
|
+
return this.http
|
|
25
|
+
.get(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetSystemTimeZones`)
|
|
26
|
+
.pipe(map((response) => {
|
|
27
|
+
if (response && response['success']) {
|
|
28
|
+
return response['result'];
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
return [];
|
|
32
|
+
}
|
|
33
|
+
}));
|
|
34
|
+
}
|
|
35
|
+
updateUserTimeZone(tz) {
|
|
36
|
+
const params = new HttpParams().set('timezone', tz);
|
|
37
|
+
return this.http
|
|
38
|
+
.post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}UpdateTimeZone`, {}, { params: params })
|
|
39
|
+
.pipe(map((response) => {
|
|
40
|
+
if (response && response['success']) {
|
|
41
|
+
return response['result'];
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
return '';
|
|
45
|
+
}
|
|
46
|
+
}));
|
|
47
|
+
}
|
|
48
|
+
getLOBList() {
|
|
49
|
+
return this.http
|
|
50
|
+
.get(`${GlobalConstants.baseURL}${this.metaAPIUrl}Lobs`)
|
|
51
|
+
.pipe(map((response) => {
|
|
52
|
+
return response;
|
|
53
|
+
}));
|
|
54
|
+
}
|
|
55
|
+
getUnreadUserEmailsCount() {
|
|
56
|
+
return this.http
|
|
57
|
+
.get(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}MailBoxCount`)
|
|
58
|
+
.pipe(map((response) => {
|
|
59
|
+
if (response && response['success'] && response['result'] > 0) {
|
|
60
|
+
return response['result'];
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
return 0;
|
|
64
|
+
}
|
|
65
|
+
}));
|
|
66
|
+
}
|
|
67
|
+
getUserAssignedMails(userDetails) {
|
|
68
|
+
return this.http
|
|
69
|
+
.post(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}MailBox`, userDetails)
|
|
70
|
+
.pipe(map((response) => {
|
|
71
|
+
if (response && response['success']) {
|
|
72
|
+
return response['result'];
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
return [];
|
|
76
|
+
}
|
|
77
|
+
}));
|
|
78
|
+
}
|
|
79
|
+
/*Method : GET
|
|
80
|
+
Action : Get Application Password */
|
|
81
|
+
getAccessToViewServicePassword(mailDetails) {
|
|
82
|
+
return this.http
|
|
83
|
+
.post(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}OpenServicePwd`, mailDetails)
|
|
84
|
+
.pipe(map((response) => {
|
|
85
|
+
if (response && response['success']) {
|
|
86
|
+
response['result'][1] = response['message'];
|
|
87
|
+
return response['result'];
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
return [];
|
|
91
|
+
}
|
|
92
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
93
|
+
}
|
|
94
|
+
getUserAssignedApps() {
|
|
95
|
+
return this.http
|
|
96
|
+
.post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetUserPriviledgesList`, {})
|
|
97
|
+
.pipe(map((response) => {
|
|
98
|
+
if (response && response['success']) {
|
|
99
|
+
return response['result'].filter((x) => x.appCode != null);
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
return [];
|
|
103
|
+
}
|
|
104
|
+
}));
|
|
105
|
+
}
|
|
106
|
+
getLoggedInUserDetails() {
|
|
107
|
+
return this.http
|
|
108
|
+
.post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetUsersDetailsById`, {})
|
|
109
|
+
.pipe(map((response) => {
|
|
110
|
+
return response;
|
|
111
|
+
}));
|
|
112
|
+
}
|
|
113
|
+
//Method: Used to Total Notification count of user
|
|
114
|
+
//Action: It used get all notification count
|
|
115
|
+
getWorkFlowTicketCount(userDetails) {
|
|
116
|
+
return this.http
|
|
117
|
+
.post(`${GlobalConstants.baseURL}${this.workflowAPIUrl}GetWorkFlowTicketCount`, userDetails)
|
|
118
|
+
.pipe(map((response) => {
|
|
119
|
+
if (response && response[0]['Success']) {
|
|
120
|
+
if (response[0]['Data'][0]) {
|
|
121
|
+
return response[0]['Data'][0];
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
return {};
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
return {};
|
|
129
|
+
}
|
|
130
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
131
|
+
}
|
|
132
|
+
getWorkFlowTicketEventwiseCount(userDetails) {
|
|
133
|
+
return this.http
|
|
134
|
+
.post(`${GlobalConstants.baseURL}${this.workflowAPIUrl}GetWorkFlowTicketCountEventWise`, userDetails)
|
|
135
|
+
.pipe(map((response) => {
|
|
136
|
+
if (response && response[0]['Success']) {
|
|
137
|
+
// return response[0]['Data'];
|
|
138
|
+
return [];
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
return [];
|
|
142
|
+
}
|
|
143
|
+
}));
|
|
144
|
+
}
|
|
145
|
+
setLandingPgPreference(moduleId) {
|
|
146
|
+
return this.http
|
|
147
|
+
.post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}SetLandingPage`, {
|
|
148
|
+
moduleId: moduleId,
|
|
149
|
+
})
|
|
150
|
+
.pipe(map((response) => {
|
|
151
|
+
if (response && response['success']) {
|
|
152
|
+
return response['result'];
|
|
153
|
+
}
|
|
154
|
+
else {
|
|
155
|
+
return '';
|
|
156
|
+
}
|
|
157
|
+
}));
|
|
158
|
+
}
|
|
159
|
+
/*Method : POST
|
|
160
|
+
Action :Will validate User entered PWD as
|
|
161
|
+
per Password Policy Set
|
|
162
|
+
*/
|
|
163
|
+
validatePassword(userDetails) {
|
|
164
|
+
return this.http
|
|
165
|
+
.post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}ValidatePassword`, userDetails)
|
|
166
|
+
.pipe(catchError((e) => throwError(this.errorHandler(e))));
|
|
167
|
+
}
|
|
168
|
+
/*Method : POST
|
|
169
|
+
Action : RESET Password for First Time User
|
|
170
|
+
*/
|
|
171
|
+
setNewpassword(loggedInUserDetails) {
|
|
172
|
+
return this.http
|
|
173
|
+
.post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}ChangeUserArcXwdManually`, loggedInUserDetails)
|
|
174
|
+
.pipe(catchError((e) => throwError(this.errorHandler(e))));
|
|
175
|
+
}
|
|
176
|
+
errorHandler(e) {
|
|
177
|
+
throw new Error('Method not implemented.');
|
|
178
|
+
}
|
|
179
|
+
/*Method : GET
|
|
180
|
+
Action : Get hiding the password for a service. */
|
|
181
|
+
getProtectedServiceCredentials(mailDetails) {
|
|
182
|
+
return this.http
|
|
183
|
+
.post(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}GetServicePasswordClose`, mailDetails)
|
|
184
|
+
.pipe(map((response) => {
|
|
185
|
+
if (response && response['success']) {
|
|
186
|
+
return response['result'];
|
|
187
|
+
}
|
|
188
|
+
else {
|
|
189
|
+
return false;
|
|
190
|
+
}
|
|
191
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
192
|
+
}
|
|
193
|
+
/*Method : POST
|
|
194
|
+
Parameter : subID , id
|
|
195
|
+
Action : Get configuration ID based on to show hide DOMAIN dropdown
|
|
196
|
+
*/
|
|
197
|
+
getglobalConfigDetails(subid, id) {
|
|
198
|
+
return this.http
|
|
199
|
+
.post(`${GlobalConstants.baseURL}${this.metaAPIUrl1}GetArcosConfigsValues?subId=${subid}`, id)
|
|
200
|
+
.pipe(map((response) => {
|
|
201
|
+
if (response['statusCode'] === 200) {
|
|
202
|
+
let result = response['result'];
|
|
203
|
+
return result;
|
|
204
|
+
}
|
|
205
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
HttpCommonService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpCommonService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
209
|
+
HttpCommonService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpCommonService, providedIn: 'root' });
|
|
210
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpCommonService, decorators: [{
|
|
211
|
+
type: Injectable,
|
|
212
|
+
args: [{
|
|
213
|
+
providedIn: 'root',
|
|
214
|
+
}]
|
|
215
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-common.service.js","sourceRoot":"","sources":["../../../../../../projects/common-header-lib/src/lib/services/http/http-common.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpParams } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { catchError, map, throwError } from 'rxjs';\nimport { GlobalConstants } from '../../model/data_model';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class HttpCommonService {\n  private xAccessAPIUrl: string = '/xaccess/api/SecureAccess/';\n  private metaAPIUrl: string = '/meta/api/metadata/';\n  private metaAPIUrl1: string = '/meta/api/Metadata/';\n  private xServiceAPIUrl: string = '/xservice/api/CIInfraAsset/';\n  private workflowAPIUrl: string = '/workflow/api/Workflow/Workflow/';\n\n  constructor(private http: HttpClient) {}\n\n  getLogo() {\n    return this.http\n      .get<any>(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}BackgroundLogo`)\n      .pipe(\n        map((response) => {\n          return response['result'];\n        }),\n      );\n  }\n\n  getGlobalTimeZone() {\n    return this.http\n      .get(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetSystemTimeZones`)\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return [];\n          }\n        }),\n      );\n  }\n\n  updateUserTimeZone(tz: string) {\n    const params = new HttpParams().set('timezone', tz);\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}UpdateTimeZone`,\n        {},\n        { params: params },\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return '';\n          }\n        }),\n      );\n  }\n\n  getLOBList() {\n    return this.http\n      .get(`${GlobalConstants.baseURL}${this.metaAPIUrl}Lobs`)\n      .pipe(\n        map((response: any) => {\n          return response;\n        }),\n      );\n  }\n\n  getUnreadUserEmailsCount() {\n    return this.http\n      .get<any>(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}MailBoxCount`)\n      .pipe(\n        map((response: any) => {\n          if (response && response['success'] && response['result'] > 0) {\n            return response['result'];\n          } else {\n            return 0;\n          }\n        }),\n      );\n  }\n\n  getUserAssignedMails(userDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xServiceAPIUrl}MailBox`,\n        userDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return [];\n          }\n        }),\n      );\n  }\n\n  /*Method : GET\n   Action : Get Application Password  */\n  getAccessToViewServicePassword(mailDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xServiceAPIUrl}OpenServicePwd`,\n        mailDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            response['result'][1] = response['message'];\n            return response['result'];\n          } else {\n            return [];\n          }\n        }),\n        catchError((e) => throwError(this.errorHandler(e))),\n      );\n  }\n\n  getUserAssignedApps() {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetUserPriviledgesList`,\n        {},\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'].filter(\n              (x: any) => x.appCode != null,\n              // (x) => x.appCode !== 'APP026' && x.appCode != null\n            );\n          } else {\n            return [];\n          }\n        }),\n      );\n  }\n\n  getLoggedInUserDetails() {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetUsersDetailsById`,\n        {},\n      )\n      .pipe(\n        map((response: any) => {\n          return response;\n        }),\n      );\n  }\n\n  //Method: Used to Total Notification count of user\n  //Action: It used get all notification count\n  getWorkFlowTicketCount(userDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.workflowAPIUrl}GetWorkFlowTicketCount`,\n        userDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response[0]['Success']) {\n            if (response[0]['Data'][0]) {\n              return response[0]['Data'][0];\n            } else {\n              return {};\n            }\n          } else {\n            return {};\n          }\n        }),\n        catchError((e) => throwError(this.errorHandler(e))),\n      );\n  }\n\n  getWorkFlowTicketEventwiseCount(userDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.workflowAPIUrl}GetWorkFlowTicketCountEventWise`,\n        userDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response[0]['Success']) {\n            // return response[0]['Data'];\n            return [];\n          } else {\n            return [];\n          }\n        }),\n      );\n  }\n\n  setLandingPgPreference(moduleId: string) {\n    return this.http\n      .post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}SetLandingPage`, {\n        moduleId: moduleId,\n      })\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return '';\n          }\n        }),\n      );\n  }\n\n  /*Method : POST\n   Action :Will validate User entered PWD as\n  per Password Policy Set\n     */\n  validatePassword(userDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}ValidatePassword`,\n        userDetails,\n      )\n      .pipe(catchError((e) => throwError(this.errorHandler(e))));\n  }\n\n  /*Method : POST\n   Action : RESET Password for First Time User\n     */\n  setNewpassword(loggedInUserDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}ChangeUserArcXwdManually`,\n        loggedInUserDetails,\n      )\n      .pipe(catchError((e) => throwError(this.errorHandler(e))));\n  }\n\n  errorHandler(e: any): any {\n    throw new Error('Method not implemented.');\n  }\n\n  /*Method : GET\n   Action : Get hiding the password for a service. */\n  getProtectedServiceCredentials(mailDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xServiceAPIUrl}GetServicePasswordClose`,\n        mailDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return false;\n          }\n        }),\n        catchError((e) => throwError(this.errorHandler(e))),\n      );\n  }\n\n  /*Method : POST\n  Parameter : subID  , id\n   Action : Get configuration ID based on to show hide DOMAIN dropdown\n     */\n\n  getglobalConfigDetails(subid: string, id: number[]) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.metaAPIUrl1}GetArcosConfigsValues?subId=${subid}`,\n        id,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response['statusCode'] === 200) {\n            let result = response['result'];\n            return result;\n          }\n        }),\n        catchError((e) => throwError(this.errorHandler(e))),\n      );\n  }\n}\n"]}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { HttpClient } from '@angular/common/http';
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { catchError, map, throwError } from 'rxjs';
|
|
4
|
+
import { GlobalConstants } from '../../model/data_model';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common/http";
|
|
7
|
+
export class HttpGeneralConfigurationService {
|
|
8
|
+
constructor(http) {
|
|
9
|
+
this.http = http;
|
|
10
|
+
this.xPageRefAPIUrl = '/xaccess/api/PagePreference/';
|
|
11
|
+
}
|
|
12
|
+
getUserPreferredAssetTypeDetails() {
|
|
13
|
+
return this.http
|
|
14
|
+
.get(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}GetAssetTypeDetails`)
|
|
15
|
+
.pipe(map((response) => {
|
|
16
|
+
if (response && response['success']) {
|
|
17
|
+
return response['result'];
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
return [];
|
|
21
|
+
}
|
|
22
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
23
|
+
}
|
|
24
|
+
getUserPreferredAssetName(payload) {
|
|
25
|
+
return this.http
|
|
26
|
+
.post(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}GetAssetName`, payload)
|
|
27
|
+
.pipe(map((response) => {
|
|
28
|
+
if (response && response['success']) {
|
|
29
|
+
return response['result'];
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
return [];
|
|
33
|
+
}
|
|
34
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
35
|
+
}
|
|
36
|
+
getServiceNameByAssetTypeEvent(payload) {
|
|
37
|
+
return this.http
|
|
38
|
+
.post(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}GetServiceDetails`, payload)
|
|
39
|
+
.pipe(map((response) => {
|
|
40
|
+
if (response && response['success']) {
|
|
41
|
+
return response['result'];
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
return [];
|
|
45
|
+
}
|
|
46
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
47
|
+
}
|
|
48
|
+
getPreferencePathDetails(payload) {
|
|
49
|
+
return this.http
|
|
50
|
+
.post(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}CurrentPreferencepathDetails`, payload)
|
|
51
|
+
.pipe(map((response) => {
|
|
52
|
+
if (response && response['success']) {
|
|
53
|
+
return response['result'];
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
return {};
|
|
57
|
+
}
|
|
58
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
59
|
+
}
|
|
60
|
+
updatePreferencePath(payload) {
|
|
61
|
+
return this.http
|
|
62
|
+
.post(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}UpdatePreferencePath`, payload)
|
|
63
|
+
.pipe(map((response) => {
|
|
64
|
+
if (response && response['success']) {
|
|
65
|
+
return true;
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
}), catchError((e) => throwError(this.errorHandler(e))));
|
|
71
|
+
}
|
|
72
|
+
errorHandler(e) {
|
|
73
|
+
throw new Error('Method not implemented.');
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
HttpGeneralConfigurationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpGeneralConfigurationService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
77
|
+
HttpGeneralConfigurationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpGeneralConfigurationService, providedIn: 'root' });
|
|
78
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpGeneralConfigurationService, decorators: [{
|
|
79
|
+
type: Injectable,
|
|
80
|
+
args: [{
|
|
81
|
+
providedIn: 'root',
|
|
82
|
+
}]
|
|
83
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1nZW5lcmFsLWNvbmZpZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uLWhlYWRlci1saWIvc3JjL2xpYi9zZXJ2aWNlcy9odHRwL2h0dHAtZ2VuZXJhbC1jb25maWcuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDbkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7QUFLekQsTUFBTSxPQUFPLCtCQUErQjtJQUcxQyxZQUFvQixJQUFnQjtRQUFoQixTQUFJLEdBQUosSUFBSSxDQUFZO1FBRjVCLG1CQUFjLEdBQVcsOEJBQThCLENBQUM7SUFFekIsQ0FBQztJQUV4QyxnQ0FBZ0M7UUFDOUIsT0FBTyxJQUFJLENBQUMsSUFBSTthQUNiLEdBQUcsQ0FDRixHQUFHLGVBQWUsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGNBQWMscUJBQXFCLENBQ3RFO2FBQ0EsSUFBSSxDQUNILEdBQUcsQ0FBQyxDQUFDLFFBQWEsRUFBRSxFQUFFO1lBQ3BCLElBQUksUUFBUSxJQUFJLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRTtnQkFDbkMsT0FBTyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUM7YUFDM0I7aUJBQU07Z0JBQ0wsT0FBTyxFQUFFLENBQUM7YUFDWDtRQUNILENBQUMsQ0FBQyxFQUNGLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUNwRCxDQUFDO0lBQ04sQ0FBQztJ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QUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgY2F0Y2hFcnJvciwgbWFwLCB0aHJvd0Vycm9yIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEdsb2JhbENvbnN0YW50cyB9IGZyb20gJy4uLy4uL21vZGVsL2RhdGFfbW9kZWwnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIEh0dHBHZW5lcmFsQ29uZmlndXJhdGlvblNlcnZpY2Uge1xyXG4gIHByaXZhdGUgeFBhZ2VSZWZBUElVcmw6IHN0cmluZyA9ICcveGFjY2Vzcy9hcGkvUGFnZVByZWZlcmVuY2UvJztcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50KSB7fVxyXG5cclxuICBnZXRVc2VyUHJlZmVycmVkQXNzZXRUeXBlRGV0YWlscygpIHtcclxuICAgIHJldHVybiB0aGlzLmh0dHBcclxuICAgICAgLmdldChcclxuICAgICAgICBgJHtHbG9iYWxDb25zdGFudHMuYmFzZVVSTH0ke3RoaXMueFBhZ2VSZWZBUElVcmx9R2V0QXNzZXRUeXBlRGV0YWlsc2BcclxuICAgICAgKVxyXG4gICAgICAucGlwZShcclxuICAgICAgICBtYXAoKHJlc3BvbnNlOiBhbnkpID0+IHtcclxuICAgICAgICAgIGlmIChyZXNwb25zZSAmJiByZXNwb25zZVsnc3VjY2VzcyddKSB7XHJcbiAgICAgICAgICAgIHJldHVybiByZXNwb25zZVsncmVzdWx0J107XHJcbiAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICByZXR1cm4gW107XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSksXHJcbiAgICAgICAgY2F0Y2hFcnJvcigoZSkgPT4gdGhyb3dFcnJvcih0aGlzLmVycm9ySGFuZGxlcihlKSkpXHJcbiAgICAgICk7XHJcbiAgfVxyXG5cclxuICBnZXRVc2VyUHJlZmVycmVkQXNzZXROYW1lKHBheWxvYWQ6IGFueSkge1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cFxyXG4gICAgICAucG9zdChcclxuICAgICAgICBgJHtHbG9iYWxDb25zdGFudHMuYmFzZVVSTH0ke3RoaXMueFBhZ2VSZWZBUElVcmx9R2V0QXNzZXROYW1lYCxcclxuICAgICAgICBwYXlsb2FkXHJcbiAgICAgIClcclxuICAgICAgLnBpcGUoXHJcbiAgICAgICAgbWFwKChyZXNwb25zZTogYW55KSA9PiB7XHJcbiAgICAgICAgICBpZiAocmVzcG9uc2UgJiYgcmVzcG9uc2VbJ3N1Y2Nlc3MnXSkge1xyXG4gICAgICAgICAgICByZXR1cm4gcmVzcG9uc2VbJ3Jlc3VsdCddO1xyXG4gICAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgcmV0dXJuIFtdO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0pLFxyXG4gICAgICAgIGNhdGNoRXJyb3IoKGUpID0+IHRocm93RXJyb3IodGhpcy5lcnJvckhhbmRsZXIoZSkpKVxyXG4gICAgICApO1xyXG4gIH1cclxuICBnZXRTZXJ2aWNlTmFtZUJ5QXNzZXRUeXBlRXZlbnQocGF5bG9hZDogYW55KSB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwXHJcbiAgICAgIC5wb3N0KFxyXG4gICAgICAgIGAke0dsb2JhbENvbnN0YW50cy5iYXNlVVJMfSR7dGhpcy54UGFnZVJlZkFQSVVybH1HZXRTZXJ2aWNlRGV0YWlsc2AsXHJcbiAgICAgICAgcGF5bG9hZFxyXG4gICAgICApXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgocmVzcG9uc2U6IGFueSkgPT4ge1xyXG4gICAgICAgICAgaWYgKHJlc3BvbnNlICYmIHJlc3BvbnNlWydzdWNjZXNzJ10pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHJlc3BvbnNlWydyZXN1bHQnXTtcclxuICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIHJldHVybiBbXTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KSxcclxuICAgICAgICBjYXRjaEVycm9yKChlKSA9PiB0aHJvd0Vycm9yKHRoaXMuZXJyb3JIYW5kbGVyKGUpKSlcclxuICAgICAgKTtcclxuICB9XHJcbiAgZ2V0UHJlZmVyZW5jZVBhdGhEZXRhaWxzKHBheWxvYWQ6IGFueSkge1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cFxyXG4gICAgICAucG9zdChcclxuICAgICAgICBgJHtHbG9iYWxDb25zdGFudHMuYmFzZVVSTH0ke3RoaXMueFBhZ2VSZWZBUElVcmx9Q3VycmVudFByZWZlcmVuY2VwYXRoRGV0YWlsc2AsXHJcbiAgICAgICAgcGF5bG9hZFxyXG4gICAgICApXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgocmVzcG9uc2U6IGFueSkgPT4ge1xyXG4gICAgICAgICAgaWYgKHJlc3BvbnNlICYmIHJlc3BvbnNlWydzdWNjZXNzJ10pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHJlc3BvbnNlWydyZXN1bHQnXTtcclxuICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIHJldHVybiB7fTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KSxcclxuICAgICAgICBjYXRjaEVycm9yKChlKSA9PiB0aHJvd0Vycm9yKHRoaXMuZXJyb3JIYW5kbGVyKGUpKSlcclxuICAgICAgKTtcclxuICB9XHJcbiAgdXBkYXRlUHJlZmVyZW5jZVBhdGgocGF5bG9hZDogYW55KSB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwXHJcbiAgICAgIC5wb3N0KFxyXG4gICAgICAgIGAke0dsb2JhbENvbnN0YW50cy5iYXNlVVJMfSR7dGhpcy54UGFnZVJlZkFQSVVybH1VcGRhdGVQcmVmZXJlbmNlUGF0aGAsXHJcbiAgICAgICAgcGF5bG9hZFxyXG4gICAgICApXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgocmVzcG9uc2U6IGFueSkgPT4ge1xyXG4gICAgICAgICAgaWYgKHJlc3BvbnNlICYmIHJlc3BvbnNlWydzdWNjZXNzJ10pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSksXHJcbiAgICAgICAgY2F0Y2hFcnJvcigoZSkgPT4gdGhyb3dFcnJvcih0aGlzLmVycm9ySGFuZGxlcihlKSkpXHJcbiAgICAgICk7XHJcbiAgfVxyXG5cclxuICBlcnJvckhhbmRsZXIoZTogYW55KTogYW55IHtcclxuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcclxuICB9XHJcbn1cclxuIl19
|