@posiwise/shared-components 0.0.136 → 0.0.137

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.
@@ -41,12 +41,8 @@ export class ResourceHeaderComponent extends AppBaseComponent {
41
41
  const logos = config.company.logos;
42
42
  // Use smaller version for better performance (100x100 instead of 1200x264)
43
43
  this.logo = isAboutUs
44
- ? logos.main_contrast?.version_100x100?.url ||
45
- logos.main_contrast?.url ||
46
- '/assets/img/landing-page/site-logo.png'
47
- : logos.main_dark?.version_100x100?.url ||
48
- logos.main_dark?.url ||
49
- '/assets/img/landing-page/site-logo.png';
44
+ ? logos.main_contrast?.url || '/assets/img/landing-page/site-logo.png'
45
+ : logos.main_dark?.url || '/assets/img/landing-page/site-logo.png';
50
46
  }
51
47
  });
52
48
  if (this.userLoggedIn) {
@@ -100,10 +96,10 @@ export class ResourceHeaderComponent extends AppBaseComponent {
100
96
  // Use smaller versions for better performance
101
97
  const logos = this.appConfig?.company?.logos;
102
98
  const newLogo = shouldScroll
103
- ? logos?.main_contrast?.version_100x100?.url ??
99
+ ? logos?.main_contrast?.url ??
104
100
  this.contrastImageUrl ??
105
101
  '/assets/img/landing-page/site-logo.png'
106
- : logos?.main_dark?.version_100x100?.url ??
102
+ : logos?.main_dark?.url ??
107
103
  this.darkImageUrl ??
108
104
  '/assets/img/landing-page/site-logo.png';
109
105
  if (this.logo !== newLogo) {
@@ -241,4 +237,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
241
237
  type: HostListener,
242
238
  args: ['document:click', ['$event']]
243
239
  }] } });
244
- //# 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    Input,\n    OnChanges,\n    OnInit,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { CustomUploaderComponent } from '../custom-uploader/custom-uploader.component';\n\ninterface LogoConfig {\n    url?: string;\n    version_100x100?: {\n        url?: string;\n    };\n}\n\ninterface LogosConfig {\n    main_contrast?: LogoConfig;\n    main_dark?: LogoConfig;\n}\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, OnChanges {\n    @ViewChild('collapsibleNavbar') navbarCollapse: ElementRef;\n    @ViewChild('editNavbarModal') editNavbarModal: TemplateRef<CustomUploaderComponent>;\n    @ViewChild('logoEditModal') logoEditModal: TemplateRef<CustomUploaderComponent>;\n    @Input() user: User;\n    @Input() userLoggedIn: boolean;\n\n    isScrolled = false;\n    open = false;\n    logo = '/assets/img/landing-page/site-logo.png'; // Static fallback for LCP optimization\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    scrollTimeout;\n\n    canEditResourcesValue = false;\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        console.log('In Header');\n        // Subscribe to appConfig changes to update logo dynamically\n        this.appConfigService.appConfig$.subscribe(config => {\n            if (config?.company?.logos) {\n                const isAboutUs = this.router.url?.includes('/about-us');\n                const logos = config.company.logos as LogosConfig;\n\n                // Use smaller version for better performance (100x100 instead of 1200x264)\n                this.logo = isAboutUs\n                    ? logos.main_contrast?.version_100x100?.url ||\n                      logos.main_contrast?.url ||\n                      '/assets/img/landing-page/site-logo.png'\n                    : logos.main_dark?.version_100x100?.url ||\n                      logos.main_dark?.url ||\n                      '/assets/img/landing-page/site-logo.png';\n            }\n        });\n\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    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['user'] || changes['userLoggedIn']) {\n            if (this.userLoggedIn && this.user) {\n                this.updateCanEditResourcesValue();\n            }\n        }\n    }\n\n    openLogoEditModal() {\n        this.modalService.open(this.logoEditModal, { centered: true, size: 'md' });\n    }\n\n    onSaveLogo(event) {\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        clearTimeout(this.scrollTimeout);\n        this.scrollTimeout = setTimeout(() => {\n            requestAnimationFrame(() => {\n                const isAboutUs = this.router?.url?.includes('/about-us');\n                const shouldScroll = window.scrollY > 150;\n                this.isScrolled = shouldScroll;\n\n                if (!isAboutUs) {\n                    // Use smaller versions for better performance\n                    const logos = this.appConfig?.company?.logos as LogosConfig;\n                    const newLogo = shouldScroll\n                        ? logos?.main_contrast?.version_100x100?.url ??\n                          this.contrastImageUrl ??\n                          '/assets/img/landing-page/site-logo.png'\n                        : logos?.main_dark?.version_100x100?.url ??\n                          this.darkImageUrl ??\n                          '/assets/img/landing-page/site-logo.png';\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\n                // Close all dropdowns when scrolling\n                this.closeAllDropdowns();\n            });\n        }, 50);\n    }\n\n    @HostListener('document:click', ['$event'])\n    onDocumentClick(event: Event): void {\n        // Close all dropdowns when clicking outside\n        const target = event.target as HTMLElement;\n        if (\n            !target.closest('.nav-item') &&\n            !target.closest('.popup') &&\n            !target.closest('.sign-btn')\n        ) {\n            this.closeAllDropdowns();\n        }\n    }\n\n    closeAllDropdowns(): void {\n        if (this.navbarItems) {\n            this.navbarItems.forEach(item => {\n                if (item.open) {\n                    item.open = false;\n                }\n            });\n        }\n    }\n\n    openDropdown(item): void {\n        // Close other dropdowns first\n        this.navbarItems.forEach(navItem => {\n            if (navItem !== item) {\n                navItem.open = false;\n            }\n        });\n        item.open = true;\n    }\n\n    onDropdownItemClick(item): void {\n        item.open = false;\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                // Update the appConfig to reflect the saved changes\n                this.appConfig.pages_config = this.appConfig.pages_config ?? {};\n                this.appConfig.pages_config.navbar = { ...this.editingNavbar };\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    private updateCanEditResourcesValue(): void {\n        this.canEditResourcesValue = HelperService.canEditResources(\n            this.user,\n            this.userLoggedIn,\n            this.permissionService\n        );\n    }\n\n    canEditResources(): boolean {\n        return this.canEditResourcesValue;\n    }\n\n    navigateToLogin(): void {\n        window.location.href = '/login';\n    }\n}\n","<nav class=\"navbar navbar-expand-md navbar-dark fixed-top primary-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=\"/assets/img/landing-page/site-logo.png\"\n          [src]=\"logo || '/assets/img/landing-page/site-logo.png'\"\n          routerLink=\"/\"\n          alt=\"logo\"\n          class=\"img-fluid logo_img\"\n          width=\"100\"\n          height=\"100\"\n          loading=\"eager\"\n          fetchpriority=\"high\"\n          sizes=\"100px\" />\n      </div>\n    </div>\n\n\n    <i *ngIf=\"canEditResourcesValue\"\n    class=\"fa fa-edit in-page-edit-icon cursor-pointer text-black me-3\"\n    (click)=\"openLogoEditModal()\"\n    (keydown.enter)=\"openLogoEditModal()\"\n    (keydown.space)=\"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>\n            <img src=\"/assets/img/landing-page/site-logo.png\"\n              [src]=\"logo || '/assets/img/landing-page/site-logo.png'\"\n              routerLink=\"/\"\n              alt=\"logo\"\n              class=\"img-fluid logo_img\"\n              width=\"100\"\n              height=\"100\"\n              loading=\"eager\"\n              fetchpriority=\"high\"\n              sizes=\"100px\" />\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=\"canEditResourcesValue\"\n          class=\"fa fa-edit in-page-edit-icon cursor-pointer text-black me-3\"\n          (click)=\"openEditNavbarModal()\"\n          (keydown.enter)=\"openEditNavbarModal()\"\n          (keydown.space)=\"openEditNavbarModal()\"\n          title=\"Edit Navbar Links\"></i>\n            <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n                <div class=\"dropdown-container\"\n                     (mouseenter)=\"openDropdown(item)\">\n                    <a\n                    class=\"nav-link\"\n                      href=\"javascript:void(0)\"\n                      [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\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                          (click)=\"onDropdownItemClick(item)\"\n                          (keydown.enter)=\"onDropdownItemClick(item)\"\n                          (keydown.space)=\"onDropdownItemClick(item)\"\n                        >\n                          {{ sub.title }}\n                        </li>\n                    </ul>\n                  </div>\n                </div>\n            </li>\n\n            <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n              <a class=\"sign-btn sign-header-btn\"\n                (click)=\"navigateToLogin()\">Log In</a>\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            <a class=\"sign-btn sign-header-btn\"\n              (click)=\"navigateToLogin()\">Log In</a>\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 for=\"navbarTitle{{i}}\" class=\"form-label\">Title</label>\n            <input id=\"navbarTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"item.title\" />\n          </div>\n          <div class=\"col-md-5 mb-2\">\n            <label for=\"navbarPath{{i}}\" class=\"form-label\">Path</label>\n            <input id=\"navbarPath{{i}}\" 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)\" (keydown.enter)=\"removeNavbarItem(i)\"\n            (keydown.space)=\"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 for=\"navbarSubtitleTitle{{i}}{{j}}\" class=\"form-label\">Subtitle Title</label>\n              <input id=\"navbarSubtitleTitle{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"sub.title\" />\n            </div>\n            <div class=\"col-md-5\">\n              <label for=\"navbarSubtitlePath{{i}}{{j}}\" class=\"form-label\">Subtitle Path</label>\n              <input id=\"navbarSubtitlePath{{i}}{{j}}\" 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)\" (keydown.enter)=\"removeNavbarSubtitle(i, j)\" (keydown.space)=\"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>"]}
240
+ //# 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    Input,\n    OnChanges,\n    OnInit,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { CustomUploaderComponent } from '../custom-uploader/custom-uploader.component';\n\ninterface LogoConfig {\n    url?: string;\n    version_100x100?: {\n        url?: string;\n    };\n}\n\ninterface LogosConfig {\n    main_contrast?: LogoConfig;\n    main_dark?: LogoConfig;\n}\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, OnChanges {\n    @ViewChild('collapsibleNavbar') navbarCollapse: ElementRef;\n    @ViewChild('editNavbarModal') editNavbarModal: TemplateRef<CustomUploaderComponent>;\n    @ViewChild('logoEditModal') logoEditModal: TemplateRef<CustomUploaderComponent>;\n    @Input() user: User;\n    @Input() userLoggedIn: boolean;\n\n    isScrolled = false;\n    open = false;\n    logo = '/assets/img/landing-page/site-logo.png'; // Static fallback for LCP optimization\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    scrollTimeout;\n\n    canEditResourcesValue = false;\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        console.log('In Header');\n        // Subscribe to appConfig changes to update logo dynamically\n        this.appConfigService.appConfig$.subscribe(config => {\n            if (config?.company?.logos) {\n                const isAboutUs = this.router.url?.includes('/about-us');\n                const logos = config.company.logos as LogosConfig;\n\n                // Use smaller version for better performance (100x100 instead of 1200x264)\n                this.logo = isAboutUs\n                    ? logos.main_contrast?.url || '/assets/img/landing-page/site-logo.png'\n                    : logos.main_dark?.url || '/assets/img/landing-page/site-logo.png';\n            }\n        });\n\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    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['user'] || changes['userLoggedIn']) {\n            if (this.userLoggedIn && this.user) {\n                this.updateCanEditResourcesValue();\n            }\n        }\n    }\n\n    openLogoEditModal() {\n        this.modalService.open(this.logoEditModal, { centered: true, size: 'md' });\n    }\n\n    onSaveLogo(event) {\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        clearTimeout(this.scrollTimeout);\n        this.scrollTimeout = setTimeout(() => {\n            requestAnimationFrame(() => {\n                const isAboutUs = this.router?.url?.includes('/about-us');\n                const shouldScroll = window.scrollY > 150;\n                this.isScrolled = shouldScroll;\n\n                if (!isAboutUs) {\n                    // Use smaller versions for better performance\n                    const logos = this.appConfig?.company?.logos as LogosConfig;\n                    const newLogo = shouldScroll\n                        ? logos?.main_contrast?.url ??\n                          this.contrastImageUrl ??\n                          '/assets/img/landing-page/site-logo.png'\n                        : logos?.main_dark?.url ??\n                          this.darkImageUrl ??\n                          '/assets/img/landing-page/site-logo.png';\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\n                // Close all dropdowns when scrolling\n                this.closeAllDropdowns();\n            });\n        }, 50);\n    }\n\n    @HostListener('document:click', ['$event'])\n    onDocumentClick(event: Event): void {\n        // Close all dropdowns when clicking outside\n        const target = event.target as HTMLElement;\n        if (\n            !target.closest('.nav-item') &&\n            !target.closest('.popup') &&\n            !target.closest('.sign-btn')\n        ) {\n            this.closeAllDropdowns();\n        }\n    }\n\n    closeAllDropdowns(): void {\n        if (this.navbarItems) {\n            this.navbarItems.forEach(item => {\n                if (item.open) {\n                    item.open = false;\n                }\n            });\n        }\n    }\n\n    openDropdown(item): void {\n        // Close other dropdowns first\n        this.navbarItems.forEach(navItem => {\n            if (navItem !== item) {\n                navItem.open = false;\n            }\n        });\n        item.open = true;\n    }\n\n    onDropdownItemClick(item): void {\n        item.open = false;\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                // Update the appConfig to reflect the saved changes\n                this.appConfig.pages_config = this.appConfig.pages_config ?? {};\n                this.appConfig.pages_config.navbar = { ...this.editingNavbar };\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    private updateCanEditResourcesValue(): void {\n        this.canEditResourcesValue = HelperService.canEditResources(\n            this.user,\n            this.userLoggedIn,\n            this.permissionService\n        );\n    }\n\n    canEditResources(): boolean {\n        return this.canEditResourcesValue;\n    }\n\n    navigateToLogin(): void {\n        window.location.href = '/login';\n    }\n}\n","<nav class=\"navbar navbar-expand-md navbar-dark fixed-top primary-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=\"/assets/img/landing-page/site-logo.png\"\n          [src]=\"logo || '/assets/img/landing-page/site-logo.png'\"\n          routerLink=\"/\"\n          alt=\"logo\"\n          class=\"img-fluid logo_img\"\n          width=\"100\"\n          height=\"100\"\n          loading=\"eager\"\n          fetchpriority=\"high\"\n          sizes=\"100px\" />\n      </div>\n    </div>\n\n\n    <i *ngIf=\"canEditResourcesValue\"\n    class=\"fa fa-edit in-page-edit-icon cursor-pointer text-black me-3\"\n    (click)=\"openLogoEditModal()\"\n    (keydown.enter)=\"openLogoEditModal()\"\n    (keydown.space)=\"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>\n            <img src=\"/assets/img/landing-page/site-logo.png\"\n              [src]=\"logo || '/assets/img/landing-page/site-logo.png'\"\n              routerLink=\"/\"\n              alt=\"logo\"\n              class=\"img-fluid logo_img\"\n              width=\"100\"\n              height=\"100\"\n              loading=\"eager\"\n              fetchpriority=\"high\"\n              sizes=\"100px\" />\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=\"canEditResourcesValue\"\n          class=\"fa fa-edit in-page-edit-icon cursor-pointer text-black me-3\"\n          (click)=\"openEditNavbarModal()\"\n          (keydown.enter)=\"openEditNavbarModal()\"\n          (keydown.space)=\"openEditNavbarModal()\"\n          title=\"Edit Navbar Links\"></i>\n            <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n                <div class=\"dropdown-container\"\n                     (mouseenter)=\"openDropdown(item)\">\n                    <a\n                    class=\"nav-link\"\n                      href=\"javascript:void(0)\"\n                      [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\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                          (click)=\"onDropdownItemClick(item)\"\n                          (keydown.enter)=\"onDropdownItemClick(item)\"\n                          (keydown.space)=\"onDropdownItemClick(item)\"\n                        >\n                          {{ sub.title }}\n                        </li>\n                    </ul>\n                  </div>\n                </div>\n            </li>\n\n            <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n              <a class=\"sign-btn sign-header-btn\"\n                (click)=\"navigateToLogin()\">Log In</a>\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            <a class=\"sign-btn sign-header-btn\"\n              (click)=\"navigateToLogin()\">Log In</a>\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 for=\"navbarTitle{{i}}\" class=\"form-label\">Title</label>\n            <input id=\"navbarTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"item.title\" />\n          </div>\n          <div class=\"col-md-5 mb-2\">\n            <label for=\"navbarPath{{i}}\" class=\"form-label\">Path</label>\n            <input id=\"navbarPath{{i}}\" 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)\" (keydown.enter)=\"removeNavbarItem(i)\"\n            (keydown.space)=\"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 for=\"navbarSubtitleTitle{{i}}{{j}}\" class=\"form-label\">Subtitle Title</label>\n              <input id=\"navbarSubtitleTitle{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"sub.title\" />\n            </div>\n            <div class=\"col-md-5\">\n              <label for=\"navbarSubtitlePath{{i}}{{j}}\" class=\"form-label\">Subtitle Path</label>\n              <input id=\"navbarSubtitlePath{{i}}{{j}}\" 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)\" (keydown.enter)=\"removeNavbarSubtitle(i, j)\" (keydown.space)=\"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>"]}
@@ -1923,12 +1923,8 @@ class ResourceHeaderComponent extends AppBaseComponent {
1923
1923
  const logos = config.company.logos;
1924
1924
  // Use smaller version for better performance (100x100 instead of 1200x264)
1925
1925
  this.logo = isAboutUs
1926
- ? logos.main_contrast?.version_100x100?.url ||
1927
- logos.main_contrast?.url ||
1928
- '/assets/img/landing-page/site-logo.png'
1929
- : logos.main_dark?.version_100x100?.url ||
1930
- logos.main_dark?.url ||
1931
- '/assets/img/landing-page/site-logo.png';
1926
+ ? logos.main_contrast?.url || '/assets/img/landing-page/site-logo.png'
1927
+ : logos.main_dark?.url || '/assets/img/landing-page/site-logo.png';
1932
1928
  }
1933
1929
  });
1934
1930
  if (this.userLoggedIn) {
@@ -1982,10 +1978,10 @@ class ResourceHeaderComponent extends AppBaseComponent {
1982
1978
  // Use smaller versions for better performance
1983
1979
  const logos = this.appConfig?.company?.logos;
1984
1980
  const newLogo = shouldScroll
1985
- ? logos?.main_contrast?.version_100x100?.url ??
1981
+ ? logos?.main_contrast?.url ??
1986
1982
  this.contrastImageUrl ??
1987
1983
  '/assets/img/landing-page/site-logo.png'
1988
- : logos?.main_dark?.version_100x100?.url ??
1984
+ : logos?.main_dark?.url ??
1989
1985
  this.darkImageUrl ??
1990
1986
  '/assets/img/landing-page/site-logo.png';
1991
1987
  if (this.logo !== newLogo) {