@posiwise/shared-components 0.0.125 → 0.0.127

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.
@@ -29,6 +29,8 @@ export class ResourceHeaderComponent extends AppBaseComponent {
29
29
  this.editingNavbar = {
30
30
  items: []
31
31
  };
32
+ this.cachedScrollY = 0;
33
+ this.cachedWindowWidth = window.innerWidth;
32
34
  }
33
35
  ngOnInit() {
34
36
  const isAboutUs = this.router.url?.includes('/about-us');
@@ -42,10 +44,10 @@ export class ResourceHeaderComponent extends AppBaseComponent {
42
44
  const data = res ? JSON.parse(res) : null;
43
45
  this.id = data?.subscriptionId;
44
46
  });
47
+ this.userService.getUserInfo().subscribe(data => {
48
+ this.user = data;
49
+ });
45
50
  }
46
- this.userService.getUserInfo().subscribe(data => {
47
- this.user = data;
48
- });
49
51
  });
50
52
  }
51
53
  openLogoEditModal() {
@@ -76,24 +78,35 @@ export class ResourceHeaderComponent extends AppBaseComponent {
76
78
  });
77
79
  }
78
80
  onScroll() {
79
- clearTimeout(this.scrollTimeout);
80
- this.scrollTimeout = setTimeout(() => {
81
- const isAboutUs = this.router?.url?.includes('/about-us');
82
- this.isScrolled = window.scrollY > 150;
83
- if (!isAboutUs) {
84
- const newLogo = window.scrollY > 150 ? this.contrastImageUrl : this.darkImageUrl;
81
+ // Throttle scroll events to prevent forced reflows
82
+ if (this.scrollThrottle) {
83
+ return;
84
+ }
85
+ this.scrollThrottle = requestAnimationFrame(() => {
86
+ this.scrollThrottle = null;
87
+ // Cache all layout queries to prevent multiple forced reflows
88
+ this.cachedScrollY = window.scrollY;
89
+ this.cachedWindowWidth = window.innerWidth;
90
+ this.cachedIsAboutUs = this.router?.url?.includes('/about-us');
91
+ const shouldScroll = this.cachedScrollY > 150;
92
+ this.isScrolled = shouldScroll;
93
+ if (!this.cachedIsAboutUs) {
94
+ const newLogo = shouldScroll ? this.contrastImageUrl : this.darkImageUrl;
85
95
  if (this.logo !== newLogo) {
86
96
  this.logo = newLogo;
87
97
  }
88
98
  }
89
- if (window.innerWidth < 768) {
99
+ if (this.cachedWindowWidth < 768) {
90
100
  this.open = false;
91
101
  const collapseElement = this.navbarCollapse?.nativeElement;
92
102
  if (collapseElement?.classList.contains('show')) {
93
- collapseElement.classList.remove('show');
103
+ // Use requestAnimationFrame for DOM manipulation to prevent reflows
104
+ requestAnimationFrame(() => {
105
+ collapseElement.classList.remove('show');
106
+ });
94
107
  }
95
108
  }
96
- }, 50);
109
+ });
97
110
  }
98
111
  openEditNavbarModal() {
99
112
  const navbarConfig = this.appConfig.pages_config?.navbar || {};
@@ -165,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
165
178
  type: HostListener,
166
179
  args: ['window:scroll', []]
167
180
  }] } });
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>"]}
181
+ //# 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\n    // Add these properties to prevent forced reflows\n    private scrollThrottle: number;\n    private cachedScrollY = 0;\n    private cachedWindowWidth = window.innerWidth;\n    private cachedIsAboutUs: boolean;\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    @HostListener('window:scroll', [])\n    onScroll(): void {\n        // Throttle scroll events to prevent forced reflows\n        if (this.scrollThrottle) {\n            return;\n        }\n\n        this.scrollThrottle = requestAnimationFrame(() => {\n            this.scrollThrottle = null;\n\n            // Cache all layout queries to prevent multiple forced reflows\n            this.cachedScrollY = window.scrollY;\n            this.cachedWindowWidth = window.innerWidth;\n            this.cachedIsAboutUs = this.router?.url?.includes('/about-us');\n\n            const shouldScroll = this.cachedScrollY > 150;\n            this.isScrolled = shouldScroll;\n\n            if (!this.cachedIsAboutUs) {\n                const newLogo = shouldScroll ? this.contrastImageUrl : this.darkImageUrl;\n                if (this.logo !== newLogo) {\n                    this.logo = newLogo;\n                }\n            }\n\n            if (this.cachedWindowWidth < 768) {\n                this.open = false;\n                const collapseElement = this.navbarCollapse?.nativeElement;\n                if (collapseElement?.classList.contains('show')) {\n                    // Use requestAnimationFrame for DOM manipulation to prevent reflows\n                    requestAnimationFrame(() => {\n                        collapseElement.classList.remove('show');\n                    });\n                }\n            }\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>"]}
@@ -1879,6 +1879,8 @@ class ResourceHeaderComponent extends AppBaseComponent {
1879
1879
  this.editingNavbar = {
1880
1880
  items: []
1881
1881
  };
1882
+ this.cachedScrollY = 0;
1883
+ this.cachedWindowWidth = window.innerWidth;
1882
1884
  }
1883
1885
  ngOnInit() {
1884
1886
  const isAboutUs = this.router.url?.includes('/about-us');
@@ -1892,10 +1894,10 @@ class ResourceHeaderComponent extends AppBaseComponent {
1892
1894
  const data = res ? JSON.parse(res) : null;
1893
1895
  this.id = data?.subscriptionId;
1894
1896
  });
1897
+ this.userService.getUserInfo().subscribe(data => {
1898
+ this.user = data;
1899
+ });
1895
1900
  }
1896
- this.userService.getUserInfo().subscribe(data => {
1897
- this.user = data;
1898
- });
1899
1901
  });
1900
1902
  }
1901
1903
  openLogoEditModal() {
@@ -1926,24 +1928,35 @@ class ResourceHeaderComponent extends AppBaseComponent {
1926
1928
  });
1927
1929
  }
1928
1930
  onScroll() {
1929
- clearTimeout(this.scrollTimeout);
1930
- this.scrollTimeout = setTimeout(() => {
1931
- const isAboutUs = this.router?.url?.includes('/about-us');
1932
- this.isScrolled = window.scrollY > 150;
1933
- if (!isAboutUs) {
1934
- const newLogo = window.scrollY > 150 ? this.contrastImageUrl : this.darkImageUrl;
1931
+ // Throttle scroll events to prevent forced reflows
1932
+ if (this.scrollThrottle) {
1933
+ return;
1934
+ }
1935
+ this.scrollThrottle = requestAnimationFrame(() => {
1936
+ this.scrollThrottle = null;
1937
+ // Cache all layout queries to prevent multiple forced reflows
1938
+ this.cachedScrollY = window.scrollY;
1939
+ this.cachedWindowWidth = window.innerWidth;
1940
+ this.cachedIsAboutUs = this.router?.url?.includes('/about-us');
1941
+ const shouldScroll = this.cachedScrollY > 150;
1942
+ this.isScrolled = shouldScroll;
1943
+ if (!this.cachedIsAboutUs) {
1944
+ const newLogo = shouldScroll ? this.contrastImageUrl : this.darkImageUrl;
1935
1945
  if (this.logo !== newLogo) {
1936
1946
  this.logo = newLogo;
1937
1947
  }
1938
1948
  }
1939
- if (window.innerWidth < 768) {
1949
+ if (this.cachedWindowWidth < 768) {
1940
1950
  this.open = false;
1941
1951
  const collapseElement = this.navbarCollapse?.nativeElement;
1942
1952
  if (collapseElement?.classList.contains('show')) {
1943
- collapseElement.classList.remove('show');
1953
+ // Use requestAnimationFrame for DOM manipulation to prevent reflows
1954
+ requestAnimationFrame(() => {
1955
+ collapseElement.classList.remove('show');
1956
+ });
1944
1957
  }
1945
1958
  }
1946
- }, 50);
1959
+ });
1947
1960
  }
1948
1961
  openEditNavbarModal() {
1949
1962
  const navbarConfig = this.appConfig.pages_config?.navbar || {};