tango-app-ui-shared 3.0.26-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/guards/stores.guard.mjs +16 -0
- package/esm2022/lib/guards/tickets.guard.mjs +16 -0
- package/esm2022/lib/interceptors/http-auth-interceptor.mjs +60 -5
- package/esm2022/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.mjs +37 -8
- package/esm2022/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.mjs +17 -12
- package/esm2022/lib/modules/layout/sidebar/sidebar.component.mjs +4 -3
- package/esm2022/lib/modules/layout/toolbar/single-store/single-store.component.mjs +5 -3
- package/esm2022/lib/modules/layout/toolbar/toolbar.component.mjs +10 -8
- package/esm2022/lib/routes/route-wraper-modules/ticket-wrapper.module.mjs +1 -1
- package/esm2022/lib/routes/routing.mjs +9 -5
- package/esm2022/lib/services/auth.service.mjs +12 -2
- package/fesm2022/tango-app-ui-shared-ticket-wrapper.module-BLrWsK0B.mjs.map +1 -1
- package/fesm2022/tango-app-ui-shared.mjs +220 -105
- package/fesm2022/tango-app-ui-shared.mjs.map +1 -1
- package/lib/guards/stores.guard.d.ts +2 -0
- package/lib/guards/tickets.guard.d.ts +2 -0
- package/lib/interceptors/http-auth-interceptor.d.ts +6 -1
- package/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.d.ts +4 -1
- package/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.d.ts +4 -3
- package/lib/modules/layout/sidebar/sidebar.component.d.ts +1 -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
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { inject } from '@angular/core';
|
|
2
|
+
import { Router } from '@angular/router';
|
|
3
|
+
import { map, take } from 'rxjs';
|
|
4
|
+
import { GlobalStateService } from 'tango-app-ui-global';
|
|
5
|
+
export const storesGuard = (route, state) => {
|
|
6
|
+
const gs = inject(GlobalStateService);
|
|
7
|
+
const router = inject(Router);
|
|
8
|
+
return gs.userAccess.pipe(take(1), map((e) => {
|
|
9
|
+
if (e && !e?.manage_stores_isView) {
|
|
10
|
+
router.navigateByUrl('/manage');
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
return true;
|
|
14
|
+
}));
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmVzLmd1YXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL2d1YXJkcy9zdG9yZXMuZ3VhcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQWlCLE1BQU0sRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2pDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3pELE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBa0IsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUU7SUFDekQsTUFBTSxFQUFFLEdBQUcsTUFBTSxDQUFDLGtCQUFrQixDQUFDLENBQUE7SUFDckMsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBRTlCLE9BQU8sRUFBRSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBQyxFQUFFO1FBQ3pDLElBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFFLG9CQUFvQixFQUFDO1lBQzdCLE1BQU0sQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLENBQUE7WUFDakMsT0FBTyxLQUFLLENBQUE7U0FDYjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQyxDQUFDLENBQUMsQ0FBQTtBQUNMLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDYW5BY3RpdmF0ZUZuLCBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBtYXAsIHRha2UgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgR2xvYmFsU3RhdGVTZXJ2aWNlIH0gZnJvbSAndGFuZ28tYXBwLXVpLWdsb2JhbCc7XHJcbmV4cG9ydCBjb25zdCBzdG9yZXNHdWFyZDogQ2FuQWN0aXZhdGVGbiA9IChyb3V0ZSwgc3RhdGUpID0+IHtcclxuICBjb25zdCBncyA9IGluamVjdChHbG9iYWxTdGF0ZVNlcnZpY2UpXHJcbiAgY29uc3Qgcm91dGVyID0gaW5qZWN0KFJvdXRlcilcclxuICBcclxuIHJldHVybiBncy51c2VyQWNjZXNzLnBpcGUodGFrZSgxKSwgbWFwKChlKT0+e1xyXG4gICAgaWYoZSAmJiAhZT8ubWFuYWdlX3N0b3Jlc19pc1ZpZXcpe1xyXG4gICAgICAgIHJvdXRlci5uYXZpZ2F0ZUJ5VXJsKCcvbWFuYWdlJylcclxuICAgICAgcmV0dXJuIGZhbHNlXHJcbiAgICB9XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9KSlcclxufTtcclxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { inject } from '@angular/core';
|
|
2
|
+
import { Router } from '@angular/router';
|
|
3
|
+
import { map } from 'rxjs';
|
|
4
|
+
import { GlobalStateService } from 'tango-app-ui-global';
|
|
5
|
+
export const ticketsGuard = (route, state) => {
|
|
6
|
+
const gs = inject(GlobalStateService);
|
|
7
|
+
const router = inject(Router);
|
|
8
|
+
return gs.userAccess.pipe(map((e) => {
|
|
9
|
+
if (e && e?.manage_tickets_isView) {
|
|
10
|
+
router.navigateByUrl('/manage');
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
return true;
|
|
14
|
+
}));
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlja2V0cy5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RhbmdvLWFwcC1zaGFyZWQvc3JjL2xpYi9ndWFyZHMvdGlja2V0cy5ndWFyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBaUIsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDeEQsT0FBTyxFQUFFLEdBQUcsRUFBUSxNQUFNLE1BQU0sQ0FBQztBQUNqQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN6RCxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQWtCLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFO0lBQzFELE1BQU0sRUFBRSxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFBO0lBQ3JDLE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQTtJQUU5QixPQUFPLEVBQUUsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBQyxFQUFFO1FBQ2pDLElBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxxQkFBcUIsRUFBQztZQUM3QixNQUFNLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFBO1lBQ2pDLE9BQU8sS0FBSyxDQUFBO1NBQ2I7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUMsQ0FBQyxDQUFDLENBQUE7QUFDTCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2FuQWN0aXZhdGVGbiwgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgbWFwLCBza2lwIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEdsb2JhbFN0YXRlU2VydmljZSB9IGZyb20gJ3RhbmdvLWFwcC11aS1nbG9iYWwnO1xyXG5leHBvcnQgY29uc3QgdGlja2V0c0d1YXJkOiBDYW5BY3RpdmF0ZUZuID0gKHJvdXRlLCBzdGF0ZSkgPT4ge1xyXG4gIGNvbnN0IGdzID0gaW5qZWN0KEdsb2JhbFN0YXRlU2VydmljZSlcclxuICBjb25zdCByb3V0ZXIgPSBpbmplY3QoUm91dGVyKVxyXG4gIFxyXG4gcmV0dXJuIGdzLnVzZXJBY2Nlc3MucGlwZSggbWFwKChlKT0+eyAgXHJcbiAgICBpZihlICYmIGU/Lm1hbmFnZV90aWNrZXRzX2lzVmlldyl7XHJcbiAgICAgICAgcm91dGVyLm5hdmlnYXRlQnlVcmwoJy9tYW5hZ2UnKVxyXG4gICAgICByZXR1cm4gZmFsc2VcclxuICAgIH1cclxuICAgIHJldHVybiB0cnVlO1xyXG4gIH0pKVxyXG59O1xyXG4iXX0=
|
|
@@ -1,11 +1,18 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
+
import { HttpErrorResponse } from '@angular/common/http';
|
|
3
|
+
import { BehaviorSubject, catchError, switchMap, throwError } from 'rxjs';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
3
5
|
import * as i1 from "tango-app-ui-global";
|
|
6
|
+
import * as i2 from "../services/auth.service";
|
|
4
7
|
export class HttpAuthInterceptor {
|
|
5
8
|
gs;
|
|
9
|
+
authService;
|
|
6
10
|
authlocalStorageToken = '';
|
|
7
|
-
|
|
11
|
+
isRefreshingToken = false;
|
|
12
|
+
tokenRefreshed = new BehaviorSubject(false);
|
|
13
|
+
constructor(gs, authService) {
|
|
8
14
|
this.gs = gs;
|
|
15
|
+
this.authService = authService;
|
|
9
16
|
this.gs.environment.subscribe((env) => {
|
|
10
17
|
if (env) {
|
|
11
18
|
this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`;
|
|
@@ -19,12 +26,60 @@ export class HttpAuthInterceptor {
|
|
|
19
26
|
Authorization: 'Bearer ' + user.authenticationToken
|
|
20
27
|
}
|
|
21
28
|
});
|
|
22
|
-
return next.handle(request)
|
|
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);
|
|
33
|
+
}
|
|
34
|
+
return throwError(error);
|
|
35
|
+
}));
|
|
36
|
+
}
|
|
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
|
+
}
|
|
23
78
|
}
|
|
24
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor, deps: [{ token: i1.GlobalStateService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
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 });
|
|
25
80
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor });
|
|
26
81
|
}
|
|
27
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: HttpAuthInterceptor, decorators: [{
|
|
28
83
|
type: Injectable
|
|
29
|
-
}], ctorParameters: () => [{ type: i1.GlobalStateService }] });
|
|
30
|
-
//# 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";
|
|
@@ -17,7 +18,10 @@ export class SidebarFooterComponent {
|
|
|
17
18
|
toggleType = '';
|
|
18
19
|
toggleState = '';
|
|
19
20
|
currentLayoutType;
|
|
21
|
+
userValuefooter = '';
|
|
20
22
|
toggleAttr;
|
|
23
|
+
shouldShowMenuTop = true;
|
|
24
|
+
destroy$ = new Subject();
|
|
21
25
|
constructor(auth, router, layout) {
|
|
22
26
|
this.auth = auth;
|
|
23
27
|
this.router = router;
|
|
@@ -26,34 +30,57 @@ export class SidebarFooterComponent {
|
|
|
26
30
|
ngOnInit() {
|
|
27
31
|
this.toggleAttr = `app-sidebar-${this.toggleType}`;
|
|
28
32
|
const layoutSubscr = this.layout.currentLayoutTypeSubject
|
|
29
|
-
.asObservable()
|
|
33
|
+
.asObservable().pipe(takeUntil(this.destroy$))
|
|
30
34
|
.subscribe((layout) => {
|
|
31
35
|
this.currentLayoutType = layout;
|
|
32
36
|
});
|
|
33
37
|
this.unsubscribe.push(layoutSubscr);
|
|
34
38
|
if ('user-info' in localStorage) {
|
|
35
39
|
const userData = JSON.parse(localStorage.getItem('user-info') || "{}");
|
|
40
|
+
// debugger
|
|
41
|
+
// if(this.userValuefooter ===''){
|
|
36
42
|
this.userValue = userData;
|
|
43
|
+
// }
|
|
37
44
|
}
|
|
38
45
|
}
|
|
39
46
|
toggleMenu() {
|
|
40
47
|
this.isSubMenuActive = !this.isSubMenuActive;
|
|
48
|
+
// const submenu = document.querySelector('.menu-sub') as HTMLElement; // Type assertion
|
|
49
|
+
// if (submenu) {
|
|
50
|
+
// const menuItem = submenu.parentElement; // Get the parent element of submenu
|
|
51
|
+
// if (menuItem) {
|
|
52
|
+
// const menuItemRect = menuItem.getBoundingClientRect(); // Get the bounding rectangle of the parent element
|
|
53
|
+
// const menuHeight = submenu.offsetHeight;
|
|
54
|
+
// const windowHeight = window.innerHeight;
|
|
55
|
+
// // const offset = menuItemRect.top + menuItemRect.height + menuHeight - windowHeight;
|
|
56
|
+
// const offset = 100
|
|
57
|
+
// if (offset > 0) {
|
|
58
|
+
// submenu.style.top = `-${offset}px`;
|
|
59
|
+
// } else {
|
|
60
|
+
// submenu.style.top = '1800px';
|
|
61
|
+
// }
|
|
62
|
+
// console.log(submenu)
|
|
63
|
+
// }
|
|
64
|
+
// }
|
|
41
65
|
}
|
|
42
66
|
logout() {
|
|
43
|
-
this.auth.logout()
|
|
44
|
-
|
|
45
|
-
|
|
67
|
+
this.auth.logout();
|
|
68
|
+
// .pipe(takeUntil(this.destroy$)).subscribe((res:any)=>{
|
|
69
|
+
this.router.navigate(["/auth/login"]);
|
|
70
|
+
// })
|
|
46
71
|
localStorage.clear();
|
|
47
72
|
}
|
|
48
73
|
ngOnDestroy() {
|
|
49
|
-
this.unsubscribe.forEach((sb) => sb.unsubscribe());
|
|
74
|
+
// this.unsubscribe.forEach((sb) => sb.unsubscribe());
|
|
75
|
+
this.destroy$.next(true);
|
|
76
|
+
this.destroy$.complete();
|
|
50
77
|
}
|
|
51
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 });
|
|
52
|
-
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" }, ngImport: i0, template: "<div id=\"kt_app_sidebar_menu_scroll\"
|
|
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" }] });
|
|
53
80
|
}
|
|
54
81
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SidebarFooterComponent, decorators: [{
|
|
55
82
|
type: Component,
|
|
56
|
-
args: [{ selector: "lib-sidebar-footer", template: "<div id=\"kt_app_sidebar_menu_scroll\"
|
|
83
|
+
args: [{ selector: "lib-sidebar-footer", 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"] }]
|
|
57
84
|
}], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.Router }, { type: i3.LayoutService }], propDecorators: { toggleButtonClass: [{
|
|
58
85
|
type: Input
|
|
59
86
|
}], toggleEnabled: [{
|
|
@@ -62,5 +89,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
62
89
|
type: Input
|
|
63
90
|
}], toggleState: [{
|
|
64
91
|
type: Input
|
|
92
|
+
}], userValuefooter: [{
|
|
93
|
+
type: Input
|
|
65
94
|
}] } });
|
|
66
|
-
//# 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;IAErC,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,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;SAC3B;IACH,CAAC;IACD,UAAU;QACR,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;IAC/C,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;uGAzCU,sBAAsB;2FAAtB,sBAAsB,oMCVnC,43IAsDA;;2FD5Ca,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;iIASrB,iBAAiB;sBAAzB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,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\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      this.userValue = userData;\r\n    }\r\n  }\r\n  toggleMenu() {\r\n    this.isSubMenuActive = !this.isSubMenuActive;\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","<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\"\r\n     [ngClass]=\"{'active': isSubMenuActive}\" 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>{{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\"  [ngClass]=\"{'menu-sub-top': isSubMenuActive}\" routerLinkActive=\"menu-active-bg\">\r\n        <div class=\"menu-item px-3 border-profile-first\">\r\n          <a class=\"menu-link without-sub\" routerLink=\"profile\" 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 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\" fill=\"#98A2B3\"/>\r\n              <path 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\" 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\" 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\" fill=\"#D0D5DD\"/>\r\n                <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" 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\" 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 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\" 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\" 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\r\n"]}
|
|
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>"]}
|