tango-app-ui-shared 3.7.3-dev1 → 3.7.3-dev10
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/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.mjs +13 -2
- package/esm2022/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.mjs +4 -3
- package/esm2022/lib/modules/layout/toolbar/single-store/single-store.component.mjs +1 -2
- package/esm2022/lib/modules/layout/toolbar/toolbar.component.mjs +9 -3
- package/esm2022/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.mjs +327 -148
- package/esm2022/lib/routes/routing.mjs +6 -1
- package/fesm2022/tango-app-ui-shared-intro.module-DYh4ZRha.mjs.map +1 -1
- package/fesm2022/tango-app-ui-shared-notification.module-C5ZmCf8U.mjs.map +1 -1
- package/fesm2022/tango-app-ui-shared.mjs +355 -154
- package/fesm2022/tango-app-ui-shared.mjs.map +1 -1
- package/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.d.ts +2 -1
- package/lib/modules/layout/sidebar/sidebar-menu/sidebar-menu.component.d.ts +1 -0
- package/lib/modules/layout/toolbar/traffic-header/traffic-header/traffic-header.component.d.ts +10 -1
- package/package.json +1 -1
|
@@ -103,9 +103,20 @@ export class SidebarFooterComponent {
|
|
|
103
103
|
}
|
|
104
104
|
});
|
|
105
105
|
}
|
|
106
|
+
captchaToken = null;
|
|
106
107
|
cleanUpAndRedirect() {
|
|
107
|
-
|
|
108
|
+
this.captchaToken = null;
|
|
108
109
|
localStorage.removeItem(this.recaptchaSiteKey);
|
|
110
|
+
sessionStorage.removeItem(this.recaptchaSiteKey);
|
|
111
|
+
localStorage.clear();
|
|
112
|
+
if (window.grecaptcha) {
|
|
113
|
+
try {
|
|
114
|
+
window.grecaptcha.reset();
|
|
115
|
+
}
|
|
116
|
+
catch (err) {
|
|
117
|
+
console.warn('Captcha reset error:', err);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
109
120
|
this.pageInfo.setTitle('login');
|
|
110
121
|
this.router.navigate(["/auth/login"]);
|
|
111
122
|
}
|
|
@@ -145,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
145
156
|
}], userValuefooter: [{
|
|
146
157
|
type: Input
|
|
147
158
|
}] } });
|
|
148
|
-
//# 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":"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","sourcesContent":["import { Component, Input, NgZone, OnDestroy, OnInit } from '@angular/core';\r\nimport { NavigationStart, Router } from '@angular/router';\r\nimport { AuthService } from '../../../../services/auth.service';\r\nimport { Subject, Subscription, takeUntil } from 'rxjs';\r\nimport { GlobalStateService, LayoutService, LayoutType, PageInfoService } from 'tango-app-ui-global';\r\nimport { ToastService } from '../../../../services/toast.service';\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  openshow: boolean =false;\r\n  userProfileData: any;\r\n  recaptchaSiteKey:any;\r\n  constructor(private auth: AuthService, private router: Router,private layout: LayoutService,private pageInfo:PageInfoService, \r\n    private ngZone: NgZone,private ts:ToastService,public gs:GlobalStateService) {\r\n this.gs.environment.pipe(takeUntil(this.destroy$)).subscribe((env) => {\r\n      if (env) {\r\n        this.recaptchaSiteKey = env.recaptchaSiteKey\r\n      }\r\n    });\r\n    this.router.events.subscribe(event => {\r\n      if (event instanceof NavigationStart) {\r\n        // Close the submenu whenever a navigation starts\r\n        this.isSubMenuActive = false;\r\n      }\r\n    });\r\n  }\r\n  // isSubMenuActive: boolean = false;\r\n  isArrowReversed: boolean = false;\r\n\r\n  setArrowDirection(isMouseOver: boolean) {\r\n    // console.log(isMouseOver)\r\n    this.isArrowReversed = isMouseOver;\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      this.userValue = userData;\r\n    }\r\n    this.getProfile();\r\n  }\r\n\r\n  toggleMenu() {\r\n    this.isSubMenuActive =!this.isSubMenuActive;\r\n  }\r\n  profileUrl() {\r\n    this.isSubMenuActive = false;\r\n  this.router.navigate(['/profile'])\r\n  // setTimeout(() => {\r\n  //   this.closeMenu();\r\n  // }, 10);\r\n}\r\ncloseMenu(){\r\n  window.location.reload()\r\n}\r\n\r\nlogout() {\r\n  this.auth.logout().pipe(takeUntil(this.destroy$)).subscribe({\r\n    next: (res: any) => {\r\n      if (res && res?.code === 200) {\r\n        this.cleanUpAndRedirect();\r\n      } else {\r\n        console.warn(\"Logout failed from server, forcing client logout.\");\r\n        this.cleanUpAndRedirect();\r\n      }\r\n    },\r\n    error: (err) => {\r\n      console.error(\"Logout API error:\", err);\r\n      // Still clear local data and redirect, but maybe also show a message\r\n      this.cleanUpAndRedirect();\r\n      this.ts.getErrorToast(\"Something went wrong while logging out. Please log in again.\");\r\n    }\r\n  });\r\n}\r\n\r\nprivate cleanUpAndRedirect() {\r\n  localStorage.clear();\r\nlocalStorage.removeItem(this.recaptchaSiteKey);\r\n  this.pageInfo.setTitle('login');\r\n  this.router.navigate([\"/auth/login\"]);\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 getProfile(){\r\n  this.auth.getPersonalInfo().pipe(takeUntil(this.destroy$)).subscribe({\r\n    next: (res:any) => {\r\n      if (res && res.code == 200) {\r\n        this.userProfileData = res.data;\r\n        // this.twoFactorEnabled =\r\n        //   this.userProfileData?.twoFactorAuthentication?.isEnable || false;\r\n      } \r\n    },\r\n    error: (err:any) => {\r\n      console.log(err);\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=\"false\" data-kt-scroll-activate=\"false\"\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\"  (mouseover)=\"setArrowDirection(true)\"\r\n        (mouseleave)=\"setArrowDirection(false)\" >\r\n        <span class=\"menu-link without-sub\">\r\n          <span class=\"menu-icon\">\r\n            <img class=\"img-src\" *ngIf=\"userProfileData?.userProfile\" (error)=\"userProfileData.userProfile = null\" [src]=\"userProfileData?.userProfile ? userProfileData?.userProfile :'./assets/tango/Images/userProfile.svg'\" alt=\"Profile Image\">\r\n            <img class=\"img-src\" *ngIf=\"!userProfileData?.userProfile\" src=\"assets/tango/Images/userProfile.svg\">\r\n          </span>\r\n          <span class=\"menu-title overflow-hidden ms-2\" 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 [class.show]=\"isSubMenuActive\" [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\"  (click)=\"profileUrl()\" >\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 overflow-hidden\">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 overflow-hidden\">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 overflow-hidden\">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>"]}
|
|
159
|
+
//# 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":"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","sourcesContent":["import { Component, Input, NgZone, OnDestroy, OnInit } from '@angular/core';\r\nimport { NavigationStart, Router } from '@angular/router';\r\nimport { AuthService } from '../../../../services/auth.service';\r\nimport { Subject, Subscription, takeUntil } from 'rxjs';\r\nimport { GlobalStateService, LayoutService, LayoutType, PageInfoService } from 'tango-app-ui-global';\r\nimport { ToastService } from '../../../../services/toast.service';\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  openshow: boolean =false;\r\n  userProfileData: any;\r\n  recaptchaSiteKey:any;\r\n  constructor(private auth: AuthService, private router: Router,private layout: LayoutService,private pageInfo:PageInfoService, \r\n    private ngZone: NgZone,private ts:ToastService,public gs:GlobalStateService) {\r\n this.gs.environment.pipe(takeUntil(this.destroy$)).subscribe((env) => {\r\n      if (env) {\r\n        this.recaptchaSiteKey = env.recaptchaSiteKey\r\n      }\r\n    });\r\n    this.router.events.subscribe(event => {\r\n      if (event instanceof NavigationStart) {\r\n        // Close the submenu whenever a navigation starts\r\n        this.isSubMenuActive = false;\r\n      }\r\n    });\r\n  }\r\n  // isSubMenuActive: boolean = false;\r\n  isArrowReversed: boolean = false;\r\n\r\n  setArrowDirection(isMouseOver: boolean) {\r\n    // console.log(isMouseOver)\r\n    this.isArrowReversed = isMouseOver;\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      this.userValue = userData;\r\n    }\r\n    this.getProfile();\r\n  }\r\n\r\n  toggleMenu() {\r\n    this.isSubMenuActive =!this.isSubMenuActive;\r\n  }\r\n  profileUrl() {\r\n    this.isSubMenuActive = false;\r\n  this.router.navigate(['/profile'])\r\n  // setTimeout(() => {\r\n  //   this.closeMenu();\r\n  // }, 10);\r\n}\r\ncloseMenu(){\r\n  window.location.reload()\r\n}\r\n\r\nlogout() {\r\n  this.auth.logout().pipe(takeUntil(this.destroy$)).subscribe({\r\n    next: (res: any) => {\r\n      if (res && res?.code === 200) {\r\n        this.cleanUpAndRedirect();\r\n      } else {\r\n        console.warn(\"Logout failed from server, forcing client logout.\");\r\n        this.cleanUpAndRedirect();\r\n      }\r\n    },\r\n    error: (err) => {\r\n      console.error(\"Logout API error:\", err);\r\n      // Still clear local data and redirect, but maybe also show a message\r\n      this.cleanUpAndRedirect();\r\n      this.ts.getErrorToast(\"Something went wrong while logging out. Please log in again.\");\r\n    }\r\n  });\r\n}\r\ncaptchaToken: string | null = null; \r\npublic cleanUpAndRedirect() {\r\n   this.captchaToken = null;\r\n  localStorage.removeItem(this.recaptchaSiteKey); \r\n  sessionStorage.removeItem(this.recaptchaSiteKey);\r\n  localStorage.clear();\r\n if ((window as any).grecaptcha) {\r\n    try {\r\n      (window as any).grecaptcha.reset();\r\n    } catch (err) {\r\n      console.warn('Captcha reset error:', err);\r\n    }\r\n  }\r\n  this.pageInfo.setTitle('login');\r\n  this.router.navigate([\"/auth/login\"]);\r\n}\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 getProfile(){\r\n  this.auth.getPersonalInfo().pipe(takeUntil(this.destroy$)).subscribe({\r\n    next: (res:any) => {\r\n      if (res && res.code == 200) {\r\n        this.userProfileData = res.data;\r\n        // this.twoFactorEnabled =\r\n        //   this.userProfileData?.twoFactorAuthentication?.isEnable || false;\r\n      } \r\n    },\r\n    error: (err:any) => {\r\n      console.log(err);\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=\"false\" data-kt-scroll-activate=\"false\"\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\"  (mouseover)=\"setArrowDirection(true)\"\r\n        (mouseleave)=\"setArrowDirection(false)\" >\r\n        <span class=\"menu-link without-sub\">\r\n          <span class=\"menu-icon\">\r\n            <img class=\"img-src\" *ngIf=\"userProfileData?.userProfile\" (error)=\"userProfileData.userProfile = null\" [src]=\"userProfileData?.userProfile ? userProfileData?.userProfile :'./assets/tango/Images/userProfile.svg'\" alt=\"Profile Image\">\r\n            <img class=\"img-src\" *ngIf=\"!userProfileData?.userProfile\" src=\"assets/tango/Images/userProfile.svg\">\r\n          </span>\r\n          <span class=\"menu-title overflow-hidden ms-2\" 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 [class.show]=\"isSubMenuActive\" [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\"  (click)=\"profileUrl()\" >\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 overflow-hidden\">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 overflow-hidden\">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 overflow-hidden\">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>"]}
|