ng-prime-tools 1.0.29 → 1.0.30

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,10 @@ export class FormBuilderTesterComponent implements OnInit {
636
636
 
637
637
  ## Changelog
638
638
 
639
+ ### Version 1.0.30 - Release Date: 10/04/2025
640
+
641
+ - fixing the disabling btn in pt-login
642
+
639
643
  ### Version 1.0.28 - 1.O.29 - Release Date: 05/04/2025
640
644
 
641
645
  - Changing style of pt-button when disabled
@@ -26,8 +26,33 @@ export class PTButtonComponent {
26
26
  }
27
27
  }
28
28
  ngOnChanges(changes) {
29
- if (changes['buttonConfig']) {
30
- this.applyButtonStyles();
29
+ const configChange = changes['buttonConfig'];
30
+ if (configChange) {
31
+ const prev = configChange.previousValue;
32
+ const curr = configChange.currentValue;
33
+ if (prev && curr) {
34
+ const onlyDisabledChanged = prev.disabled !== curr.disabled &&
35
+ JSON.stringify({ ...prev, disabled: undefined }) ===
36
+ JSON.stringify({ ...curr, disabled: undefined });
37
+ if (onlyDisabledChanged) {
38
+ this.updateDisabledStyles(curr.disabled);
39
+ }
40
+ else {
41
+ this.applyButtonStyles();
42
+ }
43
+ }
44
+ else {
45
+ // If no previous value (first load), apply full styles
46
+ this.applyButtonStyles();
47
+ }
48
+ }
49
+ }
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);
31
56
  }
32
57
  }
33
58
  ngAfterViewInit() {
@@ -59,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
59
84
  }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { buttonConfig: [{
60
85
  type: Input
61
86
  }] } });
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvcHQtYnV0dG9uL3B0LWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LWJ1dHRvbi9wdC1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxLQUFLLEdBT04sTUFBTSxlQUFlLENBQUM7OztBQVF2QixNQUFNLE9BQU8saUJBQWlCO0lBRzVCLFlBQW9CLFFBQW1CLEVBQVUsRUFBYztRQUEzQyxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQVUsT0FBRSxHQUFGLEVBQUUsQ0FBWTtJQUFHLENBQUM7SUFFbkUsUUFBUTtRQUNOLDBDQUEwQztRQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxZQUFZLEdBQUc7Z0JBQ2xCLEtBQUssRUFBRSxVQUFVO2dCQUNqQixJQUFJLEVBQUUsRUFBRTtnQkFDUixPQUFPLEVBQUUsTUFBTTtnQkFDZixRQUFRLEVBQUUsS0FBSztnQkFDZixVQUFVLEVBQUUsRUFBRTtnQkFDZCxPQUFPLEVBQUUsS0FBSztnQkFDZCxJQUFJLEVBQUUsUUFBUTtnQkFDZCxLQUFLLEVBQUUsTUFBTTtnQkFDYixNQUFNLEVBQUUsTUFBTTtnQkFDZCxTQUFTLEVBQUUsTUFBTTtnQkFDakIsZUFBZSxFQUFFLE1BQU07Z0JBQ3ZCLFdBQVcsRUFBRSxNQUFNO2FBQ3BCLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxjQUFjLENBQUMsRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxVQUFVO1FBQ1IsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLE9BQU8sS0FBSyxPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ2xFLENBQUM7SUFFRCxPQUFPO1FBQ0wsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksSUFBSSxRQUFRLENBQUM7SUFDNUMsQ0FBQztJQUVELGlCQUFpQjtRQUNmLE1BQU0sYUFBYSxHQUNqQixJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUUxRCxJQUFJLGFBQWEsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDdkMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUM7WUFFOUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQ3BCLGFBQWEsRUFDYixPQUFPLEVBQ1AsVUFBVSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUNsRCxDQUFDO1lBRUYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQ3BCLGFBQWEsRUFDYixrQkFBa0IsRUFDbEIsVUFBVSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsZUFBZSxDQUMzRCxDQUFDO1lBRUYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQ3BCLGFBQWEsRUFDYixjQUFjLEVBQ2QsVUFBVSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUN2RCxDQUFDO1lBRUYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQ3BCLGFBQWEsRUFDYixPQUFPLEVBQ1AsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLElBQUksTUFBTSxDQUNsQyxDQUFDO1lBRUYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQ3BCLGFBQWEsRUFDYixRQUFRLEVBQ1IsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLElBQUksTUFBTSxDQUNuQyxDQUFDO1FBQ0osQ0FBQztJQUNILENBQUM7K0dBaEZVLGlCQUFpQjttR0FBakIsaUJBQWlCLGdIQ2pCOUIsb1JBU0E7OzRGRFFhLGlCQUFpQjtrQkFMN0IsU0FBUzsrQkFDRSxXQUFXO3VHQUtaLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnQsXG4gIElucHV0LFxuICBPbkluaXQsXG4gIEFmdGVyVmlld0luaXQsXG4gIFJlbmRlcmVyMixcbiAgRWxlbWVudFJlZixcbiAgU2ltcGxlQ2hhbmdlcyxcbiAgT25DaGFuZ2VzLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJ1dHRvbk1vZGVsIH0gZnJvbSAnLi4vbW9kZWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncHQtYnV0dG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3B0LWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3B0LWJ1dHRvbi5jb21wb25lbnQuY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFBUQnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0LCBPbkNoYW5nZXMge1xuICBASW5wdXQoKSBidXR0b25Db25maWchOiBCdXR0b25Nb2RlbDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjIsIHByaXZhdGUgZWw6IEVsZW1lbnRSZWYpIHt9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgLy8gRmFsbGJhY2sgdG8gZGVmYXVsdCBjb25maWcgaWYgdW5kZWZpbmVkXG4gICAgaWYgKCF0aGlzLmJ1dHRvbkNvbmZpZykge1xuICAgICAgdGhpcy5idXR0b25Db25maWcgPSB7XG4gICAgICAgIGxhYmVsOiAnQ2xpY2sgTWUnLFxuICAgICAgICBpY29uOiAnJyxcbiAgICAgICAgaWNvblBvczogJ2xlZnQnLFxuICAgICAgICBkaXNhYmxlZDogZmFsc2UsXG4gICAgICAgIHN0eWxlQ2xhc3M6ICcnLFxuICAgICAgICBsb2FkaW5nOiBmYWxzZSxcbiAgICAgICAgdHlwZTogJ2J1dHRvbicsXG4gICAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICAgIGhlaWdodDogJ2F1dG8nLFxuICAgICAgICBmb250Q29sb3I6ICcjMDAwJyxcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiAnI2ZmZicsXG4gICAgICAgIGJvcmRlckNvbG9yOiAnIzAwMCcsXG4gICAgICB9O1xuICAgIH1cbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoY2hhbmdlc1snYnV0dG9uQ29uZmlnJ10pIHtcbiAgICAgIHRoaXMuYXBwbHlCdXR0b25TdHlsZXMoKTtcbiAgICB9XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgdGhpcy5hcHBseUJ1dHRvblN0eWxlcygpO1xuICB9XG5cbiAgZ2V0SWNvblBvcygpOiAnbGVmdCcgfCAncmlnaHQnIHtcbiAgICByZXR1cm4gdGhpcy5idXR0b25Db25maWcuaWNvblBvcyA9PT0gJ3JpZ2h0JyA/ICdyaWdodCcgOiAnbGVmdCc7XG4gIH1cblxuICBnZXRUeXBlKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuYnV0dG9uQ29uZmlnLnR5cGUgfHwgJ2J1dHRvbic7XG4gIH1cblxuICBhcHBseUJ1dHRvblN0eWxlcygpOiB2b2lkIHtcbiAgICBjb25zdCBidXR0b25FbGVtZW50ID1cbiAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5xdWVyeVNlbGVjdG9yKCdidXR0b24ucC1lbGVtZW50Jyk7XG5cbiAgICBpZiAoYnV0dG9uRWxlbWVudCAmJiB0aGlzLmJ1dHRvbkNvbmZpZykge1xuICAgICAgY29uc3QgaXNEaXNhYmxlZCA9IHRoaXMuYnV0dG9uQ29uZmlnLmRpc2FibGVkO1xuXG4gICAgICB0aGlzLnJlbmRlcmVyLnNldFN0eWxlKFxuICAgICAgICBidXR0b25FbGVtZW50LFxuICAgICAgICAnY29sb3InLFxuICAgICAgICBpc0Rpc2FibGVkID8gJyM5OTknIDogdGhpcy5idXR0b25Db25maWcuZm9udENvbG9yXG4gICAgICApO1xuXG4gICAgICB0aGlzLnJlbmRlcmVyLnNldFN0eWxlKFxuICAgICAgICBidXR0b25FbGVtZW50LFxuICAgICAgICAnYmFja2dyb3VuZC1jb2xvcicsXG4gICAgICAgIGlzRGlzYWJsZWQgPyAnI2UwZTBlMCcgOiB0aGlzLmJ1dHRvbkNvbmZpZy5iYWNrZ3JvdW5kQ29sb3JcbiAgICAgICk7XG5cbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUoXG4gICAgICAgIGJ1dHRvbkVsZW1lbnQsXG4gICAgICAgICdib3JkZXItY29sb3InLFxuICAgICAgICBpc0Rpc2FibGVkID8gJyNiZGJkYmQnIDogdGhpcy5idXR0b25Db25maWcuYm9yZGVyQ29sb3JcbiAgICAgICk7XG5cbiAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUoXG4gICAgICAgIGJ1dHRvbkVsZW1lbnQsXG4gICAgICAgICd3aWR0aCcsXG4gICAgICAgIHRoaXMuYnV0dG9uQ29uZmlnLndpZHRoIHx8ICdhdXRvJ1xuICAgICAgKTtcblxuICAgICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZShcbiAgICAgICAgYnV0dG9uRWxlbWVudCxcbiAgICAgICAgJ2hlaWdodCcsXG4gICAgICAgIHRoaXMuYnV0dG9uQ29uZmlnLmhlaWdodCB8fCAnYXV0bydcbiAgICAgICk7XG4gICAgfVxuICB9XG59XG4iLCI8cC1idXR0b25cbiAgW2xhYmVsXT1cImJ1dHRvbkNvbmZpZy5sYWJlbFwiXG4gIFtpY29uXT1cImJ1dHRvbkNvbmZpZy5pY29uIHx8ICcnXCJcbiAgW2ljb25Qb3NdPVwiZ2V0SWNvblBvcygpXCJcbiAgW2Rpc2FibGVkXT1cImJ1dHRvbkNvbmZpZy5kaXNhYmxlZFwiXG4gIFtsb2FkaW5nXT1cImJ1dHRvbkNvbmZpZy5sb2FkaW5nXCJcbiAgW2NsYXNzXT1cImJ1dHRvbkNvbmZpZy5zdHlsZUNsYXNzIHx8ICcnXCJcbiAgW3R5cGVdPVwiZ2V0VHlwZSgpXCJcbj48L3AtYnV0dG9uPlxuIl19
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"]}
@@ -27,7 +27,10 @@ export class PTLoginCardComponent {
27
27
  });
28
28
  // Enable/Disable the button based on form validity
29
29
  this.formGroup.statusChanges.subscribe((status) => {
30
- this.loginPageConfig.buttonConfig.disabled = status !== 'VALID';
30
+ this.loginPageConfig.buttonConfig = {
31
+ ...this.loginPageConfig.buttonConfig,
32
+ disabled: status !== 'VALID',
33
+ };
31
34
  });
32
35
  }
33
36
  // Initialize default values for all fields in loginPageConfig if not set
@@ -147,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
147
150
  }], loginSubmit: [{
148
151
  type: Output
149
152
  }] } });
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-login-card.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-prime-tools/src/lib/pt-login-page/pt-login-card/pt-login-card.component.ts","../../../../../../projects/ng-prime-tools/src/lib/pt-login-page/pt-login-card/pt-login-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n  FormBuilder,\n  FormGroup,\n  Validators,\n  FormsModule,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { LoginModel, LoginPageConfig } from '../../models';\nimport { FormInputTypeEnum } from '../../enums';\nimport { CommonModule } from '@angular/common';\nimport { PTCardModule } from '../../pt-card';\nimport { PTButtonModule } from '../../pt-button';\nimport { PTTextInputModule } from '../../pt-text-input';\n\n@Component({\n  selector: 'pt-login-card',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    PTCardModule,\n    PTButtonModule,\n    PTTextInputModule,\n  ],\n  templateUrl: './pt-login-card.component.html',\n  styleUrls: ['./pt-login-card.component.css'],\n})\nexport class PTLoginCardComponent implements OnInit {\n  @Input() loginPageConfig!: LoginPageConfig;\n  @Input() loginErrorMessage: string | null = null;\n  @Output() loginSubmit: EventEmitter<LoginModel> =\n    new EventEmitter<LoginModel>();\n\n  formGroup: FormGroup;\n\n  constructor(private fb: FormBuilder) {\n    this.formGroup = this.fb.group({});\n  }\n\n  ngOnInit(): void {\n    this.initializeDefaults();\n    this.setupFormFields();\n\n    this.formGroup.patchValue({\n      username: this.loginPageConfig?.login?.username || '',\n      password: this.loginPageConfig?.login?.password || '',\n    });\n    // Enable/Disable the button based on form validity\n    this.formGroup.statusChanges.subscribe((status) => {\n      this.loginPageConfig.buttonConfig!.disabled = status !== 'VALID';\n    });\n  }\n\n  // Initialize default values for all fields in loginPageConfig if not set\n  initializeDefaults() {\n    // Initialize backgroundImage\n    this.loginPageConfig.backgroundImage = {\n      imageUrl: this.loginPageConfig.backgroundImage?.imageUrl || '',\n      transparencyPercentage:\n        this.loginPageConfig.backgroundImage?.transparencyPercentage || '100',\n      ...this.loginPageConfig.backgroundImage,\n    };\n\n    // Initialize title\n    this.loginPageConfig.title = {\n      text: this.loginPageConfig.title?.text || 'Login',\n      position: this.loginPageConfig.title?.position || 'center',\n      color: this.loginPageConfig.title?.color || '#333',\n      fontSize: this.loginPageConfig.title?.fontSize || '24px',\n      ...this.loginPageConfig.title,\n    };\n\n    // Initialize logoUrl\n    this.loginPageConfig.logoUrl = {\n      altText: this.loginPageConfig.logoUrl?.altText || 'Logo',\n      imageUrl: this.loginPageConfig.logoUrl?.imageUrl || '',\n      width: this.loginPageConfig.logoUrl?.width || '100px',\n      height: this.loginPageConfig.logoUrl?.height || 'auto',\n      ...this.loginPageConfig.logoUrl,\n    };\n\n    // Initialize footer\n    this.loginPageConfig.footer = {\n      version: this.loginPageConfig.footer?.version || 'V1.0',\n      copyright:\n        this.loginPageConfig.footer?.copyright || 'Your Company © 2024',\n      ...this.loginPageConfig.footer,\n    };\n\n    // Initialize login\n    this.loginPageConfig.login = {\n      username: this.loginPageConfig.login?.username || '',\n      password: this.loginPageConfig.login?.password || '',\n      errorMessage: this.loginPageConfig.login?.errorMessage || '',\n      emptyFieldsErrorMessage:\n        this.loginPageConfig.login?.emptyFieldsErrorMessage ||\n        \"Veuillez saisir votre nom d'utilisateur et votre mot de passe !\",\n      ...this.loginPageConfig.login,\n    };\n\n    // Initialize cardConfig\n    this.loginPageConfig.loginCardConfig = {\n      noBorder: this.loginPageConfig.loginCardConfig?.noBorder ?? true,\n      width: this.loginPageConfig.loginCardConfig?.width ?? '400px',\n      padding: this.loginPageConfig.loginCardConfig?.padding ?? '40px',\n      ...this.loginPageConfig.loginCardConfig,\n    };\n\n    // Initialize usernameField\n    this.loginPageConfig.usernameField = {\n      name: this.loginPageConfig.usernameField?.name || 'username',\n      label: this.loginPageConfig.usernameField?.label || \"Nom d'utilisateur\",\n      required: this.loginPageConfig.usernameField?.required ?? true,\n      placeholder:\n        this.loginPageConfig.usernameField?.placeholder ||\n        \"Entrer votre nom d'utilisateur\",\n      ...this.loginPageConfig.usernameField,\n    };\n\n    // Initialize passwordField\n    this.loginPageConfig.passwordField = {\n      name: this.loginPageConfig.passwordField?.name || 'password',\n      label: this.loginPageConfig.passwordField?.label || 'Mot de passe',\n      required: this.loginPageConfig.passwordField?.required ?? true,\n      placeholder:\n        this.loginPageConfig.passwordField?.placeholder ||\n        'Entrer votre mot de passe',\n      type:\n        this.loginPageConfig.passwordField?.type || FormInputTypeEnum.PASSWORD,\n      ...this.loginPageConfig.passwordField,\n    };\n\n    // Initialize buttonConfig\n    this.loginPageConfig.buttonConfig = {\n      label: this.loginPageConfig.buttonConfig?.label || 'Login',\n      type: this.loginPageConfig.buttonConfig?.type || 'submit',\n      icon: this.loginPageConfig.buttonConfig?.icon || 'pi pi-sign-in',\n      iconPos: this.loginPageConfig.buttonConfig?.iconPos || 'left',\n      styleClass:\n        this.loginPageConfig.buttonConfig?.styleClass || 'p-button-success',\n      disabled: this.loginPageConfig.buttonConfig?.disabled ?? true,\n      width: this.loginPageConfig.buttonConfig?.width ?? '100%',\n      ...this.loginPageConfig.buttonConfig,\n    };\n  }\n\n  onSubmit(): void {\n    if (this.formGroup.valid) {\n      this.loginSubmit.emit(this.formGroup.value);\n    } else {\n      this.loginPageConfig.login!.errorMessage =\n        this.loginPageConfig.login?.emptyFieldsErrorMessage;\n    }\n  }\n\n  // Setup form fields using the usernameField and passwordField from LoginPageConfig\n  setupFormFields() {\n    const usernameValidators = this.loginPageConfig.usernameField?.required\n      ? [Validators.required]\n      : [];\n    const passwordValidators = this.loginPageConfig.passwordField?.required\n      ? [Validators.required]\n      : [];\n\n    this.formGroup.addControl(\n      this.loginPageConfig.usernameField!.name,\n      this.fb.control(this.loginPageConfig.login?.username, usernameValidators)\n    );\n    this.formGroup.addControl(\n      this.loginPageConfig.passwordField!.name,\n      this.fb.control(this.loginPageConfig.login?.password, passwordValidators)\n    );\n  }\n}\n","<pt-card [config]=\"loginPageConfig.loginCardConfig!\">\n  <!-- Logo -->\n  <div class=\"logo-container\" *ngIf=\"loginPageConfig.logoUrl?.imageUrl\">\n    <img\n      [src]=\"loginPageConfig.logoUrl?.imageUrl\"\n      [alt]=\"loginPageConfig.logoUrl?.altText || 'Logo'\"\n      [style.width]=\"loginPageConfig.logoUrl?.width || '100px'\"\n      [style.height]=\"loginPageConfig.logoUrl?.height || 'auto'\"\n    />\n  </div>\n\n  <!-- Title -->\n  <div class=\"title-container\">\n    <h1\n      [ngStyle]=\"{\n        color: loginPageConfig.title?.color || '#333',\n        'font-size': loginPageConfig.title?.fontSize || '24px'\n      }\"\n    >\n      {{ loginPageConfig.title?.text || \"Default Title\" }}\n    </h1>\n  </div>\n  <!-- Error Message -->\n  <div *ngIf=\"loginErrorMessage\" class=\"error-message\">\n    {{ loginErrorMessage }}\n  </div>\n  <!-- Form -->\n  <form class=\"form-container\" [formGroup]=\"formGroup\" (ngSubmit)=\"onSubmit()\">\n    <div *ngIf=\"loginPageConfig.login?.errorMessage\" class=\"error-message\">\n      {{ loginPageConfig.login?.errorMessage }}\n    </div>\n\n    <div class=\"field\">\n      <pt-text-input\n        [formGroup]=\"formGroup\"\n        [formField]=\"loginPageConfig.usernameField!\"\n      ></pt-text-input>\n    </div>\n    <div class=\"field\">\n      <pt-text-input\n        [formGroup]=\"formGroup\"\n        [formField]=\"loginPageConfig.passwordField!\"\n      ></pt-text-input>\n    </div>\n\n    <div class=\"submit-btn\">\n      <pt-button [buttonConfig]=\"loginPageConfig.buttonConfig!\"></pt-button>\n    </div>\n  </form>\n  <div class=\"login-footer\">\n    {{ loginPageConfig.footer?.version }}\n    <span>{{ loginPageConfig.footer?.copyright }}</span>\n  </div>\n</pt-card>\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-login-card.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-prime-tools/src/lib/pt-login-page/pt-login-card/pt-login-card.component.ts","../../../../../../projects/ng-prime-tools/src/lib/pt-login-page/pt-login-card/pt-login-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAGL,UAAU,EACV,WAAW,EACX,mBAAmB,GACpB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;;;;;;;AAgBxD,MAAM,OAAO,oBAAoB;IAQ/B,YAAoB,EAAe;QAAf,OAAE,GAAF,EAAE,CAAa;QAN1B,sBAAiB,GAAkB,IAAI,CAAC;QACvC,gBAAW,GACnB,IAAI,YAAY,EAAc,CAAC;QAK/B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACrC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;YACxB,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,KAAK,EAAE,QAAQ,IAAI,EAAE;YACrD,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,KAAK,EAAE,QAAQ,IAAI,EAAE;SACtD,CAAC,CAAC;QACH,mDAAmD;QACnD,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAChD,IAAI,CAAC,eAAe,CAAC,YAAY,GAAG;gBAClC,GAAG,IAAI,CAAC,eAAe,CAAC,YAAa;gBACrC,QAAQ,EAAE,MAAM,KAAK,OAAO;aAC7B,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,yEAAyE;IACzE,kBAAkB;QAChB,6BAA6B;QAC7B,IAAI,CAAC,eAAe,CAAC,eAAe,GAAG;YACrC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,QAAQ,IAAI,EAAE;YAC9D,sBAAsB,EACpB,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,sBAAsB,IAAI,KAAK;YACvE,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe;SACxC,CAAC;QAEF,mBAAmB;QACnB,IAAI,CAAC,eAAe,CAAC,KAAK,GAAG;YAC3B,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,IAAI,OAAO;YACjD,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,IAAI,QAAQ;YAC1D,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,KAAK,IAAI,MAAM;YAClD,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,IAAI,MAAM;YACxD,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK;SAC9B,CAAC;QAEF,qBAAqB;QACrB,IAAI,CAAC,eAAe,CAAC,OAAO,GAAG;YAC7B,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,OAAO,IAAI,MAAM;YACxD,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,QAAQ,IAAI,EAAE;YACtD,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,KAAK,IAAI,OAAO;YACrD,MAAM,EAAE,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,MAAM,IAAI,MAAM;YACtD,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO;SAChC,CAAC;QAEF,oBAAoB;QACpB,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG;YAC5B,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,OAAO,IAAI,MAAM;YACvD,SAAS,EACP,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,SAAS,IAAI,qBAAqB;YACjE,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM;SAC/B,CAAC;QAEF,mBAAmB;QACnB,IAAI,CAAC,eAAe,CAAC,KAAK,GAAG;YAC3B,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,IAAI,EAAE;YACpD,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,IAAI,EAAE;YACpD,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,YAAY,IAAI,EAAE;YAC5D,uBAAuB,EACrB,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,uBAAuB;gBACnD,iEAAiE;YACnE,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK;SAC9B,CAAC;QAEF,wBAAwB;QACxB,IAAI,CAAC,eAAe,CAAC,eAAe,GAAG;YACrC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,QAAQ,IAAI,IAAI;YAChE,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,KAAK,IAAI,OAAO;YAC7D,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,eAAe,EAAE,OAAO,IAAI,MAAM;YAChE,GAAG,IAAI,CAAC,eAAe,CAAC,eAAe;SACxC,CAAC;QAEF,2BAA2B;QAC3B,IAAI,CAAC,eAAe,CAAC,aAAa,GAAG;YACnC,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,IAAI,IAAI,UAAU;YAC5D,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,KAAK,IAAI,mBAAmB;YACvE,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,QAAQ,IAAI,IAAI;YAC9D,WAAW,EACT,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,WAAW;gBAC/C,gCAAgC;YAClC,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa;SACtC,CAAC;QAEF,2BAA2B;QAC3B,IAAI,CAAC,eAAe,CAAC,aAAa,GAAG;YACnC,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,IAAI,IAAI,UAAU;YAC5D,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,KAAK,IAAI,cAAc;YAClE,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,QAAQ,IAAI,IAAI;YAC9D,WAAW,EACT,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,WAAW;gBAC/C,2BAA2B;YAC7B,IAAI,EACF,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,IAAI,IAAI,iBAAiB,CAAC,QAAQ;YACxE,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa;SACtC,CAAC;QAEF,0BAA0B;QAC1B,IAAI,CAAC,eAAe,CAAC,YAAY,GAAG;YAClC,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,KAAK,IAAI,OAAO;YAC1D,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,IAAI,IAAI,QAAQ;YACzD,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,IAAI,IAAI,eAAe;YAChE,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,OAAO,IAAI,MAAM;YAC7D,UAAU,EACR,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,UAAU,IAAI,kBAAkB;YACrE,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,QAAQ,IAAI,IAAI;YAC7D,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,KAAK,IAAI,MAAM;YACzD,GAAG,IAAI,CAAC,eAAe,CAAC,YAAY;SACrC,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC9C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,eAAe,CAAC,KAAM,CAAC,YAAY;gBACtC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,uBAAuB,CAAC;QACxD,CAAC;IACH,CAAC;IAED,mFAAmF;IACnF,eAAe;QACb,MAAM,kBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,QAAQ;YACrE,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC;YACvB,CAAC,CAAC,EAAE,CAAC;QACP,MAAM,kBAAkB,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,QAAQ;YACrE,CAAC,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC;YACvB,CAAC,CAAC,EAAE,CAAC;QAEP,IAAI,CAAC,SAAS,CAAC,UAAU,CACvB,IAAI,CAAC,eAAe,CAAC,aAAc,CAAC,IAAI,EACxC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,EAAE,kBAAkB,CAAC,CAC1E,CAAC;QACF,IAAI,CAAC,SAAS,CAAC,UAAU,CACvB,IAAI,CAAC,eAAe,CAAC,aAAc,CAAC,IAAI,EACxC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,EAAE,kBAAkB,CAAC,CAC1E,CAAC;IACJ,CAAC;+GApJU,oBAAoB;mGAApB,oBAAoB,0MC7BjC,0tDAsDA,uuBDnCI,YAAY,uNACZ,WAAW,mSACX,mBAAmB,+KACnB,YAAY,wHACZ,cAAc,kIACd,iBAAiB;;4FAKR,oBAAoB;kBAdhC,SAAS;+BACE,eAAe,cACb,IAAI,WACP;wBACP,YAAY;wBACZ,WAAW;wBACX,mBAAmB;wBACnB,YAAY;wBACZ,cAAc;wBACd,iBAAiB;qBAClB;gFAKQ,eAAe;sBAAvB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n  FormBuilder,\n  FormGroup,\n  Validators,\n  FormsModule,\n  ReactiveFormsModule,\n} from '@angular/forms';\nimport { LoginModel, LoginPageConfig } from '../../models';\nimport { FormInputTypeEnum } from '../../enums';\nimport { CommonModule } from '@angular/common';\nimport { PTCardModule } from '../../pt-card';\nimport { PTButtonModule } from '../../pt-button';\nimport { PTTextInputModule } from '../../pt-text-input';\n\n@Component({\n  selector: 'pt-login-card',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    PTCardModule,\n    PTButtonModule,\n    PTTextInputModule,\n  ],\n  templateUrl: './pt-login-card.component.html',\n  styleUrls: ['./pt-login-card.component.css'],\n})\nexport class PTLoginCardComponent implements OnInit {\n  @Input() loginPageConfig!: LoginPageConfig;\n  @Input() loginErrorMessage: string | null = null;\n  @Output() loginSubmit: EventEmitter<LoginModel> =\n    new EventEmitter<LoginModel>();\n\n  formGroup: FormGroup;\n\n  constructor(private fb: FormBuilder) {\n    this.formGroup = this.fb.group({});\n  }\n\n  ngOnInit(): void {\n    this.initializeDefaults();\n    this.setupFormFields();\n\n    this.formGroup.patchValue({\n      username: this.loginPageConfig?.login?.username || '',\n      password: this.loginPageConfig?.login?.password || '',\n    });\n    // Enable/Disable the button based on form validity\n    this.formGroup.statusChanges.subscribe((status) => {\n      this.loginPageConfig.buttonConfig = {\n        ...this.loginPageConfig.buttonConfig!,\n        disabled: status !== 'VALID',\n      };\n    });\n  }\n\n  // Initialize default values for all fields in loginPageConfig if not set\n  initializeDefaults() {\n    // Initialize backgroundImage\n    this.loginPageConfig.backgroundImage = {\n      imageUrl: this.loginPageConfig.backgroundImage?.imageUrl || '',\n      transparencyPercentage:\n        this.loginPageConfig.backgroundImage?.transparencyPercentage || '100',\n      ...this.loginPageConfig.backgroundImage,\n    };\n\n    // Initialize title\n    this.loginPageConfig.title = {\n      text: this.loginPageConfig.title?.text || 'Login',\n      position: this.loginPageConfig.title?.position || 'center',\n      color: this.loginPageConfig.title?.color || '#333',\n      fontSize: this.loginPageConfig.title?.fontSize || '24px',\n      ...this.loginPageConfig.title,\n    };\n\n    // Initialize logoUrl\n    this.loginPageConfig.logoUrl = {\n      altText: this.loginPageConfig.logoUrl?.altText || 'Logo',\n      imageUrl: this.loginPageConfig.logoUrl?.imageUrl || '',\n      width: this.loginPageConfig.logoUrl?.width || '100px',\n      height: this.loginPageConfig.logoUrl?.height || 'auto',\n      ...this.loginPageConfig.logoUrl,\n    };\n\n    // Initialize footer\n    this.loginPageConfig.footer = {\n      version: this.loginPageConfig.footer?.version || 'V1.0',\n      copyright:\n        this.loginPageConfig.footer?.copyright || 'Your Company © 2024',\n      ...this.loginPageConfig.footer,\n    };\n\n    // Initialize login\n    this.loginPageConfig.login = {\n      username: this.loginPageConfig.login?.username || '',\n      password: this.loginPageConfig.login?.password || '',\n      errorMessage: this.loginPageConfig.login?.errorMessage || '',\n      emptyFieldsErrorMessage:\n        this.loginPageConfig.login?.emptyFieldsErrorMessage ||\n        \"Veuillez saisir votre nom d'utilisateur et votre mot de passe !\",\n      ...this.loginPageConfig.login,\n    };\n\n    // Initialize cardConfig\n    this.loginPageConfig.loginCardConfig = {\n      noBorder: this.loginPageConfig.loginCardConfig?.noBorder ?? true,\n      width: this.loginPageConfig.loginCardConfig?.width ?? '400px',\n      padding: this.loginPageConfig.loginCardConfig?.padding ?? '40px',\n      ...this.loginPageConfig.loginCardConfig,\n    };\n\n    // Initialize usernameField\n    this.loginPageConfig.usernameField = {\n      name: this.loginPageConfig.usernameField?.name || 'username',\n      label: this.loginPageConfig.usernameField?.label || \"Nom d'utilisateur\",\n      required: this.loginPageConfig.usernameField?.required ?? true,\n      placeholder:\n        this.loginPageConfig.usernameField?.placeholder ||\n        \"Entrer votre nom d'utilisateur\",\n      ...this.loginPageConfig.usernameField,\n    };\n\n    // Initialize passwordField\n    this.loginPageConfig.passwordField = {\n      name: this.loginPageConfig.passwordField?.name || 'password',\n      label: this.loginPageConfig.passwordField?.label || 'Mot de passe',\n      required: this.loginPageConfig.passwordField?.required ?? true,\n      placeholder:\n        this.loginPageConfig.passwordField?.placeholder ||\n        'Entrer votre mot de passe',\n      type:\n        this.loginPageConfig.passwordField?.type || FormInputTypeEnum.PASSWORD,\n      ...this.loginPageConfig.passwordField,\n    };\n\n    // Initialize buttonConfig\n    this.loginPageConfig.buttonConfig = {\n      label: this.loginPageConfig.buttonConfig?.label || 'Login',\n      type: this.loginPageConfig.buttonConfig?.type || 'submit',\n      icon: this.loginPageConfig.buttonConfig?.icon || 'pi pi-sign-in',\n      iconPos: this.loginPageConfig.buttonConfig?.iconPos || 'left',\n      styleClass:\n        this.loginPageConfig.buttonConfig?.styleClass || 'p-button-success',\n      disabled: this.loginPageConfig.buttonConfig?.disabled ?? true,\n      width: this.loginPageConfig.buttonConfig?.width ?? '100%',\n      ...this.loginPageConfig.buttonConfig,\n    };\n  }\n\n  onSubmit(): void {\n    if (this.formGroup.valid) {\n      this.loginSubmit.emit(this.formGroup.value);\n    } else {\n      this.loginPageConfig.login!.errorMessage =\n        this.loginPageConfig.login?.emptyFieldsErrorMessage;\n    }\n  }\n\n  // Setup form fields using the usernameField and passwordField from LoginPageConfig\n  setupFormFields() {\n    const usernameValidators = this.loginPageConfig.usernameField?.required\n      ? [Validators.required]\n      : [];\n    const passwordValidators = this.loginPageConfig.passwordField?.required\n      ? [Validators.required]\n      : [];\n\n    this.formGroup.addControl(\n      this.loginPageConfig.usernameField!.name,\n      this.fb.control(this.loginPageConfig.login?.username, usernameValidators)\n    );\n    this.formGroup.addControl(\n      this.loginPageConfig.passwordField!.name,\n      this.fb.control(this.loginPageConfig.login?.password, passwordValidators)\n    );\n  }\n}\n","<pt-card [config]=\"loginPageConfig.loginCardConfig!\">\n  <!-- Logo -->\n  <div class=\"logo-container\" *ngIf=\"loginPageConfig.logoUrl?.imageUrl\">\n    <img\n      [src]=\"loginPageConfig.logoUrl?.imageUrl\"\n      [alt]=\"loginPageConfig.logoUrl?.altText || 'Logo'\"\n      [style.width]=\"loginPageConfig.logoUrl?.width || '100px'\"\n      [style.height]=\"loginPageConfig.logoUrl?.height || 'auto'\"\n    />\n  </div>\n\n  <!-- Title -->\n  <div class=\"title-container\">\n    <h1\n      [ngStyle]=\"{\n        color: loginPageConfig.title?.color || '#333',\n        'font-size': loginPageConfig.title?.fontSize || '24px'\n      }\"\n    >\n      {{ loginPageConfig.title?.text || \"Default Title\" }}\n    </h1>\n  </div>\n  <!-- Error Message -->\n  <div *ngIf=\"loginErrorMessage\" class=\"error-message\">\n    {{ loginErrorMessage }}\n  </div>\n  <!-- Form -->\n  <form class=\"form-container\" [formGroup]=\"formGroup\" (ngSubmit)=\"onSubmit()\">\n    <div *ngIf=\"loginPageConfig.login?.errorMessage\" class=\"error-message\">\n      {{ loginPageConfig.login?.errorMessage }}\n    </div>\n\n    <div class=\"field\">\n      <pt-text-input\n        [formGroup]=\"formGroup\"\n        [formField]=\"loginPageConfig.usernameField!\"\n      ></pt-text-input>\n    </div>\n    <div class=\"field\">\n      <pt-text-input\n        [formGroup]=\"formGroup\"\n        [formField]=\"loginPageConfig.passwordField!\"\n      ></pt-text-input>\n    </div>\n\n    <div class=\"submit-btn\">\n      <pt-button [buttonConfig]=\"loginPageConfig.buttonConfig!\"></pt-button>\n    </div>\n  </form>\n  <div class=\"login-footer\">\n    {{ loginPageConfig.footer?.version }}\n    <span>{{ loginPageConfig.footer?.copyright }}</span>\n  </div>\n</pt-card>\n"]}
@@ -3245,8 +3245,33 @@ class PTButtonComponent {
3245
3245
  }
3246
3246
  }
3247
3247
  ngOnChanges(changes) {
3248
- if (changes['buttonConfig']) {
3249
- this.applyButtonStyles();
3248
+ const configChange = changes['buttonConfig'];
3249
+ if (configChange) {
3250
+ const prev = configChange.previousValue;
3251
+ const curr = configChange.currentValue;
3252
+ if (prev && curr) {
3253
+ const onlyDisabledChanged = prev.disabled !== curr.disabled &&
3254
+ JSON.stringify({ ...prev, disabled: undefined }) ===
3255
+ JSON.stringify({ ...curr, disabled: undefined });
3256
+ if (onlyDisabledChanged) {
3257
+ this.updateDisabledStyles(curr.disabled);
3258
+ }
3259
+ else {
3260
+ this.applyButtonStyles();
3261
+ }
3262
+ }
3263
+ else {
3264
+ // If no previous value (first load), apply full styles
3265
+ this.applyButtonStyles();
3266
+ }
3267
+ }
3268
+ }
3269
+ updateDisabledStyles(isDisabled) {
3270
+ const buttonElement = this.el.nativeElement.querySelector('button.p-element');
3271
+ if (buttonElement) {
3272
+ this.renderer.setStyle(buttonElement, 'color', isDisabled ? '#999' : this.buttonConfig.fontColor);
3273
+ this.renderer.setStyle(buttonElement, 'background-color', isDisabled ? '#e0e0e0' : this.buttonConfig.backgroundColor);
3274
+ this.renderer.setStyle(buttonElement, 'border-color', isDisabled ? '#bdbdbd' : this.buttonConfig.borderColor);
3250
3275
  }
3251
3276
  }
3252
3277
  ngAfterViewInit() {
@@ -3309,7 +3334,10 @@ class PTLoginCardComponent {
3309
3334
  });
3310
3335
  // Enable/Disable the button based on form validity
3311
3336
  this.formGroup.statusChanges.subscribe((status) => {
3312
- this.loginPageConfig.buttonConfig.disabled = status !== 'VALID';
3337
+ this.loginPageConfig.buttonConfig = {
3338
+ ...this.loginPageConfig.buttonConfig,
3339
+ disabled: status !== 'VALID',
3340
+ };
3313
3341
  });
3314
3342
  }
3315
3343
  // Initialize default values for all fields in loginPageConfig if not set