ng-prime-tools 1.0.31 → 1.0.32
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/esm2022/lib/models/button.model.mjs +1 -1
- package/esm2022/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.mjs +37 -52
- package/esm2022/lib/pt-button/pt-button.component.mjs +44 -16
- package/esm2022/lib/pt-dialog/pt-dialog.component.mjs +164 -129
- package/fesm2022/ng-prime-tools.mjs +241 -194
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/models/button.model.d.ts +1 -0
- package/lib/models/button.model.d.ts.map +1 -1
- package/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.d.ts +7 -2
- package/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.d.ts.map +1 -1
- package/lib/pt-button/pt-button.component.d.ts +7 -1
- package/lib/pt-button/pt-button.component.d.ts.map +1 -1
- package/lib/pt-dialog/pt-dialog.component.d.ts +18 -1
- package/lib/pt-dialog/pt-dialog.component.d.ts.map +1 -1
- package/lib/pt-metric-panel/pt-metric-panel.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -22,6 +22,7 @@ export class PTButtonComponent {
|
|
|
22
22
|
fontColor: '#000',
|
|
23
23
|
backgroundColor: '#fff',
|
|
24
24
|
borderColor: '#000',
|
|
25
|
+
outlined: false,
|
|
25
26
|
};
|
|
26
27
|
}
|
|
27
28
|
}
|
|
@@ -35,7 +36,7 @@ export class PTButtonComponent {
|
|
|
35
36
|
JSON.stringify({ ...prev, disabled: undefined }) ===
|
|
36
37
|
JSON.stringify({ ...curr, disabled: undefined });
|
|
37
38
|
if (onlyDisabledChanged) {
|
|
38
|
-
this.updateDisabledStyles(curr.disabled);
|
|
39
|
+
this.updateDisabledStyles(curr.disabled ?? false);
|
|
39
40
|
}
|
|
40
41
|
else {
|
|
41
42
|
this.applyButtonStyles();
|
|
@@ -47,14 +48,6 @@ export class PTButtonComponent {
|
|
|
47
48
|
}
|
|
48
49
|
}
|
|
49
50
|
}
|
|
50
|
-
updateDisabledStyles(isDisabled) {
|
|
51
|
-
const buttonElement = this.el.nativeElement.querySelector('button.p-element');
|
|
52
|
-
if (buttonElement) {
|
|
53
|
-
this.renderer.setStyle(buttonElement, 'color', isDisabled ? '#999' : this.buttonConfig.fontColor);
|
|
54
|
-
this.renderer.setStyle(buttonElement, 'background-color', isDisabled ? '#e0e0e0' : this.buttonConfig.backgroundColor);
|
|
55
|
-
this.renderer.setStyle(buttonElement, 'border-color', isDisabled ? '#bdbdbd' : this.buttonConfig.borderColor);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
51
|
ngAfterViewInit() {
|
|
59
52
|
this.applyButtonStyles();
|
|
60
53
|
}
|
|
@@ -64,24 +57,59 @@ export class PTButtonComponent {
|
|
|
64
57
|
getType() {
|
|
65
58
|
return this.buttonConfig.type || 'button';
|
|
66
59
|
}
|
|
60
|
+
updateDisabledStyles(isDisabled) {
|
|
61
|
+
const buttonElement = this.el.nativeElement.querySelector('button.p-element');
|
|
62
|
+
if (buttonElement) {
|
|
63
|
+
this.renderer.setStyle(buttonElement, 'color', isDisabled ? '#999' : this.buttonConfig.fontColor);
|
|
64
|
+
this.renderer.setStyle(buttonElement, 'background-color', isDisabled ? '#e0e0e0' : this.buttonConfig.backgroundColor);
|
|
65
|
+
this.renderer.setStyle(buttonElement, 'border-color', isDisabled ? '#bdbdbd' : this.buttonConfig.borderColor);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* We delegate colors to PrimeNG theme when:
|
|
70
|
+
* - outlined = true
|
|
71
|
+
* - and no manual color is provided (no backgroundColor, borderColor, fontColor)
|
|
72
|
+
*/
|
|
73
|
+
shouldUseThemeColors() {
|
|
74
|
+
if (!this.buttonConfig) {
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
const outlined = !!this.buttonConfig.outlined; // ✅ coerce to boolean
|
|
78
|
+
return (outlined &&
|
|
79
|
+
!this.buttonConfig.backgroundColor &&
|
|
80
|
+
!this.buttonConfig.borderColor &&
|
|
81
|
+
!this.buttonConfig.fontColor);
|
|
82
|
+
}
|
|
67
83
|
applyButtonStyles() {
|
|
68
84
|
const buttonElement = this.el.nativeElement.querySelector('button.p-element');
|
|
69
|
-
if (buttonElement
|
|
70
|
-
|
|
85
|
+
if (!buttonElement || !this.buttonConfig) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
const isDisabled = !!this.buttonConfig.disabled;
|
|
89
|
+
const useThemeColors = this.shouldUseThemeColors();
|
|
90
|
+
// Width / height always applied
|
|
91
|
+
this.renderer.setStyle(buttonElement, 'width', this.buttonConfig.width || 'auto');
|
|
92
|
+
this.renderer.setStyle(buttonElement, 'height', this.buttonConfig.height || 'auto');
|
|
93
|
+
// ✅ Only override colors when we are NOT delegating to PrimeNG theme
|
|
94
|
+
if (!useThemeColors) {
|
|
71
95
|
this.renderer.setStyle(buttonElement, 'color', isDisabled ? '#999' : this.buttonConfig.fontColor);
|
|
72
96
|
this.renderer.setStyle(buttonElement, 'background-color', isDisabled ? '#e0e0e0' : this.buttonConfig.backgroundColor);
|
|
73
97
|
this.renderer.setStyle(buttonElement, 'border-color', isDisabled ? '#bdbdbd' : this.buttonConfig.borderColor);
|
|
74
|
-
|
|
75
|
-
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
// If we delegate to theme, clear any inline overrides
|
|
101
|
+
this.renderer.removeStyle(buttonElement, 'color');
|
|
102
|
+
this.renderer.removeStyle(buttonElement, 'background-color');
|
|
103
|
+
this.renderer.removeStyle(buttonElement, 'border-color');
|
|
76
104
|
}
|
|
77
105
|
}
|
|
78
106
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTButtonComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTButtonComponent, selector: "pt-button", inputs: { buttonConfig: "buttonConfig" }, usesOnChanges: true, ngImport: i0, template: "<p-button\n [label]=\"buttonConfig.label\"\n [icon]=\"buttonConfig.icon || ''\"\n [iconPos]=\"getIconPos()\"\n [disabled]=\"buttonConfig.disabled\"\n [loading]=\"buttonConfig.loading\"\n [class]=\"buttonConfig.styleClass || ''\"\n [type]=\"getType()\"\n></p-button>\n", styles: ["::ng-deep p-button{display:block}\n"], dependencies: [{ kind: "component", type: i1.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }] }); }
|
|
107
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTButtonComponent, selector: "pt-button", inputs: { buttonConfig: "buttonConfig" }, usesOnChanges: true, ngImport: i0, template: "<p-button\n [label]=\"buttonConfig.label\"\n [icon]=\"buttonConfig.icon || ''\"\n [iconPos]=\"getIconPos()\"\n [disabled]=\"buttonConfig.disabled\"\n [loading]=\"buttonConfig.loading\"\n [class]=\"buttonConfig.styleClass || ''\"\n [type]=\"getType()\"\n [severity]=\"buttonConfig.severity\"\n [outlined]=\"buttonConfig.outlined\"\n></p-button>\n", styles: ["::ng-deep p-button{display:block}\n"], dependencies: [{ kind: "component", type: i1.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }] }); }
|
|
80
108
|
}
|
|
81
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTButtonComponent, decorators: [{
|
|
82
110
|
type: Component,
|
|
83
|
-
args: [{ selector: 'pt-button', template: "<p-button\n [label]=\"buttonConfig.label\"\n [icon]=\"buttonConfig.icon || ''\"\n [iconPos]=\"getIconPos()\"\n [disabled]=\"buttonConfig.disabled\"\n [loading]=\"buttonConfig.loading\"\n [class]=\"buttonConfig.styleClass || ''\"\n [type]=\"getType()\"\n></p-button>\n", styles: ["::ng-deep p-button{display:block}\n"] }]
|
|
111
|
+
args: [{ selector: 'pt-button', template: "<p-button\n [label]=\"buttonConfig.label\"\n [icon]=\"buttonConfig.icon || ''\"\n [iconPos]=\"getIconPos()\"\n [disabled]=\"buttonConfig.disabled\"\n [loading]=\"buttonConfig.loading\"\n [class]=\"buttonConfig.styleClass || ''\"\n [type]=\"getType()\"\n [severity]=\"buttonConfig.severity\"\n [outlined]=\"buttonConfig.outlined\"\n></p-button>\n", styles: ["::ng-deep p-button{display:block}\n"] }]
|
|
84
112
|
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { buttonConfig: [{
|
|
85
113
|
type: Input
|
|
86
114
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-button.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-button/pt-button.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-button/pt-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  AfterViewInit,\n  Renderer2,\n  ElementRef,\n  SimpleChanges,\n  OnChanges,\n} from '@angular/core';\nimport { ButtonModel } from '../models';\n\n@Component({\n  selector: 'pt-button',\n  templateUrl: './pt-button.component.html',\n  styleUrls: ['./pt-button.component.css'],\n})\nexport class PTButtonComponent implements OnInit, AfterViewInit, OnChanges {\n  @Input() buttonConfig!: ButtonModel;\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  ngOnInit(): void {\n    // Fallback to default config if undefined\n    if (!this.buttonConfig) {\n      this.buttonConfig = {\n        label: 'Click Me',\n        icon: '',\n        iconPos: 'left',\n        disabled: false,\n        styleClass: '',\n        loading: false,\n        type: 'button',\n        width: '100%',\n        height: 'auto',\n        fontColor: '#000',\n        backgroundColor: '#fff',\n        borderColor: '#000',\n      };\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const configChange = changes['buttonConfig'];\n\n    if (configChange) {\n      const prev = configChange.previousValue;\n      const curr = configChange.currentValue;\n\n      if (prev && curr) {\n        const onlyDisabledChanged =\n          prev.disabled !== curr.disabled &&\n          JSON.stringify({ ...prev, disabled: undefined }) ===\n            JSON.stringify({ ...curr, disabled: undefined });\n\n        if (onlyDisabledChanged) {\n          this.updateDisabledStyles(curr.disabled);\n        } else {\n          this.applyButtonStyles();\n        }\n      } else {\n        // If no previous value (first load), apply full styles\n        this.applyButtonStyles();\n      }\n    }\n  }\n  updateDisabledStyles(isDisabled: boolean): void {\n    const buttonElement =\n      this.el.nativeElement.querySelector('button.p-element');\n\n    if (buttonElement) {\n      this.renderer.setStyle(\n        buttonElement,\n        'color',\n        isDisabled ? '#999' : this.buttonConfig.fontColor\n      );\n      this.renderer.setStyle(\n        buttonElement,\n        'background-color',\n        isDisabled ? '#e0e0e0' : this.buttonConfig.backgroundColor\n      );\n      this.renderer.setStyle(\n        buttonElement,\n        'border-color',\n        isDisabled ? '#bdbdbd' : this.buttonConfig.borderColor\n      );\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.applyButtonStyles();\n  }\n\n  getIconPos(): 'left' | 'right' {\n    return this.buttonConfig.iconPos === 'right' ? 'right' : 'left';\n  }\n\n  getType(): string {\n    return this.buttonConfig.type || 'button';\n  }\n\n  applyButtonStyles(): void {\n    const buttonElement =\n      this.el.nativeElement.querySelector('button.p-element');\n\n    if (buttonElement && this.buttonConfig) {\n      const isDisabled = this.buttonConfig.disabled;\n\n      this.renderer.setStyle(\n        buttonElement,\n        'color',\n        isDisabled ? '#999' : this.buttonConfig.fontColor\n      );\n\n      this.renderer.setStyle(\n        buttonElement,\n        'background-color',\n        isDisabled ? '#e0e0e0' : this.buttonConfig.backgroundColor\n      );\n\n      this.renderer.setStyle(\n        buttonElement,\n        'border-color',\n        isDisabled ? '#bdbdbd' : this.buttonConfig.borderColor\n      );\n\n      this.renderer.setStyle(\n        buttonElement,\n        'width',\n        this.buttonConfig.width || 'auto'\n      );\n\n      this.renderer.setStyle(\n        buttonElement,\n        'height',\n        this.buttonConfig.height || 'auto'\n      );\n    }\n  }\n}\n","<p-button\n  [label]=\"buttonConfig.label\"\n  [icon]=\"buttonConfig.icon || ''\"\n  [iconPos]=\"getIconPos()\"\n  [disabled]=\"buttonConfig.disabled\"\n  [loading]=\"buttonConfig.loading\"\n  [class]=\"buttonConfig.styleClass || ''\"\n  [type]=\"getType()\"\n></p-button>\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-button.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-button/pt-button.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-button/pt-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit,\n  AfterViewInit,\n  Renderer2,\n  ElementRef,\n  SimpleChanges,\n  OnChanges,\n} from '@angular/core';\nimport { ButtonModel } from '../models';\n\n@Component({\n  selector: 'pt-button',\n  templateUrl: './pt-button.component.html',\n  styleUrls: ['./pt-button.component.css'],\n})\nexport class PTButtonComponent implements OnInit, AfterViewInit, OnChanges {\n  @Input() buttonConfig!: ButtonModel;\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  ngOnInit(): void {\n    // Fallback to default config if undefined\n    if (!this.buttonConfig) {\n      this.buttonConfig = {\n        label: 'Click Me',\n        icon: '',\n        iconPos: 'left',\n        disabled: false,\n        styleClass: '',\n        loading: false,\n        type: 'button',\n        width: '100%',\n        height: 'auto',\n        fontColor: '#000',\n        backgroundColor: '#fff',\n        borderColor: '#000',\n        outlined: false,\n      };\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const configChange = changes['buttonConfig'];\n\n    if (configChange) {\n      const prev = configChange.previousValue as ButtonModel | undefined;\n      const curr = configChange.currentValue as ButtonModel | undefined;\n\n      if (prev && curr) {\n        const onlyDisabledChanged =\n          prev.disabled !== curr.disabled &&\n          JSON.stringify({ ...prev, disabled: undefined }) ===\n            JSON.stringify({ ...curr, disabled: undefined });\n\n        if (onlyDisabledChanged) {\n          this.updateDisabledStyles(curr.disabled ?? false);\n        } else {\n          this.applyButtonStyles();\n        }\n      } else {\n        // If no previous value (first load), apply full styles\n        this.applyButtonStyles();\n      }\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.applyButtonStyles();\n  }\n\n  getIconPos(): 'left' | 'right' {\n    return this.buttonConfig.iconPos === 'right' ? 'right' : 'left';\n  }\n\n  getType(): string {\n    return this.buttonConfig.type || 'button';\n  }\n\n  private updateDisabledStyles(isDisabled: boolean): void {\n    const buttonElement =\n      this.el.nativeElement.querySelector('button.p-element');\n\n    if (buttonElement) {\n      this.renderer.setStyle(\n        buttonElement,\n        'color',\n        isDisabled ? '#999' : this.buttonConfig.fontColor\n      );\n      this.renderer.setStyle(\n        buttonElement,\n        'background-color',\n        isDisabled ? '#e0e0e0' : this.buttonConfig.backgroundColor\n      );\n      this.renderer.setStyle(\n        buttonElement,\n        'border-color',\n        isDisabled ? '#bdbdbd' : this.buttonConfig.borderColor\n      );\n    }\n  }\n\n  /**\n   * We delegate colors to PrimeNG theme when:\n   * - outlined = true\n   * - and no manual color is provided (no backgroundColor, borderColor, fontColor)\n   */\n  private shouldUseThemeColors(): boolean {\n    if (!this.buttonConfig) {\n      return false;\n    }\n\n    const outlined = !!this.buttonConfig.outlined; // ✅ coerce to boolean\n\n    return (\n      outlined &&\n      !this.buttonConfig.backgroundColor &&\n      !this.buttonConfig.borderColor &&\n      !this.buttonConfig.fontColor\n    );\n  }\n\n  applyButtonStyles(): void {\n    const buttonElement =\n      this.el.nativeElement.querySelector('button.p-element');\n\n    if (!buttonElement || !this.buttonConfig) {\n      return;\n    }\n\n    const isDisabled = !!this.buttonConfig.disabled;\n    const useThemeColors = this.shouldUseThemeColors();\n\n    // Width / height always applied\n    this.renderer.setStyle(\n      buttonElement,\n      'width',\n      this.buttonConfig.width || 'auto'\n    );\n\n    this.renderer.setStyle(\n      buttonElement,\n      'height',\n      this.buttonConfig.height || 'auto'\n    );\n\n    // ✅ Only override colors when we are NOT delegating to PrimeNG theme\n    if (!useThemeColors) {\n      this.renderer.setStyle(\n        buttonElement,\n        'color',\n        isDisabled ? '#999' : this.buttonConfig.fontColor\n      );\n\n      this.renderer.setStyle(\n        buttonElement,\n        'background-color',\n        isDisabled ? '#e0e0e0' : this.buttonConfig.backgroundColor\n      );\n\n      this.renderer.setStyle(\n        buttonElement,\n        'border-color',\n        isDisabled ? '#bdbdbd' : this.buttonConfig.borderColor\n      );\n    } else {\n      // If we delegate to theme, clear any inline overrides\n      this.renderer.removeStyle(buttonElement, 'color');\n      this.renderer.removeStyle(buttonElement, 'background-color');\n      this.renderer.removeStyle(buttonElement, 'border-color');\n    }\n  }\n}\n","<p-button\n  [label]=\"buttonConfig.label\"\n  [icon]=\"buttonConfig.icon || ''\"\n  [iconPos]=\"getIconPos()\"\n  [disabled]=\"buttonConfig.disabled\"\n  [loading]=\"buttonConfig.loading\"\n  [class]=\"buttonConfig.styleClass || ''\"\n  [type]=\"getType()\"\n  [severity]=\"buttonConfig.severity\"\n  [outlined]=\"buttonConfig.outlined\"\n></p-button>\n"]}
|