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 +7 -0
- package/esm2022/lib/models/card-config.model.mjs +1 -1
- package/esm2022/lib/models/nav-bar-menu-config.model.mjs +1 -1
- package/esm2022/lib/models/pattern.model.mjs +1 -1
- package/esm2022/lib/pt-card/pt-card.component.mjs +34 -15
- package/esm2022/lib/pt-menu/pt-menu.component.mjs +2 -2
- package/esm2022/lib/pt-menu-fancy/pt-menu-fancy.component.mjs +2 -2
- package/esm2022/lib/pt-nav-bar-menu/pt-nav-bar-menu.component.mjs +34 -7
- package/esm2022/lib/pt-page-skeleton/pt-page-skeleton.component.mjs +3 -1
- package/esm2022/lib/pt-side-bar-menu/pt-side-bar-menu.component.mjs +4 -1
- package/fesm2022/ng-prime-tools.mjs +74 -23
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/models/card-config.model.d.ts +1 -0
- package/lib/models/card-config.model.d.ts.map +1 -1
- package/lib/models/nav-bar-menu-config.model.d.ts +2 -0
- package/lib/models/nav-bar-menu-config.model.d.ts.map +1 -1
- package/lib/models/pattern.model.d.ts +1 -0
- package/lib/models/pattern.model.d.ts.map +1 -1
- package/lib/pt-card/pt-card.component.d.ts +8 -5
- package/lib/pt-card/pt-card.component.d.ts.map +1 -1
- package/lib/pt-menu-fancy/pt-menu-fancy.component.d.ts.map +1 -1
- package/lib/pt-nav-bar-menu/pt-nav-bar-menu.component.d.ts +8 -1
- package/lib/pt-nav-bar-menu/pt-nav-bar-menu.component.d.ts.map +1 -1
- package/lib/pt-page-skeleton/pt-page-skeleton.component.d.ts.map +1 -1
- package/lib/pt-side-bar-menu/pt-side-bar-menu.component.d.ts.map +1 -1
- package/package.json +1 -1
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,
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1jb25maWcubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL21vZGVscy9jYXJkLWNvbmZpZy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUNvbmZpZyB9IGZyb20gJy4vbWVudS1jb25maWcubW9kZWwnO1xuaW1wb3J0IHsgVGl0bGVTdHlsZSB9IGZyb20gJy4vdGl0bGUtc3R5bGUubW9kZWwnO1xuaW1wb3J0IHsgUGF0dGVybiB9IGZyb20gJy4vcGF0dGVybi5tb2RlbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FyZENvbmZpZyB7XG4gIGlkZW50aWZpZXI/OiBzdHJpbmc7XG4gIHRpdGxlPzogc3RyaW5nIHwgVGl0bGVTdHlsZTtcbiAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xuICB3aWR0aD86IHN0cmluZztcbiAgaGVpZ2h0Pzogc3RyaW5nO1xuICBwYWRkaW5nPzogc3RyaW5nO1xuICBtYXJnaW4/OiBzdHJpbmc7XG4gIGJvcmRlckNvbG9yPzogc3RyaW5nO1xuICBib3JkZXJXaWR0aD86IHN0cmluZztcbiAgbWVudT86IE1lbnVDb25maWc7XG4gIG1lbnVQb3NpdGlvbj86ICdsZWZ0JyB8ICdyaWdodCc7XG4gIHNjcm9sbGFibGVWZXJ0aWNhbD86IGJvb2xlYW47XG4gIHNjcm9sbGFibGVIb3Jpem9udGFsPzogYm9vbGVhbjtcbiAgcGF0dGVybj86IFBhdHRlcm47XG4gIG5vQm9yZGVyPzogYm9vbGVhbjtcbiAgYm9yZGVyUmFkaXVzPzogc3RyaW5nO1xuICBib3hTaGFkb3c/OiBzdHJpbmc7XG59XG4iXX0=
|
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LWJhci1tZW51LWNvbmZpZy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL25hdi1iYXItbWVudS1jb25maWcubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEltYWdlU3R5bGUgfSBmcm9tICcuL2ltYWdlLXN0eWxlLm1vZGVsJztcbmltcG9ydCB7IE1lbnVDb25maWcgfSBmcm9tICcuL21lbnUtY29uZmlnLm1vZGVsJztcbmltcG9ydCB7IFBhdHRlcm4gfSBmcm9tICcuL3BhdHRlcm4ubW9kZWwnO1xuaW1wb3J0IHsgVGV4dFN0eWxlIH0gZnJvbSAnLi90ZXh0LXN0eWxlLm1vZGVsJztcblxuZXhwb3J0IGludGVyZmFjZSBOYXZCYXJNZW51Q29uZmlnIHtcbiAgbG9nbz86IHN0cmluZyB8IEltYWdlU3R5bGU7XG4gIGFwcE5hbWU/
|
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/
|
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;
|
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
|
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',
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
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
|
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
|
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,
|
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
|
74
|
-
|
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:
|
80
|
-
backgroundPosition:
|
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
|
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
|
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,
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LXBhZ2Utc2tlbGV0b24vcHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LXBhZ2Utc2tlbGV0b24vcHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7QUFRL0UsTUFBTSxPQUFPLHVCQUF1QjtJQUxwQztRQU9ZLGtCQUFhLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFFdkUscUJBQWdCLEdBQVksSUFBSSxDQUFDO0tBb0NsQztJQWxDQyxRQUFRO1FBQ04sSUFBSSxDQUFDLDhCQUE4QixFQUFFLENBQUM7UUFDdEMsSUFBSSxDQUFDLDJCQUEyQixFQUFFLENBQUM7SUFDckMsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7UUFDL0MsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRUQsc0RBQXNEO0lBQ3RELDhCQUE4QjtRQUM1QixJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLEdBQUc7WUFDN0MsVUFBVSxFQUFFLDZCQUE2QjtZQUN6QyxRQUFRLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixFQUFFLFFBQVEsSUFBSSxJQUFJO1lBQ3hFLGVBQWUsRUFDYixJQUFJLENBQUMsa0JBQWtCLENBQUMsb0JBQW9CLEVBQUUsZUFBZSxJQUFJLE1BQU07WUFDekUsT0FBTyxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxvQkFBb0IsRUFBRSxPQUFPLElBQUksTUFBTTtZQUN4RSxNQUFNLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQixFQUFFLE1BQU0sSUFBSSxNQUFNO1lBQ3RFLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLG9CQUFvQjtTQUNoRCxDQUFDO0lBQ0osQ0FBQztJQUVELGtFQUFrRTtJQUNsRSwyQkFBMkI7UUFDekIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGlCQUFpQixHQUFHO1lBQzFDLFVBQVUsRUFBRSwwQkFBMEI7WUFDdEMsUUFBUSxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxpQkFBaUIsRUFBRSxRQUFRLElBQUksS0FBSztZQUN0RSxlQUFlLEVBQ2IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGlCQUFpQixFQUFFLGVBQWUsSUFBSSxTQUFTO1lBQ3pFLE9BQU8sRUFBRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCLEVBQUUsT0FBTyxJQUFJLE1BQU07WUFDckUsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCO1NBQzdDLENBQUM7SUFDSixDQUFDOytHQXZDVSx1QkFBdUI7bUdBQXZCLHVCQUF1QiwySkNScEMsa3ZDQXdDQTs7NEZEaENhLHVCQUF1QjtrQkFMbkMsU0FBUzsrQkFDRSxrQkFBa0I7OEJBS25CLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDSSxhQUFhO3NCQUF0QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUGFnZVNrZWxldG9uQ29uZmlnLCBDYXJkQ29uZmlnIH0gZnJvbSAnLi4vbW9kZWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncHQtcGFnZS1za2VsZXRvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9wdC1wYWdlLXNrZWxldG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcHQtcGFnZS1za2VsZXRvbi5jb21wb25lbnQuY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFBUUGFnZVNrZWxldG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgcGFnZVNrZWxldG9uQ29uZmlnITogUGFnZVNrZWxldG9uQ29uZmlnO1xuICBAT3V0cHV0KCkgdG9nZ2xlU2lkZWJhcjogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIGlzU2lkZWJhclZpc2libGU6IGJvb2xlYW4gPSB0cnVlO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuaW5pdGlhbGl6ZUJhY2tncm91bmRDYXJkQ29uZmlnKCk7XG4gICAgdGhpcy5pbml0aWFsaXplQ29udGVudENhcmRDb25maWcoKTtcbiAgfVxuXG4gIG9uVG9nZ2xlU2lkZWJhcigpOiB2b2lkIHtcbiAgICB0aGlzLmlzU2lkZWJhclZpc2libGUgPSAhdGhpcy5pc1NpZGViYXJWaXNpYmxlO1xuICAgIHRoaXMudG9nZ2xlU2lkZWJhci5lbWl0KCk7XG4gIH1cblxuICAvLyBJbml0aWFsaXplIGJhY2tncm91bmRDYXJkQ29uZmlnIHdpdGggZGVmYXVsdCB2YWx1ZXNcbiAgaW5pdGlhbGl6ZUJhY2tncm91bmRDYXJkQ29uZmlnKCkge1xuICAgIHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnID0ge1xuICAgICAgaWRlbnRpZmllcjogJ3B0LXBhZ2Utc2tlbGV0b24vYmFja2dyb3VuZCcsXG4gICAgICBub0JvcmRlcjogdGhpcy5wYWdlU2tlbGV0b25Db25maWcuYmFja2dyb3VuZENhcmRDb25maWc/Lm5vQm9yZGVyID8/IHRydWUsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6XG4gICAgICAgIHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnPy5iYWNrZ3JvdW5kQ29sb3IgfHwgJyNmZmYnLFxuICAgICAgcGFkZGluZzogdGhpcy5wYWdlU2tlbGV0b25Db25maWcuYmFja2dyb3VuZENhcmRDb25maWc/LnBhZGRpbmcgfHwgJzIwcHgnLFxuICAgICAgbWFyZ2luOiB0aGlzLnBhZ2VTa2VsZXRvbkNvbmZpZy5iYWNrZ3JvdW5kQ2FyZENvbmZpZz8ubWFyZ2luIHx8ICcxMHB4JyxcbiAgICAgIC4uLnRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnLFxuICAgIH07XG4gIH1cblxuICAvLyBJbml0aWFsaXplIGNvbnRlbnRDYXJkQ29uZmlnIHdpdGggZGVmYXVsdCB2YWx1ZXMgKGlmIG5lY2Vzc2FyeSlcbiAgaW5pdGlhbGl6ZUNvbnRlbnRDYXJkQ29uZmlnKCkge1xuICAgIHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnID0ge1xuICAgICAgaWRlbnRpZmllcjogJ3B0LXBhZ2Utc2tlbGV0b24vY29udGVudCcsXG4gICAgICBub0JvcmRlcjogdGhpcy5wYWdlU2tlbGV0b25Db25maWcuY29udGVudENhcmRDb25maWc/Lm5vQm9yZGVyID8/IGZhbHNlLFxuICAgICAgYmFja2dyb3VuZENvbG9yOlxuICAgICAgICB0aGlzLnBhZ2VTa2VsZXRvbkNvbmZpZy5jb250ZW50Q2FyZENvbmZpZz8uYmFja2dyb3VuZENvbG9yIHx8ICcjZjBmMGYwJyxcbiAgICAgIHBhZGRpbmc6IHRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnPy5wYWRkaW5nIHx8ICcxNXB4JyxcbiAgICAgIC4uLnRoaXMucGFnZVNrZWxldG9uQ29uZmlnLmNvbnRlbnRDYXJkQ29uZmlnLFxuICAgIH07XG4gIH1cbn1cbiIsIjxwdC1jYXJkIFtjb25maWddPVwicGFnZVNrZWxldG9uQ29uZmlnLmJhY2tncm91bmRDYXJkQ29uZmlnIVwiPlxuICA8IS0tIE5hdmJhciAtLT5cbiAgPHB0LW5hdi1iYXItbWVudVxuICAgIFtuYXZCYXJNZW51Q29uZmlnXT1cInBhZ2VTa2VsZXRvbkNvbmZpZy5uYXZCYXJNZW51Q29uZmlnXCJcbiAgICAodG9nZ2xlU2lkZWJhcik9XCJvblRvZ2dsZVNpZGViYXIoKVwiXG4gID48L3B0LW5hdi1iYXItbWVudT5cblxuICA8ZGl2IGNsYXNzPVwibWFpbi1jb250ZW50XCI+XG4gICAgPCEtLSBTaWRlYmFyICh1c2UgKm5nSWYgdG8gdG9nZ2xlIHZpc2liaWxpdHkpIC0tPlxuICAgIDxwdC1zaWRlLWJhci1tZW51XG4gICAgICAqbmdJZj1cImlzU2lkZWJhclZpc2libGVcIlxuICAgICAgW21lbnVDb25maWddPVwicGFnZVNrZWxldG9uQ29uZmlnLnNpZGVNZW51QmFyQ29uZmlnXCJcbiAgICAgIGNsYXNzPVwic2lkZWJhclwiXG4gICAgPjwvcHQtc2lkZS1iYXItbWVudT5cblxuICAgIDwhLS0gTWFpbiBWaWV3IEFyZWEgLS0+XG4gICAgPGRpdiBjbGFzcz1cImNvbnRlbnQtYXJlYVwiIFtuZ0NsYXNzXT1cInsgJ2Z1bGwtd2lkdGgnOiAhaXNTaWRlYmFyVmlzaWJsZSB9XCI+XG4gICAgICA8IS0tIENvbnRlbnQgQ2FyZCBXcmFwcGVyIC0tPlxuICAgICAgPHB0LWNhcmQgW2NvbmZpZ109XCJwYWdlU2tlbGV0b25Db25maWcuY29udGVudENhcmRDb25maWdcIj5cbiAgICAgICAgPCEtLSBCcmVhZGNydW1iIC0tPlxuICAgICAgICA8cHQtYnJlYWQtY3J1bWJcbiAgICAgICAgICAqbmdJZj1cInBhZ2VTa2VsZXRvbkNvbmZpZy5icmVhZENydW1iQ29uZmlnXCJcbiAgICAgICAgICBbYnJlYWRDcnVtYkNvbmZpZ109XCJwYWdlU2tlbGV0b25Db25maWcuYnJlYWRDcnVtYkNvbmZpZ1wiXG4gICAgICAgICAgY2xhc3M9XCJicmVhZC1jcnVtYlwiXG4gICAgICAgID48L3B0LWJyZWFkLWNydW1iPlxuXG4gICAgICAgIDwhLS0gQmFja2dyb3VuZCBDYXJkIC0tPlxuXG4gICAgICAgIDxyb3V0ZXItb3V0bGV0Pjwvcm91dGVyLW91dGxldD5cbiAgICAgIDwvcHQtY2FyZD5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG5cbiAgPCEtLSBGb290ZXIgLS0+XG4gIDxwdC1mb290ZXJcbiAgICAqbmdJZj1cInBhZ2VTa2VsZXRvbkNvbmZpZy5mb290ZXJDb25maWdcIlxuICAgIFtmb290ZXJDb25maWddPVwicGFnZVNrZWxldG9uQ29uZmlnLmZvb3RlckNvbmZpZ1wiXG4gICAgY2xhc3M9XCJwdC1mb290ZXJcIlxuICA+PC9wdC1mb290ZXI+XG48L3B0LWNhcmQ+XG4iXX0=
|