ng-prime-tools 1.0.12 → 1.0.13

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.
@@ -24,10 +24,12 @@ export class PTSideBarMenuComponent {
24
24
  hoverColorSubMenu: '#e0e0e0', // Default hover color for submenu
25
25
  };
26
26
  this.searchCardConfig = {
27
+ identifier: 'pt-side-bar-menu/search',
27
28
  backgroundColor: 'white',
28
29
  height: '72px',
29
30
  };
30
31
  this.cardConfig = {
32
+ identifier: 'pt-side-bar-menu',
31
33
  backgroundColor: '',
32
34
  width: '',
33
35
  height: '',
@@ -45,6 +47,7 @@ export class PTSideBarMenuComponent {
45
47
  }
46
48
  ngOnInit() {
47
49
  this.cardConfig = {
50
+ identifier: 'pt-side-bar-menu',
48
51
  backgroundColor: this.menuConfig.backgroundColor,
49
52
  width: this.menuConfig.width,
50
53
  height: this.menuConfig.height,
@@ -203,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
203
206
  }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { menuConfig: [{
204
207
  type: Input
205
208
  }] } });
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-side-bar-menu.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-side-bar-menu/pt-side-bar-menu.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-side-bar-menu/pt-side-bar-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  Renderer2,\n} from '@angular/core';\nimport { FormGroup, FormControl } from '@angular/forms';\nimport {\n  Menu,\n  FormTextField,\n  SideMenuBarConfig,\n  CardConfig,\n  Badge,\n} from '../models';\nimport { BadgeType } from '../enums';\n\n@Component({\n  selector: 'pt-side-bar-menu',\n  templateUrl: './pt-side-bar-menu.component.html',\n  styleUrls: ['./pt-side-bar-menu.component.css'],\n})\nexport class PTSideBarMenuComponent implements OnInit, AfterViewInit {\n  @Input() menuConfig: SideMenuBarConfig = {\n    menus: [],\n    isVisible: true,\n    searchable: true,\n    width: '250px',\n    height: '100vh',\n    scrollable: true,\n    backgroundColor: 'white',\n    fontColor: '#333', // Default main font color\n    fontColorSubMenu: '#666', // Default submenu font color\n    hoverColor: '#f1f1f1', // Default hover color for main menu\n    hoverColorSubMenu: '#e0e0e0', // Default hover color for submenu\n  };\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  searchCardConfig: CardConfig = {\n    backgroundColor: 'white',\n    height: '72px',\n  };\n\n  cardConfig: CardConfig = {\n    backgroundColor: '',\n    width: '',\n    height: '',\n    scrollableVertical: false,\n  };\n\n  formGroup: FormGroup = new FormGroup({\n    search: new FormControl(''),\n  });\n\n  searchField: FormTextField = {\n    name: 'search',\n    placeholder: 'Search...',\n    iconClass: 'pi pi-search',\n  };\n\n  filteredMenus: Menu[] = [];\n\n  ngOnInit(): void {\n    this.cardConfig = {\n      backgroundColor: this.menuConfig.backgroundColor,\n      width: this.menuConfig.width,\n      height: this.menuConfig.height,\n      scrollableVertical: this.menuConfig.scrollable,\n      pattern: this.menuConfig.pattern,\n    };\n\n    this.filteredMenus = this.menuConfig.menus;\n\n    const cardWidth = this.menuConfig.width\n      ? parseInt(this.menuConfig.width)\n      : 250;\n    this.searchField.width = `${cardWidth - 60}px`;\n    this.searchCardConfig.width = this.menuConfig.width;\n    this.searchCardConfig.pattern = this.menuConfig.pattern;\n\n    if (this.menuConfig.searchable) {\n      this.formGroup\n        .get('search')\n        ?.valueChanges.subscribe((searchTerm: string) => {\n          this.onSearch(searchTerm);\n        });\n    }\n  }\n\n  toggleMenu(item: Menu, event: Event): void {\n    item.isExpanded = !item.isExpanded;\n    event.preventDefault();\n  }\n\n  getChevronClass(item: Menu): string {\n    return item.isExpanded ? 'fa fa-chevron-down' : 'fa fa-chevron-right';\n  }\n\n  getBadgeStyles(badge: Badge) {\n    const defaultColors = this.getDefaultBadgeColors(\n      badge.type || BadgeType.Info\n    );\n\n    return {\n      color: badge.color || defaultColors.color,\n      backgroundColor: badge.backgroundColor || defaultColors.backgroundColor,\n      padding: '2px 8px',\n      borderRadius: '5px',\n      fontSize: '12px',\n    };\n  }\n\n  getDefaultBadgeColors(type: BadgeType) {\n    switch (type) {\n      case BadgeType.Info:\n        return { color: 'white', backgroundColor: '#17a2b8' };\n      case BadgeType.Danger:\n        return { color: 'white', backgroundColor: '#dc3545' };\n      case BadgeType.Warning:\n        return { color: 'white', backgroundColor: '#ffc107' };\n      default:\n        return { color: 'white', backgroundColor: '#6c757d' };\n    }\n  }\n\n  onSearch(searchTerm: string): void {\n    if (searchTerm.trim() === '') {\n      this.filteredMenus = this.menuConfig.menus;\n      this.collapseAllMenus();\n    } else {\n      const lowerCaseSearch = searchTerm.toLowerCase();\n      this.filteredMenus = this.menuConfig.menus\n        .map((menu) => this.searchInMenu({ ...menu }, lowerCaseSearch))\n        .filter(Boolean) as Menu[];\n    }\n  }\n\n  searchInMenu(menu: Menu, searchTerm: string): Menu | null {\n    const isMatch = menu.label.toLowerCase().includes(searchTerm);\n\n    if (menu.children) {\n      const matchingChildren = menu.children\n        .map((child) => this.searchInMenu(child, searchTerm))\n        .filter(Boolean) as Menu[];\n\n      if (matchingChildren.length > 0) {\n        menu.children = matchingChildren;\n        menu.isExpanded = true;\n        return menu;\n      }\n    }\n\n    return isMatch ? menu : null;\n  }\n\n  collapseAllMenus(): void {\n    this.menuConfig.menus.forEach((menu) => {\n      menu.isExpanded = false;\n    });\n  }\n\n  getMenuItemStyles(): any {\n    return {\n      color: this.menuConfig.fontColor || '#333', // Set default font color if not specified in config\n    };\n  }\n\n  getMenuLinkStyles(): any {\n    return {\n      color: this.menuConfig.fontColor || '#333',\n      'text-decoration': 'none',\n      'border-radius': '8px',\n      padding: '10px 15px',\n      'font-size': '16px',\n      transition: 'background-color 0.2s, color 0.2s',\n      display: 'flex',\n      'align-items': 'center',\n      ':hover': {\n        backgroundColor: this.menuConfig.hoverColor || '#f1f1f1',\n        color: '#111',\n      },\n    };\n  }\n\n  getSubMenuLinkStyles(): any {\n    return {\n      color:\n        this.menuConfig.fontColorSubMenu || this.menuConfig.fontColor || '#666',\n      'text-decoration': 'none',\n      'border-radius': '5px',\n      padding: '5px 10px',\n      transition: 'background-color 0.2s, color 0.2s',\n      ':hover': {\n        backgroundColor: this.menuConfig.hoverColorSubMenu || '#e0e0e0',\n      },\n    };\n  }\n  ngAfterViewInit(): void {\n    this.applyHoverEffects();\n  }\n\n  applyHoverEffects(): void {\n    const menuLinks = this.el.nativeElement.querySelectorAll('a.menu-link');\n    const subMenuLinks =\n      this.el.nativeElement.querySelectorAll('a.submenu-link');\n\n    // Apply hover effects for main menu links\n    menuLinks.forEach((link: HTMLElement) => {\n      this.renderer.listen(link, 'mouseenter', () => {\n        this.renderer.setStyle(\n          link,\n          'background-color',\n          this.menuConfig.hoverColor || '#f1f1f1'\n        );\n        this.renderer.setStyle(\n          link,\n          'color',\n          this.menuConfig.hoverFontColor || 'white'\n        );\n      });\n\n      this.renderer.listen(link, 'mouseleave', () => {\n        this.renderer.removeStyle(link, 'background-color');\n        this.renderer.setStyle(\n          link,\n          'color',\n          this.menuConfig.fontColor || '#333'\n        );\n      });\n    });\n\n    // Apply hover effects for submenu links\n    subMenuLinks.forEach((link: HTMLElement) => {\n      this.renderer.listen(link, 'mouseenter', () => {\n        this.renderer.setStyle(\n          link,\n          'background-color',\n          this.menuConfig.hoverColorSubMenu ||\n            this.menuConfig.hoverColor ||\n            '#f1f1f1'\n        );\n        this.renderer.setStyle(\n          link,\n          'color',\n          this.menuConfig.hoverFontColorSubMenu ||\n            this.menuConfig.hoverFontColor ||\n            '#fff'\n        );\n      });\n\n      this.renderer.listen(link, 'mouseleave', () => {\n        this.renderer.removeStyle(link, 'background-color');\n        this.renderer.setStyle(\n          link,\n          'color',\n          this.menuConfig.fontColorSubMenu ||\n            this.menuConfig.fontColor ||\n            '#666'\n        );\n      });\n    });\n  }\n}\n","<div class=\"pt-side-bar-menu\">\n  <pt-card\n    *ngIf=\"menuConfig.searchable\"\n    [config]=\"searchCardConfig\"\n    [ngClass]=\"{ 'sidebar-hidden': !menuConfig.isVisible }\"\n  >\n    <div class=\"search-input\">\n      <pt-text-input [formGroup]=\"formGroup\" [formField]=\"searchField\">\n      </pt-text-input>\n    </div>\n  </pt-card>\n\n  <pt-card\n    [config]=\"cardConfig\"\n    [ngClass]=\"{ 'sidebar-hidden': !menuConfig.isVisible }\"\n  >\n    <ul class=\"menu-list\">\n      <li\n        *ngFor=\"let item of filteredMenus\"\n        class=\"menu-item\"\n        [ngClass]=\"{ 'menu-item-expanded': item.isExpanded }\"\n        [ngStyle]=\"getMenuItemStyles()\"\n      >\n        <!-- Main menu items without children -->\n        <a\n          *ngIf=\"!item.children?.length\"\n          [routerLink]=\"item.url\"\n          class=\"menu-link\"\n          [ngStyle]=\"getMenuLinkStyles()\"\n        >\n          <i [ngClass]=\"item.icon\"></i>\n          <span>{{ item.label }}</span>\n          <span\n            *ngIf=\"item.badge\"\n            [ngStyle]=\"getBadgeStyles(item.badge)\"\n            class=\"badge\"\n          >\n            {{ item.badge.count }}\n          </span>\n        </a>\n\n        <!-- Menu items with children -->\n        <a\n          *ngIf=\"item.children?.length\"\n          class=\"menu-link\"\n          (click)=\"toggleMenu(item, $event)\"\n          [ngStyle]=\"getMenuLinkStyles()\"\n        >\n          <i [ngClass]=\"item.icon\"></i>\n          <span>{{ item.label }}</span>\n          <span\n            *ngIf=\"item.badge\"\n            [ngStyle]=\"getBadgeStyles(item.badge)\"\n            class=\"badge\"\n          >\n            {{ item.badge.count }}\n          </span>\n          <i [ngClass]=\"getChevronClass(item)\" class=\"chevron\"></i>\n        </a>\n\n        <!-- Submenu -->\n        <ul class=\"submenu-list\">\n          <li *ngFor=\"let child of item.children\" class=\"submenu-item\">\n            <a\n              [routerLink]=\"child.url\"\n              class=\"submenu-link\"\n              [ngStyle]=\"getSubMenuLinkStyles()\"\n            >\n              <i [ngClass]=\"child.icon\"></i>\n              <span class=\"submenu-title\">{{ child.label }}</span>\n              <span\n                *ngIf=\"child.badge\"\n                [ngStyle]=\"getBadgeStyles(child.badge)\"\n                class=\"badge\"\n              >\n                {{ child.badge.count }}\n              </span>\n            </a>\n          </li>\n        </ul>\n      </li>\n    </ul>\n  </pt-card>\n</div>\n"]}
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-side-bar-menu.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-side-bar-menu/pt-side-bar-menu.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-side-bar-menu/pt-side-bar-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  Renderer2,\n} from '@angular/core';\nimport { FormGroup, FormControl } from '@angular/forms';\nimport {\n  Menu,\n  FormTextField,\n  SideMenuBarConfig,\n  CardConfig,\n  Badge,\n} from '../models';\nimport { BadgeType } from '../enums';\n\n@Component({\n  selector: 'pt-side-bar-menu',\n  templateUrl: './pt-side-bar-menu.component.html',\n  styleUrls: ['./pt-side-bar-menu.component.css'],\n})\nexport class PTSideBarMenuComponent implements OnInit, AfterViewInit {\n  @Input() menuConfig: SideMenuBarConfig = {\n    menus: [],\n    isVisible: true,\n    searchable: true,\n    width: '250px',\n    height: '100vh',\n    scrollable: true,\n    backgroundColor: 'white',\n    fontColor: '#333', // Default main font color\n    fontColorSubMenu: '#666', // Default submenu font color\n    hoverColor: '#f1f1f1', // Default hover color for main menu\n    hoverColorSubMenu: '#e0e0e0', // Default hover color for submenu\n  };\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  searchCardConfig: CardConfig = {\n    identifier: 'pt-side-bar-menu/search',\n    backgroundColor: 'white',\n    height: '72px',\n  };\n\n  cardConfig: CardConfig = {\n    identifier: 'pt-side-bar-menu',\n    backgroundColor: '',\n    width: '',\n    height: '',\n    scrollableVertical: false,\n  };\n\n  formGroup: FormGroup = new FormGroup({\n    search: new FormControl(''),\n  });\n\n  searchField: FormTextField = {\n    name: 'search',\n    placeholder: 'Search...',\n    iconClass: 'pi pi-search',\n  };\n\n  filteredMenus: Menu[] = [];\n\n  ngOnInit(): void {\n    this.cardConfig = {\n      identifier: 'pt-side-bar-menu',\n      backgroundColor: this.menuConfig.backgroundColor,\n      width: this.menuConfig.width,\n      height: this.menuConfig.height,\n      scrollableVertical: this.menuConfig.scrollable,\n      pattern: this.menuConfig.pattern,\n    };\n\n    this.filteredMenus = this.menuConfig.menus;\n\n    const cardWidth = this.menuConfig.width\n      ? parseInt(this.menuConfig.width)\n      : 250;\n    this.searchField.width = `${cardWidth - 60}px`;\n    this.searchCardConfig.width = this.menuConfig.width;\n    this.searchCardConfig.pattern = this.menuConfig.pattern;\n\n    if (this.menuConfig.searchable) {\n      this.formGroup\n        .get('search')\n        ?.valueChanges.subscribe((searchTerm: string) => {\n          this.onSearch(searchTerm);\n        });\n    }\n  }\n\n  toggleMenu(item: Menu, event: Event): void {\n    item.isExpanded = !item.isExpanded;\n    event.preventDefault();\n  }\n\n  getChevronClass(item: Menu): string {\n    return item.isExpanded ? 'fa fa-chevron-down' : 'fa fa-chevron-right';\n  }\n\n  getBadgeStyles(badge: Badge) {\n    const defaultColors = this.getDefaultBadgeColors(\n      badge.type || BadgeType.Info\n    );\n\n    return {\n      color: badge.color || defaultColors.color,\n      backgroundColor: badge.backgroundColor || defaultColors.backgroundColor,\n      padding: '2px 8px',\n      borderRadius: '5px',\n      fontSize: '12px',\n    };\n  }\n\n  getDefaultBadgeColors(type: BadgeType) {\n    switch (type) {\n      case BadgeType.Info:\n        return { color: 'white', backgroundColor: '#17a2b8' };\n      case BadgeType.Danger:\n        return { color: 'white', backgroundColor: '#dc3545' };\n      case BadgeType.Warning:\n        return { color: 'white', backgroundColor: '#ffc107' };\n      default:\n        return { color: 'white', backgroundColor: '#6c757d' };\n    }\n  }\n\n  onSearch(searchTerm: string): void {\n    if (searchTerm.trim() === '') {\n      this.filteredMenus = this.menuConfig.menus;\n      this.collapseAllMenus();\n    } else {\n      const lowerCaseSearch = searchTerm.toLowerCase();\n      this.filteredMenus = this.menuConfig.menus\n        .map((menu) => this.searchInMenu({ ...menu }, lowerCaseSearch))\n        .filter(Boolean) as Menu[];\n    }\n  }\n\n  searchInMenu(menu: Menu, searchTerm: string): Menu | null {\n    const isMatch = menu.label.toLowerCase().includes(searchTerm);\n\n    if (menu.children) {\n      const matchingChildren = menu.children\n        .map((child) => this.searchInMenu(child, searchTerm))\n        .filter(Boolean) as Menu[];\n\n      if (matchingChildren.length > 0) {\n        menu.children = matchingChildren;\n        menu.isExpanded = true;\n        return menu;\n      }\n    }\n\n    return isMatch ? menu : null;\n  }\n\n  collapseAllMenus(): void {\n    this.menuConfig.menus.forEach((menu) => {\n      menu.isExpanded = false;\n    });\n  }\n\n  getMenuItemStyles(): any {\n    return {\n      color: this.menuConfig.fontColor || '#333', // Set default font color if not specified in config\n    };\n  }\n\n  getMenuLinkStyles(): any {\n    return {\n      color: this.menuConfig.fontColor || '#333',\n      'text-decoration': 'none',\n      'border-radius': '8px',\n      padding: '10px 15px',\n      'font-size': '16px',\n      transition: 'background-color 0.2s, color 0.2s',\n      display: 'flex',\n      'align-items': 'center',\n      ':hover': {\n        backgroundColor: this.menuConfig.hoverColor || '#f1f1f1',\n        color: '#111',\n      },\n    };\n  }\n\n  getSubMenuLinkStyles(): any {\n    return {\n      color:\n        this.menuConfig.fontColorSubMenu || this.menuConfig.fontColor || '#666',\n      'text-decoration': 'none',\n      'border-radius': '5px',\n      padding: '5px 10px',\n      transition: 'background-color 0.2s, color 0.2s',\n      ':hover': {\n        backgroundColor: this.menuConfig.hoverColorSubMenu || '#e0e0e0',\n      },\n    };\n  }\n  ngAfterViewInit(): void {\n    this.applyHoverEffects();\n  }\n\n  applyHoverEffects(): void {\n    const menuLinks = this.el.nativeElement.querySelectorAll('a.menu-link');\n    const subMenuLinks =\n      this.el.nativeElement.querySelectorAll('a.submenu-link');\n\n    // Apply hover effects for main menu links\n    menuLinks.forEach((link: HTMLElement) => {\n      this.renderer.listen(link, 'mouseenter', () => {\n        this.renderer.setStyle(\n          link,\n          'background-color',\n          this.menuConfig.hoverColor || '#f1f1f1'\n        );\n        this.renderer.setStyle(\n          link,\n          'color',\n          this.menuConfig.hoverFontColor || 'white'\n        );\n      });\n\n      this.renderer.listen(link, 'mouseleave', () => {\n        this.renderer.removeStyle(link, 'background-color');\n        this.renderer.setStyle(\n          link,\n          'color',\n          this.menuConfig.fontColor || '#333'\n        );\n      });\n    });\n\n    // Apply hover effects for submenu links\n    subMenuLinks.forEach((link: HTMLElement) => {\n      this.renderer.listen(link, 'mouseenter', () => {\n        this.renderer.setStyle(\n          link,\n          'background-color',\n          this.menuConfig.hoverColorSubMenu ||\n            this.menuConfig.hoverColor ||\n            '#f1f1f1'\n        );\n        this.renderer.setStyle(\n          link,\n          'color',\n          this.menuConfig.hoverFontColorSubMenu ||\n            this.menuConfig.hoverFontColor ||\n            '#fff'\n        );\n      });\n\n      this.renderer.listen(link, 'mouseleave', () => {\n        this.renderer.removeStyle(link, 'background-color');\n        this.renderer.setStyle(\n          link,\n          'color',\n          this.menuConfig.fontColorSubMenu ||\n            this.menuConfig.fontColor ||\n            '#666'\n        );\n      });\n    });\n  }\n}\n","<div class=\"pt-side-bar-menu\">\n  <pt-card\n    *ngIf=\"menuConfig.searchable\"\n    [config]=\"searchCardConfig\"\n    [ngClass]=\"{ 'sidebar-hidden': !menuConfig.isVisible }\"\n  >\n    <div class=\"search-input\">\n      <pt-text-input [formGroup]=\"formGroup\" [formField]=\"searchField\">\n      </pt-text-input>\n    </div>\n  </pt-card>\n\n  <pt-card\n    [config]=\"cardConfig\"\n    [ngClass]=\"{ 'sidebar-hidden': !menuConfig.isVisible }\"\n  >\n    <ul class=\"menu-list\">\n      <li\n        *ngFor=\"let item of filteredMenus\"\n        class=\"menu-item\"\n        [ngClass]=\"{ 'menu-item-expanded': item.isExpanded }\"\n        [ngStyle]=\"getMenuItemStyles()\"\n      >\n        <!-- Main menu items without children -->\n        <a\n          *ngIf=\"!item.children?.length\"\n          [routerLink]=\"item.url\"\n          class=\"menu-link\"\n          [ngStyle]=\"getMenuLinkStyles()\"\n        >\n          <i [ngClass]=\"item.icon\"></i>\n          <span>{{ item.label }}</span>\n          <span\n            *ngIf=\"item.badge\"\n            [ngStyle]=\"getBadgeStyles(item.badge)\"\n            class=\"badge\"\n          >\n            {{ item.badge.count }}\n          </span>\n        </a>\n\n        <!-- Menu items with children -->\n        <a\n          *ngIf=\"item.children?.length\"\n          class=\"menu-link\"\n          (click)=\"toggleMenu(item, $event)\"\n          [ngStyle]=\"getMenuLinkStyles()\"\n        >\n          <i [ngClass]=\"item.icon\"></i>\n          <span>{{ item.label }}</span>\n          <span\n            *ngIf=\"item.badge\"\n            [ngStyle]=\"getBadgeStyles(item.badge)\"\n            class=\"badge\"\n          >\n            {{ item.badge.count }}\n          </span>\n          <i [ngClass]=\"getChevronClass(item)\" class=\"chevron\"></i>\n        </a>\n\n        <!-- Submenu -->\n        <ul class=\"submenu-list\">\n          <li *ngFor=\"let child of item.children\" class=\"submenu-item\">\n            <a\n              [routerLink]=\"child.url\"\n              class=\"submenu-link\"\n              [ngStyle]=\"getSubMenuLinkStyles()\"\n            >\n              <i [ngClass]=\"child.icon\"></i>\n              <span class=\"submenu-title\">{{ child.label }}</span>\n              <span\n                *ngIf=\"child.badge\"\n                [ngStyle]=\"getBadgeStyles(child.badge)\"\n                class=\"badge\"\n              >\n                {{ child.badge.count }}\n              </span>\n            </a>\n          </li>\n        </ul>\n      </li>\n    </ul>\n  </pt-card>\n</div>\n"]}
@@ -2125,11 +2125,11 @@ class PTMenuComponent {
2125
2125
  }
2126
2126
  }
2127
2127
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
2128
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTMenuComponent, selector: "pt-menu", inputs: { config: "config" }, host: { listeners: { "document:click": "onDocumentClick($event)" } }, ngImport: i0, template: "<div\n [ngClass]=\"{\n open: isOpen,\n 'menu-left': config.menuDirection === 'left',\n 'menu-right': config.menuDirection === 'right'\n }\"\n class=\"pt-menu\"\n>\n <i\n class=\"menu-icon\"\n (click)=\"toggleMenu()\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n ></i>\n <div class=\"menu-dropdown\" *ngIf=\"isOpen\">\n <div\n class=\"menu-item\"\n *ngFor=\"let item of config.menuItems\"\n (click)=\"item.action()\"\n >\n <i\n [ngClass]=\"getMenuItemIconClass(item)\"\n [ngStyle]=\"getMenuItemIconStyles(item)\"\n ></i>\n <span [ngStyle]=\"getTextStyles(item)\">{{ item.text }}</span>\n </div>\n </div>\n</div>\n", styles: [".pt-menu{position:relative;display:inline-block}.pt-menu .menu-icon{font-style:normal;font-weight:400;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;padding:8px;transition:background-color .2s,box-shadow .2s}.pt-menu .menu-icon:hover{background-color:#5959591a;box-shadow:0 0 0 1px #5959591a}.pt-menu .menu-dropdown{display:none;position:absolute;background-color:#fff;box-shadow:0 8px 16px #0003;min-width:160px;z-index:1;border-radius:5px;overflow:hidden}.pt-menu .menu-item{padding:8px 16px;cursor:pointer;display:flex;align-items:center}.pt-menu .menu-item i{margin-right:10px}.pt-menu .menu-item:hover{background-color:#f1f1f1}.pt-menu.open .menu-dropdown{display:block}.pt-menu.menu-left .menu-dropdown{right:0;left:auto}.pt-menu.menu-right .menu-dropdown{left:0;right:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
2128
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTMenuComponent, selector: "pt-menu", inputs: { config: "config" }, host: { listeners: { "document:click": "onDocumentClick($event)" } }, ngImport: i0, template: "<div\n [ngClass]=\"{\n open: isOpen,\n 'menu-left': config.menuDirection === 'left',\n 'menu-right': config.menuDirection === 'right'\n }\"\n class=\"pt-menu\"\n>\n <i\n class=\"menu-icon\"\n (click)=\"toggleMenu()\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n ></i>\n <div class=\"menu-dropdown\" *ngIf=\"isOpen\">\n <div\n class=\"menu-item\"\n *ngFor=\"let item of config.menuItems\"\n (click)=\"item.action()\"\n >\n <i\n [ngClass]=\"getMenuItemIconClass(item)\"\n [ngStyle]=\"getMenuItemIconStyles(item)\"\n ></i>\n <span [ngStyle]=\"getTextStyles(item)\">{{ item.text }}</span>\n </div>\n </div>\n</div>\n", styles: [".pt-menu{position:relative;display:inline-block}.pt-menu .menu-icon{font-style:normal;font-weight:400;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;padding:8px;transition:background-color .2s,box-shadow .2s}.pt-menu .menu-icon:hover{background-color:#5959591a;box-shadow:0 0 0 1px #5959591a}.pt-menu .menu-dropdown{display:none;position:absolute;background-color:#fff;box-shadow:0 8px 16px #0003;min-width:160px;z-index:1;border-radius:5px;overflow:hidden}.pt-menu .menu-item{padding:8px 16px;cursor:pointer;display:flex;align-items:center}.pt-menu .menu-item i{margin-right:10px}.pt-menu .menu-item:hover{background-color:#f1f1f1}.pt-menu.open .menu-dropdown{display:block}.pt-menu.menu-left .menu-dropdown{right:0;left:auto;z-index:2}.pt-menu.menu-right .menu-dropdown{left:0;right:auto;z-index:2}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
2129
2129
  }
2130
2130
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMenuComponent, decorators: [{
2131
2131
  type: Component,
2132
- args: [{ selector: 'pt-menu', template: "<div\n [ngClass]=\"{\n open: isOpen,\n 'menu-left': config.menuDirection === 'left',\n 'menu-right': config.menuDirection === 'right'\n }\"\n class=\"pt-menu\"\n>\n <i\n class=\"menu-icon\"\n (click)=\"toggleMenu()\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n ></i>\n <div class=\"menu-dropdown\" *ngIf=\"isOpen\">\n <div\n class=\"menu-item\"\n *ngFor=\"let item of config.menuItems\"\n (click)=\"item.action()\"\n >\n <i\n [ngClass]=\"getMenuItemIconClass(item)\"\n [ngStyle]=\"getMenuItemIconStyles(item)\"\n ></i>\n <span [ngStyle]=\"getTextStyles(item)\">{{ item.text }}</span>\n </div>\n </div>\n</div>\n", styles: [".pt-menu{position:relative;display:inline-block}.pt-menu .menu-icon{font-style:normal;font-weight:400;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;padding:8px;transition:background-color .2s,box-shadow .2s}.pt-menu .menu-icon:hover{background-color:#5959591a;box-shadow:0 0 0 1px #5959591a}.pt-menu .menu-dropdown{display:none;position:absolute;background-color:#fff;box-shadow:0 8px 16px #0003;min-width:160px;z-index:1;border-radius:5px;overflow:hidden}.pt-menu .menu-item{padding:8px 16px;cursor:pointer;display:flex;align-items:center}.pt-menu .menu-item i{margin-right:10px}.pt-menu .menu-item:hover{background-color:#f1f1f1}.pt-menu.open .menu-dropdown{display:block}.pt-menu.menu-left .menu-dropdown{right:0;left:auto}.pt-menu.menu-right .menu-dropdown{left:0;right:auto}\n"] }]
2132
+ args: [{ selector: 'pt-menu', template: "<div\n [ngClass]=\"{\n open: isOpen,\n 'menu-left': config.menuDirection === 'left',\n 'menu-right': config.menuDirection === 'right'\n }\"\n class=\"pt-menu\"\n>\n <i\n class=\"menu-icon\"\n (click)=\"toggleMenu()\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n ></i>\n <div class=\"menu-dropdown\" *ngIf=\"isOpen\">\n <div\n class=\"menu-item\"\n *ngFor=\"let item of config.menuItems\"\n (click)=\"item.action()\"\n >\n <i\n [ngClass]=\"getMenuItemIconClass(item)\"\n [ngStyle]=\"getMenuItemIconStyles(item)\"\n ></i>\n <span [ngStyle]=\"getTextStyles(item)\">{{ item.text }}</span>\n </div>\n </div>\n</div>\n", styles: [".pt-menu{position:relative;display:inline-block}.pt-menu .menu-icon{font-style:normal;font-weight:400;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;padding:8px;transition:background-color .2s,box-shadow .2s}.pt-menu .menu-icon:hover{background-color:#5959591a;box-shadow:0 0 0 1px #5959591a}.pt-menu .menu-dropdown{display:none;position:absolute;background-color:#fff;box-shadow:0 8px 16px #0003;min-width:160px;z-index:1;border-radius:5px;overflow:hidden}.pt-menu .menu-item{padding:8px 16px;cursor:pointer;display:flex;align-items:center}.pt-menu .menu-item i{margin-right:10px}.pt-menu .menu-item:hover{background-color:#f1f1f1}.pt-menu.open .menu-dropdown{display:block}.pt-menu.menu-left .menu-dropdown{right:0;left:auto;z-index:2}.pt-menu.menu-right .menu-dropdown{left:0;right:auto;z-index:2}\n"] }]
2133
2133
  }], propDecorators: { config: [{
2134
2134
  type: Input
2135
2135
  }], onDocumentClick: [{
@@ -2154,6 +2154,14 @@ class PTCardComponent {
2154
2154
  static { this.DEFAULT_TRANSPARENCY = '100'; }
2155
2155
  static { this.DEFAULT_PADDING = '16px'; }
2156
2156
  static { this.DEFAULT_MARGIN = '16px 0'; }
2157
+ ngAfterViewInit() {
2158
+ this.logPatternUrl();
2159
+ }
2160
+ logPatternUrl() {
2161
+ if (this.config.pattern?.imageUrl) {
2162
+ console.log(`[PTCardComponent] Identifier: ${this.config.identifier}, Pattern URL: ${this.config.pattern.imageUrl}`);
2163
+ }
2164
+ }
2157
2165
  isTitleObject() {
2158
2166
  return typeof this.config.title === 'object';
2159
2167
  }
@@ -2217,13 +2225,25 @@ class PTCardComponent {
2217
2225
  getCardStyles() {
2218
2226
  const transparency = this.config.pattern?.transparencyPercentage
2219
2227
  ? parseFloat(this.config.pattern.transparencyPercentage) / 100
2220
- : 1; // Default to no transparency (1 = fully opaque)
2228
+ : 1;
2229
+ const imageUrl = this.config.pattern?.imageUrl || '';
2230
+ const backgroundColor = this.config.pattern?.backgroundColor ||
2231
+ PTCardComponent.DEFAULT_BACKGROUND_COLOR;
2232
+ const patternWidth = this.config.pattern?.width || '100%';
2233
+ const patternHeight = this.config.pattern?.height || 'auto';
2234
+ // Determine background-repeat value
2235
+ const repeatX = this.config.pattern?.repeatX ? 'repeat' : 'no-repeat';
2236
+ const repeatY = this.config.pattern?.repeatY ? 'repeat' : 'no-repeat';
2237
+ const backgroundRepeat = `${repeatX} ${repeatY}`;
2238
+ // Adjust background-size based on repeatCount if provided
2239
+ const repeatCount = this.config.pattern?.repeatCount || 1;
2240
+ const backgroundSize = repeatCount > 1
2241
+ ? `${patternWidth} ${patternHeight}`
2242
+ : `${patternWidth} ${patternHeight}`;
2243
+ // Determine background-position based on the position parameter
2244
+ const backgroundPosition = this.config.pattern?.position || 'center';
2221
2245
  return {
2222
- backgroundColor: this.config.pattern?.imageUrl
2223
- ? this.config.pattern.backgroundColor ||
2224
- PTCardComponent.DEFAULT_BACKGROUND_COLOR
2225
- : this.config.backgroundColor ||
2226
- PTCardComponent.DEFAULT_BACKGROUND_COLOR,
2246
+ backgroundColor,
2227
2247
  width: this.config.width || PTCardComponent.DEFAULT_WIDTH,
2228
2248
  height: this.config.height || PTCardComponent.DEFAULT_HEIGHT,
2229
2249
  border: this.config.noBorder
@@ -2233,12 +2253,11 @@ class PTCardComponent {
2233
2253
  margin: this.config.margin || PTCardComponent.DEFAULT_MARGIN,
2234
2254
  borderRadius: this.config.borderRadius || '8px',
2235
2255
  boxShadow: this.config.boxShadow || '0 2px 4px rgba(0, 0, 0, 0.1)',
2236
- position: 'relative', // Needed for ::before positioning
2237
- '--background-image-url': this.config.pattern?.imageUrl
2238
- ? `url(${this.config.pattern.imageUrl})`
2239
- : '',
2240
- '--image-opacity': transparency.toString(), // Pass transparency to CSS
2241
- overflow: 'hidden', // Ensure no overflow
2256
+ position: 'relative',
2257
+ backgroundImage: imageUrl ? `url(${imageUrl})` : 'none',
2258
+ backgroundSize,
2259
+ backgroundPosition,
2260
+ backgroundRepeat,
2242
2261
  };
2243
2262
  }
2244
2263
  isScrollableHorizontal() {
@@ -2248,11 +2267,11 @@ class PTCardComponent {
2248
2267
  return !!this.config.scrollableVertical;
2249
2268
  }
2250
2269
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTCardComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
2251
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTCardComponent, selector: "pt-card", inputs: { config: "config" }, ngImport: i0, template: "<div class=\"pt-card card\" [ngStyle]=\"getCardStyles()\">\n <div *ngIf=\"hasTitle()\" class=\"card-header\" [ngStyle]=\"getTitleStyles()\">\n <i\n *ngIf=\"getIconClass() && getIconPosition() === 'left'\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n class=\"card-header-icon-left\"\n ></i>\n <span>{{ getTitleText() }}</span>\n <i\n *ngIf=\"getIconClass() && getIconPosition() === 'right'\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n class=\"card-header-icon-right\"\n ></i>\n <pt-menu\n *ngIf=\"config.menu\"\n [config]=\"config.menu\"\n [ngClass]=\"{\n 'menu-left': getMenuPosition() === 'left',\n 'menu-right': getMenuPosition() === 'right'\n }\"\n ></pt-menu>\n </div>\n <div\n class=\"card-body\"\n [ngClass]=\"{\n 'card-body-scrollable-vertical': isScrollableVertical(),\n 'card-body-scrollable-horizontal': isScrollableHorizontal()\n }\"\n >\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".pt-card .card{padding:16px;margin:16px 0;display:flex;flex-direction:column;max-height:100vh;overflow:hidden;background-color:var(--background-color, #fff);position:relative}.pt-card .card:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background-image:var( --background-image-url );background-size:cover;background-position:center;opacity:var(--image-opacity, 1);pointer-events:none}.pt-card .card-body{flex-grow:1;max-width:100%;z-index:1}.pt-card .card-body-scrollable-horizontal{overflow-x:auto;padding-bottom:8px}.pt-card .card-body-scrollable-vertical{flex-grow:1;overflow-y:auto;padding-right:8px}.pt-card .card-header{margin-bottom:16px;display:flex;align-items:center;justify-content:var(--text-align, left);position:relative}.pt-card .card-header-icon-left{margin-right:6px}.pt-card .card-header-icon-right{margin-left:6px}.pt-card .menu-left{position:absolute;left:0;top:0}.pt-card .menu-right{position:absolute;right:0;top:-2px}.pt-card .card-menu{margin-left:auto;cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: PTMenuComponent, selector: "pt-menu", inputs: ["config"] }] }); }
2270
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTCardComponent, selector: "pt-card", inputs: { config: "config" }, ngImport: i0, template: "<div\n class=\"pt-card card\"\n [attr.id]=\"config.identifier\"\n [ngStyle]=\"getCardStyles()\"\n>\n <div *ngIf=\"hasTitle()\" class=\"card-header\" [ngStyle]=\"getTitleStyles()\">\n <i\n *ngIf=\"getIconClass() && getIconPosition() === 'left'\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n class=\"card-header-icon-left\"\n ></i>\n <span>{{ getTitleText() }}</span>\n <i\n *ngIf=\"getIconClass() && getIconPosition() === 'right'\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n class=\"card-header-icon-right\"\n ></i>\n <pt-menu\n *ngIf=\"config.menu\"\n [config]=\"config.menu\"\n [ngClass]=\"{\n 'menu-left': getMenuPosition() === 'left',\n 'menu-right': getMenuPosition() === 'right'\n }\"\n ></pt-menu>\n </div>\n <div\n class=\"card-body\"\n [ngClass]=\"{\n 'card-body-scrollable-vertical': isScrollableVertical(),\n 'card-body-scrollable-horizontal': isScrollableHorizontal()\n }\"\n >\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".pt-card .card{padding:16px;margin:16px 0;display:flex;flex-direction:column;max-height:100vh;overflow:hidden;position:relative}.pt-card .card:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;pointer-events:none}.pt-card .card-body{flex-grow:1;max-width:100%;z-index:1}.pt-card .card-body-scrollable-horizontal{overflow-x:auto;padding-bottom:8px}.pt-card .card-body-scrollable-vertical{flex-grow:1;overflow-y:auto;padding-right:8px}.pt-card .card-header{margin-bottom:16px;display:flex;align-items:center;justify-content:var(--text-align, left);position:relative}.pt-card .card-header-icon-left{margin-right:6px}.pt-card .card-header-icon-right{margin-left:6px}.pt-card .menu-left{position:absolute;left:0;top:0}.pt-card .menu-right{position:absolute;right:0;top:-2px}.pt-card .card-menu{margin-left:auto;cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: PTMenuComponent, selector: "pt-menu", inputs: ["config"] }] }); }
2252
2271
  }
2253
2272
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTCardComponent, decorators: [{
2254
2273
  type: Component,
2255
- args: [{ selector: 'pt-card', template: "<div class=\"pt-card card\" [ngStyle]=\"getCardStyles()\">\n <div *ngIf=\"hasTitle()\" class=\"card-header\" [ngStyle]=\"getTitleStyles()\">\n <i\n *ngIf=\"getIconClass() && getIconPosition() === 'left'\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n class=\"card-header-icon-left\"\n ></i>\n <span>{{ getTitleText() }}</span>\n <i\n *ngIf=\"getIconClass() && getIconPosition() === 'right'\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n class=\"card-header-icon-right\"\n ></i>\n <pt-menu\n *ngIf=\"config.menu\"\n [config]=\"config.menu\"\n [ngClass]=\"{\n 'menu-left': getMenuPosition() === 'left',\n 'menu-right': getMenuPosition() === 'right'\n }\"\n ></pt-menu>\n </div>\n <div\n class=\"card-body\"\n [ngClass]=\"{\n 'card-body-scrollable-vertical': isScrollableVertical(),\n 'card-body-scrollable-horizontal': isScrollableHorizontal()\n }\"\n >\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".pt-card .card{padding:16px;margin:16px 0;display:flex;flex-direction:column;max-height:100vh;overflow:hidden;background-color:var(--background-color, #fff);position:relative}.pt-card .card:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background-image:var( --background-image-url );background-size:cover;background-position:center;opacity:var(--image-opacity, 1);pointer-events:none}.pt-card .card-body{flex-grow:1;max-width:100%;z-index:1}.pt-card .card-body-scrollable-horizontal{overflow-x:auto;padding-bottom:8px}.pt-card .card-body-scrollable-vertical{flex-grow:1;overflow-y:auto;padding-right:8px}.pt-card .card-header{margin-bottom:16px;display:flex;align-items:center;justify-content:var(--text-align, left);position:relative}.pt-card .card-header-icon-left{margin-right:6px}.pt-card .card-header-icon-right{margin-left:6px}.pt-card .menu-left{position:absolute;left:0;top:0}.pt-card .menu-right{position:absolute;right:0;top:-2px}.pt-card .card-menu{margin-left:auto;cursor:pointer}\n"] }]
2274
+ args: [{ selector: 'pt-card', template: "<div\n class=\"pt-card card\"\n [attr.id]=\"config.identifier\"\n [ngStyle]=\"getCardStyles()\"\n>\n <div *ngIf=\"hasTitle()\" class=\"card-header\" [ngStyle]=\"getTitleStyles()\">\n <i\n *ngIf=\"getIconClass() && getIconPosition() === 'left'\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n class=\"card-header-icon-left\"\n ></i>\n <span>{{ getTitleText() }}</span>\n <i\n *ngIf=\"getIconClass() && getIconPosition() === 'right'\"\n [ngClass]=\"getIconClass()\"\n [ngStyle]=\"getIconStyles()\"\n class=\"card-header-icon-right\"\n ></i>\n <pt-menu\n *ngIf=\"config.menu\"\n [config]=\"config.menu\"\n [ngClass]=\"{\n 'menu-left': getMenuPosition() === 'left',\n 'menu-right': getMenuPosition() === 'right'\n }\"\n ></pt-menu>\n </div>\n <div\n class=\"card-body\"\n [ngClass]=\"{\n 'card-body-scrollable-vertical': isScrollableVertical(),\n 'card-body-scrollable-horizontal': isScrollableHorizontal()\n }\"\n >\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".pt-card .card{padding:16px;margin:16px 0;display:flex;flex-direction:column;max-height:100vh;overflow:hidden;position:relative}.pt-card .card:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;pointer-events:none}.pt-card .card-body{flex-grow:1;max-width:100%;z-index:1}.pt-card .card-body-scrollable-horizontal{overflow-x:auto;padding-bottom:8px}.pt-card .card-body-scrollable-vertical{flex-grow:1;overflow-y:auto;padding-right:8px}.pt-card .card-header{margin-bottom:16px;display:flex;align-items:center;justify-content:var(--text-align, left);position:relative}.pt-card .card-header-icon-left{margin-right:6px}.pt-card .card-header-icon-right{margin-left:6px}.pt-card .menu-left{position:absolute;left:0;top:0}.pt-card .menu-right{position:absolute;right:0;top:-2px}.pt-card .card-menu{margin-left:auto;cursor:pointer}\n"] }]
2256
2275
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { config: [{
2257
2276
  type: Input
2258
2277
  }] } });
@@ -2291,7 +2310,7 @@ class PTMenuFancyComponent {
2291
2310
  icon: { code: 'pi pi-ellipsis-v', color: '#000', fontSize: '15px' },
2292
2311
  menuDirection: 'right',
2293
2312
  };
2294
- this.cardMenuConfig = { noBorder: true };
2313
+ this.cardMenuConfig = { noBorder: true, margin: '0', padding: '5px' };
2295
2314
  this.isOpen = false;
2296
2315
  }
2297
2316
  static { this.DEFAULT_TEXT_COLOR = '#000'; }
@@ -2388,6 +2407,8 @@ class PTNavbarMenuComponent {
2388
2407
  static { this.DEFAULT_APP_NAME_FONT_SIZE = '24px'; }
2389
2408
  static { this.DEFAULT_TRANSPARENCY = '100'; }
2390
2409
  static { this.DEFAULT_ICON_COLOR = '#333'; }
2410
+ static { this.DEFAULT_TOGGLE_BUTTON_ICON = 'pi pi-bars'; }
2411
+ static { this.DEFAULT_TOGGLE_BUTTON_COLOR = '#333'; }
2391
2412
  isImageStyle(object) {
2392
2413
  return typeof object === 'object' && 'imageUrl' in object;
2393
2414
  }
@@ -2440,25 +2461,50 @@ class PTNavbarMenuComponent {
2440
2461
  getNavbarStyles() {
2441
2462
  const transparency = this.navBarMenuConfig.pattern?.transparencyPercentage ||
2442
2463
  PTNavbarMenuComponent.DEFAULT_TRANSPARENCY;
2443
- const backgroundImage = this.navBarMenuConfig.pattern
2444
- ? `linear-gradient(rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100}), rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100})), url(${this.navBarMenuConfig.pattern.imageUrl})`
2464
+ const imageUrl = this.navBarMenuConfig.pattern?.imageUrl || '';
2465
+ const patternWidth = this.navBarMenuConfig.pattern?.width || '100%';
2466
+ const patternHeight = this.navBarMenuConfig.pattern?.height || 'auto';
2467
+ // Determine background-repeat value
2468
+ const repeatX = this.navBarMenuConfig.pattern?.repeatX
2469
+ ? 'repeat'
2470
+ : 'no-repeat';
2471
+ const repeatY = this.navBarMenuConfig.pattern?.repeatY
2472
+ ? 'repeat'
2473
+ : 'no-repeat';
2474
+ const backgroundRepeat = `${repeatX} ${repeatY}`;
2475
+ // Use the position directly from the pattern configuration
2476
+ const backgroundPosition = this.navBarMenuConfig.pattern?.position || 'center';
2477
+ // Construct the background image style with transparency
2478
+ const backgroundImage = imageUrl
2479
+ ? `linear-gradient(rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100}), rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100})), url(${imageUrl})`
2445
2480
  : '';
2446
2481
  return {
2447
2482
  backgroundColor: this.navBarMenuConfig.pattern ? 'transparent' : '#fff',
2448
2483
  backgroundImage: backgroundImage,
2449
- backgroundSize: 'cover',
2450
- backgroundPosition: 'center',
2484
+ backgroundSize: `${patternWidth} ${patternHeight}`,
2485
+ backgroundPosition: backgroundPosition,
2486
+ backgroundRepeat: backgroundRepeat,
2451
2487
  };
2452
2488
  }
2453
2489
  toggleMenu() {
2454
2490
  this.toggleSidebar.emit();
2455
2491
  }
2492
+ getToggleButtonIcon() {
2493
+ return (this.navBarMenuConfig.toggleButtonIcon ||
2494
+ PTNavbarMenuComponent.DEFAULT_TOGGLE_BUTTON_ICON);
2495
+ }
2496
+ getToggleButtonStyles() {
2497
+ return {
2498
+ color: this.navBarMenuConfig.toggleButtonColor ||
2499
+ PTNavbarMenuComponent.DEFAULT_TOGGLE_BUTTON_COLOR,
2500
+ };
2501
+ }
2456
2502
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTNavbarMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
2457
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTNavbarMenuComponent, selector: "pt-nav-bar-menu", inputs: { navBarMenuConfig: "navBarMenuConfig" }, outputs: { toggleSidebar: "toggleSidebar" }, ngImport: i0, template: "<div class=\"pt-nav-bar-menu\" [ngStyle]=\"getNavbarStyles()\">\n <div class=\"navbar-left\">\n <a\n [routerLink]=\"\n isImageStyle(navBarMenuConfig.logo)\n ? navBarMenuConfig.logo.routerLink\n : '/'\n \"\n class=\"logo-link\"\n >\n <img\n [src]=\"getLogoUrl()\"\n [alt]=\"getLogoAltText()\"\n [ngStyle]=\"getLogoStyles()\"\n class=\"navbar-logo\"\n />\n <span class=\"navbar-title\" [ngStyle]=\"getAppNameStyles()\">\n {{ getAppName() }}\n </span>\n </a>\n <a (click)=\"toggleMenu()\" class=\"toggle-btn\">\n <i class=\"pi pi-bars\"></i>\n </a>\n </div>\n <div class=\"navbar-right\">\n <pt-menu-fancy\n *ngFor=\"let menuConfig of navBarMenuConfig.menus\"\n [config]=\"menuConfig\"\n ></pt-menu-fancy>\n </div>\n</div>\n", styles: [".pt-nav-bar-menu{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px solid #ddd;background-color:#fff;background-size:cover;background-position:center}.pt-nav-bar-menu .navbar-left{display:flex;align-items:center}.pt-nav-bar-menu .logo-link{display:flex;align-items:center;text-decoration:none;color:inherit}.pt-nav-bar-menu .navbar-logo{margin-left:10px;margin-right:20px}.pt-nav-bar-menu .navbar-right{display:flex;align-items:center}.pt-nav-bar-menu .navbar-right a{margin-left:20px;color:#333;text-decoration:none;font-size:20px;cursor:pointer}.pt-nav-bar-menu .navbar-right a:hover{color:#000;cursor:pointer}.pt-nav-bar-menu .toggle-btn>.pi.pi-bars{font-size:1.5rem;color:#333}.pt-nav-bar-menu .toggle-btn:hover{background-color:#f1f1f1}.pt-nav-bar-menu .toggle-btn{margin-left:2rem;cursor:pointer;padding:7px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2$2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: PTMenuFancyComponent, selector: "pt-menu-fancy", inputs: ["config"] }] }); }
2503
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTNavbarMenuComponent, selector: "pt-nav-bar-menu", inputs: { navBarMenuConfig: "navBarMenuConfig" }, outputs: { toggleSidebar: "toggleSidebar" }, ngImport: i0, template: "<div class=\"pt-nav-bar-menu\" [ngStyle]=\"getNavbarStyles()\">\n <div class=\"navbar-left\">\n <a\n [routerLink]=\"\n isImageStyle(navBarMenuConfig.logo)\n ? navBarMenuConfig.logo.routerLink\n : '/'\n \"\n class=\"logo-link\"\n >\n <img\n [src]=\"getLogoUrl()\"\n [alt]=\"getLogoAltText()\"\n [ngStyle]=\"getLogoStyles()\"\n class=\"navbar-logo\"\n />\n <span class=\"navbar-title\" [ngStyle]=\"getAppNameStyles()\">\n {{ getAppName() }}\n </span>\n </a>\n <!-- Toggle Button -->\n <a (click)=\"toggleMenu()\" class=\"toggle-btn\">\n <i\n [class]=\"getToggleButtonIcon()\"\n [ngStyle]=\"getToggleButtonStyles()\"\n ></i>\n </a>\n </div>\n <div class=\"navbar-right\">\n <pt-menu-fancy\n *ngFor=\"let menuConfig of navBarMenuConfig.menus\"\n [config]=\"menuConfig\"\n ></pt-menu-fancy>\n </div>\n</div>\n", styles: [".pt-nav-bar-menu{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px solid #ddd;background-color:#fff;background-size:cover;background-position:center}.pt-nav-bar-menu .navbar-left{display:flex;align-items:center}.pt-nav-bar-menu .logo-link{display:flex;align-items:center;text-decoration:none;color:inherit}.pt-nav-bar-menu .navbar-logo{margin-left:10px;margin-right:20px}.pt-nav-bar-menu .navbar-right{display:flex;align-items:center}.pt-nav-bar-menu .navbar-right a{margin-left:20px;color:#333;text-decoration:none;font-size:20px;cursor:pointer}.pt-nav-bar-menu .navbar-right a:hover{color:#000;cursor:pointer}.pt-nav-bar-menu .toggle-btn>.pi.pi-bars{font-size:1.5rem;color:#333}.pt-nav-bar-menu .toggle-btn:hover{background-color:#f1f1f1}.pt-nav-bar-menu .toggle-btn{margin-left:2rem;cursor:pointer;padding:7px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2$2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: PTMenuFancyComponent, selector: "pt-menu-fancy", inputs: ["config"] }] }); }
2458
2504
  }
2459
2505
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTNavbarMenuComponent, decorators: [{
2460
2506
  type: Component,
2461
- args: [{ selector: 'pt-nav-bar-menu', template: "<div class=\"pt-nav-bar-menu\" [ngStyle]=\"getNavbarStyles()\">\n <div class=\"navbar-left\">\n <a\n [routerLink]=\"\n isImageStyle(navBarMenuConfig.logo)\n ? navBarMenuConfig.logo.routerLink\n : '/'\n \"\n class=\"logo-link\"\n >\n <img\n [src]=\"getLogoUrl()\"\n [alt]=\"getLogoAltText()\"\n [ngStyle]=\"getLogoStyles()\"\n class=\"navbar-logo\"\n />\n <span class=\"navbar-title\" [ngStyle]=\"getAppNameStyles()\">\n {{ getAppName() }}\n </span>\n </a>\n <a (click)=\"toggleMenu()\" class=\"toggle-btn\">\n <i class=\"pi pi-bars\"></i>\n </a>\n </div>\n <div class=\"navbar-right\">\n <pt-menu-fancy\n *ngFor=\"let menuConfig of navBarMenuConfig.menus\"\n [config]=\"menuConfig\"\n ></pt-menu-fancy>\n </div>\n</div>\n", styles: [".pt-nav-bar-menu{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px solid #ddd;background-color:#fff;background-size:cover;background-position:center}.pt-nav-bar-menu .navbar-left{display:flex;align-items:center}.pt-nav-bar-menu .logo-link{display:flex;align-items:center;text-decoration:none;color:inherit}.pt-nav-bar-menu .navbar-logo{margin-left:10px;margin-right:20px}.pt-nav-bar-menu .navbar-right{display:flex;align-items:center}.pt-nav-bar-menu .navbar-right a{margin-left:20px;color:#333;text-decoration:none;font-size:20px;cursor:pointer}.pt-nav-bar-menu .navbar-right a:hover{color:#000;cursor:pointer}.pt-nav-bar-menu .toggle-btn>.pi.pi-bars{font-size:1.5rem;color:#333}.pt-nav-bar-menu .toggle-btn:hover{background-color:#f1f1f1}.pt-nav-bar-menu .toggle-btn{margin-left:2rem;cursor:pointer;padding:7px}\n"] }]
2507
+ args: [{ selector: 'pt-nav-bar-menu', template: "<div class=\"pt-nav-bar-menu\" [ngStyle]=\"getNavbarStyles()\">\n <div class=\"navbar-left\">\n <a\n [routerLink]=\"\n isImageStyle(navBarMenuConfig.logo)\n ? navBarMenuConfig.logo.routerLink\n : '/'\n \"\n class=\"logo-link\"\n >\n <img\n [src]=\"getLogoUrl()\"\n [alt]=\"getLogoAltText()\"\n [ngStyle]=\"getLogoStyles()\"\n class=\"navbar-logo\"\n />\n <span class=\"navbar-title\" [ngStyle]=\"getAppNameStyles()\">\n {{ getAppName() }}\n </span>\n </a>\n <!-- Toggle Button -->\n <a (click)=\"toggleMenu()\" class=\"toggle-btn\">\n <i\n [class]=\"getToggleButtonIcon()\"\n [ngStyle]=\"getToggleButtonStyles()\"\n ></i>\n </a>\n </div>\n <div class=\"navbar-right\">\n <pt-menu-fancy\n *ngFor=\"let menuConfig of navBarMenuConfig.menus\"\n [config]=\"menuConfig\"\n ></pt-menu-fancy>\n </div>\n</div>\n", styles: [".pt-nav-bar-menu{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px solid #ddd;background-color:#fff;background-size:cover;background-position:center}.pt-nav-bar-menu .navbar-left{display:flex;align-items:center}.pt-nav-bar-menu .logo-link{display:flex;align-items:center;text-decoration:none;color:inherit}.pt-nav-bar-menu .navbar-logo{margin-left:10px;margin-right:20px}.pt-nav-bar-menu .navbar-right{display:flex;align-items:center}.pt-nav-bar-menu .navbar-right a{margin-left:20px;color:#333;text-decoration:none;font-size:20px;cursor:pointer}.pt-nav-bar-menu .navbar-right a:hover{color:#000;cursor:pointer}.pt-nav-bar-menu .toggle-btn>.pi.pi-bars{font-size:1.5rem;color:#333}.pt-nav-bar-menu .toggle-btn:hover{background-color:#f1f1f1}.pt-nav-bar-menu .toggle-btn{margin-left:2rem;cursor:pointer;padding:7px}\n"] }]
2462
2508
  }], propDecorators: { navBarMenuConfig: [{
2463
2509
  type: Input
2464
2510
  }], toggleSidebar: [{
@@ -2511,10 +2557,12 @@ class PTSideBarMenuComponent {
2511
2557
  hoverColorSubMenu: '#e0e0e0', // Default hover color for submenu
2512
2558
  };
2513
2559
  this.searchCardConfig = {
2560
+ identifier: 'pt-side-bar-menu/search',
2514
2561
  backgroundColor: 'white',
2515
2562
  height: '72px',
2516
2563
  };
2517
2564
  this.cardConfig = {
2565
+ identifier: 'pt-side-bar-menu',
2518
2566
  backgroundColor: '',
2519
2567
  width: '',
2520
2568
  height: '',
@@ -2532,6 +2580,7 @@ class PTSideBarMenuComponent {
2532
2580
  }
2533
2581
  ngOnInit() {
2534
2582
  this.cardConfig = {
2583
+ identifier: 'pt-side-bar-menu',
2535
2584
  backgroundColor: this.menuConfig.backgroundColor,
2536
2585
  width: this.menuConfig.width,
2537
2586
  height: this.menuConfig.height,
@@ -2890,6 +2939,7 @@ class PTPageSkeletonComponent {
2890
2939
  // Initialize backgroundCardConfig with default values
2891
2940
  initializeBackgroundCardConfig() {
2892
2941
  this.pageSkeletonConfig.backgroundCardConfig = {
2942
+ identifier: 'pt-page-skeleton/background',
2893
2943
  noBorder: this.pageSkeletonConfig.backgroundCardConfig?.noBorder ?? true,
2894
2944
  backgroundColor: this.pageSkeletonConfig.backgroundCardConfig?.backgroundColor || '#fff',
2895
2945
  padding: this.pageSkeletonConfig.backgroundCardConfig?.padding || '20px',
@@ -2900,6 +2950,7 @@ class PTPageSkeletonComponent {
2900
2950
  // Initialize contentCardConfig with default values (if necessary)
2901
2951
  initializeContentCardConfig() {
2902
2952
  this.pageSkeletonConfig.contentCardConfig = {
2953
+ identifier: 'pt-page-skeleton/content',
2903
2954
  noBorder: this.pageSkeletonConfig.contentCardConfig?.noBorder ?? false,
2904
2955
  backgroundColor: this.pageSkeletonConfig.contentCardConfig?.backgroundColor || '#f0f0f0',
2905
2956
  padding: this.pageSkeletonConfig.contentCardConfig?.padding || '15px',