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.
package/README.md CHANGED
@@ -636,6 +636,13 @@ export class FormBuilderTesterComponent implements OnInit {
636
636
 
637
637
  ## Changelog
638
638
 
639
+ ### Version 1.0.13 - Release Date: 12/11/2024
640
+
641
+ - fix menu z-index
642
+ - adding parametrable toggle
643
+ - adding position param for background image in pt-card
644
+ - remove background transparency for pt-card
645
+
639
646
  ### Version 1.0.12 - Release Date: 28/09/2024
640
647
 
641
648
  - fix background transparency for pt-card
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1jb25maWcubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL21vZGVscy9jYXJkLWNvbmZpZy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUNvbmZpZyB9IGZyb20gJy4vbWVudS1jb25maWcubW9kZWwnO1xuaW1wb3J0IHsgVGl0bGVTdHlsZSB9IGZyb20gJy4vdGl0bGUtc3R5bGUubW9kZWwnO1xuaW1wb3J0IHsgUGF0dGVybiB9IGZyb20gJy4vcGF0dGVybi5tb2RlbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FyZENvbmZpZyB7XG4gIHRpdGxlPzogc3RyaW5nIHwgVGl0bGVTdHlsZTtcbiAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICB3aWR0aD86IHN0cmluZztcbiAgaGVpZ2h0Pzogc3RyaW5nO1xuICBwYWRkaW5nPzogc3RyaW5nO1xuICBtYXJnaW4/OiBzdHJpbmc7XG4gIGJvcmRlckNvbG9yPzogc3RyaW5nO1xuICBib3JkZXJXaWR0aD86IHN0cmluZztcbiAgbWVudT86IE1lbnVDb25maWc7XG4gIG1lbnVQb3NpdGlvbj86ICdsZWZ0JyB8ICdyaWdodCc7XG4gIHNjcm9sbGFibGVWZXJ0aWNhbD86IGJvb2xlYW47XG4gIHNjcm9sbGFibGVIb3Jpem9udGFsPzogYm9vbGVhbjtcbiAgcGF0dGVybj86IFBhdHRlcm47XG4gIG5vQm9yZGVyPzogYm9vbGVhbjtcbiAgYm9yZGVyUmFkaXVzPzogc3RyaW5nO1xuICBib3hTaGFkb3c/OiBzdHJpbmc7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1jb25maWcubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL21vZGVscy9jYXJkLWNvbmZpZy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUNvbmZpZyB9IGZyb20gJy4vbWVudS1jb25maWcubW9kZWwnO1xuaW1wb3J0IHsgVGl0bGVTdHlsZSB9IGZyb20gJy4vdGl0bGUtc3R5bGUubW9kZWwnO1xuaW1wb3J0IHsgUGF0dGVybiB9IGZyb20gJy4vcGF0dGVybi5tb2RlbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FyZENvbmZpZyB7XG4gIGlkZW50aWZpZXI/OiBzdHJpbmc7XG4gIHRpdGxlPzogc3RyaW5nIHwgVGl0bGVTdHlsZTtcbiAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICB3aWR0aD86IHN0cmluZztcbiAgaGVpZ2h0Pzogc3RyaW5nO1xuICBwYWRkaW5nPzogc3RyaW5nO1xuICBtYXJnaW4/OiBzdHJpbmc7XG4gIGJvcmRlckNvbG9yPzogc3RyaW5nO1xuICBib3JkZXJXaWR0aD86IHN0cmluZztcbiAgbWVudT86IE1lbnVDb25maWc7XG4gIG1lbnVQb3NpdGlvbj86ICdsZWZ0JyB8ICdyaWdodCc7XG4gIHNjcm9sbGFibGVWZXJ0aWNhbD86IGJvb2xlYW47XG4gIHNjcm9sbGFibGVIb3Jpem9udGFsPzogYm9vbGVhbjtcbiAgcGF0dGVybj86IFBhdHRlcm47XG4gIG5vQm9yZGVyPzogYm9vbGVhbjtcbiAgYm9yZGVyUmFkaXVzPzogc3RyaW5nO1xuICBib3hTaGFkb3c/OiBzdHJpbmc7XG59XG4iXX0=
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LWJhci1tZW51LWNvbmZpZy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL25hdi1iYXItbWVudS1jb25maWcubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEltYWdlU3R5bGUgfSBmcm9tICcuL2ltYWdlLXN0eWxlLm1vZGVsJztcbmltcG9ydCB7IE1lbnVDb25maWcgfSBmcm9tICcuL21lbnUtY29uZmlnLm1vZGVsJztcbmltcG9ydCB7IFBhdHRlcm4gfSBmcm9tICcuL3BhdHRlcm4ubW9kZWwnO1xuaW1wb3J0IHsgVGV4dFN0eWxlIH0gZnJvbSAnLi90ZXh0LXN0eWxlLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBOYXZCYXJNZW51Q29uZmlnIHtcbiAgbG9nbz86IHN0cmluZyB8IEltYWdlU3R5bGU7XG4gIGFwcE5hbWU/OiBzdHJpbmcgfCBUZXh0U3R5bGU7XG4gIG1lbnVzPzogTWVudUNvbmZpZ1tdO1xuICBwYXR0ZXJuPzogUGF0dGVybjtcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LWJhci1tZW51LWNvbmZpZy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL25hdi1iYXItbWVudS1jb25maWcubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEltYWdlU3R5bGUgfSBmcm9tICcuL2ltYWdlLXN0eWxlLm1vZGVsJztcbmltcG9ydCB7IE1lbnVDb25maWcgfSBmcm9tICcuL21lbnUtY29uZmlnLm1vZGVsJztcbmltcG9ydCB7IFBhdHRlcm4gfSBmcm9tICcuL3BhdHRlcm4ubW9kZWwnO1xuaW1wb3J0IHsgVGV4dFN0eWxlIH0gZnJvbSAnLi90ZXh0LXN0eWxlLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBOYXZCYXJNZW51Q29uZmlnIHtcbiAgbG9nbz86IHN0cmluZyB8IEltYWdlU3R5bGU7XG4gIGFwcE5hbWU/OiBzdHJpbmcgfCBUZXh0U3R5bGU7XG4gIG1lbnVzPzogTWVudUNvbmZpZ1tdO1xuICBwYXR0ZXJuPzogUGF0dGVybjtcbiAgdG9nZ2xlQnV0dG9uSWNvbj86IHN0cmluZztcbiAgdG9nZ2xlQnV0dG9uQ29sb3I/OiBzdHJpbmc7XG59XG4iXX0=
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0dGVybi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL3BhdHRlcm4ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUGF0dGVybiB7XG4gIGltYWdlVXJsOiBzdHJpbmc7XG4gIHRyYW5zcGFyZW5jeVBlcmNlbnRhZ2U/OiBzdHJpbmc7XG4gIGJhY2tncm91bmRDb2xvcj86IHN0cmluZztcbiAgd2lkdGg/OiBzdHJpbmc7XG4gIGhlaWdodD86IHN0cmluZztcbiAgcmVwZWF0WD86IGJvb2xlYW47XG4gIHJlcGVhdFk/OiBib29sZWFuO1xuICByZXBlYXRDb3VudD86IG51bWJlcjtcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF0dGVybi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL3BhdHRlcm4ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUGF0dGVybiB7XG4gIGltYWdlVXJsOiBzdHJpbmc7XG4gIHRyYW5zcGFyZW5jeVBlcmNlbnRhZ2U/OiBzdHJpbmc7XG4gIGJhY2tncm91bmRDb2xvcj86IHN0cmluZztcbiAgd2lkdGg/OiBzdHJpbmc7XG4gIGhlaWdodD86IHN0cmluZztcbiAgcmVwZWF0WD86IGJvb2xlYW47XG4gIHJlcGVhdFk/OiBib29sZWFuO1xuICByZXBlYXRDb3VudD86IG51bWJlcjtcbiAgcG9zaXRpb24/OlxuICAgIHwgJ2xlZnQgdG9wJ1xuICAgIHwgJ3RvcCBjZW50ZXInXG4gICAgfCAncmlnaHQgdG9wJ1xuICAgIHwgJ2xlZnQgYm90dG9tJ1xuICAgIHwgJ2JvdHRvbSBjZW50ZXInXG4gICAgfCAncmlnaHQgYm90dG9tJ1xuICAgIHwgJ2NlbnRlcic7XG59XG4iXX0=
@@ -19,6 +19,14 @@ export class PTCardComponent {
19
19
  static { this.DEFAULT_TRANSPARENCY = '100'; }
20
20
  static { this.DEFAULT_PADDING = '16px'; }
21
21
  static { this.DEFAULT_MARGIN = '16px 0'; }
22
+ ngAfterViewInit() {
23
+ this.logPatternUrl();
24
+ }
25
+ logPatternUrl() {
26
+ if (this.config.pattern?.imageUrl) {
27
+ console.log(`[PTCardComponent] Identifier: ${this.config.identifier}, Pattern URL: ${this.config.pattern.imageUrl}`);
28
+ }
29
+ }
22
30
  isTitleObject() {
23
31
  return typeof this.config.title === 'object';
24
32
  }
@@ -82,13 +90,25 @@ export class PTCardComponent {
82
90
  getCardStyles() {
83
91
  const transparency = this.config.pattern?.transparencyPercentage
84
92
  ? parseFloat(this.config.pattern.transparencyPercentage) / 100
85
- : 1; // Default to no transparency (1 = fully opaque)
93
+ : 1;
94
+ const imageUrl = this.config.pattern?.imageUrl || '';
95
+ const backgroundColor = this.config.pattern?.backgroundColor ||
96
+ PTCardComponent.DEFAULT_BACKGROUND_COLOR;
97
+ const patternWidth = this.config.pattern?.width || '100%';
98
+ const patternHeight = this.config.pattern?.height || 'auto';
99
+ // Determine background-repeat value
100
+ const repeatX = this.config.pattern?.repeatX ? 'repeat' : 'no-repeat';
101
+ const repeatY = this.config.pattern?.repeatY ? 'repeat' : 'no-repeat';
102
+ const backgroundRepeat = `${repeatX} ${repeatY}`;
103
+ // Adjust background-size based on repeatCount if provided
104
+ const repeatCount = this.config.pattern?.repeatCount || 1;
105
+ const backgroundSize = repeatCount > 1
106
+ ? `${patternWidth} ${patternHeight}`
107
+ : `${patternWidth} ${patternHeight}`;
108
+ // Determine background-position based on the position parameter
109
+ const backgroundPosition = this.config.pattern?.position || 'center';
86
110
  return {
87
- backgroundColor: this.config.pattern?.imageUrl
88
- ? this.config.pattern.backgroundColor ||
89
- PTCardComponent.DEFAULT_BACKGROUND_COLOR
90
- : this.config.backgroundColor ||
91
- PTCardComponent.DEFAULT_BACKGROUND_COLOR,
111
+ backgroundColor,
92
112
  width: this.config.width || PTCardComponent.DEFAULT_WIDTH,
93
113
  height: this.config.height || PTCardComponent.DEFAULT_HEIGHT,
94
114
  border: this.config.noBorder
@@ -98,12 +118,11 @@ export class PTCardComponent {
98
118
  margin: this.config.margin || PTCardComponent.DEFAULT_MARGIN,
99
119
  borderRadius: this.config.borderRadius || '8px',
100
120
  boxShadow: this.config.boxShadow || '0 2px 4px rgba(0, 0, 0, 0.1)',
101
- position: 'relative', // Needed for ::before positioning
102
- '--background-image-url': this.config.pattern?.imageUrl
103
- ? `url(${this.config.pattern.imageUrl})`
104
- : '',
105
- '--image-opacity': transparency.toString(), // Pass transparency to CSS
106
- overflow: 'hidden', // Ensure no overflow
121
+ position: 'relative',
122
+ backgroundImage: imageUrl ? `url(${imageUrl})` : 'none',
123
+ backgroundSize,
124
+ backgroundPosition,
125
+ backgroundRepeat,
107
126
  };
108
127
  }
109
128
  isScrollableHorizontal() {
@@ -113,12 +132,12 @@ export class PTCardComponent {
113
132
  return !!this.config.scrollableVertical;
114
133
  }
115
134
  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 }); }
116
- 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: i2.PTMenuComponent, selector: "pt-menu", inputs: ["config"] }] }); }
135
+ 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: i2.PTMenuComponent, selector: "pt-menu", inputs: ["config"] }] }); }
117
136
  }
118
137
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTCardComponent, decorators: [{
119
138
  type: Component,
120
- 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"] }]
139
+ 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"] }]
121
140
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { config: [{
122
141
  type: Input
123
142
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-card.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-card/pt-card.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-card/pt-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  Input,\n} from '@angular/core';\nimport { CardConfig, IconStyle, TitleStyle } from '../models';\n\n@Component({\n  selector: 'pt-card',\n  templateUrl: './pt-card.component.html',\n  styleUrls: ['./pt-card.component.css'],\n})\nexport class PTCardComponent {\n  @Input() config: CardConfig = {};\n\n  // Default values as readonly variables\n  private static readonly DEFAULT_TITLE_COLOR = '#333';\n  private static readonly DEFAULT_TITLE_FONT_SIZE = '1.5em';\n  private static readonly DEFAULT_ICON_COLOR = '#333';\n  private static readonly DEFAULT_ICON_FONT_SIZE = '1em';\n  private static readonly DEFAULT_ICON_POSITION = 'left';\n  private static readonly DEFAULT_BACKGROUND_COLOR = '#fff';\n  private static readonly DEFAULT_WIDTH = '100%';\n  private static readonly DEFAULT_HEIGHT = 'auto';\n  private static readonly DEFAULT_TITLE_POSITION = 'left';\n  private static readonly DEFAULT_MENU_POSITION = 'right';\n  private static readonly DEFAULT_BORDER_COLOR = '#ddd';\n  private static readonly DEFAULT_BORDER_WIDTH = '1px';\n  private static readonly DEFAULT_TRANSPARENCY = '100';\n  private static readonly DEFAULT_PADDING = '16px';\n  private static readonly DEFAULT_MARGIN = '16px 0';\n\n  isTitleObject(): boolean {\n    return typeof this.config.title === 'object';\n  }\n\n  hasTitle(): boolean {\n    return this.config.title !== undefined && this.config.title !== null;\n  }\n\n  getTitleText(): string {\n    return this.isTitleObject()\n      ? (this.config.title as TitleStyle).text\n      : (this.config.title as string);\n  }\n\n  getTitleStyles() {\n    const title = this.config.title as TitleStyle | undefined;\n    const alignMap: { [key: string]: string } = {\n      left: 'flex-start',\n      center: 'center',\n      right: 'flex-end',\n    };\n    return {\n      color: title?.color || PTCardComponent.DEFAULT_TITLE_COLOR,\n      fontSize: title?.fontSize || PTCardComponent.DEFAULT_TITLE_FONT_SIZE,\n      '--text-align':\n        alignMap[title?.position || PTCardComponent.DEFAULT_TITLE_POSITION],\n    };\n  }\n\n  constructor(private cd: ChangeDetectorRef) {}\n\n  updateStyles() {\n    // After data is fetched or updated\n    this.getCardStyles();\n    this.cd.detectChanges(); // Force Angular to detect the changes\n  }\n\n  getIconClass(): string | null {\n    const icon = (this.config.title as TitleStyle)?.icon;\n    return typeof icon === 'string' ? icon : (icon as IconStyle)?.code || null;\n  }\n\n  getIconStyles() {\n    const icon = (this.config.title as TitleStyle)?.icon;\n    if (typeof icon !== 'string') {\n      return {\n        color: icon?.color || PTCardComponent.DEFAULT_ICON_COLOR,\n        fontSize: icon?.fontSize || PTCardComponent.DEFAULT_ICON_FONT_SIZE,\n      };\n    }\n    return {\n      color: PTCardComponent.DEFAULT_ICON_COLOR,\n      fontSize: PTCardComponent.DEFAULT_ICON_FONT_SIZE,\n    };\n  }\n\n  getIconPosition(): 'left' | 'right' | null {\n    const icon = (this.config.title as TitleStyle)?.icon;\n    if (typeof icon !== 'string' && icon?.position) {\n      return icon.position;\n    }\n    return PTCardComponent.DEFAULT_ICON_POSITION;\n  }\n\n  getMenuPosition(): 'left' | 'right' {\n    return this.config.menuPosition || PTCardComponent.DEFAULT_MENU_POSITION;\n  }\n\n  getCardStyles() {\n    const transparency = this.config.pattern?.transparencyPercentage\n      ? parseFloat(this.config.pattern.transparencyPercentage) / 100\n      : 1; // Default to no transparency (1 = fully opaque)\n\n    return {\n      backgroundColor: this.config.pattern?.imageUrl\n        ? this.config.pattern.backgroundColor ||\n          PTCardComponent.DEFAULT_BACKGROUND_COLOR\n        : this.config.backgroundColor ||\n          PTCardComponent.DEFAULT_BACKGROUND_COLOR,\n      width: this.config.width || PTCardComponent.DEFAULT_WIDTH,\n      height: this.config.height || PTCardComponent.DEFAULT_HEIGHT,\n      border: this.config.noBorder\n        ? 'none'\n        : `solid ${\n            this.config.borderWidth || PTCardComponent.DEFAULT_BORDER_WIDTH\n          } ${this.config.borderColor || PTCardComponent.DEFAULT_BORDER_COLOR}`,\n      padding: this.config.padding || PTCardComponent.DEFAULT_PADDING,\n      margin: this.config.margin || PTCardComponent.DEFAULT_MARGIN,\n      borderRadius: this.config.borderRadius || '8px',\n      boxShadow: this.config.boxShadow || '0 2px 4px rgba(0, 0, 0, 0.1)',\n      position: 'relative', // Needed for ::before positioning\n      '--background-image-url': this.config.pattern?.imageUrl\n        ? `url(${this.config.pattern.imageUrl})`\n        : '',\n      '--image-opacity': transparency.toString(), // Pass transparency to CSS\n      overflow: 'hidden', // Ensure no overflow\n    };\n  }\n\n  isScrollableHorizontal(): boolean {\n    return !!this.config.scrollableHorizontal;\n  }\n\n  isScrollableVertical(): boolean {\n    return !!this.config.scrollableVertical;\n  }\n}\n","<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"]}
143
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-card.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-card/pt-card.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-card/pt-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnChanges,\n  OnInit,\n} from '@angular/core';\nimport { CardConfig, IconStyle, TitleStyle } from '../models';\n\n@Component({\n  selector: 'pt-card',\n  templateUrl: './pt-card.component.html',\n  styleUrls: ['./pt-card.component.css'],\n})\nexport class PTCardComponent implements AfterViewInit {\n  @Input() config: CardConfig = {};\n\n  // Default values as readonly variables\n  private static readonly DEFAULT_TITLE_COLOR = '#333';\n  private static readonly DEFAULT_TITLE_FONT_SIZE = '1.5em';\n  private static readonly DEFAULT_ICON_COLOR = '#333';\n  private static readonly DEFAULT_ICON_FONT_SIZE = '1em';\n  private static readonly DEFAULT_ICON_POSITION = 'left';\n  private static readonly DEFAULT_BACKGROUND_COLOR = '#fff';\n  private static readonly DEFAULT_WIDTH = '100%';\n  private static readonly DEFAULT_HEIGHT = 'auto';\n  private static readonly DEFAULT_TITLE_POSITION = 'left';\n  private static readonly DEFAULT_MENU_POSITION = 'right';\n  private static readonly DEFAULT_BORDER_COLOR = '#ddd';\n  private static readonly DEFAULT_BORDER_WIDTH = '1px';\n  private static readonly DEFAULT_TRANSPARENCY = '100';\n  private static readonly DEFAULT_PADDING = '16px';\n  private static readonly DEFAULT_MARGIN = '16px 0';\n\n  ngAfterViewInit() {\n    this.logPatternUrl();\n  }\n\n  private logPatternUrl() {\n    if (this.config.pattern?.imageUrl) {\n      console.log(\n        `[PTCardComponent] Identifier: ${this.config.identifier}, Pattern URL: ${this.config.pattern.imageUrl}`\n      );\n    }\n  }\n\n  isTitleObject(): boolean {\n    return typeof this.config.title === 'object';\n  }\n\n  hasTitle(): boolean {\n    return this.config.title !== undefined && this.config.title !== null;\n  }\n\n  getTitleText(): string {\n    return this.isTitleObject()\n      ? (this.config.title as TitleStyle).text\n      : (this.config.title as string);\n  }\n\n  getTitleStyles() {\n    const title = this.config.title as TitleStyle | undefined;\n    const alignMap: { [key: string]: string } = {\n      left: 'flex-start',\n      center: 'center',\n      right: 'flex-end',\n    };\n    return {\n      color: title?.color || PTCardComponent.DEFAULT_TITLE_COLOR,\n      fontSize: title?.fontSize || PTCardComponent.DEFAULT_TITLE_FONT_SIZE,\n      '--text-align':\n        alignMap[title?.position || PTCardComponent.DEFAULT_TITLE_POSITION],\n    };\n  }\n\n  constructor(private cd: ChangeDetectorRef) {}\n\n  updateStyles() {\n    // After data is fetched or updated\n    this.getCardStyles();\n    this.cd.detectChanges(); // Force Angular to detect the changes\n  }\n\n  getIconClass(): string | null {\n    const icon = (this.config.title as TitleStyle)?.icon;\n    return typeof icon === 'string' ? icon : (icon as IconStyle)?.code || null;\n  }\n\n  getIconStyles() {\n    const icon = (this.config.title as TitleStyle)?.icon;\n    if (typeof icon !== 'string') {\n      return {\n        color: icon?.color || PTCardComponent.DEFAULT_ICON_COLOR,\n        fontSize: icon?.fontSize || PTCardComponent.DEFAULT_ICON_FONT_SIZE,\n      };\n    }\n    return {\n      color: PTCardComponent.DEFAULT_ICON_COLOR,\n      fontSize: PTCardComponent.DEFAULT_ICON_FONT_SIZE,\n    };\n  }\n\n  getIconPosition(): 'left' | 'right' | null {\n    const icon = (this.config.title as TitleStyle)?.icon;\n    if (typeof icon !== 'string' && icon?.position) {\n      return icon.position;\n    }\n    return PTCardComponent.DEFAULT_ICON_POSITION;\n  }\n\n  getMenuPosition(): 'left' | 'right' {\n    return this.config.menuPosition || PTCardComponent.DEFAULT_MENU_POSITION;\n  }\n\n  getCardStyles() {\n    const transparency = this.config.pattern?.transparencyPercentage\n      ? parseFloat(this.config.pattern.transparencyPercentage) / 100\n      : 1;\n\n    const imageUrl = this.config.pattern?.imageUrl || '';\n    const backgroundColor =\n      this.config.pattern?.backgroundColor ||\n      PTCardComponent.DEFAULT_BACKGROUND_COLOR;\n    const patternWidth = this.config.pattern?.width || '100%';\n    const patternHeight = this.config.pattern?.height || 'auto';\n\n    // Determine background-repeat value\n    const repeatX = this.config.pattern?.repeatX ? 'repeat' : 'no-repeat';\n    const repeatY = this.config.pattern?.repeatY ? 'repeat' : 'no-repeat';\n    const backgroundRepeat = `${repeatX} ${repeatY}`;\n\n    // Adjust background-size based on repeatCount if provided\n    const repeatCount = this.config.pattern?.repeatCount || 1;\n    const backgroundSize =\n      repeatCount > 1\n        ? `${patternWidth} ${patternHeight}`\n        : `${patternWidth} ${patternHeight}`;\n\n    // Determine background-position based on the position parameter\n    const backgroundPosition = this.config.pattern?.position || 'center';\n\n    return {\n      backgroundColor,\n      width: this.config.width || PTCardComponent.DEFAULT_WIDTH,\n      height: this.config.height || PTCardComponent.DEFAULT_HEIGHT,\n      border: this.config.noBorder\n        ? 'none'\n        : `solid ${\n            this.config.borderWidth || PTCardComponent.DEFAULT_BORDER_WIDTH\n          } ${this.config.borderColor || PTCardComponent.DEFAULT_BORDER_COLOR}`,\n      padding: this.config.padding || PTCardComponent.DEFAULT_PADDING,\n      margin: this.config.margin || PTCardComponent.DEFAULT_MARGIN,\n      borderRadius: this.config.borderRadius || '8px',\n      boxShadow: this.config.boxShadow || '0 2px 4px rgba(0, 0, 0, 0.1)',\n      position: 'relative',\n      backgroundImage: imageUrl ? `url(${imageUrl})` : 'none',\n      backgroundSize,\n      backgroundPosition,\n      backgroundRepeat,\n    };\n  }\n\n  isScrollableHorizontal(): boolean {\n    return !!this.config.scrollableHorizontal;\n  }\n\n  isScrollableVertical(): boolean {\n    return !!this.config.scrollableVertical;\n  }\n}\n","<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"]}
@@ -76,11 +76,11 @@ export class PTMenuComponent {
76
76
  }
77
77
  }
78
78
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
79
- 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"] }] }); }
79
+ 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"] }] }); }
80
80
  }
81
81
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMenuComponent, decorators: [{
82
82
  type: Component,
83
- 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"] }]
83
+ 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"] }]
84
84
  }], propDecorators: { config: [{
85
85
  type: Input
86
86
  }], onDocumentClick: [{
@@ -8,7 +8,7 @@ export class PTMenuFancyComponent {
8
8
  icon: { code: 'pi pi-ellipsis-v', color: '#000', fontSize: '15px' },
9
9
  menuDirection: 'right',
10
10
  };
11
- this.cardMenuConfig = { noBorder: true };
11
+ this.cardMenuConfig = { noBorder: true, margin: '0', padding: '5px' };
12
12
  this.isOpen = false;
13
13
  }
14
14
  static { this.DEFAULT_TEXT_COLOR = '#000'; }
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
89
89
  type: HostListener,
90
90
  args: ['document:click', ['$event']]
91
91
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-menu-fancy.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-menu-fancy/pt-menu-fancy.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-menu-fancy/pt-menu-fancy.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostListener } from '@angular/core';\nimport { MenuItem, MenuConfig, CardConfig } from '../models';\n\n@Component({\n  selector: 'pt-menu-fancy',\n  templateUrl: './pt-menu-fancy.component.html',\n  styleUrls: ['./pt-menu-fancy.component.css'],\n})\nexport class PTMenuFancyComponent {\n  @Input() config: MenuConfig = {\n    icon: { code: 'pi pi-ellipsis-v', color: '#000', fontSize: '15px' },\n    menuDirection: 'right',\n  };\n\n  cardMenuConfig: CardConfig = { noBorder: true };\n\n  private static readonly DEFAULT_TEXT_COLOR = '#000';\n  private static readonly DEFAULT_TEXT_FONT_SIZE = '15px';\n  private static readonly DEFAULT_ICON_COLOR = '#000';\n  private static readonly DEFAULT_ICON_FONT_SIZE = '15px';\n  private static readonly DEFAULT_ICON_CODE = 'pi pi-ellipsis-v';\n\n  private static openMenuInstance: PTMenuFancyComponent | null = null;\n\n  isOpen = false;\n\n  toggleMenu() {\n    if (\n      PTMenuFancyComponent.openMenuInstance &&\n      PTMenuFancyComponent.openMenuInstance !== this\n    ) {\n      PTMenuFancyComponent.openMenuInstance.closeMenu();\n    }\n\n    this.isOpen = !this.isOpen;\n\n    if (this.isOpen) {\n      PTMenuFancyComponent.openMenuInstance = this;\n    } else {\n      PTMenuFancyComponent.openMenuInstance = null;\n    }\n  }\n\n  closeMenu() {\n    this.isOpen = false;\n    if (PTMenuFancyComponent.openMenuInstance === this) {\n      PTMenuFancyComponent.openMenuInstance = null;\n    }\n  }\n\n  getMenuItemIconClass(item: MenuItem): string {\n    // Assuming that icons starting with \"fa\" are FontAwesome icons\n    return typeof item.icon === 'string' ? item.icon : item.icon?.code || '';\n  }\n\n  getMenuItemIconStyles(item: MenuItem) {\n    if (typeof item.icon !== 'string') {\n      return {\n        color: item.icon?.color || PTMenuFancyComponent.DEFAULT_ICON_COLOR,\n        fontSize:\n          item.icon?.fontSize || PTMenuFancyComponent.DEFAULT_ICON_FONT_SIZE,\n      };\n    }\n    return {\n      color: PTMenuFancyComponent.DEFAULT_ICON_COLOR,\n      fontSize: PTMenuFancyComponent.DEFAULT_ICON_FONT_SIZE,\n    };\n  }\n\n  getIconClass(): string {\n    return this.config.icon?.code || PTMenuFancyComponent.DEFAULT_ICON_CODE;\n  }\n\n  getIconStyles() {\n    return {\n      color:\n        this.config.color ||\n        this.config.icon?.color ||\n        PTMenuFancyComponent.DEFAULT_ICON_COLOR,\n      fontSize:\n        this.config.fontSize ||\n        this.config.icon?.fontSize ||\n        PTMenuFancyComponent.DEFAULT_ICON_FONT_SIZE,\n    };\n  }\n\n  getTextStyles(item: MenuItem) {\n    return {\n      color: item.color || PTMenuFancyComponent.DEFAULT_TEXT_COLOR,\n      fontSize: item.fontSize || PTMenuFancyComponent.DEFAULT_TEXT_FONT_SIZE,\n    };\n  }\n\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: MouseEvent) {\n    const clickedInside = (event.target as HTMLElement).closest(\n      '.pt-menu-fancy'\n    );\n    if (!clickedInside) {\n      this.closeMenu();\n    }\n  }\n}\n","<div\n  [ngClass]=\"{\n    open: isOpen,\n    'menu-left': config.menuDirection === 'left',\n    'menu-right': config.menuDirection === 'right'\n  }\"\n  class=\"pt-menu-fancy\"\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    <pt-card [config]=\"cardMenuConfig\">\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    </pt-card>\n  </div>\n</div>\n"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-menu-fancy.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-menu-fancy/pt-menu-fancy.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-menu-fancy/pt-menu-fancy.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostListener } from '@angular/core';\nimport { MenuItem, MenuConfig, CardConfig } from '../models';\n\n@Component({\n  selector: 'pt-menu-fancy',\n  templateUrl: './pt-menu-fancy.component.html',\n  styleUrls: ['./pt-menu-fancy.component.css'],\n})\nexport class PTMenuFancyComponent {\n  @Input() config: MenuConfig = {\n    icon: { code: 'pi pi-ellipsis-v', color: '#000', fontSize: '15px' },\n    menuDirection: 'right',\n  };\n\n  cardMenuConfig: CardConfig = { noBorder: true, margin: '0', padding: '5px' };\n\n  private static readonly DEFAULT_TEXT_COLOR = '#000';\n  private static readonly DEFAULT_TEXT_FONT_SIZE = '15px';\n  private static readonly DEFAULT_ICON_COLOR = '#000';\n  private static readonly DEFAULT_ICON_FONT_SIZE = '15px';\n  private static readonly DEFAULT_ICON_CODE = 'pi pi-ellipsis-v';\n\n  private static openMenuInstance: PTMenuFancyComponent | null = null;\n\n  isOpen = false;\n\n  toggleMenu() {\n    if (\n      PTMenuFancyComponent.openMenuInstance &&\n      PTMenuFancyComponent.openMenuInstance !== this\n    ) {\n      PTMenuFancyComponent.openMenuInstance.closeMenu();\n    }\n\n    this.isOpen = !this.isOpen;\n\n    if (this.isOpen) {\n      PTMenuFancyComponent.openMenuInstance = this;\n    } else {\n      PTMenuFancyComponent.openMenuInstance = null;\n    }\n  }\n\n  closeMenu() {\n    this.isOpen = false;\n    if (PTMenuFancyComponent.openMenuInstance === this) {\n      PTMenuFancyComponent.openMenuInstance = null;\n    }\n  }\n\n  getMenuItemIconClass(item: MenuItem): string {\n    // Assuming that icons starting with \"fa\" are FontAwesome icons\n    return typeof item.icon === 'string' ? item.icon : item.icon?.code || '';\n  }\n\n  getMenuItemIconStyles(item: MenuItem) {\n    if (typeof item.icon !== 'string') {\n      return {\n        color: item.icon?.color || PTMenuFancyComponent.DEFAULT_ICON_COLOR,\n        fontSize:\n          item.icon?.fontSize || PTMenuFancyComponent.DEFAULT_ICON_FONT_SIZE,\n      };\n    }\n    return {\n      color: PTMenuFancyComponent.DEFAULT_ICON_COLOR,\n      fontSize: PTMenuFancyComponent.DEFAULT_ICON_FONT_SIZE,\n    };\n  }\n\n  getIconClass(): string {\n    return this.config.icon?.code || PTMenuFancyComponent.DEFAULT_ICON_CODE;\n  }\n\n  getIconStyles() {\n    return {\n      color:\n        this.config.color ||\n        this.config.icon?.color ||\n        PTMenuFancyComponent.DEFAULT_ICON_COLOR,\n      fontSize:\n        this.config.fontSize ||\n        this.config.icon?.fontSize ||\n        PTMenuFancyComponent.DEFAULT_ICON_FONT_SIZE,\n    };\n  }\n\n  getTextStyles(item: MenuItem) {\n    return {\n      color: item.color || PTMenuFancyComponent.DEFAULT_TEXT_COLOR,\n      fontSize: item.fontSize || PTMenuFancyComponent.DEFAULT_TEXT_FONT_SIZE,\n    };\n  }\n\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: MouseEvent) {\n    const clickedInside = (event.target as HTMLElement).closest(\n      '.pt-menu-fancy'\n    );\n    if (!clickedInside) {\n      this.closeMenu();\n    }\n  }\n}\n","<div\n  [ngClass]=\"{\n    open: isOpen,\n    'menu-left': config.menuDirection === 'left',\n    'menu-right': config.menuDirection === 'right'\n  }\"\n  class=\"pt-menu-fancy\"\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    <pt-card [config]=\"cardMenuConfig\">\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    </pt-card>\n  </div>\n</div>\n"]}
@@ -18,6 +18,8 @@ export class PTNavbarMenuComponent {
18
18
  static { this.DEFAULT_APP_NAME_FONT_SIZE = '24px'; }
19
19
  static { this.DEFAULT_TRANSPARENCY = '100'; }
20
20
  static { this.DEFAULT_ICON_COLOR = '#333'; }
21
+ static { this.DEFAULT_TOGGLE_BUTTON_ICON = 'pi pi-bars'; }
22
+ static { this.DEFAULT_TOGGLE_BUTTON_COLOR = '#333'; }
21
23
  isImageStyle(object) {
22
24
  return typeof object === 'object' && 'imageUrl' in object;
23
25
  }
@@ -70,28 +72,53 @@ export class PTNavbarMenuComponent {
70
72
  getNavbarStyles() {
71
73
  const transparency = this.navBarMenuConfig.pattern?.transparencyPercentage ||
72
74
  PTNavbarMenuComponent.DEFAULT_TRANSPARENCY;
73
- const backgroundImage = this.navBarMenuConfig.pattern
74
- ? `linear-gradient(rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100}), rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100})), url(${this.navBarMenuConfig.pattern.imageUrl})`
75
+ const imageUrl = this.navBarMenuConfig.pattern?.imageUrl || '';
76
+ const patternWidth = this.navBarMenuConfig.pattern?.width || '100%';
77
+ const patternHeight = this.navBarMenuConfig.pattern?.height || 'auto';
78
+ // Determine background-repeat value
79
+ const repeatX = this.navBarMenuConfig.pattern?.repeatX
80
+ ? 'repeat'
81
+ : 'no-repeat';
82
+ const repeatY = this.navBarMenuConfig.pattern?.repeatY
83
+ ? 'repeat'
84
+ : 'no-repeat';
85
+ const backgroundRepeat = `${repeatX} ${repeatY}`;
86
+ // Use the position directly from the pattern configuration
87
+ const backgroundPosition = this.navBarMenuConfig.pattern?.position || 'center';
88
+ // Construct the background image style with transparency
89
+ const backgroundImage = imageUrl
90
+ ? `linear-gradient(rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100}), rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100})), url(${imageUrl})`
75
91
  : '';
76
92
  return {
77
93
  backgroundColor: this.navBarMenuConfig.pattern ? 'transparent' : '#fff',
78
94
  backgroundImage: backgroundImage,
79
- backgroundSize: 'cover',
80
- backgroundPosition: 'center',
95
+ backgroundSize: `${patternWidth} ${patternHeight}`,
96
+ backgroundPosition: backgroundPosition,
97
+ backgroundRepeat: backgroundRepeat,
81
98
  };
82
99
  }
83
100
  toggleMenu() {
84
101
  this.toggleSidebar.emit();
85
102
  }
103
+ getToggleButtonIcon() {
104
+ return (this.navBarMenuConfig.toggleButtonIcon ||
105
+ PTNavbarMenuComponent.DEFAULT_TOGGLE_BUTTON_ICON);
106
+ }
107
+ getToggleButtonStyles() {
108
+ return {
109
+ color: this.navBarMenuConfig.toggleButtonColor ||
110
+ PTNavbarMenuComponent.DEFAULT_TOGGLE_BUTTON_COLOR,
111
+ };
112
+ }
86
113
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTNavbarMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
87
- 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.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i3.PTMenuFancyComponent, selector: "pt-menu-fancy", inputs: ["config"] }] }); }
114
+ 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.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i3.PTMenuFancyComponent, selector: "pt-menu-fancy", inputs: ["config"] }] }); }
88
115
  }
89
116
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTNavbarMenuComponent, decorators: [{
90
117
  type: Component,
91
- 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"] }]
118
+ 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"] }]
92
119
  }], propDecorators: { navBarMenuConfig: [{
93
120
  type: Input
94
121
  }], toggleSidebar: [{
95
122
  type: Output
96
123
  }] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-nav-bar-menu.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-nav-bar-menu/pt-nav-bar-menu.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-nav-bar-menu/pt-nav-bar-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ImageStyle, NavBarMenuConfig, TextStyle } from '../models';\n\n@Component({\n  selector: 'pt-nav-bar-menu',\n  templateUrl: './pt-nav-bar-menu.component.html',\n  styleUrls: ['./pt-nav-bar-menu.component.css'],\n})\nexport class PTNavbarMenuComponent {\n  @Input() navBarMenuConfig: NavBarMenuConfig = {};\n\n  @Output() toggleSidebar: EventEmitter<void> = new EventEmitter<void>();\n\n  // Default values as readonly variables\n  private static readonly DEFAULT_LOGO_URL: string = '';\n  private static readonly DEFAULT_LOGO_ALT_TEXT: string = 'Logo';\n  private static readonly DEFAULT_LOGO_WIDTH: string = '40px';\n  private static readonly DEFAULT_LOGO_HEIGHT: string = 'auto';\n  private static readonly DEFAULT_APP_NAME: string = 'Application';\n  private static readonly DEFAULT_APP_NAME_COLOR: string = '#000';\n  private static readonly DEFAULT_APP_NAME_FONT_SIZE: string = '24px';\n  private static readonly DEFAULT_TRANSPARENCY: string = '100';\n  private static readonly DEFAULT_ICON_COLOR: string = '#333';\n\n  isImageStyle(object: any): object is ImageStyle {\n    return typeof object === 'object' && 'imageUrl' in object;\n  }\n\n  isTextStyle(object: any): object is TextStyle {\n    return typeof object === 'object' && 'text' in object;\n  }\n\n  getLogoUrl(): string {\n    return this.isImageStyle(this.navBarMenuConfig.logo)\n      ? this.navBarMenuConfig.logo.imageUrl\n      : PTNavbarMenuComponent.DEFAULT_LOGO_URL;\n  }\n\n  getLogoAltText(): string {\n    return this.isImageStyle(this.navBarMenuConfig.logo)\n      ? this.navBarMenuConfig.logo.altText ||\n          PTNavbarMenuComponent.DEFAULT_LOGO_ALT_TEXT\n      : PTNavbarMenuComponent.DEFAULT_LOGO_ALT_TEXT;\n  }\n\n  getLogoStyles() {\n    if (this.isImageStyle(this.navBarMenuConfig.logo)) {\n      return {\n        color:\n          this.navBarMenuConfig.logo.color ||\n          PTNavbarMenuComponent.DEFAULT_ICON_COLOR,\n        width:\n          this.navBarMenuConfig.logo.width ||\n          PTNavbarMenuComponent.DEFAULT_LOGO_WIDTH,\n        height:\n          this.navBarMenuConfig.logo.height ||\n          PTNavbarMenuComponent.DEFAULT_LOGO_HEIGHT,\n      };\n    }\n    return {};\n  }\n\n  getAppName(): string {\n    return this.isTextStyle(this.navBarMenuConfig.appName)\n      ? this.navBarMenuConfig.appName.text\n      : PTNavbarMenuComponent.DEFAULT_APP_NAME;\n  }\n\n  getAppNameStyles() {\n    if (this.isTextStyle(this.navBarMenuConfig.appName)) {\n      return {\n        color:\n          this.navBarMenuConfig.appName.color ||\n          PTNavbarMenuComponent.DEFAULT_APP_NAME_COLOR,\n        fontSize:\n          this.navBarMenuConfig.appName.fontSize ||\n          PTNavbarMenuComponent.DEFAULT_APP_NAME_FONT_SIZE,\n      };\n    }\n    return {\n      color: PTNavbarMenuComponent.DEFAULT_APP_NAME_COLOR,\n      fontSize: PTNavbarMenuComponent.DEFAULT_APP_NAME_FONT_SIZE,\n    };\n  }\n\n  getNavbarStyles() {\n    const transparency =\n      this.navBarMenuConfig.pattern?.transparencyPercentage ||\n      PTNavbarMenuComponent.DEFAULT_TRANSPARENCY;\n    const backgroundImage = this.navBarMenuConfig.pattern\n      ? `linear-gradient(rgba(255, 255, 255, ${\n          1 - parseFloat(transparency) / 100\n        }), rgba(255, 255, 255, ${1 - parseFloat(transparency) / 100})), url(${\n          this.navBarMenuConfig.pattern.imageUrl\n        })`\n      : '';\n\n    return {\n      backgroundColor: this.navBarMenuConfig.pattern ? 'transparent' : '#fff',\n      backgroundImage: backgroundImage,\n      backgroundSize: 'cover',\n      backgroundPosition: 'center',\n    };\n  }\n\n  toggleMenu() {\n    this.toggleSidebar.emit();\n  }\n}\n","<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"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-nav-bar-menu.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-nav-bar-menu/pt-nav-bar-menu.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-nav-bar-menu/pt-nav-bar-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ImageStyle, NavBarMenuConfig, TextStyle } from '../models';\n\n@Component({\n  selector: 'pt-nav-bar-menu',\n  templateUrl: './pt-nav-bar-menu.component.html',\n  styleUrls: ['./pt-nav-bar-menu.component.css'],\n})\nexport class PTNavbarMenuComponent {\n  @Input() navBarMenuConfig: NavBarMenuConfig = {};\n\n  @Output() toggleSidebar: EventEmitter<void> = new EventEmitter<void>();\n\n  // Default values as readonly variables\n  private static readonly DEFAULT_LOGO_URL: string = '';\n  private static readonly DEFAULT_LOGO_ALT_TEXT: string = 'Logo';\n  private static readonly DEFAULT_LOGO_WIDTH: string = '40px';\n  private static readonly DEFAULT_LOGO_HEIGHT: string = 'auto';\n  private static readonly DEFAULT_APP_NAME: string = 'Application';\n  private static readonly DEFAULT_APP_NAME_COLOR: string = '#000';\n  private static readonly DEFAULT_APP_NAME_FONT_SIZE: string = '24px';\n  private static readonly DEFAULT_TRANSPARENCY: string = '100';\n  private static readonly DEFAULT_ICON_COLOR: string = '#333';\n  private static readonly DEFAULT_TOGGLE_BUTTON_ICON: string = 'pi pi-bars';\n  private static readonly DEFAULT_TOGGLE_BUTTON_COLOR: string = '#333';\n\n  isImageStyle(object: any): object is ImageStyle {\n    return typeof object === 'object' && 'imageUrl' in object;\n  }\n\n  isTextStyle(object: any): object is TextStyle {\n    return typeof object === 'object' && 'text' in object;\n  }\n\n  getLogoUrl(): string {\n    return this.isImageStyle(this.navBarMenuConfig.logo)\n      ? this.navBarMenuConfig.logo.imageUrl\n      : PTNavbarMenuComponent.DEFAULT_LOGO_URL;\n  }\n\n  getLogoAltText(): string {\n    return this.isImageStyle(this.navBarMenuConfig.logo)\n      ? this.navBarMenuConfig.logo.altText ||\n          PTNavbarMenuComponent.DEFAULT_LOGO_ALT_TEXT\n      : PTNavbarMenuComponent.DEFAULT_LOGO_ALT_TEXT;\n  }\n\n  getLogoStyles() {\n    if (this.isImageStyle(this.navBarMenuConfig.logo)) {\n      return {\n        color:\n          this.navBarMenuConfig.logo.color ||\n          PTNavbarMenuComponent.DEFAULT_ICON_COLOR,\n        width:\n          this.navBarMenuConfig.logo.width ||\n          PTNavbarMenuComponent.DEFAULT_LOGO_WIDTH,\n        height:\n          this.navBarMenuConfig.logo.height ||\n          PTNavbarMenuComponent.DEFAULT_LOGO_HEIGHT,\n      };\n    }\n    return {};\n  }\n\n  getAppName(): string {\n    return this.isTextStyle(this.navBarMenuConfig.appName)\n      ? this.navBarMenuConfig.appName.text\n      : PTNavbarMenuComponent.DEFAULT_APP_NAME;\n  }\n\n  getAppNameStyles() {\n    if (this.isTextStyle(this.navBarMenuConfig.appName)) {\n      return {\n        color:\n          this.navBarMenuConfig.appName.color ||\n          PTNavbarMenuComponent.DEFAULT_APP_NAME_COLOR,\n        fontSize:\n          this.navBarMenuConfig.appName.fontSize ||\n          PTNavbarMenuComponent.DEFAULT_APP_NAME_FONT_SIZE,\n      };\n    }\n    return {\n      color: PTNavbarMenuComponent.DEFAULT_APP_NAME_COLOR,\n      fontSize: PTNavbarMenuComponent.DEFAULT_APP_NAME_FONT_SIZE,\n    };\n  }\n\n  getNavbarStyles() {\n    const transparency =\n      this.navBarMenuConfig.pattern?.transparencyPercentage ||\n      PTNavbarMenuComponent.DEFAULT_TRANSPARENCY;\n    const imageUrl = this.navBarMenuConfig.pattern?.imageUrl || '';\n    const patternWidth = this.navBarMenuConfig.pattern?.width || '100%';\n    const patternHeight = this.navBarMenuConfig.pattern?.height || 'auto';\n\n    // Determine background-repeat value\n    const repeatX = this.navBarMenuConfig.pattern?.repeatX\n      ? 'repeat'\n      : 'no-repeat';\n    const repeatY = this.navBarMenuConfig.pattern?.repeatY\n      ? 'repeat'\n      : 'no-repeat';\n    const backgroundRepeat = `${repeatX} ${repeatY}`;\n\n    // Use the position directly from the pattern configuration\n    const backgroundPosition =\n      this.navBarMenuConfig.pattern?.position || 'center';\n\n    // Construct the background image style with transparency\n    const backgroundImage = imageUrl\n      ? `linear-gradient(rgba(255, 255, 255, ${\n          1 - parseFloat(transparency) / 100\n        }), rgba(255, 255, 255, ${\n          1 - parseFloat(transparency) / 100\n        })), url(${imageUrl})`\n      : '';\n\n    return {\n      backgroundColor: this.navBarMenuConfig.pattern ? 'transparent' : '#fff',\n      backgroundImage: backgroundImage,\n      backgroundSize: `${patternWidth} ${patternHeight}`,\n      backgroundPosition: backgroundPosition,\n      backgroundRepeat: backgroundRepeat,\n    };\n  }\n\n  toggleMenu() {\n    this.toggleSidebar.emit();\n  }\n\n  getToggleButtonIcon(): string {\n    return (\n      this.navBarMenuConfig.toggleButtonIcon ||\n      PTNavbarMenuComponent.DEFAULT_TOGGLE_BUTTON_ICON\n    );\n  }\n\n  getToggleButtonStyles() {\n    return {\n      color:\n        this.navBarMenuConfig.toggleButtonColor ||\n        PTNavbarMenuComponent.DEFAULT_TOGGLE_BUTTON_COLOR,\n    };\n  }\n}\n","<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"]}
@@ -23,6 +23,7 @@ export class PTPageSkeletonComponent {
23
23
  // Initialize backgroundCardConfig with default values
24
24
  initializeBackgroundCardConfig() {
25
25
  this.pageSkeletonConfig.backgroundCardConfig = {
26
+ identifier: 'pt-page-skeleton/background',
26
27
  noBorder: this.pageSkeletonConfig.backgroundCardConfig?.noBorder ?? true,
27
28
  backgroundColor: this.pageSkeletonConfig.backgroundCardConfig?.backgroundColor || '#fff',
28
29
  padding: this.pageSkeletonConfig.backgroundCardConfig?.padding || '20px',
@@ -33,6 +34,7 @@ export class PTPageSkeletonComponent {
33
34
  // Initialize contentCardConfig with default values (if necessary)
34
35
  initializeContentCardConfig() {
35
36
  this.pageSkeletonConfig.contentCardConfig = {
37
+ identifier: 'pt-page-skeleton/content',
36
38
  noBorder: this.pageSkeletonConfig.contentCardConfig?.noBorder ?? false,
37
39
  backgroundColor: this.pageSkeletonConfig.contentCardConfig?.backgroundColor || '#f0f0f0',
38
40
  padding: this.pageSkeletonConfig.contentCardConfig?.padding || '15px',
@@ -50,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
50
52
  }], toggleSidebar: [{
51
53
  type: Output
52
54
  }] } });
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LXBhZ2Utc2tlbGV0b24vcHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LXBhZ2Utc2tlbGV0b24vcHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7QUFRL0UsTUFBTSxPQUFPLHVCQUF1QjtJQUxwQztRQU9ZLGtCQUFhLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFFdkUscUJBQWdCLEdBQVksSUFBSSxDQUFDO0tBa0NsQztJQWhDQyxRQUFRO1FBQ04sSUFBSSxDQUFDLDhCQUE4QixFQUFFLENBQUM7UUFDdEMsSUFBSSxDQUFDLDJCQUEyQixFQUFFLENBQUM7SUFDckMsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7UUFDL0MsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRUQsc0RBQXNEO0lBQ3RELDhCQUE4QjtRQUM1QixJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLEdBQUc7WUFDN0MsUUFBUSxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxvQkFBb0IsRUFBRSxRQUFRLElBQUksSUFBSTtZQUN4RSxlQUFlLEVBQ2IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixFQUFFLGVBQWUsSUFBSSxNQUFNO1lBQ3pFLE9BQU8sRUFBRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLEVBQUUsT0FBTyxJQUFJLE1BQU07WUFDeEUsTUFBTSxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxvQkFBb0IsRUFBRSxNQUFNLElBQUksTUFBTTtZQUN0RSxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxvQkFBb0I7U0FDaEQsQ0FBQztJQUNKLENBQUM7SUFFRCxrRUFBa0U7SUFDbEUsMkJBQTJCO1FBQ3pCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxpQkFBaUIsR0FBRztZQUMxQyxRQUFRLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGlCQUFpQixFQUFFLFFBQVEsSUFBSSxLQUFLO1lBQ3RFLGVBQWUsRUFDYixJQUFJLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCLEVBQUUsZUFBZSxJQUFJLFNBQVM7WUFDekUsT0FBTyxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxpQkFBaUIsRUFBRSxPQUFPLElBQUksTUFBTTtZQUNyRSxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxpQkFBaUI7U0FDN0MsQ0FBQztJQUNKLENBQUM7K0dBckNVLHVCQUF1QjttR0FBdkIsdUJBQXVCLDJKQ1JwQyxrdkNBd0NBOzs0RkRoQ2EsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLGtCQUFrQjs4QkFLbkIsa0JBQWtCO3NCQUExQixLQUFLO2dCQUNJLGFBQWE7c0JBQXRCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQYWdlU2tlbGV0b25Db25maWcsIENhcmRDb25maWcgfSBmcm9tICcuLi9tb2RlbHMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwdC1wYWdlLXNrZWxldG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3B0LXBhZ2Utc2tlbGV0b24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9wdC1wYWdlLXNrZWxldG9uLmNvbXBvbmVudC5jc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgUFRQYWdlU2tlbGV0b25Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSBwYWdlU2tlbGV0b25Db25maWchOiBQYWdlU2tlbGV0b25Db25maWc7XG4gIEBPdXRwdXQoKSB0b2dnbGVTaWRlYmFyOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cbiAgaXNTaWRlYmFyVmlzaWJsZTogYm9vbGVhbiA9IHRydWU7XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5pbml0aWFsaXplQmFja2dyb3VuZENhcmRDb25maWcoKTtcbiAgICB0aGlzLmluaXRpYWxpemVDb250ZW50Q2FyZENvbmZpZygpO1xuICB9XG5cbiAgb25Ub2dnbGVTaWRlYmFyKCk6IHZvaWQge1xuICAgIHRoaXMuaXNTaWRlYmFyVmlzaWJsZSA9ICF0aGlzLmlzU2lkZWJhclZpc2libGU7XG4gICAgdGhpcy50b2dnbGVTaWRlYmFyLmVtaXQoKTtcbiAgfVxuXG4gIC8vIEluaXRpYWxpemUgYmFja2dyb3VuZENhcmRDb25maWcgd2l0aCBkZWZhdWx0IHZhbHVlc1xuICBpbml0aWFsaXplQmFja2dyb3VuZENhcmRDb25maWcoKSB7XG4gICAgdGhpcy5wYWdlU2tlbGV0b25Db25maWcuYmFja2dyb3VuZENhcmRDb25maWcgPSB7XG4gICAgICBub0JvcmRlcjogdGhpcy5wYWdlU2tlbGV0b25Db25maWcuYmFja2dyb3VuZENhcmRDb25maWc/Lm5vQm9yZGVyID8/IHRydWUsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6XG4gICAgICAgIHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnPy5iYWNrZ3JvdW5kQ29sb3IgfHwgJyNmZmYnLFxuICAgICAgcGFkZGluZzogdGhpcy5wYWdlU2tlbGV0b25Db25maWcuYmFja2dyb3VuZENhcmRDb25maWc/LnBhZGRpbmcgfHwgJzIwcHgnLFxuICAgICAgbWFyZ2luOiB0aGlzLnBhZ2VTa2VsZXRvbkNvbmZpZy5iYWNrZ3JvdW5kQ2FyZENvbmZpZz8ubWFyZ2luIHx8ICcxMHB4JyxcbiAgICAgIC4uLnRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnLFxuICAgIH07XG4gIH1cblxuICAvLyBJbml0aWFsaXplIGNvbnRlbnRDYXJkQ29uZmlnIHdpdGggZGVmYXVsdCB2YWx1ZXMgKGlmIG5lY2Vzc2FyeSlcbiAgaW5pdGlhbGl6ZUNvbnRlbnRDYXJkQ29uZmlnKCkge1xuICAgIHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnID0ge1xuICAgICAgbm9Cb3JkZXI6IHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnPy5ub0JvcmRlciA/PyBmYWxzZSxcbiAgICAgIGJhY2tncm91bmRDb2xvcjpcbiAgICAgICAgdGhpcy5wYWdlU2tlbGV0b25Db25maWcuY29udGVudENhcmRDb25maWc/LmJhY2tncm91bmRDb2xvciB8fCAnI2YwZjBmMCcsXG4gICAgICBwYWRkaW5nOiB0aGlzLnBhZ2VTa2VsZXRvbkNvbmZpZy5jb250ZW50Q2FyZENvbmZpZz8ucGFkZGluZyB8fCAnMTVweCcsXG4gICAgICAuLi50aGlzLnBhZ2VTa2VsZXRvbkNvbmZpZy5jb250ZW50Q2FyZENvbmZpZyxcbiAgICB9O1xuICB9XG59XG4iLCI8cHQtY2FyZCBbY29uZmlnXT1cInBhZ2VTa2VsZXRvbkNvbmZpZy5iYWNrZ3JvdW5kQ2FyZENvbmZpZyFcIj5cbiAgPCEtLSBOYXZiYXIgLS0+XG4gIDxwdC1uYXYtYmFyLW1lbnVcbiAgICBbbmF2QmFyTWVudUNvbmZpZ109XCJwYWdlU2tlbGV0b25Db25maWcubmF2QmFyTWVudUNvbmZpZ1wiXG4gICAgKHRvZ2dsZVNpZGViYXIpPVwib25Ub2dnbGVTaWRlYmFyKClcIlxuICA+PC9wdC1uYXYtYmFyLW1lbnU+XG5cbiAgPGRpdiBjbGFzcz1cIm1haW4tY29udGVudFwiPlxuICAgIDwhLS0gU2lkZWJhciAodXNlICpuZ0lmIHRvIHRvZ2dsZSB2aXNpYmlsaXR5KSAtLT5cbiAgICA8cHQtc2lkZS1iYXItbWVudVxuICAgICAgKm5nSWY9XCJpc1NpZGViYXJWaXNpYmxlXCJcbiAgICAgIFttZW51Q29uZmlnXT1cInBhZ2VTa2VsZXRvbkNvbmZpZy5zaWRlTWVudUJhckNvbmZpZ1wiXG4gICAgICBjbGFzcz1cInNpZGViYXJcIlxuICAgID48L3B0LXNpZGUtYmFyLW1lbnU+XG5cbiAgICA8IS0tIE1haW4gVmlldyBBcmVhIC0tPlxuICAgIDxkaXYgY2xhc3M9XCJjb250ZW50LWFyZWFcIiBbbmdDbGFzc109XCJ7ICdmdWxsLXdpZHRoJzogIWlzU2lkZWJhclZpc2libGUgfVwiPlxuICAgICAgPCEtLSBDb250ZW50IENhcmQgV3JhcHBlciAtLT5cbiAgICAgIDxwdC1jYXJkIFtjb25maWddPVwicGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnXCI+XG4gICAgICAgIDwhLS0gQnJlYWRjcnVtYiAtLT5cbiAgICAgICAgPHB0LWJyZWFkLWNydW1iXG4gICAgICAgICAgKm5nSWY9XCJwYWdlU2tlbGV0b25Db25maWcuYnJlYWRDcnVtYkNvbmZpZ1wiXG4gICAgICAgICAgW2JyZWFkQ3J1bWJDb25maWddPVwicGFnZVNrZWxldG9uQ29uZmlnLmJyZWFkQ3J1bWJDb25maWdcIlxuICAgICAgICAgIGNsYXNzPVwiYnJlYWQtY3J1bWJcIlxuICAgICAgICA+PC9wdC1icmVhZC1jcnVtYj5cblxuICAgICAgICA8IS0tIEJhY2tncm91bmQgQ2FyZCAtLT5cblxuICAgICAgICA8cm91dGVyLW91dGxldD48L3JvdXRlci1vdXRsZXQ+XG4gICAgICA8L3B0LWNhcmQ+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuXG4gIDwhLS0gRm9vdGVyIC0tPlxuICA8cHQtZm9vdGVyXG4gICAgKm5nSWY9XCJwYWdlU2tlbGV0b25Db25maWcuZm9vdGVyQ29uZmlnXCJcbiAgICBbZm9vdGVyQ29uZmlnXT1cInBhZ2VTa2VsZXRvbkNvbmZpZy5mb290ZXJDb25maWdcIlxuICAgIGNsYXNzPVwicHQtZm9vdGVyXCJcbiAgPjwvcHQtZm9vdGVyPlxuPC9wdC1jYXJkPlxuIl19
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LXBhZ2Utc2tlbGV0b24vcHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LXBhZ2Utc2tlbGV0b24vcHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7QUFRL0UsTUFBTSxPQUFPLHVCQUF1QjtJQUxwQztRQU9ZLGtCQUFhLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFFdkUscUJBQWdCLEdBQVksSUFBSSxDQUFDO0tBb0NsQztJQWxDQyxRQUFRO1FBQ04sSUFBSSxDQUFDLDhCQUE4QixFQUFFLENBQUM7UUFDdEMsSUFBSSxDQUFDLDJCQUEyQixFQUFFLENBQUM7SUFDckMsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7UUFDL0MsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRUQsc0RBQXNEO0lBQ3RELDhCQUE4QjtRQUM1QixJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLEdBQUc7WUFDN0MsVUFBVSxFQUFFLDZCQUE2QjtZQUN6QyxRQUFRLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixFQUFFLFFBQVEsSUFBSSxJQUFJO1lBQ3hFLGVBQWUsRUFDYixJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLEVBQUUsZUFBZSxJQUFJLE1BQU07WUFDekUsT0FBTyxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxvQkFBb0IsRUFBRSxPQUFPLElBQUksTUFBTTtZQUN4RSxNQUFNLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixFQUFFLE1BQU0sSUFBSSxNQUFNO1lBQ3RFLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQjtTQUNoRCxDQUFDO0lBQ0osQ0FBQztJQUVELGtFQUFrRTtJQUNsRSwyQkFBMkI7UUFDekIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGlCQUFpQixHQUFHO1lBQzFDLFVBQVUsRUFBRSwwQkFBMEI7WUFDdEMsUUFBUSxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxpQkFBaUIsRUFBRSxRQUFRLElBQUksS0FBSztZQUN0RSxlQUFlLEVBQ2IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGlCQUFpQixFQUFFLGVBQWUsSUFBSSxTQUFTO1lBQ3pFLE9BQU8sRUFBRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCLEVBQUUsT0FBTyxJQUFJLE1BQU07WUFDckUsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCO1NBQzdDLENBQUM7SUFDSixDQUFDOytHQXZDVSx1QkFBdUI7bUdBQXZCLHVCQUF1QiwySkNScEMsa3ZDQXdDQTs7NEZEaENhLHVCQUF1QjtrQkFMbkMsU0FBUzsrQkFDRSxrQkFBa0I7OEJBS25CLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDSSxhQUFhO3NCQUF0QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUGFnZVNrZWxldG9uQ29uZmlnLCBDYXJkQ29uZmlnIH0gZnJvbSAnLi4vbW9kZWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncHQtcGFnZS1za2VsZXRvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9wdC1wYWdlLXNrZWxldG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQuY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFBUUGFnZVNrZWxldG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgcGFnZVNrZWxldG9uQ29uZmlnITogUGFnZVNrZWxldG9uQ29uZmlnO1xuICBAT3V0cHV0KCkgdG9nZ2xlU2lkZWJhcjogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIGlzU2lkZWJhclZpc2libGU6IGJvb2xlYW4gPSB0cnVlO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuaW5pdGlhbGl6ZUJhY2tncm91bmRDYXJkQ29uZmlnKCk7XG4gICAgdGhpcy5pbml0aWFsaXplQ29udGVudENhcmRDb25maWcoKTtcbiAgfVxuXG4gIG9uVG9nZ2xlU2lkZWJhcigpOiB2b2lkIHtcbiAgICB0aGlzLmlzU2lkZWJhclZpc2libGUgPSAhdGhpcy5pc1NpZGViYXJWaXNpYmxlO1xuICAgIHRoaXMudG9nZ2xlU2lkZWJhci5lbWl0KCk7XG4gIH1cblxuICAvLyBJbml0aWFsaXplIGJhY2tncm91bmRDYXJkQ29uZmlnIHdpdGggZGVmYXVsdCB2YWx1ZXNcbiAgaW5pdGlhbGl6ZUJhY2tncm91bmRDYXJkQ29uZmlnKCkge1xuICAgIHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnID0ge1xuICAgICAgaWRlbnRpZmllcjogJ3B0LXBhZ2Utc2tlbGV0b24vYmFja2dyb3VuZCcsXG4gICAgICBub0JvcmRlcjogdGhpcy5wYWdlU2tlbGV0b25Db25maWcuYmFja2dyb3VuZENhcmRDb25maWc/Lm5vQm9yZGVyID8/IHRydWUsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6XG4gICAgICAgIHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnPy5iYWNrZ3JvdW5kQ29sb3IgfHwgJyNmZmYnLFxuICAgICAgcGFkZGluZzogdGhpcy5wYWdlU2tlbGV0b25Db25maWcuYmFja2dyb3VuZENhcmRDb25maWc/LnBhZGRpbmcgfHwgJzIwcHgnLFxuICAgICAgbWFyZ2luOiB0aGlzLnBhZ2VTa2VsZXRvbkNvbmZpZy5iYWNrZ3JvdW5kQ2FyZENvbmZpZz8ubWFyZ2luIHx8ICcxMHB4JyxcbiAgICAgIC4uLnRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnLFxuICAgIH07XG4gIH1cblxuICAvLyBJbml0aWFsaXplIGNvbnRlbnRDYXJkQ29uZmlnIHdpdGggZGVmYXVsdCB2YWx1ZXMgKGlmIG5lY2Vzc2FyeSlcbiAgaW5pdGlhbGl6ZUNvbnRlbnRDYXJkQ29uZmlnKCkge1xuICAgIHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnID0ge1xuICAgICAgaWRlbnRpZmllcjogJ3B0LXBhZ2Utc2tlbGV0b24vY29udGVudCcsXG4gICAgICBub0JvcmRlcjogdGhpcy5wYWdlU2tlbGV0b25Db25maWcuY29udGVudENhcmRDb25maWc/Lm5vQm9yZGVyID8/IGZhbHNlLFxuICAgICAgYmFja2dyb3VuZENvbG9yOlxuICAgICAgICB0aGlzLnBhZ2VTa2VsZXRvbkNvbmZpZy5jb250ZW50Q2FyZENvbmZpZz8uYmFja2dyb3VuZENvbG9yIHx8ICcjZjBmMGYwJyxcbiAgICAgIHBhZGRpbmc6IHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnPy5wYWRkaW5nIHx8ICcxNXB4JyxcbiAgICAgIC4uLnRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnLFxuICAgIH07XG4gIH1cbn1cbiIsIjxwdC1jYXJkIFtjb25maWddPVwicGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnIVwiPlxuICA8IS0tIE5hdmJhciAtLT5cbiAgPHB0LW5hdi1iYXItbWVudVxuICAgIFtuYXZCYXJNZW51Q29uZmlnXT1cInBhZ2VTa2VsZXRvbkNvbmZpZy5uYXZCYXJNZW51Q29uZmlnXCJcbiAgICAodG9nZ2xlU2lkZWJhcik9XCJvblRvZ2dsZVNpZGViYXIoKVwiXG4gID48L3B0LW5hdi1iYXItbWVudT5cblxuICA8ZGl2IGNsYXNzPVwibWFpbi1jb250ZW50XCI+XG4gICAgPCEtLSBTaWRlYmFyICh1c2UgKm5nSWYgdG8gdG9nZ2xlIHZpc2liaWxpdHkpIC0tPlxuICAgIDxwdC1zaWRlLWJhci1tZW51XG4gICAgICAqbmdJZj1cImlzU2lkZWJhclZpc2libGVcIlxuICAgICAgW21lbnVDb25maWddPVwicGFnZVNrZWxldG9uQ29uZmlnLnNpZGVNZW51QmFyQ29uZmlnXCJcbiAgICAgIGNsYXNzPVwic2lkZWJhclwiXG4gICAgPjwvcHQtc2lkZS1iYXItbWVudT5cblxuICAgIDwhLS0gTWFpbiBWaWV3IEFyZWEgLS0+XG4gICAgPGRpdiBjbGFzcz1cImNvbnRlbnQtYXJlYVwiIFtuZ0NsYXNzXT1cInsgJ2Z1bGwtd2lkdGgnOiAhaXNTaWRlYmFyVmlzaWJsZSB9XCI+XG4gICAgICA8IS0tIENvbnRlbnQgQ2FyZCBXcmFwcGVyIC0tPlxuICAgICAgPHB0LWNhcmQgW2NvbmZpZ109XCJwYWdlU2tlbGV0b25Db25maWcuY29udGVudENhcmRDb25maWdcIj5cbiAgICAgICAgPCEtLSBCcmVhZGNydW1iIC0tPlxuICAgICAgICA8cHQtYnJlYWQtY3J1bWJcbiAgICAgICAgICAqbmdJZj1cInBhZ2VTa2VsZXRvbkNvbmZpZy5icmVhZENydW1iQ29uZmlnXCJcbiAgICAgICAgICBbYnJlYWRDcnVtYkNvbmZpZ109XCJwYWdlU2tlbGV0b25Db25maWcuYnJlYWRDcnVtYkNvbmZpZ1wiXG4gICAgICAgICAgY2xhc3M9XCJicmVhZC1jcnVtYlwiXG4gICAgICAgID48L3B0LWJyZWFkLWNydW1iPlxuXG4gICAgICAgIDwhLS0gQmFja2dyb3VuZCBDYXJkIC0tPlxuXG4gICAgICAgIDxyb3V0ZXItb3V0bGV0Pjwvcm91dGVyLW91dGxldD5cbiAgICAgIDwvcHQtY2FyZD5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG5cbiAgPCEtLSBGb290ZXIgLS0+XG4gIDxwdC1mb290ZXJcbiAgICAqbmdJZj1cInBhZ2VTa2VsZXRvbkNvbmZpZy5mb290ZXJDb25maWdcIlxuICAgIFtmb290ZXJDb25maWddPVwicGFnZVNrZWxldG9uQ29uZmlnLmZvb3RlckNvbmZpZ1wiXG4gICAgY2xhc3M9XCJwdC1mb290ZXJcIlxuICA+PC9wdC1mb290ZXI+XG48L3B0LWNhcmQ+XG4iXX0=