tango-app-ui-shared 3.0.27-dev → 3.0.28-dev
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/interceptors/http-auth-interceptor.mjs +56 -19
- package/esm2022/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.mjs +12 -6
- package/esm2022/lib/routes/routing.mjs +6 -6
- package/esm2022/lib/services/auth.service.mjs +12 -2
- package/fesm2022/tango-app-ui-shared.mjs +81 -28
- package/fesm2022/tango-app-ui-shared.mjs.map +1 -1
- package/lib/interceptors/http-auth-interceptor.d.ts +5 -4
- package/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.d.ts +2 -0
- package/lib/services/auth.service.d.ts +1 -0
- package/package.json +1 -1
- package/esm2022/lib/routes/route-wraper-modules/edge-wrapper.module.mjs +0 -18
- package/fesm2022/tango-app-ui-shared-edge-wrapper.module-DM8Er_Bd.mjs +0 -21
- package/fesm2022/tango-app-ui-shared-edge-wrapper.module-DM8Er_Bd.mjs.map +0 -1
- package/lib/routes/route-wraper-modules/edge-wrapper.module.d.ts +0 -7
|
@@ -1,19 +1,18 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { HttpErrorResponse } from '@angular/common/http';
|
|
3
|
-
import { catchError, throwError } from 'rxjs';
|
|
3
|
+
import { BehaviorSubject, catchError, switchMap, throwError } from 'rxjs';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "tango-app-ui-global";
|
|
6
6
|
import * as i2 from "../services/auth.service";
|
|
7
|
-
import * as i3 from "@angular/router";
|
|
8
7
|
export class HttpAuthInterceptor {
|
|
9
8
|
gs;
|
|
10
|
-
|
|
11
|
-
router;
|
|
9
|
+
authService;
|
|
12
10
|
authlocalStorageToken = '';
|
|
13
|
-
|
|
11
|
+
isRefreshingToken = false;
|
|
12
|
+
tokenRefreshed = new BehaviorSubject(false);
|
|
13
|
+
constructor(gs, authService) {
|
|
14
14
|
this.gs = gs;
|
|
15
|
-
this.
|
|
16
|
-
this.router = router;
|
|
15
|
+
this.authService = authService;
|
|
17
16
|
this.gs.environment.subscribe((env) => {
|
|
18
17
|
if (env) {
|
|
19
18
|
this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`;
|
|
@@ -27,22 +26,60 @@ export class HttpAuthInterceptor {
|
|
|
27
26
|
Authorization: 'Bearer ' + user.authenticationToken
|
|
28
27
|
}
|
|
29
28
|
});
|
|
30
|
-
return next.handle(request).pipe(catchError(
|
|
31
|
-
if (
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
this.router.navigate(["/auth/login"]);
|
|
35
|
-
});
|
|
36
|
-
localStorage.clear();
|
|
37
|
-
}
|
|
29
|
+
return next.handle(request).pipe(catchError((error) => {
|
|
30
|
+
if (error instanceof HttpErrorResponse && error.status === 401) {
|
|
31
|
+
// If the error is due to unauthorized access, try to refresh the token
|
|
32
|
+
return this.handle401Error(request, next);
|
|
38
33
|
}
|
|
39
|
-
return throwError(
|
|
34
|
+
return throwError(error);
|
|
40
35
|
}));
|
|
41
36
|
}
|
|
42
|
-
|
|
37
|
+
handle401Error(request, next) {
|
|
38
|
+
if (!this.isRefreshingToken) {
|
|
39
|
+
this.isRefreshingToken = true;
|
|
40
|
+
return this.authService.refreshToken().pipe(switchMap((res) => {
|
|
41
|
+
if (res && res.code == 200 && res.data.result) {
|
|
42
|
+
// Update local storage with the new token
|
|
43
|
+
localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));
|
|
44
|
+
// Clone the request with the new token
|
|
45
|
+
request = request.clone({
|
|
46
|
+
setHeaders: {
|
|
47
|
+
Authorization: `Bearer ${res.data.result.authenticationToken}`
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
// Reset the flag for token refreshing
|
|
51
|
+
this.isRefreshingToken = false;
|
|
52
|
+
// Retry the original request with the new token
|
|
53
|
+
return next.handle(request);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
// Logout user if refresh token fails
|
|
57
|
+
this.authService.logout();
|
|
58
|
+
return throwError('Token Expired Please Login Again!');
|
|
59
|
+
}
|
|
60
|
+
}), catchError((error) => {
|
|
61
|
+
// Logout user if refresh token fails
|
|
62
|
+
this.authService.logout();
|
|
63
|
+
return throwError(error);
|
|
64
|
+
}));
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
// If already refreshing the token, queue the request and wait
|
|
68
|
+
return this.tokenRefreshed.pipe(switchMap(() => {
|
|
69
|
+
const tokens = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
|
|
70
|
+
request = request.clone({
|
|
71
|
+
setHeaders: {
|
|
72
|
+
Authorization: 'Bearer ' + tokens.authenticationToken
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
return next.handle(request);
|
|
76
|
+
}));
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1.GlobalStateService }, { token: i2.AuthService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
43
80
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor });
|
|
44
81
|
}
|
|
45
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor, decorators: [{
|
|
46
83
|
type: Injectable
|
|
47
|
-
}], ctorParameters: () => [{ type: i1.GlobalStateService }, { type: i2.AuthService }
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
}], ctorParameters: () => [{ type: i1.GlobalStateService }, { type: i2.AuthService }] });
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-auth-interceptor.js","sourceRoot":"","sources":["../../../../../projects/tango-app-shared/src/lib/interceptors/http-auth-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport {\r\n  HttpRequest,\r\n  HttpHandler,\r\n  HttpEvent,\r\n  HttpInterceptor,\r\n  HttpErrorResponse\r\n} from '@angular/common/http';\r\nimport { BehaviorSubject, Observable, catchError, switchMap, throwError } from 'rxjs';\r\nimport { GlobalStateService } from 'tango-app-ui-global';\r\nimport { AuthService } from '../services/auth.service';\r\n@Injectable()\r\nexport class HttpAuthInterceptor implements HttpInterceptor {\r\n\r\n  authlocalStorageToken: string='';\r\n  private isRefreshingToken: boolean = false;\r\n  private tokenRefreshed: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\r\n  \r\n  constructor(\r\n    private gs:GlobalStateService,\r\n    private authService: AuthService\r\n  ) {\r\n    this.gs.environment.subscribe((env)=>{\r\n      if(env){\r\n       this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`;}\r\n     })\r\n  }\r\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n    const user: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');\r\n    request = request.clone({\r\n      setHeaders: {\r\n        Authorization: 'Bearer ' + user.authenticationToken\r\n      }\r\n    });\r\n    return next.handle(request).pipe(\r\n      catchError((error:any)=>{\r\n        if (error instanceof HttpErrorResponse && error.status === 401) {\r\n          // If the error is due to unauthorized access, try to refresh the token\r\n          return this.handle401Error(request, next);\r\n        }\r\n        return throwError(error);\r\n      })\r\n    );\r\n  }\r\n\r\n  private handle401Error(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n    if (!this.isRefreshingToken) {\r\n      this.isRefreshingToken = true;\r\n      return this.authService.refreshToken().pipe(\r\n        switchMap((res: any) => {\r\n          if (res && res.code == 200 && res.data.result) {\r\n            // Update local storage with the new token\r\n            localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));\r\n            \r\n            // Clone the request with the new token\r\n            request = request.clone({\r\n              setHeaders: {\r\n                Authorization: `Bearer ${res.data.result.authenticationToken}`\r\n              }\r\n            });\r\n  \r\n            // Reset the flag for token refreshing\r\n            this.isRefreshingToken = false;\r\n  \r\n            // Retry the original request with the new token\r\n            return next.handle(request);\r\n          } else {\r\n            // Logout user if refresh token fails\r\n            this.authService.logout();\r\n            return throwError('Token Expired Please Login Again!');\r\n          }\r\n        }),\r\n        catchError((error) => {\r\n          // Logout user if refresh token fails\r\n          this.authService.logout();\r\n          return throwError(error);\r\n        })\r\n      );\r\n    } else {\r\n      // If already refreshing the token, queue the request and wait\r\n      return this.tokenRefreshed.pipe(\r\n        switchMap(() => {\r\n          const tokens: any = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');\r\n          request = request.clone({\r\n            setHeaders: {\r\n              Authorization: 'Bearer ' + tokens.authenticationToken\r\n            }\r\n          });\r\n          return next.handle(request);\r\n        })\r\n      );\r\n    }\r\n  }\r\n  \r\n}"]}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
import * as i1 from "../../../../services/auth.service";
|
|
4
5
|
import * as i2 from "@angular/router";
|
|
@@ -19,6 +20,8 @@ export class SidebarFooterComponent {
|
|
|
19
20
|
currentLayoutType;
|
|
20
21
|
userValuefooter = '';
|
|
21
22
|
toggleAttr;
|
|
23
|
+
shouldShowMenuTop = true;
|
|
24
|
+
destroy$ = new Subject();
|
|
22
25
|
constructor(auth, router, layout) {
|
|
23
26
|
this.auth = auth;
|
|
24
27
|
this.router = router;
|
|
@@ -27,7 +30,7 @@ export class SidebarFooterComponent {
|
|
|
27
30
|
ngOnInit() {
|
|
28
31
|
this.toggleAttr = `app-sidebar-${this.toggleType}`;
|
|
29
32
|
const layoutSubscr = this.layout.currentLayoutTypeSubject
|
|
30
|
-
.asObservable()
|
|
33
|
+
.asObservable().pipe(takeUntil(this.destroy$))
|
|
31
34
|
.subscribe((layout) => {
|
|
32
35
|
this.currentLayoutType = layout;
|
|
33
36
|
});
|
|
@@ -61,13 +64,16 @@ export class SidebarFooterComponent {
|
|
|
61
64
|
// }
|
|
62
65
|
}
|
|
63
66
|
logout() {
|
|
64
|
-
this.auth.logout()
|
|
65
|
-
|
|
66
|
-
|
|
67
|
+
this.auth.logout();
|
|
68
|
+
// .pipe(takeUntil(this.destroy$)).subscribe((res:any)=>{
|
|
69
|
+
this.router.navigate(["/auth/login"]);
|
|
70
|
+
// })
|
|
67
71
|
localStorage.clear();
|
|
68
72
|
}
|
|
69
73
|
ngOnDestroy() {
|
|
70
|
-
this.unsubscribe.forEach((sb) => sb.unsubscribe());
|
|
74
|
+
// this.unsubscribe.forEach((sb) => sb.unsubscribe());
|
|
75
|
+
this.destroy$.next(true);
|
|
76
|
+
this.destroy$.complete();
|
|
71
77
|
}
|
|
72
78
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SidebarFooterComponent, deps: [{ token: i1.AuthService }, { token: i2.Router }, { token: i3.LayoutService }], target: i0.ɵɵFactoryTarget.Component });
|
|
73
79
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: SidebarFooterComponent, selector: "lib-sidebar-footer", inputs: { toggleButtonClass: "toggleButtonClass", toggleEnabled: "toggleEnabled", toggleType: "toggleType", toggleState: "toggleState", userValuefooter: "userValuefooter" }, ngImport: i0, template: "<div class=\"container-with-overflow\">\r\n <div id=\"kt_app_sidebar_menu_scroll\" class=\"\" data-kt-scroll=\"true\" data-kt-scroll-activate=\"true\"\r\n data-kt-scroll-height=\"auto\" data-kt-scroll-dependencies=\"#kt_app_sidebar_logo, #kt_app_sidebar_footer\"\r\n data-kt-scroll-wrappers=\"#kt_app_sidebar_menu\" data-kt-scroll-offset=\"5px\" data-kt-scroll-save-state=\"true\">\r\n <div class=\"menu menu-column menu-rounded menu-sub-indention fw-semibold fs-6\" id=\"kt_app_sidebar_menu\"\r\n data-kt-menu=\"true\" data-kt-menu-expand=\"false\">\r\n <div class=\"menu-item menu-accordion w-100 px-3\" id=\"#kt_app_sidebar_menu\" [ngClass]=\"{'active': isSubMenuActive}\"\r\n data-kt-menu-trigger=\"click\" routerLinkActive=\"here show\">\r\n <span class=\"menu-link without-sub\">\r\n <span class=\"menu-icon\">\r\n <img src=\"./assets/tango/Icons/Avatar.svg\">\r\n </span>\r\n <span class=\"menu-title\" data-link=\"/crafted/account\">{{ userValue.userName | titlecase}}<br>\r\n {{ userValue.email | titlecase}}</span>\r\n <span class=\"menu-arrow\"></span>\r\n </span>\r\n <div class=\"menu-sub menu-sub-accordion w-100\" #accordion [ngClass]=\"{'menu-sub-top': isSubMenuActive}\"\r\n routerLinkActive=\"menu-active-bg\">\r\n <div class=\"menu-item px-3 border-profile-first\">\r\n <a class=\"menu-link without-sub\" href=\"/profile\" >\r\n <span class=\"menu-bullet\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M11.8574 3.83162C11.8574 5.94799 10.0668 7.66324 7.85742 7.66324C5.64805 7.66324 3.85742 5.94799 3.85742 3.83162C3.85742 1.71525 5.64805 0 7.85742 0C10.0668 0 11.8574 1.71525 11.8574 3.83162Z\"\r\n fill=\"#98A2B3\" />\r\n <path\r\n d=\"M6.36786 9.38452C2.85 9.38452 0 11.9226 0 15.0554C0 15.577 0.475 16.0001 1.06071 16.0001H14.9393C15.525 16.0001 16 15.577 16 15.0554C16 11.9226 13.15 9.38452 9.63214 9.38452H6.36786Z\"\r\n fill=\"#667085\" />\r\n </svg>\r\n </span>\r\n <span class=\"menu-title\">Profile</span>\r\n </a>\r\n </div>\r\n <div class=\"menu-item px-3\" style=\"border-radius: 0px;\">\r\n <a class=\"menu-link without-sub\" routerLinkActive=\"active\">\r\n <span class=\"menu-bullet\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path opacity=\"0.3\"\r\n d=\"M14.2222 11.5556V8C14.2222 4.56356 11.4364 1.77778 8 1.77778C4.56356 1.77778 1.77778 4.56356 1.77778 8V11.5556H14.2222ZM16 11.5556H0V8C0 3.58172 3.58172 0 8 0C12.4183 0 16 3.58172 16 8V11.5556Z\"\r\n fill=\"#D0D5DD\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M1.77778 9.77759H2.66667C3.64851 9.77759 4.44444 10.5735 4.44444 11.5554V14.222C4.44444 15.2039 3.64851 15.9998 2.66667 15.9998H1.77778C0.795938 15.9998 0 15.2039 0 14.222V11.5554C0 10.5735 0.795938 9.77759 1.77778 9.77759ZM13.3333 9.77759H14.2222C15.2041 9.77759 16 10.5735 16 11.5554V14.222C16 15.2039 15.2041 15.9998 14.2222 15.9998H13.3333C12.3515 15.9998 11.5556 15.2039 11.5556 14.222V11.5554C11.5556 10.5735 12.3515 9.77759 13.3333 9.77759Z\"\r\n fill=\"#667085\" />\r\n </svg>\r\n </span>\r\n <span class=\"menu-title\">Support</span>\r\n </a>\r\n </div>\r\n <div class=\"menu-item px-3\" style=\"border-radius: 0px;\">\r\n <a class=\"menu-link without-sub\" (click)=\"logout()\" routerLinkActive=\"active\">\r\n <span class=\"menu-bullet\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\">\r\n <path\r\n d=\"M5 13H2.33333C1.97971 13 1.64057 12.8595 1.39052 12.6095C1.14048 12.3594 1 12.0203 1 11.6667V2.33333C1 1.97971 1.14048 1.64057 1.39052 1.39052C1.64057 1.14048 1.97971 1 2.33333 1H5\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n <path d=\"M9.66667 10.3332L13 6.99984M13 6.99984L9.66667 3.6665M13 6.99984H5\" stroke=\"#D0D5DD\"\r\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span class=\"menu-title\">Logout</span>\r\n </a>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".menu{background:var(--Gray-700, #344054)}.menu .menu-item{position:relative;background:var(--Gray-700, #344054)}.menu .border-profile-first{border-top-left-radius:8px;border-top-right-radius:8px}.menu .menu-sub{position:absolute;top:100;bottom:calc(100% + 5px);left:0}.menu .menu-sub-top{bottom:auto;top:calc(100% + 5px)}.menu-sub-indention .menu-sub{margin-left:0rem!important}.custom-scroll{max-height:300px}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "pipe", type: i4.TitleCasePipe, name: "titlecase" }] });
|
|
@@ -86,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
86
92
|
}], userValuefooter: [{
|
|
87
93
|
type: Input
|
|
88
94
|
}] } });
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-footer.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;;;;;;AAUpE,MAAM,OAAO,sBAAsB;IAYb;IAA2B;IAAuB;IAXtE,eAAe,GAAY,KAAK,CAAC;IACjC,SAAS,CAAM;IACf,OAAO,GAAG,KAAK,CAAC;IACR,WAAW,GAAmB,EAAE,CAAC;IAChC,iBAAiB,GAAW,EAAE,CAAC;IAC/B,aAAa,CAAU;IACvB,UAAU,GAAW,EAAE,CAAC;IACxB,WAAW,GAAW,EAAE,CAAC;IAClC,iBAAiB,CAAoB;IAC5B,eAAe,GAAM,EAAE,CAAC;IACjC,UAAU,CAAS;IACnB,YAAoB,IAAiB,EAAU,MAAc,EAAS,MAAqB;QAAvE,SAAI,GAAJ,IAAI,CAAa;QAAU,WAAM,GAAN,MAAM,CAAQ;QAAS,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAE/F,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,eAAe,IAAI,CAAC,UAAU,EAAE,CAAC;QACnD,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,wBAAwB;aACtD,YAAY,EAAE;aACd,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpB,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC;QAClC,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACpC,IAAI,WAAW,IAAI,YAAY,EAAE;YAC/B,MAAM,QAAQ,GAAQ,IAAI,CAAC,KAAK,CAC9B,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,CAC1C,CAAC;YACF,WAAW;YACX,kCAAkC;YAClC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,IAAI;SACL;IACH,CAAC;IACD,UAAU;QACR,IAAI,CAAC,eAAe,GAAE,CAAC,IAAI,CAAC,eAAe,CAAC;QAC5C,wFAAwF;QACxF,iBAAiB;QACjB,iFAAiF;QACjF,oBAAoB;QACpB,iHAAiH;QACjH,+CAA+C;QAC/C,+CAA+C;QAC/C,4FAA4F;QAC5F,0BAA0B;QAC1B,wBAAwB;QACxB,4CAA4C;QAC5C,eAAe;QACf,sCAAsC;QACtC,QAAQ;QACR,2BAA2B;QAC3B,MAAM;QACN,IAAI;IACN,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,CAAC,GAAO,EAAC,EAAE;YACxC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;QACtC,CAAC,CAAC,CAAA;QACF,YAAY,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IACD,WAAW;QACT,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;IACrD,CAAC;uGA7DU,sBAAsB;2FAAtB,sBAAsB,wOCVnC,ixJAmEM;;2FDzDO,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;iIASrB,iBAAiB;sBAAzB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEG,eAAe;sBAAvB,KAAK","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { AuthService } from '../../../../services/auth.service';\r\nimport { Subscription } from 'rxjs';\r\nimport { LayoutService, LayoutType } from 'tango-app-ui-global';\r\n@Component({\r\n  selector: \"lib-sidebar-footer\",\r\n  templateUrl: \"./sidebar-footer.component.html\",\r\n  styleUrls: [\"./sidebar-footer.component.scss\"],\r\n})\r\nexport class SidebarFooterComponent implements OnInit,OnDestroy {\r\n  isSubMenuActive: boolean = false;\r\n  userValue: any;\r\n  hovered = false;\r\n  private unsubscribe: Subscription[] = [];\r\n  @Input() toggleButtonClass: string = '';\r\n  @Input() toggleEnabled: boolean;\r\n  @Input() toggleType: string = '';\r\n  @Input() toggleState: string = '';\r\n  currentLayoutType: LayoutType | null;\r\n  @Input() userValuefooter: any='';\r\n  toggleAttr: string;\r\n  constructor(private auth: AuthService, private router: Router,private layout: LayoutService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.toggleAttr = `app-sidebar-${this.toggleType}`;\r\n    const layoutSubscr = this.layout.currentLayoutTypeSubject\r\n      .asObservable()\r\n      .subscribe((layout) => {\r\n        this.currentLayoutType = layout;\r\n      });\r\n    this.unsubscribe.push(layoutSubscr);\r\n    if ('user-info' in localStorage) {\r\n      const userData: any = JSON.parse(\r\n        localStorage.getItem('user-info') || \"{}\"\r\n      );\r\n      // debugger\r\n      // if(this.userValuefooter ===''){\r\n      this.userValue = userData;\r\n      // }\r\n    }\r\n  }\r\n  toggleMenu() {\r\n    this.isSubMenuActive =!this.isSubMenuActive;\r\n    // const submenu = document.querySelector('.menu-sub') as HTMLElement; // Type assertion\r\n    // if (submenu) {\r\n    //   const menuItem = submenu.parentElement; // Get the parent element of submenu\r\n    //   if (menuItem) {\r\n    //     const menuItemRect = menuItem.getBoundingClientRect(); // Get the bounding rectangle of the parent element\r\n    //     const menuHeight = submenu.offsetHeight;\r\n    //     const windowHeight = window.innerHeight;\r\n    //     // const offset = menuItemRect.top + menuItemRect.height + menuHeight - windowHeight;\r\n    //     const offset  = 100\r\n    //     if (offset > 0) {\r\n    //       submenu.style.top = `-${offset}px`;\r\n    //     } else {\r\n    //       submenu.style.top = '1800px';\r\n    //     }\r\n    //     console.log(submenu)\r\n    //   }\r\n    // }\r\n  }\r\n\r\n  logout() {\r\n    this.auth.logout().subscribe((res:any)=>{\r\n    this.router.navigate([\"/auth/login\"]);\r\n    })\r\n    localStorage.clear();\r\n  }\r\n  ngOnDestroy() {\r\n    this.unsubscribe.forEach((sb) => sb.unsubscribe());\r\n  }\r\n\r\n  \r\n}\r\n","<div class=\"container-with-overflow\">\r\n  <div id=\"kt_app_sidebar_menu_scroll\" class=\"\" data-kt-scroll=\"true\" data-kt-scroll-activate=\"true\"\r\n    data-kt-scroll-height=\"auto\" data-kt-scroll-dependencies=\"#kt_app_sidebar_logo, #kt_app_sidebar_footer\"\r\n    data-kt-scroll-wrappers=\"#kt_app_sidebar_menu\" data-kt-scroll-offset=\"5px\" data-kt-scroll-save-state=\"true\">\r\n    <div class=\"menu menu-column menu-rounded menu-sub-indention fw-semibold fs-6\" id=\"kt_app_sidebar_menu\"\r\n      data-kt-menu=\"true\" data-kt-menu-expand=\"false\">\r\n      <div class=\"menu-item menu-accordion w-100 px-3\" id=\"#kt_app_sidebar_menu\" [ngClass]=\"{'active': isSubMenuActive}\"\r\n        data-kt-menu-trigger=\"click\" routerLinkActive=\"here show\">\r\n        <span class=\"menu-link without-sub\">\r\n          <span class=\"menu-icon\">\r\n            <img src=\"./assets/tango/Icons/Avatar.svg\">\r\n          </span>\r\n          <span class=\"menu-title\" data-link=\"/crafted/account\">{{ userValue.userName | titlecase}}<br>\r\n          {{ userValue.email | titlecase}}</span>\r\n          <span class=\"menu-arrow\"></span>\r\n        </span>\r\n        <div class=\"menu-sub menu-sub-accordion w-100\" #accordion [ngClass]=\"{'menu-sub-top': isSubMenuActive}\"\r\n          routerLinkActive=\"menu-active-bg\">\r\n          <div class=\"menu-item px-3 border-profile-first\">\r\n            <a class=\"menu-link without-sub\" href=\"/profile\" >\r\n              <span class=\"menu-bullet\">\r\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                  <path\r\n                    d=\"M11.8574 3.83162C11.8574 5.94799 10.0668 7.66324 7.85742 7.66324C5.64805 7.66324 3.85742 5.94799 3.85742 3.83162C3.85742 1.71525 5.64805 0 7.85742 0C10.0668 0 11.8574 1.71525 11.8574 3.83162Z\"\r\n                    fill=\"#98A2B3\" />\r\n                  <path\r\n                    d=\"M6.36786 9.38452C2.85 9.38452 0 11.9226 0 15.0554C0 15.577 0.475 16.0001 1.06071 16.0001H14.9393C15.525 16.0001 16 15.577 16 15.0554C16 11.9226 13.15 9.38452 9.63214 9.38452H6.36786Z\"\r\n                    fill=\"#667085\" />\r\n                </svg>\r\n              </span>\r\n              <span class=\"menu-title\">Profile</span>\r\n            </a>\r\n          </div>\r\n          <div class=\"menu-item px-3\" style=\"border-radius: 0px;\">\r\n            <a class=\"menu-link without-sub\" routerLinkActive=\"active\">\r\n              <span class=\"menu-bullet\">\r\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                  <path opacity=\"0.3\"\r\n                    d=\"M14.2222 11.5556V8C14.2222 4.56356 11.4364 1.77778 8 1.77778C4.56356 1.77778 1.77778 4.56356 1.77778 8V11.5556H14.2222ZM16 11.5556H0V8C0 3.58172 3.58172 0 8 0C12.4183 0 16 3.58172 16 8V11.5556Z\"\r\n                    fill=\"#D0D5DD\" />\r\n                  <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                    d=\"M1.77778 9.77759H2.66667C3.64851 9.77759 4.44444 10.5735 4.44444 11.5554V14.222C4.44444 15.2039 3.64851 15.9998 2.66667 15.9998H1.77778C0.795938 15.9998 0 15.2039 0 14.222V11.5554C0 10.5735 0.795938 9.77759 1.77778 9.77759ZM13.3333 9.77759H14.2222C15.2041 9.77759 16 10.5735 16 11.5554V14.222C16 15.2039 15.2041 15.9998 14.2222 15.9998H13.3333C12.3515 15.9998 11.5556 15.2039 11.5556 14.222V11.5554C11.5556 10.5735 12.3515 9.77759 13.3333 9.77759Z\"\r\n                    fill=\"#667085\" />\r\n                </svg>\r\n              </span>\r\n              <span class=\"menu-title\">Support</span>\r\n            </a>\r\n          </div>\r\n          <div class=\"menu-item px-3\" style=\"border-radius: 0px;\">\r\n            <a class=\"menu-link without-sub\" (click)=\"logout()\" routerLinkActive=\"active\">\r\n              <span class=\"menu-bullet\">\r\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\">\r\n                  <path\r\n                    d=\"M5 13H2.33333C1.97971 13 1.64057 12.8595 1.39052 12.6095C1.14048 12.3594 1 12.0203 1 11.6667V2.33333C1 1.97971 1.14048 1.64057 1.39052 1.39052C1.64057 1.14048 1.97971 1 2.33333 1H5\"\r\n                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                  <path d=\"M9.66667 10.3332L13 6.99984M13 6.99984L9.66667 3.6665M13 6.99984H5\" stroke=\"#D0D5DD\"\r\n                    stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                </svg>\r\n              </span>\r\n              <span class=\"menu-title\">Logout</span>\r\n            </a>\r\n          </div>\r\n\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-footer.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAGpE,OAAO,EAAE,OAAO,EAAgB,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;AAOxD,MAAM,OAAO,sBAAsB;IAcb;IAA2B;IAAuB;IAbtE,eAAe,GAAY,KAAK,CAAC;IACjC,SAAS,CAAM;IACf,OAAO,GAAG,KAAK,CAAC;IACR,WAAW,GAAmB,EAAE,CAAC;IAChC,iBAAiB,GAAW,EAAE,CAAC;IAC/B,aAAa,CAAU;IACvB,UAAU,GAAW,EAAE,CAAC;IACxB,WAAW,GAAW,EAAE,CAAC;IAClC,iBAAiB,CAAoB;IAC5B,eAAe,GAAM,EAAE,CAAC;IACjC,UAAU,CAAS;IACnB,iBAAiB,GAAY,IAAI,CAAC;IACjB,QAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;IAC1C,YAAoB,IAAiB,EAAU,MAAc,EAAS,MAAqB;QAAvE,SAAI,GAAJ,IAAI,CAAa;QAAU,WAAM,GAAN,MAAM,CAAQ;QAAS,WAAM,GAAN,MAAM,CAAe;IAAG,CAAC;IAE/F,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,eAAe,IAAI,CAAC,UAAU,EAAE,CAAC;QACnD,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,wBAAwB;aACtD,YAAY,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC7C,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpB,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC;QAClC,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACpC,IAAI,WAAW,IAAI,YAAY,EAAE;YAC/B,MAAM,QAAQ,GAAQ,IAAI,CAAC,KAAK,CAC9B,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,CAC1C,CAAC;YACF,WAAW;YACX,kCAAkC;YAClC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,IAAI;SACL;IACH,CAAC;IACD,UAAU;QACR,IAAI,CAAC,eAAe,GAAE,CAAC,IAAI,CAAC,eAAe,CAAC;QAC5C,wFAAwF;QACxF,iBAAiB;QACjB,iFAAiF;QACjF,oBAAoB;QACpB,iHAAiH;QACjH,+CAA+C;QAC/C,+CAA+C;QAC/C,4FAA4F;QAC5F,0BAA0B;QAC1B,wBAAwB;QACxB,4CAA4C;QAC5C,eAAe;QACf,sCAAsC;QACtC,QAAQ;QACR,2BAA2B;QAC3B,MAAM;QACN,IAAI;IACN,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAA;QAClB,yDAAyD;QACzD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;QACtC,KAAK;QACL,YAAY,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IACD,WAAW;QACT,sDAAsD;QACpD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;uGAlEU,sBAAsB;2FAAtB,sBAAsB,wOCVnC,ixJAmEM;;2FDzDO,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;iIASrB,iBAAiB;sBAAzB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEG,eAAe;sBAAvB,KAAK","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { AuthService } from '../../../../services/auth.service';\r\nimport { Subject, Subscription, takeUntil } from 'rxjs';\r\nimport { LayoutService, LayoutType } from 'tango-app-ui-global';\r\n@Component({\r\n  selector: \"lib-sidebar-footer\",\r\n  templateUrl: \"./sidebar-footer.component.html\",\r\n  styleUrls: [\"./sidebar-footer.component.scss\"],\r\n})\r\nexport class SidebarFooterComponent implements OnInit,OnDestroy {\r\n  isSubMenuActive: boolean = false;\r\n  userValue: any;\r\n  hovered = false;\r\n  private unsubscribe: Subscription[] = [];\r\n  @Input() toggleButtonClass: string = '';\r\n  @Input() toggleEnabled: boolean;\r\n  @Input() toggleType: string = '';\r\n  @Input() toggleState: string = '';\r\n  currentLayoutType: LayoutType | null;\r\n  @Input() userValuefooter: any='';\r\n  toggleAttr: string;\r\n  shouldShowMenuTop: boolean = true;\r\n  private readonly destroy$ = new Subject();\r\n  constructor(private auth: AuthService, private router: Router,private layout: LayoutService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.toggleAttr = `app-sidebar-${this.toggleType}`;\r\n    const layoutSubscr = this.layout.currentLayoutTypeSubject\r\n      .asObservable().pipe(takeUntil(this.destroy$))\r\n      .subscribe((layout) => {\r\n        this.currentLayoutType = layout;\r\n      });\r\n    this.unsubscribe.push(layoutSubscr);\r\n    if ('user-info' in localStorage) {\r\n      const userData: any = JSON.parse(\r\n        localStorage.getItem('user-info') || \"{}\"\r\n      );\r\n      // debugger\r\n      // if(this.userValuefooter ===''){\r\n      this.userValue = userData;\r\n      // }\r\n    }\r\n  }\r\n  toggleMenu() {\r\n    this.isSubMenuActive =!this.isSubMenuActive;\r\n    // const submenu = document.querySelector('.menu-sub') as HTMLElement; // Type assertion\r\n    // if (submenu) {\r\n    //   const menuItem = submenu.parentElement; // Get the parent element of submenu\r\n    //   if (menuItem) {\r\n    //     const menuItemRect = menuItem.getBoundingClientRect(); // Get the bounding rectangle of the parent element\r\n    //     const menuHeight = submenu.offsetHeight;\r\n    //     const windowHeight = window.innerHeight;\r\n    //     // const offset = menuItemRect.top + menuItemRect.height + menuHeight - windowHeight;\r\n    //     const offset  = 100\r\n    //     if (offset > 0) {\r\n    //       submenu.style.top = `-${offset}px`;\r\n    //     } else {\r\n    //       submenu.style.top = '1800px';\r\n    //     }\r\n    //     console.log(submenu)\r\n    //   }\r\n    // }\r\n  }\r\n\r\n  logout() {\r\n    this.auth.logout()\r\n    // .pipe(takeUntil(this.destroy$)).subscribe((res:any)=>{\r\n    this.router.navigate([\"/auth/login\"]);\r\n    // })\r\n    localStorage.clear();\r\n  }\r\n  ngOnDestroy() {\r\n    // this.unsubscribe.forEach((sb) => sb.unsubscribe());\r\n      this.destroy$.next(true);\r\n      this.destroy$.complete();\r\n  }\r\n\r\n  \r\n}\r\n","<div class=\"container-with-overflow\">\r\n  <div id=\"kt_app_sidebar_menu_scroll\" class=\"\" data-kt-scroll=\"true\" data-kt-scroll-activate=\"true\"\r\n    data-kt-scroll-height=\"auto\" data-kt-scroll-dependencies=\"#kt_app_sidebar_logo, #kt_app_sidebar_footer\"\r\n    data-kt-scroll-wrappers=\"#kt_app_sidebar_menu\" data-kt-scroll-offset=\"5px\" data-kt-scroll-save-state=\"true\">\r\n    <div class=\"menu menu-column menu-rounded menu-sub-indention fw-semibold fs-6\" id=\"kt_app_sidebar_menu\"\r\n      data-kt-menu=\"true\" data-kt-menu-expand=\"false\">\r\n      <div class=\"menu-item menu-accordion w-100 px-3\" id=\"#kt_app_sidebar_menu\" [ngClass]=\"{'active': isSubMenuActive}\"\r\n        data-kt-menu-trigger=\"click\" routerLinkActive=\"here show\">\r\n        <span class=\"menu-link without-sub\">\r\n          <span class=\"menu-icon\">\r\n            <img src=\"./assets/tango/Icons/Avatar.svg\">\r\n          </span>\r\n          <span class=\"menu-title\" data-link=\"/crafted/account\">{{ userValue.userName | titlecase}}<br>\r\n          {{ userValue.email | titlecase}}</span>\r\n          <span class=\"menu-arrow\"></span>\r\n        </span>\r\n        <div class=\"menu-sub menu-sub-accordion w-100\" #accordion [ngClass]=\"{'menu-sub-top': isSubMenuActive}\"\r\n          routerLinkActive=\"menu-active-bg\">\r\n          <div class=\"menu-item px-3 border-profile-first\">\r\n            <a class=\"menu-link without-sub\" href=\"/profile\" >\r\n              <span class=\"menu-bullet\">\r\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                  <path\r\n                    d=\"M11.8574 3.83162C11.8574 5.94799 10.0668 7.66324 7.85742 7.66324C5.64805 7.66324 3.85742 5.94799 3.85742 3.83162C3.85742 1.71525 5.64805 0 7.85742 0C10.0668 0 11.8574 1.71525 11.8574 3.83162Z\"\r\n                    fill=\"#98A2B3\" />\r\n                  <path\r\n                    d=\"M6.36786 9.38452C2.85 9.38452 0 11.9226 0 15.0554C0 15.577 0.475 16.0001 1.06071 16.0001H14.9393C15.525 16.0001 16 15.577 16 15.0554C16 11.9226 13.15 9.38452 9.63214 9.38452H6.36786Z\"\r\n                    fill=\"#667085\" />\r\n                </svg>\r\n              </span>\r\n              <span class=\"menu-title\">Profile</span>\r\n            </a>\r\n          </div>\r\n          <div class=\"menu-item px-3\" style=\"border-radius: 0px;\">\r\n            <a class=\"menu-link without-sub\" routerLinkActive=\"active\">\r\n              <span class=\"menu-bullet\">\r\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n                  <path opacity=\"0.3\"\r\n                    d=\"M14.2222 11.5556V8C14.2222 4.56356 11.4364 1.77778 8 1.77778C4.56356 1.77778 1.77778 4.56356 1.77778 8V11.5556H14.2222ZM16 11.5556H0V8C0 3.58172 3.58172 0 8 0C12.4183 0 16 3.58172 16 8V11.5556Z\"\r\n                    fill=\"#D0D5DD\" />\r\n                  <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                    d=\"M1.77778 9.77759H2.66667C3.64851 9.77759 4.44444 10.5735 4.44444 11.5554V14.222C4.44444 15.2039 3.64851 15.9998 2.66667 15.9998H1.77778C0.795938 15.9998 0 15.2039 0 14.222V11.5554C0 10.5735 0.795938 9.77759 1.77778 9.77759ZM13.3333 9.77759H14.2222C15.2041 9.77759 16 10.5735 16 11.5554V14.222C16 15.2039 15.2041 15.9998 14.2222 15.9998H13.3333C12.3515 15.9998 11.5556 15.2039 11.5556 14.222V11.5554C11.5556 10.5735 12.3515 9.77759 13.3333 9.77759Z\"\r\n                    fill=\"#667085\" />\r\n                </svg>\r\n              </span>\r\n              <span class=\"menu-title\">Support</span>\r\n            </a>\r\n          </div>\r\n          <div class=\"menu-item px-3\" style=\"border-radius: 0px;\">\r\n            <a class=\"menu-link without-sub\" (click)=\"logout()\" routerLinkActive=\"active\">\r\n              <span class=\"menu-bullet\">\r\n                <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\">\r\n                  <path\r\n                    d=\"M5 13H2.33333C1.97971 13 1.64057 12.8595 1.39052 12.6095C1.14048 12.3594 1 12.0203 1 11.6667V2.33333C1 1.97971 1.14048 1.64057 1.39052 1.39052C1.64057 1.14048 1.97971 1 2.33333 1H5\"\r\n                    stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                  <path d=\"M9.66667 10.3332L13 6.99984M13 6.99984L9.66667 3.6665M13 6.99984H5\" stroke=\"#D0D5DD\"\r\n                    stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                </svg>\r\n              </span>\r\n              <span class=\"menu-title\">Logout</span>\r\n            </a>\r\n          </div>\r\n\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>"]}
|
|
@@ -4,11 +4,11 @@ const Routing = [
|
|
|
4
4
|
path: 'manage',
|
|
5
5
|
loadChildren: () => import('./route-wraper-modules/manage-wrapper.module').then((m) => m.ManageWrapperModule),
|
|
6
6
|
},
|
|
7
|
-
{
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
},
|
|
7
|
+
// {
|
|
8
|
+
// path: 'manage/stores/edge-app',
|
|
9
|
+
// loadChildren: () => import('./route-wraper-modules/edge-wrapper.module').then((m) => m.TangoEdgeAppWrapperModule),
|
|
10
|
+
// canActivate:[storesGuard]
|
|
11
|
+
// },
|
|
12
12
|
{
|
|
13
13
|
path: 'manage/stores/:id',
|
|
14
14
|
loadChildren: () => import('./route-wraper-modules/store-wrapper.module').then((m) => m.StoreWrapperModule),
|
|
@@ -34,4 +34,4 @@ const Routing = [
|
|
|
34
34
|
},
|
|
35
35
|
];
|
|
36
36
|
export { Routing };
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RhbmdvLWFwcC1zaGFyZWQvc3JjL2xpYi9yb3V0ZXMvcm91dGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFJckQsTUFBTSxPQUFPLEdBQVc7SUFDdEI7UUFDRSxJQUFJLEVBQUUsUUFBUTtRQUNkLFlBQVksRUFBRSxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsOENBQThDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxtQkFBbUIsQ0FBQztLQUM5RztJQUNELElBQUk7SUFDSixvQ0FBb0M7SUFDcEMsdUhBQXVIO0lBQ3ZILDhCQUE4QjtJQUM5QixLQUFLO0lBQ0w7UUFDRSxJQUFJLEVBQUUsbUJBQW1CO1FBQ3pCLFlBQVksRUFBRSxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsNkNBQTZDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQztRQUMzRyxXQUFXLEVBQUMsQ0FBQyxXQUFXLENBQUM7S0FDMUI7SUFDRDtRQUNFLElBQUksRUFBRSxTQUFTO1FBQ2YsWUFBWSxFQUFFLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQywrQ0FBK0MsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLG9CQUFvQixDQUFDO0tBQ2hIO0lBQ0Q7UUFDRSxJQUFJLEVBQUUsU0FBUztRQUNmLFlBQVksRUFBRSxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsOENBQThDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxtQkFBbUIsQ0FBQztRQUM3Ryw2QkFBNkI7S0FDOUI7SUFDRDtRQUNFLElBQUksRUFBRSxFQUFFO1FBQ1IsVUFBVSxFQUFFLFNBQVM7UUFDckIsU0FBUyxFQUFFLE1BQU07S0FDbEI7SUFDRDtRQUNFLElBQUksRUFBRSxJQUFJO1FBQ1YsVUFBVSxFQUFFLFdBQVc7S0FDeEI7Q0FDRixDQUFDO0FBRUYsT0FBTyxFQUFFLE9BQU8sRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUm91dGVzIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgc3RvcmVzR3VhcmQgfSBmcm9tICcuLi9ndWFyZHMvc3RvcmVzLmd1YXJkJztcclxuaW1wb3J0IHsgdGlja2V0c0d1YXJkIH0gZnJvbSAnLi4vZ3VhcmRzL3RpY2tldHMuZ3VhcmQnO1xyXG5cclxuXHJcbmNvbnN0IFJvdXRpbmc6IFJvdXRlcyA9IFtcclxuICB7XHJcbiAgICBwYXRoOiAnbWFuYWdlJyxcclxuICAgIGxvYWRDaGlsZHJlbjogKCkgPT4gaW1wb3J0KCcuL3JvdXRlLXdyYXBlci1tb2R1bGVzL21hbmFnZS13cmFwcGVyLm1vZHVsZScpLnRoZW4oKG0pID0+IG0uTWFuYWdlV3JhcHBlck1vZHVsZSksXHJcbiAgfSxcclxuICAvLyB7XHJcbiAgLy8gICBwYXRoOiAnbWFuYWdlL3N0b3Jlcy9lZGdlLWFwcCcsXHJcbiAgLy8gICBsb2FkQ2hpbGRyZW46ICgpID0+IGltcG9ydCgnLi9yb3V0ZS13cmFwZXItbW9kdWxlcy9lZGdlLXdyYXBwZXIubW9kdWxlJykudGhlbigobSkgPT4gbS5UYW5nb0VkZ2VBcHBXcmFwcGVyTW9kdWxlKSxcclxuICAvLyAgIGNhbkFjdGl2YXRlOltzdG9yZXNHdWFyZF1cclxuICAvLyB9LFxyXG4gIHtcclxuICAgIHBhdGg6ICdtYW5hZ2Uvc3RvcmVzLzppZCcsXHJcbiAgICBsb2FkQ2hpbGRyZW46ICgpID0+IGltcG9ydCgnLi9yb3V0ZS13cmFwZXItbW9kdWxlcy9zdG9yZS13cmFwcGVyLm1vZHVsZScpLnRoZW4oKG0pID0+IG0uU3RvcmVXcmFwcGVyTW9kdWxlKSxcclxuICAgIGNhbkFjdGl2YXRlOltzdG9yZXNHdWFyZF1cclxuICB9LFxyXG4gIHtcclxuICAgIHBhdGg6ICdwcm9maWxlJyxcclxuICAgIGxvYWRDaGlsZHJlbjogKCkgPT4gaW1wb3J0KCcuL3JvdXRlLXdyYXBlci1tb2R1bGVzL3Byb2ZpbGUtd3JhcHBlci5tb2R1bGUnKS50aGVuKChtKSA9PiBtLlByb2ZpbGVXcmFwcGVyTW9kdWxlKSxcclxuICB9LFxyXG4gIHtcclxuICAgIHBhdGg6ICd0aWNrZXRzJyxcclxuICAgIGxvYWRDaGlsZHJlbjogKCkgPT4gaW1wb3J0KCcuL3JvdXRlLXdyYXBlci1tb2R1bGVzL3RpY2tldC13cmFwcGVyLm1vZHVsZScpLnRoZW4oKG0pID0+IG0uVGlja2V0V3JhcHBlck1vZHVsZSksXHJcbiAgICAvLyBjYW5BY3RpdmF0ZTpbdGlja2V0c0d1YXJkXVxyXG4gIH0sXHJcbiAge1xyXG4gICAgcGF0aDogJycsXHJcbiAgICByZWRpcmVjdFRvOiAnL21hbmFnZScsXHJcbiAgICBwYXRoTWF0Y2g6ICdmdWxsJyxcclxuICB9LFxyXG4gIHtcclxuICAgIHBhdGg6ICcqKicsXHJcbiAgICByZWRpcmVjdFRvOiAnZXJyb3IvNDA0JyxcclxuICB9LFxyXG5dO1xyXG5cclxuZXhwb3J0IHsgUm91dGluZyB9O1xyXG4iXX0=
|
|
@@ -4,7 +4,6 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
import * as i1 from "@angular/router";
|
|
5
5
|
import * as i2 from "tango-app-ui-global";
|
|
6
6
|
import * as i3 from "@angular/common/http";
|
|
7
|
-
// import { GlobalStateService } from './global-state.service';
|
|
8
7
|
export class AuthService {
|
|
9
8
|
router;
|
|
10
9
|
gs;
|
|
@@ -63,6 +62,17 @@ export class AuthService {
|
|
|
63
62
|
return response;
|
|
64
63
|
}), catchError(this.handleError));
|
|
65
64
|
}
|
|
65
|
+
refreshToken() {
|
|
66
|
+
const userId = JSON.parse(localStorage.getItem("user-info") || "")?._id;
|
|
67
|
+
const refreshToken = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || "")?.refreshToken;
|
|
68
|
+
let params = {
|
|
69
|
+
userId: userId,
|
|
70
|
+
refreshToken: refreshToken,
|
|
71
|
+
};
|
|
72
|
+
return this.http
|
|
73
|
+
.get(`${this.userApiUrl}/refresh-token`, { params: params })
|
|
74
|
+
.pipe(map((response) => response), catchError(this.handleError));
|
|
75
|
+
}
|
|
66
76
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AuthService, deps: [{ token: i1.Router }, { token: i2.GlobalStateService }, { token: i3.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
67
77
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AuthService, providedIn: 'root' });
|
|
68
78
|
}
|
|
@@ -72,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
72
82
|
providedIn: 'root'
|
|
73
83
|
}]
|
|
74
84
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.GlobalStateService }, { type: i3.HttpClient }] });
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL3NlcnZpY2VzL2F1dGguc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBYyxVQUFVLEVBQUUsR0FBRyxFQUFNLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7QUFPbkUsTUFBTSxPQUFPLFdBQVc7SUFPRjtJQUFzQjtJQUE4QjtJQU54RSxZQUFZLENBQVM7SUFDckIscUJBQXFCLENBQVM7SUFDOUIsVUFBVSxDQUFTO0lBQ25CLFdBQVcsQ0FBUztJQUNwQixlQUFlLENBQVM7SUFFeEIsWUFBb0IsTUFBYSxFQUFTLEVBQXFCLEVBQVMsSUFBZTtRQUFuRSxXQUFNLEdBQU4sTUFBTSxDQUFPO1FBQVMsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFBUyxTQUFJLEdBQUosSUFBSSxDQUFXO1FBQ3JGLElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBQyxFQUFFO1lBQ3JDLElBQUcsR0FBRyxFQUFDO2dCQUNOLElBQUksQ0FBQyxZQUFZLEdBQUksR0FBRyxDQUFDLFlBQVksQ0FBQztnQkFDdEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxHQUFHLENBQUMsVUFBVSxDQUFDO2dCQUNqQyxJQUFJLENBQUMsV0FBVyxHQUFFLEdBQUcsQ0FBQyxXQUFXLENBQUM7Z0JBQ2xDLElBQUksQ0FBQyxlQUFlLEdBQUUsR0FBRyxDQUFDLGVBQWUsQ0FBQztnQkFDMUMsSUFBSSxDQUFDLHFCQUFxQixHQUFHLEdBQUcsR0FBRyxDQUFDLFVBQVUsSUFBSSxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7YUFDckU7UUFDRixDQUFDLENBQUMsQ0FBQTtJQUFDLENBQUM7SUFFSixX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dUdBOUVVLFdBQVc7MkdBQVgsV0FBVyxjQUZWLE1BQU07OzJGQUVQLFdBQVc7a0JBSHZCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBjYXRjaEVycm9yLCBtYXAsIG9mLCB0aHJvd0Vycm9yIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IEdsb2JhbFN0YXRlU2VydmljZSB9IGZyb20gJ3RhbmdvLWFwcC11aS1nbG9iYWwnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQXV0aFNlcnZpY2Uge1xyXG4gIGNsaWVudEFwaVVybDogc3RyaW5nO1xyXG4gIGF1dGhsb2NhbFN0b3JhZ2VUb2tlbjogc3RyaW5nO1xyXG4gIHVzZXJBcGlVcmw6IHN0cmluZztcclxuICBzdG9yZUFwaVVybDogc3RyaW5nO1xyXG4gIG9sZERhc2hib2FyZFVybDogc3RyaW5nO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJvdXRlcjpSb3V0ZXIscHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UscHJpdmF0ZSBodHRwOkh0dHBDbGllbnQpIHsgIFxyXG4gICAgdGhpcy5ncy5lbnZpcm9ubWVudC5zdWJzY3JpYmUoKGVudik9PntcclxuICAgIGlmKGVudil7XHJcbiAgICAgdGhpcy5jbGllbnRBcGlVcmwgPSAgZW52LmNsaWVudEFwaVVybDtcclxuICAgICB0aGlzLnVzZXJBcGlVcmwgPSBlbnYudXNlckFwaVVybDsgXHJcbiAgICAgdGhpcy5zdG9yZUFwaVVybCA9ZW52LnN0b3JlQXBpVXJsO1xyXG4gICAgIHRoaXMub2xkRGFzaGJvYXJkVXJsID1lbnYub2xkRGFzaGJvYXJkVXJsO1xyXG4gICAgIHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuID0gYCR7ZW52LmFwcFZlcnNpb259LSR7ZW52LlVTRVJEQVRBX0tFWX1gO1xyXG4gICAgfVxyXG4gICB9KSB9XHJcbiAgIFxyXG4gICBoYW5kbGVFcnJvcihyZXM6IGFueSkge1xyXG4gICAgcmV0dXJuIHRocm93RXJyb3IocmVzLmVycm9yKTtcclxufVxyXG5nZXRIZWFkZXJzKCkge1xyXG4gIGNvbnN0IGhlYWRlcnMgPSB7XHJcbiAgICAgICdBdXRob3JpemF0aW9uJzogJ0JlYXJlciAnICsgdGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW5cclxuICB9O1xyXG5cclxuICByZXR1cm4gaGVhZGVycztcclxufVxyXG5cclxuICBsb2dvdXQoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldChgJHt0aGlzLnVzZXJBcGlVcmx9L2xvZ291dGAsIHtcclxuICAgICAgaGVhZGVyczogdGhpcy5nZXRIZWFkZXJzKClcclxuICAgIH0pXHJcbiAgfVxyXG4gIGdldENsaWVudHMoKXtcclxuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0KGAke3RoaXMuY2xpZW50QXBpVXJsfS9nZXQtY2xpZW50c2AsIHtcclxuICB9KVxyXG4gICAgICAucGlwZShtYXAoKHJlc3BvbnNlOiBhbnkpID0+IHJlc3BvbnNlKSxcclxuICAgICAgICAgIGNhdGNoRXJyb3IodGhpcy5oYW5kbGVFcnJvcikpO1xyXG4gIH1cclxuICBnZXRTdG9yZXMoaWQ6YW55KXtcclxuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0KGAke3RoaXMuc3RvcmVBcGlVcmx9L2dldC1zdG9yZXM/Y2xpZW50SWQ9JHtpZH1gLCB7XHJcbiAgfSlcclxuICAgICAgLnBpcGUobWFwKChyZXNwb25zZTogYW55KSA9PiByZXNwb25zZSksXHJcbiAgICAgICAgICBjYXRjaEVycm9yKHRoaXMuaGFuZGxlRXJyb3IpKTtcclxuICB9XHJcbiAgZ2V0T2xkRGFzaGJvYXJkUmVkaXJlY3QoZGF0YTphbnkpe1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5wb3N0KGAke3RoaXMub2xkRGFzaGJvYXJkVXJsfS9hdXRoL29sZERhc2hib2FyZFVzZXJMb2dpbmAsZGF0YSwge1xyXG4gICAgICBoZWFkZXJzOiB0aGlzLmdldEhlYWRlcnMoKVxyXG4gICAgfSlcclxuICB9XHJcbiAgdXNlclByb2ZpbGVEZXQoKTogT2JzZXJ2YWJsZTxhbnk+IHtcclxuICAgIHJldHVybiB0aGlzLmh0dHBcclxuICAgICAgLmdldChgJHt0aGlzLnVzZXJBcGlVcmx9L3Byb2ZpbGVgLCB7IGhlYWRlcnM6IHRoaXMuZ2V0SGVhZGVycygpIH0pXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgocmVzcG9uc2U6IGFueSkgPT4ge1xyXG4gICAgICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oXCJ1c2VyLWluZm9cIiwgSlNPTi5zdHJpbmdpZnkocmVzcG9uc2UuZGF0YSkpO1xyXG4gICAgICAgICAgcmV0dXJuIHJlc3BvbnNlO1xyXG4gICAgICAgIH0pLFxyXG4gICAgICAgIGNhdGNoRXJyb3IodGhpcy5oYW5kbGVFcnJvcilcclxuICAgICAgKTtcclxuICB9XHJcblxyXG4gIHJlZnJlc2hUb2tlbigpIHtcclxuICAgIGNvbnN0IHVzZXJJZCA9IEpTT04ucGFyc2UobG9jYWxTdG9yYWdlLmdldEl0ZW0oXCJ1c2VyLWluZm9cIikgfHwgXCJcIik/Ll9pZDtcclxuICAgIGNvbnN0IHJlZnJlc2hUb2tlbiA9IEpTT04ucGFyc2UoXHJcbiAgICAgIGxvY2FsU3RvcmFnZS5nZXRJdGVtKHRoaXMuYXV0aGxvY2FsU3RvcmFnZVRva2VuKSB8fCBcIlwiXHJcbiAgICApPy5yZWZyZXNoVG9rZW47XHJcbiAgICBsZXQgcGFyYW1zOiBhbnkgPSB7XHJcbiAgICAgIHVzZXJJZDogdXNlcklkLFxyXG4gICAgICByZWZyZXNoVG9rZW46IHJlZnJlc2hUb2tlbixcclxuICAgIH07XHJcbiAgICByZXR1cm4gdGhpcy5odHRwXHJcbiAgICAgIC5nZXQoYCR7dGhpcy51c2VyQXBpVXJsfS9yZWZyZXNoLXRva2VuYCwgeyBwYXJhbXM6IHBhcmFtcyB9KVxyXG4gICAgICAucGlwZShcclxuICAgICAgICBtYXAoKHJlc3BvbnNlOiBhbnkpID0+IHJlc3BvbnNlKSxcclxuICAgICAgICBjYXRjaEVycm9yKHRoaXMuaGFuZGxlRXJyb3IpXHJcbiAgICAgICk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -4,7 +4,7 @@ import * as i1 from '@angular/router';
|
|
|
4
4
|
import { NavigationEnd, NavigationCancel, ResolveEnd, Router, RouterModule } from '@angular/router';
|
|
5
5
|
import * as i1$1 from 'tango-app-ui-global';
|
|
6
6
|
import { MenuComponent, ToggleComponent, ScrollTopComponent, DrawerComponent, StickyComponent, ScrollComponent, GlobalStateService } from 'tango-app-ui-global';
|
|
7
|
-
import { throwError, map, catchError, takeUntil, Subject, take } from 'rxjs';
|
|
7
|
+
import { throwError, map, catchError, takeUntil, Subject, take, BehaviorSubject, switchMap } from 'rxjs';
|
|
8
8
|
import * as i3 from '@angular/common/http';
|
|
9
9
|
import { HttpErrorResponse } from '@angular/common/http';
|
|
10
10
|
import Swal from 'sweetalert2';
|
|
@@ -28,7 +28,6 @@ import { TranslateModule } from '@ngx-translate/core';
|
|
|
28
28
|
import { InlineSVGModule } from 'ng-inline-svg-2';
|
|
29
29
|
import { NgbDropdownModule, NgbProgressbarModule, NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';
|
|
30
30
|
|
|
31
|
-
// import { GlobalStateService } from './global-state.service';
|
|
32
31
|
class AuthService {
|
|
33
32
|
router;
|
|
34
33
|
gs;
|
|
@@ -87,6 +86,17 @@ class AuthService {
|
|
|
87
86
|
return response;
|
|
88
87
|
}), catchError(this.handleError));
|
|
89
88
|
}
|
|
89
|
+
refreshToken() {
|
|
90
|
+
const userId = JSON.parse(localStorage.getItem("user-info") || "")?._id;
|
|
91
|
+
const refreshToken = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || "")?.refreshToken;
|
|
92
|
+
let params = {
|
|
93
|
+
userId: userId,
|
|
94
|
+
refreshToken: refreshToken,
|
|
95
|
+
};
|
|
96
|
+
return this.http
|
|
97
|
+
.get(`${this.userApiUrl}/refresh-token`, { params: params })
|
|
98
|
+
.pipe(map((response) => response), catchError(this.handleError));
|
|
99
|
+
}
|
|
90
100
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AuthService, deps: [{ token: i1.Router }, { token: i1$1.GlobalStateService }, { token: i3.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
91
101
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AuthService, providedIn: 'root' });
|
|
92
102
|
}
|
|
@@ -2789,6 +2799,8 @@ class SidebarFooterComponent {
|
|
|
2789
2799
|
currentLayoutType;
|
|
2790
2800
|
userValuefooter = '';
|
|
2791
2801
|
toggleAttr;
|
|
2802
|
+
shouldShowMenuTop = true;
|
|
2803
|
+
destroy$ = new Subject();
|
|
2792
2804
|
constructor(auth, router, layout) {
|
|
2793
2805
|
this.auth = auth;
|
|
2794
2806
|
this.router = router;
|
|
@@ -2797,7 +2809,7 @@ class SidebarFooterComponent {
|
|
|
2797
2809
|
ngOnInit() {
|
|
2798
2810
|
this.toggleAttr = `app-sidebar-${this.toggleType}`;
|
|
2799
2811
|
const layoutSubscr = this.layout.currentLayoutTypeSubject
|
|
2800
|
-
.asObservable()
|
|
2812
|
+
.asObservable().pipe(takeUntil(this.destroy$))
|
|
2801
2813
|
.subscribe((layout) => {
|
|
2802
2814
|
this.currentLayoutType = layout;
|
|
2803
2815
|
});
|
|
@@ -2831,13 +2843,16 @@ class SidebarFooterComponent {
|
|
|
2831
2843
|
// }
|
|
2832
2844
|
}
|
|
2833
2845
|
logout() {
|
|
2834
|
-
this.auth.logout()
|
|
2835
|
-
|
|
2836
|
-
|
|
2846
|
+
this.auth.logout();
|
|
2847
|
+
// .pipe(takeUntil(this.destroy$)).subscribe((res:any)=>{
|
|
2848
|
+
this.router.navigate(["/auth/login"]);
|
|
2849
|
+
// })
|
|
2837
2850
|
localStorage.clear();
|
|
2838
2851
|
}
|
|
2839
2852
|
ngOnDestroy() {
|
|
2840
|
-
this.unsubscribe.forEach((sb) => sb.unsubscribe());
|
|
2853
|
+
// this.unsubscribe.forEach((sb) => sb.unsubscribe());
|
|
2854
|
+
this.destroy$.next(true);
|
|
2855
|
+
this.destroy$.complete();
|
|
2841
2856
|
}
|
|
2842
2857
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SidebarFooterComponent, deps: [{ token: AuthService }, { token: i1.Router }, { token: i1$1.LayoutService }], target: i0.ɵɵFactoryTarget.Component });
|
|
2843
2858
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: SidebarFooterComponent, selector: "lib-sidebar-footer", inputs: { toggleButtonClass: "toggleButtonClass", toggleEnabled: "toggleEnabled", toggleType: "toggleType", toggleState: "toggleState", userValuefooter: "userValuefooter" }, ngImport: i0, template: "<div class=\"container-with-overflow\">\r\n <div id=\"kt_app_sidebar_menu_scroll\" class=\"\" data-kt-scroll=\"true\" data-kt-scroll-activate=\"true\"\r\n data-kt-scroll-height=\"auto\" data-kt-scroll-dependencies=\"#kt_app_sidebar_logo, #kt_app_sidebar_footer\"\r\n data-kt-scroll-wrappers=\"#kt_app_sidebar_menu\" data-kt-scroll-offset=\"5px\" data-kt-scroll-save-state=\"true\">\r\n <div class=\"menu menu-column menu-rounded menu-sub-indention fw-semibold fs-6\" id=\"kt_app_sidebar_menu\"\r\n data-kt-menu=\"true\" data-kt-menu-expand=\"false\">\r\n <div class=\"menu-item menu-accordion w-100 px-3\" id=\"#kt_app_sidebar_menu\" [ngClass]=\"{'active': isSubMenuActive}\"\r\n data-kt-menu-trigger=\"click\" routerLinkActive=\"here show\">\r\n <span class=\"menu-link without-sub\">\r\n <span class=\"menu-icon\">\r\n <img src=\"./assets/tango/Icons/Avatar.svg\">\r\n </span>\r\n <span class=\"menu-title\" data-link=\"/crafted/account\">{{ userValue.userName | titlecase}}<br>\r\n {{ userValue.email | titlecase}}</span>\r\n <span class=\"menu-arrow\"></span>\r\n </span>\r\n <div class=\"menu-sub menu-sub-accordion w-100\" #accordion [ngClass]=\"{'menu-sub-top': isSubMenuActive}\"\r\n routerLinkActive=\"menu-active-bg\">\r\n <div class=\"menu-item px-3 border-profile-first\">\r\n <a class=\"menu-link without-sub\" href=\"/profile\" >\r\n <span class=\"menu-bullet\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path\r\n d=\"M11.8574 3.83162C11.8574 5.94799 10.0668 7.66324 7.85742 7.66324C5.64805 7.66324 3.85742 5.94799 3.85742 3.83162C3.85742 1.71525 5.64805 0 7.85742 0C10.0668 0 11.8574 1.71525 11.8574 3.83162Z\"\r\n fill=\"#98A2B3\" />\r\n <path\r\n d=\"M6.36786 9.38452C2.85 9.38452 0 11.9226 0 15.0554C0 15.577 0.475 16.0001 1.06071 16.0001H14.9393C15.525 16.0001 16 15.577 16 15.0554C16 11.9226 13.15 9.38452 9.63214 9.38452H6.36786Z\"\r\n fill=\"#667085\" />\r\n </svg>\r\n </span>\r\n <span class=\"menu-title\">Profile</span>\r\n </a>\r\n </div>\r\n <div class=\"menu-item px-3\" style=\"border-radius: 0px;\">\r\n <a class=\"menu-link without-sub\" routerLinkActive=\"active\">\r\n <span class=\"menu-bullet\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\r\n <path opacity=\"0.3\"\r\n d=\"M14.2222 11.5556V8C14.2222 4.56356 11.4364 1.77778 8 1.77778C4.56356 1.77778 1.77778 4.56356 1.77778 8V11.5556H14.2222ZM16 11.5556H0V8C0 3.58172 3.58172 0 8 0C12.4183 0 16 3.58172 16 8V11.5556Z\"\r\n fill=\"#D0D5DD\" />\r\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n d=\"M1.77778 9.77759H2.66667C3.64851 9.77759 4.44444 10.5735 4.44444 11.5554V14.222C4.44444 15.2039 3.64851 15.9998 2.66667 15.9998H1.77778C0.795938 15.9998 0 15.2039 0 14.222V11.5554C0 10.5735 0.795938 9.77759 1.77778 9.77759ZM13.3333 9.77759H14.2222C15.2041 9.77759 16 10.5735 16 11.5554V14.222C16 15.2039 15.2041 15.9998 14.2222 15.9998H13.3333C12.3515 15.9998 11.5556 15.2039 11.5556 14.222V11.5554C11.5556 10.5735 12.3515 9.77759 13.3333 9.77759Z\"\r\n fill=\"#667085\" />\r\n </svg>\r\n </span>\r\n <span class=\"menu-title\">Support</span>\r\n </a>\r\n </div>\r\n <div class=\"menu-item px-3\" style=\"border-radius: 0px;\">\r\n <a class=\"menu-link without-sub\" (click)=\"logout()\" routerLinkActive=\"active\">\r\n <span class=\"menu-bullet\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\">\r\n <path\r\n d=\"M5 13H2.33333C1.97971 13 1.64057 12.8595 1.39052 12.6095C1.14048 12.3594 1 12.0203 1 11.6667V2.33333C1 1.97971 1.14048 1.64057 1.39052 1.39052C1.64057 1.14048 1.97971 1 2.33333 1H5\"\r\n stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n <path d=\"M9.66667 10.3332L13 6.99984M13 6.99984L9.66667 3.6665M13 6.99984H5\" stroke=\"#D0D5DD\"\r\n stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <span class=\"menu-title\">Logout</span>\r\n </a>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".menu{background:var(--Gray-700, #344054)}.menu .menu-item{position:relative;background:var(--Gray-700, #344054)}.menu .border-profile-first{border-top-left-radius:8px;border-top-right-radius:8px}.menu .menu-sub{position:absolute;top:100;bottom:calc(100% + 5px);left:0}.menu .menu-sub-top{bottom:auto;top:calc(100% + 5px)}.menu-sub-indention .menu-sub{margin-left:0rem!important}.custom-scroll{max-height:300px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "pipe", type: i2.TitleCasePipe, name: "titlecase" }] });
|
|
@@ -4460,11 +4475,11 @@ const Routing = [
|
|
|
4460
4475
|
path: 'manage',
|
|
4461
4476
|
loadChildren: () => import('./tango-app-ui-shared-manage-wrapper.module-B6GJQNQZ.mjs').then((m) => m.ManageWrapperModule),
|
|
4462
4477
|
},
|
|
4463
|
-
{
|
|
4464
|
-
|
|
4465
|
-
|
|
4466
|
-
|
|
4467
|
-
},
|
|
4478
|
+
// {
|
|
4479
|
+
// path: 'manage/stores/edge-app',
|
|
4480
|
+
// loadChildren: () => import('./route-wraper-modules/edge-wrapper.module').then((m) => m.TangoEdgeAppWrapperModule),
|
|
4481
|
+
// canActivate:[storesGuard]
|
|
4482
|
+
// },
|
|
4468
4483
|
{
|
|
4469
4484
|
path: 'manage/stores/:id',
|
|
4470
4485
|
loadChildren: () => import('./tango-app-ui-shared-store-wrapper.module-UYYC9an_.mjs').then((m) => m.StoreWrapperModule),
|
|
@@ -4729,13 +4744,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
4729
4744
|
|
|
4730
4745
|
class HttpAuthInterceptor {
|
|
4731
4746
|
gs;
|
|
4732
|
-
|
|
4733
|
-
router;
|
|
4747
|
+
authService;
|
|
4734
4748
|
authlocalStorageToken = '';
|
|
4735
|
-
|
|
4749
|
+
isRefreshingToken = false;
|
|
4750
|
+
tokenRefreshed = new BehaviorSubject(false);
|
|
4751
|
+
constructor(gs, authService) {
|
|
4736
4752
|
this.gs = gs;
|
|
4737
|
-
this.
|
|
4738
|
-
this.router = router;
|
|
4753
|
+
this.authService = authService;
|
|
4739
4754
|
this.gs.environment.subscribe((env) => {
|
|
4740
4755
|
if (env) {
|
|
4741
4756
|
this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`;
|
|
@@ -4749,24 +4764,62 @@ class HttpAuthInterceptor {
|
|
|
4749
4764
|
Authorization: 'Bearer ' + user.authenticationToken
|
|
4750
4765
|
}
|
|
4751
4766
|
});
|
|
4752
|
-
return next.handle(request).pipe(catchError(
|
|
4753
|
-
if (
|
|
4754
|
-
|
|
4755
|
-
|
|
4756
|
-
this.router.navigate(["/auth/login"]);
|
|
4757
|
-
});
|
|
4758
|
-
localStorage.clear();
|
|
4759
|
-
}
|
|
4767
|
+
return next.handle(request).pipe(catchError((error) => {
|
|
4768
|
+
if (error instanceof HttpErrorResponse && error.status === 401) {
|
|
4769
|
+
// If the error is due to unauthorized access, try to refresh the token
|
|
4770
|
+
return this.handle401Error(request, next);
|
|
4760
4771
|
}
|
|
4761
|
-
return throwError(
|
|
4772
|
+
return throwError(error);
|
|
4762
4773
|
}));
|
|
4763
4774
|
}
|
|
4764
|
-
|
|
4775
|
+
handle401Error(request, next) {
|
|
4776
|
+
if (!this.isRefreshingToken) {
|
|
4777
|
+
this.isRefreshingToken = true;
|
|
4778
|
+
return this.authService.refreshToken().pipe(switchMap((res) => {
|
|
4779
|
+
if (res && res.code == 200 && res.data.result) {
|
|
4780
|
+
// Update local storage with the new token
|
|
4781
|
+
localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res.data.result));
|
|
4782
|
+
// Clone the request with the new token
|
|
4783
|
+
request = request.clone({
|
|
4784
|
+
setHeaders: {
|
|
4785
|
+
Authorization: `Bearer ${res.data.result.authenticationToken}`
|
|
4786
|
+
}
|
|
4787
|
+
});
|
|
4788
|
+
// Reset the flag for token refreshing
|
|
4789
|
+
this.isRefreshingToken = false;
|
|
4790
|
+
// Retry the original request with the new token
|
|
4791
|
+
return next.handle(request);
|
|
4792
|
+
}
|
|
4793
|
+
else {
|
|
4794
|
+
// Logout user if refresh token fails
|
|
4795
|
+
this.authService.logout();
|
|
4796
|
+
return throwError('Token Expired Please Login Again!');
|
|
4797
|
+
}
|
|
4798
|
+
}), catchError((error) => {
|
|
4799
|
+
// Logout user if refresh token fails
|
|
4800
|
+
this.authService.logout();
|
|
4801
|
+
return throwError(error);
|
|
4802
|
+
}));
|
|
4803
|
+
}
|
|
4804
|
+
else {
|
|
4805
|
+
// If already refreshing the token, queue the request and wait
|
|
4806
|
+
return this.tokenRefreshed.pipe(switchMap(() => {
|
|
4807
|
+
const tokens = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || '{}');
|
|
4808
|
+
request = request.clone({
|
|
4809
|
+
setHeaders: {
|
|
4810
|
+
Authorization: 'Bearer ' + tokens.authenticationToken
|
|
4811
|
+
}
|
|
4812
|
+
});
|
|
4813
|
+
return next.handle(request);
|
|
4814
|
+
}));
|
|
4815
|
+
}
|
|
4816
|
+
}
|
|
4817
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1$1.GlobalStateService }, { token: AuthService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
4765
4818
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor });
|
|
4766
4819
|
}
|
|
4767
4820
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor, decorators: [{
|
|
4768
4821
|
type: Injectable
|
|
4769
|
-
}], ctorParameters: () => [{ type: i1$1.GlobalStateService }, { type: AuthService }
|
|
4822
|
+
}], ctorParameters: () => [{ type: i1$1.GlobalStateService }, { type: AuthService }] });
|
|
4770
4823
|
|
|
4771
4824
|
/*
|
|
4772
4825
|
* Public API Surface of tango-app-shared
|