@posiwise/shared-components 0.0.125 → 0.0.126

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.
@@ -42,10 +42,10 @@ export class ResourceHeaderComponent extends AppBaseComponent {
42
42
  const data = res ? JSON.parse(res) : null;
43
43
  this.id = data?.subscriptionId;
44
44
  });
45
+ this.userService.getUserInfo().subscribe(data => {
46
+ this.user = data;
47
+ });
45
48
  }
46
- this.userService.getUserInfo().subscribe(data => {
47
- this.user = data;
48
- });
49
49
  });
50
50
  }
51
51
  openLogoEditModal() {
@@ -165,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
165
165
  type: HostListener,
166
166
  args: ['window:scroll', []]
167
167
  }] } });
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-header.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/resource-header/resource-header.component.ts","../../../../../../libs/shared-components/src/lib/resource-header/resource-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { moveItemInArray } from '@angular/cdk/drag-drop';\nimport { DOCUMENT } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    HostListener,\n    Inject,\n    Injector,\n    OnInit,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { TOKEN_KEY, User } from '@posiwise/common-utilities';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { CustomUploaderComponent } from '../custom-uploader/custom-uploader.component';\n\n@Component({\n    selector: 'pw-resource-header',\n    templateUrl: './resource-header.component.html',\n    styleUrls: ['./resource-header.component.scss']\n})\nexport class ResourceHeaderComponent extends AppBaseComponent implements OnInit {\n    @ViewChild('collapsibleNavbar') navbarCollapse: ElementRef;\n    @ViewChild('editNavbarModal') editNavbarModal: TemplateRef<CustomUploaderComponent>;\n    @ViewChild('logoEditModal') logoEditModal: TemplateRef<CustomUploaderComponent>;\n\n    isScrolled = false;\n    open = false;\n    logo;\n    navbarItems = this.appConfig?.pages_config?.navbar?.items;\n    domainId = this.appConfig?.domain_id;\n    contrastImageUrl = this.appConfig?.company?.logos?.main_contrast?.url;\n    darkImageUrl = this.appConfig?.company?.logos?.main_dark?.url;\n\n    editingNavbar = {\n        items: []\n    };\n    id: string;\n    userLoggedIn: boolean;\n    user: User;\n    scrollTimeout;\n\n\n    constructor(\n        injector: Injector,\n        @Inject(DOCUMENT) private readonly document: Document,\n        private readonly adminService: AdminService,\n        private readonly modalService: NgbModal\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        const isAboutUs = this.router.url?.includes('/about-us');\n\n        this.logo = isAboutUs\n            ? this.appConfig?.company?.logos?.main_contrast?.url\n            : this.appConfig?.company?.logos?.main_dark?.url;\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.id = data?.subscriptionId;\n                });\n            }\n            this.userService.getUserInfo().subscribe(data => {\n                this.user = data;\n            });\n        });\n    }\n\n    openLogoEditModal() {\n        this.modalService.open(this.logoEditModal, { centered: true, size: 'md' });\n    }\n\n    onSaveLogo(event) {\n        console.log(this.isScrolled);\n        const formData = new FormData();\n        formData.append('subscription_id', this.id);\n        if (event.file instanceof File) {\n            formData.append(this.isScrolled ? 'logo_main_contrast' : 'logo_main_dark', event.file);\n        } else {\n            formData.append(\n                this.isScrolled ? 'remove_logo_main_contrast' : 'remove_logo_main_dark',\n                'true'\n            );\n        }\n\n        this.adminService.updateDomainConfig(this.domainId, formData).subscribe(() => {\n            if (event.file) {\n                this.logo = URL.createObjectURL(event.file);\n                if (this.isScrolled) {\n                    this.contrastImageUrl = URL.createObjectURL(event.file);\n                } else {\n                    this.darkImageUrl = URL.createObjectURL(event.file);\n                }\n                this.modalService.dismissAll();\n            }\n            this.toast.success(event.file ? 'Logo updated' : 'Logo removed');\n        });\n    }\n\n\n    @HostListener('window:scroll', [])\n    onScroll(): void {\n      clearTimeout(this.scrollTimeout);\n      this.scrollTimeout = setTimeout(() => {\n        const isAboutUs = this.router?.url?.includes('/about-us');\n        this.isScrolled = window.scrollY > 150;\n\n        if (!isAboutUs) {\n          const newLogo = window.scrollY > 150 ? this.contrastImageUrl : this.darkImageUrl;\n          if (this.logo !== newLogo) {\n            this.logo = newLogo;\n          }\n        }\n\n        if (window.innerWidth < 768) {\n          this.open = false;\n          const collapseElement = this.navbarCollapse?.nativeElement;\n          if (collapseElement?.classList.contains('show')) {\n            collapseElement.classList.remove('show');\n          }\n        }\n      }, 50);\n    }\n\n\n    openEditNavbarModal(): void {\n        const navbarConfig = this.appConfig.pages_config?.navbar || {};\n        navbarConfig.items = navbarConfig.items || [];\n\n        this.editingNavbar = JSON.parse(JSON.stringify(navbarConfig));\n        this.modalService.open(this.editNavbarModal, {\n            size: 'lg',\n            centered: true,\n            windowClass: 'modal-holder'\n        });\n    }\n\n    saveNavbarLinks(modal): void {\n        const updatedConfig = {\n            navbar: this.editingNavbar,\n            subscription_id: this.id\n        };\n\n        this.adminService\n            .updateDomainConfig(this.appConfig?.domain_id, updatedConfig)\n            .subscribe(() => {\n                this.toast.success('Navbar links updated');\n                this.navbarItems = [...this.editingNavbar.items];\n                modal.close();\n            });\n    }\n\n    addNavbarItem(): void {\n        this.editingNavbar.items.push({\n            title: '',\n            path: '',\n            subtitles: []\n        });\n    }\n\n    removeNavbarItem(index: number): void {\n        this.editingNavbar.items.splice(index, 1);\n    }\n\n    addNavbarSubtitle(index: number): void {\n        this.editingNavbar.items[index].subtitles.push({\n            title: '',\n            path: ''\n        });\n    }\n\n    removeNavbarSubtitle(navIndex: number, subIndex: number): void {\n        this.editingNavbar.items[navIndex].subtitles.splice(subIndex, 1);\n    }\n\n    dropNavbarItems(event): void {\n        moveItemInArray(this.editingNavbar.items, event.previousIndex, event.currentIndex);\n    }\n\n    dropNavbarSubtitles(index: number, event): void {\n        moveItemInArray(\n            this.editingNavbar.items[index].subtitles,\n            event.previousIndex,\n            event.currentIndex\n        );\n    }\n}\n","<nav class=\"navbar navbar-expand-md navbar-dark fixed-top cloudolive-nav-bg-color resource-header\"\n  id=\"banner\">\n  <div class=\"container container-wrapper banner-section\">\n\n    <!-- Toggler/collapsibe Button -->\n    <button class=\"navbar-toggler header-menu-bar\"\n      type=\"button\"\n      aria-label=\"Toggle navigation\"\n      data-bs-toggle=\"collapse\"\n      data-bs-target=\"#collapsibleNavbar\">\n      <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\"\n        class=\"img-fluid navbar-toggle-icon\"\n        alt=\"\" />\n    </button>\n\n    <!-- Mobile Logo -->\n    <div class=\"d-md-none mb-icon\">\n      <div>\n        <img [src]=\"logo\"\n          routerLink=\"/\"\n          alt=\"logo\"\n          class=\"img-fluid logo_img\" />\n      </div>\n    </div>\n\n\n    <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n    class=\"fa fa-edit in-page-edit-icon cursor-pointer text-black me-3\"\n    (click)=\"openLogoEditModal()\"\n    title=\"Edit Logo\"></i>\n\n\n    <!-- Navbar links -->\n    <div class=\"collapse navbar-collapse mt-3 mt-md-0\"\n      id=\"collapsibleNavbar\"\n      #collapsibleNavbar>\n      <div class=\"row align-items-center w-100\">\n\n        <!-- Always occupy 3 columns for logo -->\n        <div class=\"col-md-2 d-none d-md-flex align-items-center\">\n          <div *ngIf=\"logo\">\n            <img [src]=\"logo\"\n              (load)=\"logoLoaded = true\"\n              (error)=\"logoLoaded = false\"\n              routerLink=\"/\"\n              alt=\"logo\"\n              class=\"img-fluid logo_img\" />\n          </div>\n        </div>\n\n\n        <div class=\"col-md-7 d-flex justify-content-start\">\n          <ul #anchorLinks\n            class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\"\n            data-wow-duration=\"2s\">\n\n          <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          class=\"fa fa-edit in-page-edit-icon cursor-pointer text-black me-3\"\n          (click)=\"openEditNavbarModal()\"\n          title=\"Edit Navbar Links\"></i>\n            <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n                <a\n                class=\"nav-link\"\n                  href=\"javascript:void(0)\"\n                  [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\n                  (mouseenter)=\"item.open = true\"\n                  (click)=\"item.subtitles?.length ? (item.open = !item.open) : null\"\n                  [attr.href]=\"!(item.subtitles?.length) ? item.path : null\"\n                >\n                  {{ item?.title }}\n                  <i *ngIf=\"item.subtitles.length > 0 && item.open\" class=\"fa-solid fa-caret-down\"></i>\n                    </a>\n              <div class=\"popup position-absolute\"\n              *ngIf=\"item.subtitles.length > 0 && item.open\">\n              <ul>\n                <li\n                    *ngFor=\"let sub of item.subtitles\"\n                    [routerLink]=\"sub.path\"\n                    class=\"dropdownItem\"\n                  >\n                    {{ sub.title }}\n                  </li>\n              </ul>\n            </div>\n            </li>\n\n            <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n              <button class=\"sign-btn sign-header-btn\"\n                routerLink=\"/login\">Log In</button>\n            </li>\n          </ul>\n        </div>\n\n        <!-- Always 3 columns for login -->\n        <div class=\"col-md-3 d-none d-md-flex justify-content-end\">\n          <button class=\"sign-btn sign-header-btn\"\n            routerLink=\"/login\">Log In</button>\n        </div>\n\n      </div>\n    </div>\n  </div>\n</nav>\n\n\n\n<ng-template #editNavbarModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Navbar Links</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <h4 class=\"mb-3\">Navbar Section</h4>\n    <div cdkDropList (cdkDropListDropped)=\"dropNavbarItems($event)\">\n      <div *ngFor=\"let item of editingNavbar.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n        <div class=\"row\">\n          <div class=\"col-md-5 mb-2\">\n            <label class=\"form-label\">Title</label>\n            <input class=\"form-control\" [(ngModel)]=\"item.title\" />\n          </div>\n          <div class=\"col-md-5 mb-2\">\n            <label class=\"form-label\">Path</label>\n            <input class=\"form-control\" [(ngModel)]=\"item.path\" />\n          </div>\n          <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n            <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeNavbarItem(i)\"></i>\n            <i class=\"fa fa-bars in-page-bars-icon cursor-pointer\" cdkDragHandle></i>\n          </div>\n        </div>\n\n        <div cdkDropList (cdkDropListDropped)=\"dropNavbarSubtitles(i, $event)\">\n          <div *ngFor=\"let sub of item.subtitles; let j = index\" class=\"row border p-3 mb-2 align-items-center\" cdkDrag>\n            <div class=\"col-md-5\">\n              <label class=\"form-label\">Subtitle Title</label>\n              <input class=\"form-control\" [(ngModel)]=\"sub.title\" />\n            </div>\n            <div class=\"col-md-5\">\n              <label class=\"form-label\">Subtitle Path</label>\n              <input class=\"form-control\" [(ngModel)]=\"sub.path\" />\n            </div>\n            <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n              <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeNavbarSubtitle(i, j)\"></i>\n              <i class=\"fa fa-bars in-page-bars-icon cursor-pointer\" cdkDragHandle></i>\n            </div>\n          </div>\n        </div>\n\n        <button class=\"btn btn-outline-primary btn-sm mt-2\" (click)=\"addNavbarSubtitle(i)\">\n          + Add Subtitle\n        </button>\n      </div>\n    </div>\n\n    <button class=\"btn btn-primary mt-3\" (click)=\"addNavbarItem()\">\n      + Add Navbar Item\n    </button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveNavbarLinks(modal)\">Save</button>\n  </div>\n</ng-template>\n\n\n\n\n<ng-template #logoEditModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Upload Logo</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n  <div class=\"modal-body\">\n    <pw-custom-uploader\n      [title]=\"'Main Logo'\"\n      [controlName]=\"'logo_main'\"\n      [aspectRatio]=\"'fullLogo'\"\n      [previewData]=\"{ url: logo, name: 'logo_main.png' }\"\n      (saveEvent)=\"onSaveLogo($event)\">\n    </pw-custom-uploader>\n  </div>\n</ng-template>"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-header.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/resource-header/resource-header.component.ts","../../../../../../libs/shared-components/src/lib/resource-header/resource-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { moveItemInArray } from '@angular/cdk/drag-drop';\nimport { DOCUMENT } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    HostListener,\n    Inject,\n    Injector,\n    OnInit,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { TOKEN_KEY, User } from '@posiwise/common-utilities';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { CustomUploaderComponent } from '../custom-uploader/custom-uploader.component';\n\n@Component({\n    selector: 'pw-resource-header',\n    templateUrl: './resource-header.component.html',\n    styleUrls: ['./resource-header.component.scss']\n})\nexport class ResourceHeaderComponent extends AppBaseComponent implements OnInit {\n    @ViewChild('collapsibleNavbar') navbarCollapse: ElementRef;\n    @ViewChild('editNavbarModal') editNavbarModal: TemplateRef<CustomUploaderComponent>;\n    @ViewChild('logoEditModal') logoEditModal: TemplateRef<CustomUploaderComponent>;\n\n    isScrolled = false;\n    open = false;\n    logo;\n    navbarItems = this.appConfig?.pages_config?.navbar?.items;\n    domainId = this.appConfig?.domain_id;\n    contrastImageUrl = this.appConfig?.company?.logos?.main_contrast?.url;\n    darkImageUrl = this.appConfig?.company?.logos?.main_dark?.url;\n\n    editingNavbar = {\n        items: []\n    };\n    id: string;\n    userLoggedIn: boolean;\n    user: User;\n    scrollTimeout;\n\n\n    constructor(\n        injector: Injector,\n        @Inject(DOCUMENT) private readonly document: Document,\n        private readonly adminService: AdminService,\n        private readonly modalService: NgbModal\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        const isAboutUs = this.router.url?.includes('/about-us');\n\n        this.logo = isAboutUs\n            ? this.appConfig?.company?.logos?.main_contrast?.url\n            : this.appConfig?.company?.logos?.main_dark?.url;\n        this.localStorage.getItem$(TOKEN_KEY).subscribe(res => {\n            this.userLoggedIn = !!res;\n            if (this.userLoggedIn) {\n                this.localStorage.getItem$('product').subscribe(res => {\n                    const data = res ? JSON.parse(res) : null;\n                    this.id = data?.subscriptionId;\n                });\n                  this.userService.getUserInfo().subscribe(data => {\n                    this.user = data;\n                });\n            }\n        });\n    }\n\n    openLogoEditModal() {\n        this.modalService.open(this.logoEditModal, { centered: true, size: 'md' });\n    }\n\n    onSaveLogo(event) {\n        console.log(this.isScrolled);\n        const formData = new FormData();\n        formData.append('subscription_id', this.id);\n        if (event.file instanceof File) {\n            formData.append(this.isScrolled ? 'logo_main_contrast' : 'logo_main_dark', event.file);\n        } else {\n            formData.append(\n                this.isScrolled ? 'remove_logo_main_contrast' : 'remove_logo_main_dark',\n                'true'\n            );\n        }\n\n        this.adminService.updateDomainConfig(this.domainId, formData).subscribe(() => {\n            if (event.file) {\n                this.logo = URL.createObjectURL(event.file);\n                if (this.isScrolled) {\n                    this.contrastImageUrl = URL.createObjectURL(event.file);\n                } else {\n                    this.darkImageUrl = URL.createObjectURL(event.file);\n                }\n                this.modalService.dismissAll();\n            }\n            this.toast.success(event.file ? 'Logo updated' : 'Logo removed');\n        });\n    }\n\n\n    @HostListener('window:scroll', [])\n    onScroll(): void {\n      clearTimeout(this.scrollTimeout);\n      this.scrollTimeout = setTimeout(() => {\n        const isAboutUs = this.router?.url?.includes('/about-us');\n        this.isScrolled = window.scrollY > 150;\n\n        if (!isAboutUs) {\n          const newLogo = window.scrollY > 150 ? this.contrastImageUrl : this.darkImageUrl;\n          if (this.logo !== newLogo) {\n            this.logo = newLogo;\n          }\n        }\n\n        if (window.innerWidth < 768) {\n          this.open = false;\n          const collapseElement = this.navbarCollapse?.nativeElement;\n          if (collapseElement?.classList.contains('show')) {\n            collapseElement.classList.remove('show');\n          }\n        }\n      }, 50);\n    }\n\n\n    openEditNavbarModal(): void {\n        const navbarConfig = this.appConfig.pages_config?.navbar || {};\n        navbarConfig.items = navbarConfig.items || [];\n\n        this.editingNavbar = JSON.parse(JSON.stringify(navbarConfig));\n        this.modalService.open(this.editNavbarModal, {\n            size: 'lg',\n            centered: true,\n            windowClass: 'modal-holder'\n        });\n    }\n\n    saveNavbarLinks(modal): void {\n        const updatedConfig = {\n            navbar: this.editingNavbar,\n            subscription_id: this.id\n        };\n\n        this.adminService\n            .updateDomainConfig(this.appConfig?.domain_id, updatedConfig)\n            .subscribe(() => {\n                this.toast.success('Navbar links updated');\n                this.navbarItems = [...this.editingNavbar.items];\n                modal.close();\n            });\n    }\n\n    addNavbarItem(): void {\n        this.editingNavbar.items.push({\n            title: '',\n            path: '',\n            subtitles: []\n        });\n    }\n\n    removeNavbarItem(index: number): void {\n        this.editingNavbar.items.splice(index, 1);\n    }\n\n    addNavbarSubtitle(index: number): void {\n        this.editingNavbar.items[index].subtitles.push({\n            title: '',\n            path: ''\n        });\n    }\n\n    removeNavbarSubtitle(navIndex: number, subIndex: number): void {\n        this.editingNavbar.items[navIndex].subtitles.splice(subIndex, 1);\n    }\n\n    dropNavbarItems(event): void {\n        moveItemInArray(this.editingNavbar.items, event.previousIndex, event.currentIndex);\n    }\n\n    dropNavbarSubtitles(index: number, event): void {\n        moveItemInArray(\n            this.editingNavbar.items[index].subtitles,\n            event.previousIndex,\n            event.currentIndex\n        );\n    }\n}\n","<nav class=\"navbar navbar-expand-md navbar-dark fixed-top cloudolive-nav-bg-color resource-header\"\n  id=\"banner\">\n  <div class=\"container container-wrapper banner-section\">\n\n    <!-- Toggler/collapsibe Button -->\n    <button class=\"navbar-toggler header-menu-bar\"\n      type=\"button\"\n      aria-label=\"Toggle navigation\"\n      data-bs-toggle=\"collapse\"\n      data-bs-target=\"#collapsibleNavbar\">\n      <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\"\n        class=\"img-fluid navbar-toggle-icon\"\n        alt=\"\" />\n    </button>\n\n    <!-- Mobile Logo -->\n    <div class=\"d-md-none mb-icon\">\n      <div>\n        <img [src]=\"logo\"\n          routerLink=\"/\"\n          alt=\"logo\"\n          class=\"img-fluid logo_img\" />\n      </div>\n    </div>\n\n\n    <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n    class=\"fa fa-edit in-page-edit-icon cursor-pointer text-black me-3\"\n    (click)=\"openLogoEditModal()\"\n    title=\"Edit Logo\"></i>\n\n\n    <!-- Navbar links -->\n    <div class=\"collapse navbar-collapse mt-3 mt-md-0\"\n      id=\"collapsibleNavbar\"\n      #collapsibleNavbar>\n      <div class=\"row align-items-center w-100\">\n\n        <!-- Always occupy 3 columns for logo -->\n        <div class=\"col-md-2 d-none d-md-flex align-items-center\">\n          <div *ngIf=\"logo\">\n            <img [src]=\"logo\"\n              (load)=\"logoLoaded = true\"\n              (error)=\"logoLoaded = false\"\n              routerLink=\"/\"\n              alt=\"logo\"\n              class=\"img-fluid logo_img\" />\n          </div>\n        </div>\n\n\n        <div class=\"col-md-7 d-flex justify-content-start\">\n          <ul #anchorLinks\n            class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\"\n            data-wow-duration=\"2s\">\n\n          <i *ngIf=\"userLoggedIn && user?.auth?.granted['Pages.Admin']\"\n          class=\"fa fa-edit in-page-edit-icon cursor-pointer text-black me-3\"\n          (click)=\"openEditNavbarModal()\"\n          title=\"Edit Navbar Links\"></i>\n            <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n                <a\n                class=\"nav-link\"\n                  href=\"javascript:void(0)\"\n                  [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\n                  (mouseenter)=\"item.open = true\"\n                  (click)=\"item.subtitles?.length ? (item.open = !item.open) : null\"\n                  [attr.href]=\"!(item.subtitles?.length) ? item.path : null\"\n                >\n                  {{ item?.title }}\n                  <i *ngIf=\"item.subtitles.length > 0 && item.open\" class=\"fa-solid fa-caret-down\"></i>\n                    </a>\n              <div class=\"popup position-absolute\"\n              *ngIf=\"item.subtitles.length > 0 && item.open\">\n              <ul>\n                <li\n                    *ngFor=\"let sub of item.subtitles\"\n                    [routerLink]=\"sub.path\"\n                    class=\"dropdownItem\"\n                  >\n                    {{ sub.title }}\n                  </li>\n              </ul>\n            </div>\n            </li>\n\n            <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n              <button class=\"sign-btn sign-header-btn\"\n                routerLink=\"/login\">Log In</button>\n            </li>\n          </ul>\n        </div>\n\n        <!-- Always 3 columns for login -->\n        <div class=\"col-md-3 d-none d-md-flex justify-content-end\">\n          <button class=\"sign-btn sign-header-btn\"\n            routerLink=\"/login\">Log In</button>\n        </div>\n\n      </div>\n    </div>\n  </div>\n</nav>\n\n\n\n<ng-template #editNavbarModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Navbar Links</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <h4 class=\"mb-3\">Navbar Section</h4>\n    <div cdkDropList (cdkDropListDropped)=\"dropNavbarItems($event)\">\n      <div *ngFor=\"let item of editingNavbar.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n        <div class=\"row\">\n          <div class=\"col-md-5 mb-2\">\n            <label class=\"form-label\">Title</label>\n            <input class=\"form-control\" [(ngModel)]=\"item.title\" />\n          </div>\n          <div class=\"col-md-5 mb-2\">\n            <label class=\"form-label\">Path</label>\n            <input class=\"form-control\" [(ngModel)]=\"item.path\" />\n          </div>\n          <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n            <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeNavbarItem(i)\"></i>\n            <i class=\"fa fa-bars in-page-bars-icon cursor-pointer\" cdkDragHandle></i>\n          </div>\n        </div>\n\n        <div cdkDropList (cdkDropListDropped)=\"dropNavbarSubtitles(i, $event)\">\n          <div *ngFor=\"let sub of item.subtitles; let j = index\" class=\"row border p-3 mb-2 align-items-center\" cdkDrag>\n            <div class=\"col-md-5\">\n              <label class=\"form-label\">Subtitle Title</label>\n              <input class=\"form-control\" [(ngModel)]=\"sub.title\" />\n            </div>\n            <div class=\"col-md-5\">\n              <label class=\"form-label\">Subtitle Path</label>\n              <input class=\"form-control\" [(ngModel)]=\"sub.path\" />\n            </div>\n            <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n              <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeNavbarSubtitle(i, j)\"></i>\n              <i class=\"fa fa-bars in-page-bars-icon cursor-pointer\" cdkDragHandle></i>\n            </div>\n          </div>\n        </div>\n\n        <button class=\"btn btn-outline-primary btn-sm mt-2\" (click)=\"addNavbarSubtitle(i)\">\n          + Add Subtitle\n        </button>\n      </div>\n    </div>\n\n    <button class=\"btn btn-primary mt-3\" (click)=\"addNavbarItem()\">\n      + Add Navbar Item\n    </button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveNavbarLinks(modal)\">Save</button>\n  </div>\n</ng-template>\n\n\n\n\n<ng-template #logoEditModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Upload Logo</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n  <div class=\"modal-body\">\n    <pw-custom-uploader\n      [title]=\"'Main Logo'\"\n      [controlName]=\"'logo_main'\"\n      [aspectRatio]=\"'fullLogo'\"\n      [previewData]=\"{ url: logo, name: 'logo_main.png' }\"\n      (saveEvent)=\"onSaveLogo($event)\">\n    </pw-custom-uploader>\n  </div>\n</ng-template>"]}
@@ -1892,10 +1892,10 @@ class ResourceHeaderComponent extends AppBaseComponent {
1892
1892
  const data = res ? JSON.parse(res) : null;
1893
1893
  this.id = data?.subscriptionId;
1894
1894
  });
1895
+ this.userService.getUserInfo().subscribe(data => {
1896
+ this.user = data;
1897
+ });
1895
1898
  }
1896
- this.userService.getUserInfo().subscribe(data => {
1897
- this.user = data;
1898
- });
1899
1899
  });
1900
1900
  }
1901
1901
  openLogoEditModal() {