ng-prime-tools 1.0.66 → 1.0.67
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/pt-dropdown/pt-dropdown.component.mjs +7 -3
- package/fesm2022/ng-prime-tools.mjs +6 -2
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/pt-dropdown/pt-dropdown.component.d.ts +1 -0
- package/lib/pt-dropdown/pt-dropdown.component.d.ts.map +1 -1
- package/lib/pt-metric-panel/pt-metric-panel.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -24,13 +24,14 @@ export class PTDropdownComponent {
|
|
|
24
24
|
if (!this.formGroup || !this.formField?.name) {
|
|
25
25
|
return;
|
|
26
26
|
}
|
|
27
|
+
const hasExplicitValue = this.hasExplicitFieldValue(this.formField.value);
|
|
27
28
|
const normalizedValue = this.normalizeValue(this.formField.value);
|
|
28
29
|
let control = this.formGroup.get(this.formField.name);
|
|
29
30
|
if (!control) {
|
|
30
|
-
control = new FormControl(normalizedValue);
|
|
31
|
+
control = new FormControl(hasExplicitValue ? normalizedValue : null);
|
|
31
32
|
this.formGroup.addControl(this.formField.name, control);
|
|
32
33
|
}
|
|
33
|
-
else {
|
|
34
|
+
else if (hasExplicitValue) {
|
|
34
35
|
control.setValue(normalizedValue, { emitEvent: false });
|
|
35
36
|
}
|
|
36
37
|
control.setValidators(this.getValidators());
|
|
@@ -42,6 +43,9 @@ export class PTDropdownComponent {
|
|
|
42
43
|
}
|
|
43
44
|
control.updateValueAndValidity({ emitEvent: false });
|
|
44
45
|
}
|
|
46
|
+
hasExplicitFieldValue(value) {
|
|
47
|
+
return value !== null && value !== undefined && value !== '';
|
|
48
|
+
}
|
|
45
49
|
normalizeValue(value) {
|
|
46
50
|
if (value === null || value === undefined || value === '') {
|
|
47
51
|
return null;
|
|
@@ -170,4 +174,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
170
174
|
}], formField: [{
|
|
171
175
|
type: Input
|
|
172
176
|
}] } });
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-dropdown/pt-dropdown.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-dropdown/pt-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges,\n} from '@angular/core';\nimport {\n  FormGroup,\n  FormControl,\n  Validators,\n  ValidatorFn,\n} from '@angular/forms';\nimport { FormDropdownField } from '../models/form-drop-down-field.model';\nimport { IconStyle } from '../models/icon-style.model';\nimport { IconImageStyle } from '../models/icon-image-style.model';\n\n@Component({\n  selector: 'pt-dropdown',\n  templateUrl: './pt-dropdown.component.html',\n  styleUrls: ['./pt-dropdown.component.css'],\n})\nexport class PTDropdownComponent implements OnInit, OnChanges {\n  @Input() formGroup!: FormGroup;\n  @Input() formField!: FormDropdownField;\n\n  ngOnInit(): void {\n    this.setupControl();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['formField'] && !changes['formField'].firstChange) {\n      this.setupControl();\n    }\n  }\n\n  get inputId(): string {\n    return `pt-dropdown-${this.formField?.name || 'field'}`;\n  }\n\n  get labelId(): string {\n    return `pt-dropdown-label-${this.formField?.name || 'field'}`;\n  }\n\n  private setupControl(): void {\n    if (!this.formGroup || !this.formField?.name) {\n      return;\n    }\n\n    const normalizedValue = this.normalizeValue(this.formField.value);\n    let control = this.formGroup.get(this.formField.name) as FormControl | null;\n\n    if (!control) {\n      control = new FormControl(normalizedValue);\n      this.formGroup.addControl(this.formField.name, control);\n    } else {\n      control.setValue(normalizedValue, { emitEvent: false });\n    }\n\n    control.setValidators(this.getValidators());\n\n    if (this.formField.disabled) {\n      control.disable({ emitEvent: false });\n    } else {\n      control.enable({ emitEvent: false });\n    }\n\n    control.updateValueAndValidity({ emitEvent: false });\n  }\n\n  private normalizeValue(value: any): any {\n    if (value === null || value === undefined || value === '') {\n      return null;\n    }\n\n    if (typeof value === 'object' && 'value' in value) {\n      return value.value;\n    }\n\n    return value;\n  }\n\n  private getValidators(): ValidatorFn[] {\n    const validators: ValidatorFn[] = [];\n\n    if (this.formField.required) {\n      validators.push(Validators.required);\n    }\n\n    return validators;\n  }\n\n  getErrorMessage(): string {\n    const control = this.formGroup.get(this.formField.name);\n\n    if (control?.hasError('required')) {\n      return this.formField.errorText || `${this.formField.label} is required`;\n    }\n\n    return '';\n  }\n\n  getResolvedIcon(option: any): {\n    type: 'none' | 'font' | 'image';\n    fontIconClass?: string;\n    fontIconStyle?: { [k: string]: any };\n    imageUrl?: string;\n    imageStyle?: { [k: string]: any };\n  } {\n    const source =\n      option?.iconStyle ||\n      option?.iconImageStyle ||\n      option?.icon ||\n      this.formField.icon;\n\n    if (!source) {\n      return { type: 'none' };\n    }\n\n    if (this.isIconImageStyle(source)) {\n      const img = source as IconImageStyle;\n      return {\n        type: 'image',\n        imageUrl: img.url,\n        imageStyle: this.buildImageStyle(img),\n      };\n    }\n\n    if (this.isIconStyle(source)) {\n      const style = source as IconStyle;\n      return {\n        type: 'font',\n        fontIconClass: style.code,\n        fontIconStyle: this.buildFontIconStyle(style),\n      };\n    }\n\n    if (typeof source === 'string') {\n      return {\n        type: 'font',\n        fontIconClass: source,\n        fontIconStyle: {},\n      };\n    }\n\n    return { type: 'none' };\n  }\n\n  private isIconStyle(value: any): value is IconStyle {\n    return !!value && typeof value === 'object' && 'code' in value;\n  }\n\n  private isIconImageStyle(value: any): value is IconImageStyle {\n    return !!value && typeof value === 'object' && 'url' in value;\n  }\n\n  private buildFontIconStyle(icon: IconStyle): { [k: string]: any } {\n    const styles: { [k: string]: any } = {};\n\n    if (icon.color) {\n      styles.color = icon.color;\n    }\n\n    if (icon.fontSize) {\n      styles['font-size'] = icon.fontSize;\n    }\n\n    if (icon.backgroundColor) {\n      styles['background-color'] = icon.backgroundColor;\n      styles.padding = styles.padding ?? '0.15rem 0.3rem';\n    }\n\n    if (icon.shape === 'circular') {\n      styles['border-radius'] = '50%';\n    } else if (icon.shape === 'rounded-square') {\n      styles['border-radius'] = '6px';\n    }\n\n    return styles;\n  }\n\n  private buildImageStyle(icon: IconImageStyle): { [k: string]: any } {\n    const styles: { [k: string]: any } = {};\n\n    if (icon.width) styles.width = icon.width;\n    if (icon.height) styles.height = icon.height;\n    if (icon.marginLeft) styles['margin-left'] = icon.marginLeft;\n    if (icon.marginRight) styles['margin-right'] = icon.marginRight;\n    if (icon.marginTop) styles['margin-top'] = icon.marginTop;\n    if (icon.marginBottom) styles['margin-bottom'] = icon.marginBottom;\n\n    if (icon.shape === 'circular') {\n      styles['border-radius'] = '50%';\n    } else if (icon.shape === 'rounded-square') {\n      styles['border-radius'] = '6px';\n    }\n\n    return styles;\n  }\n\n  getIconPosition(option: any): 'left' | 'right' {\n    const src =\n      option?.iconStyle ||\n      option?.iconImageStyle ||\n      option?.icon ||\n      this.formField.icon;\n\n    if (this.isIconStyle(src) && src.position) {\n      return src.position;\n    }\n\n    if (this.isIconImageStyle(src) && src.position) {\n      return src.position;\n    }\n\n    return 'left';\n  }\n}\n","<div\n  [formGroup]=\"formGroup\"\n  class=\"form-field\"\n  [ngStyle]=\"{ width: formField.width || '100%' }\"\n  *ngIf=\"!formField.hidden\"\n>\n  <label *ngIf=\"formField.label\" [id]=\"labelId\">\n    {{ formField.label }}\n  </label>\n\n  <p-dropdown\n    [inputId]=\"inputId\"\n    [name]=\"formField.name\"\n    [formControlName]=\"formField.name\"\n    [options]=\"formField.options\"\n    [placeholder]=\"formField.placeholder || 'Select an option'\"\n    optionLabel=\"label\"\n    optionValue=\"value\"\n    dataKey=\"value\"\n    [appendTo]=\"'body'\"\n    [overlayOptions]=\"{ baseZIndex: 11000 }\"\n    [ariaLabelledBy]=\"labelId\"\n  >\n    <ng-template pTemplate=\"selectedItem\" let-option>\n      <ng-container *ngIf=\"option; else placeholderTpl\">\n        <div class=\"pt-dropdown-item\">\n          <ng-container *ngIf=\"getResolvedIcon(option) as iconMeta\">\n            <img\n              *ngIf=\"iconMeta.type === 'image'\"\n              [src]=\"iconMeta.imageUrl\"\n              [ngStyle]=\"iconMeta.imageStyle\"\n              class=\"pt-dropdown-icon-image\"\n            />\n\n            <i\n              *ngIf=\"iconMeta.type === 'font'\"\n              [ngClass]=\"iconMeta.fontIconClass\"\n              [ngStyle]=\"iconMeta.fontIconStyle\"\n              class=\"pt-dropdown-icon-font\"\n            ></i>\n          </ng-container>\n\n          <span class=\"pt-dropdown-label\">{{ option.label }}</span>\n        </div>\n      </ng-container>\n    </ng-template>\n\n    <ng-template #placeholderTpl>\n      <span>{{ formField.placeholder || \"Select an option\" }}</span>\n    </ng-template>\n\n    <ng-template pTemplate=\"item\" let-option>\n      <div class=\"pt-dropdown-item\">\n        <ng-container *ngIf=\"getResolvedIcon(option) as iconMeta\">\n          <img\n            *ngIf=\"iconMeta.type === 'image'\"\n            [src]=\"iconMeta.imageUrl\"\n            [ngStyle]=\"iconMeta.imageStyle\"\n            class=\"pt-dropdown-icon-image\"\n          />\n\n          <i\n            *ngIf=\"iconMeta.type === 'font'\"\n            [ngClass]=\"iconMeta.fontIconClass\"\n            [ngStyle]=\"iconMeta.fontIconStyle\"\n            class=\"pt-dropdown-icon-font\"\n          ></i>\n        </ng-container>\n\n        <span class=\"pt-dropdown-label\">{{ option.label }}</span>\n      </div>\n    </ng-template>\n  </p-dropdown>\n\n  <div\n    *ngIf=\"\n      formGroup.get(formField.name)?.invalid &&\n      formGroup.get(formField.name)?.touched\n    \"\n  >\n    <small class=\"p-error\">{{ getErrorMessage() }}</small>\n  </div>\n</div>\n"]}
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-dropdown/pt-dropdown.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-dropdown/pt-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges,\n} from '@angular/core';\nimport {\n  FormGroup,\n  FormControl,\n  Validators,\n  ValidatorFn,\n} from '@angular/forms';\nimport { FormDropdownField } from '../models/form-drop-down-field.model';\nimport { IconStyle } from '../models/icon-style.model';\nimport { IconImageStyle } from '../models/icon-image-style.model';\n\n@Component({\n  selector: 'pt-dropdown',\n  templateUrl: './pt-dropdown.component.html',\n  styleUrls: ['./pt-dropdown.component.css'],\n})\nexport class PTDropdownComponent implements OnInit, OnChanges {\n  @Input() formGroup!: FormGroup;\n  @Input() formField!: FormDropdownField;\n\n  ngOnInit(): void {\n    this.setupControl();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['formField'] && !changes['formField'].firstChange) {\n      this.setupControl();\n    }\n  }\n\n  get inputId(): string {\n    return `pt-dropdown-${this.formField?.name || 'field'}`;\n  }\n\n  get labelId(): string {\n    return `pt-dropdown-label-${this.formField?.name || 'field'}`;\n  }\n\n  private setupControl(): void {\n    if (!this.formGroup || !this.formField?.name) {\n      return;\n    }\n\n    const hasExplicitValue = this.hasExplicitFieldValue(this.formField.value);\n    const normalizedValue = this.normalizeValue(this.formField.value);\n\n    let control = this.formGroup.get(this.formField.name) as FormControl | null;\n\n    if (!control) {\n      control = new FormControl(hasExplicitValue ? normalizedValue : null);\n      this.formGroup.addControl(this.formField.name, control);\n    } else if (hasExplicitValue) {\n      control.setValue(normalizedValue, { emitEvent: false });\n    }\n\n    control.setValidators(this.getValidators());\n\n    if (this.formField.disabled) {\n      control.disable({ emitEvent: false });\n    } else {\n      control.enable({ emitEvent: false });\n    }\n\n    control.updateValueAndValidity({ emitEvent: false });\n  }\n\n  private hasExplicitFieldValue(value: any): boolean {\n    return value !== null && value !== undefined && value !== '';\n  }\n\n  private normalizeValue(value: any): any {\n    if (value === null || value === undefined || value === '') {\n      return null;\n    }\n\n    if (typeof value === 'object' && 'value' in value) {\n      return value.value;\n    }\n\n    return value;\n  }\n\n  private getValidators(): ValidatorFn[] {\n    const validators: ValidatorFn[] = [];\n\n    if (this.formField.required) {\n      validators.push(Validators.required);\n    }\n\n    return validators;\n  }\n\n  getErrorMessage(): string {\n    const control = this.formGroup.get(this.formField.name);\n\n    if (control?.hasError('required')) {\n      return this.formField.errorText || `${this.formField.label} is required`;\n    }\n\n    return '';\n  }\n\n  getResolvedIcon(option: any): {\n    type: 'none' | 'font' | 'image';\n    fontIconClass?: string;\n    fontIconStyle?: { [k: string]: any };\n    imageUrl?: string;\n    imageStyle?: { [k: string]: any };\n  } {\n    const source =\n      option?.iconStyle ||\n      option?.iconImageStyle ||\n      option?.icon ||\n      this.formField.icon;\n\n    if (!source) {\n      return { type: 'none' };\n    }\n\n    if (this.isIconImageStyle(source)) {\n      const img = source as IconImageStyle;\n      return {\n        type: 'image',\n        imageUrl: img.url,\n        imageStyle: this.buildImageStyle(img),\n      };\n    }\n\n    if (this.isIconStyle(source)) {\n      const style = source as IconStyle;\n      return {\n        type: 'font',\n        fontIconClass: style.code,\n        fontIconStyle: this.buildFontIconStyle(style),\n      };\n    }\n\n    if (typeof source === 'string') {\n      return {\n        type: 'font',\n        fontIconClass: source,\n        fontIconStyle: {},\n      };\n    }\n\n    return { type: 'none' };\n  }\n\n  private isIconStyle(value: any): value is IconStyle {\n    return !!value && typeof value === 'object' && 'code' in value;\n  }\n\n  private isIconImageStyle(value: any): value is IconImageStyle {\n    return !!value && typeof value === 'object' && 'url' in value;\n  }\n\n  private buildFontIconStyle(icon: IconStyle): { [k: string]: any } {\n    const styles: { [k: string]: any } = {};\n\n    if (icon.color) {\n      styles.color = icon.color;\n    }\n\n    if (icon.fontSize) {\n      styles['font-size'] = icon.fontSize;\n    }\n\n    if (icon.backgroundColor) {\n      styles['background-color'] = icon.backgroundColor;\n      styles.padding = styles.padding ?? '0.15rem 0.3rem';\n    }\n\n    if (icon.shape === 'circular') {\n      styles['border-radius'] = '50%';\n    } else if (icon.shape === 'rounded-square') {\n      styles['border-radius'] = '6px';\n    }\n\n    return styles;\n  }\n\n  private buildImageStyle(icon: IconImageStyle): { [k: string]: any } {\n    const styles: { [k: string]: any } = {};\n\n    if (icon.width) styles.width = icon.width;\n    if (icon.height) styles.height = icon.height;\n    if (icon.marginLeft) styles['margin-left'] = icon.marginLeft;\n    if (icon.marginRight) styles['margin-right'] = icon.marginRight;\n    if (icon.marginTop) styles['margin-top'] = icon.marginTop;\n    if (icon.marginBottom) styles['margin-bottom'] = icon.marginBottom;\n\n    if (icon.shape === 'circular') {\n      styles['border-radius'] = '50%';\n    } else if (icon.shape === 'rounded-square') {\n      styles['border-radius'] = '6px';\n    }\n\n    return styles;\n  }\n\n  getIconPosition(option: any): 'left' | 'right' {\n    const src =\n      option?.iconStyle ||\n      option?.iconImageStyle ||\n      option?.icon ||\n      this.formField.icon;\n\n    if (this.isIconStyle(src) && src.position) {\n      return src.position;\n    }\n\n    if (this.isIconImageStyle(src) && src.position) {\n      return src.position;\n    }\n\n    return 'left';\n  }\n}\n","<div\n  [formGroup]=\"formGroup\"\n  class=\"form-field\"\n  [ngStyle]=\"{ width: formField.width || '100%' }\"\n  *ngIf=\"!formField.hidden\"\n>\n  <label *ngIf=\"formField.label\" [id]=\"labelId\">\n    {{ formField.label }}\n  </label>\n\n  <p-dropdown\n    [inputId]=\"inputId\"\n    [name]=\"formField.name\"\n    [formControlName]=\"formField.name\"\n    [options]=\"formField.options\"\n    [placeholder]=\"formField.placeholder || 'Select an option'\"\n    optionLabel=\"label\"\n    optionValue=\"value\"\n    dataKey=\"value\"\n    [appendTo]=\"'body'\"\n    [overlayOptions]=\"{ baseZIndex: 11000 }\"\n    [ariaLabelledBy]=\"labelId\"\n  >\n    <ng-template pTemplate=\"selectedItem\" let-option>\n      <ng-container *ngIf=\"option; else placeholderTpl\">\n        <div class=\"pt-dropdown-item\">\n          <ng-container *ngIf=\"getResolvedIcon(option) as iconMeta\">\n            <img\n              *ngIf=\"iconMeta.type === 'image'\"\n              [src]=\"iconMeta.imageUrl\"\n              [ngStyle]=\"iconMeta.imageStyle\"\n              class=\"pt-dropdown-icon-image\"\n            />\n\n            <i\n              *ngIf=\"iconMeta.type === 'font'\"\n              [ngClass]=\"iconMeta.fontIconClass\"\n              [ngStyle]=\"iconMeta.fontIconStyle\"\n              class=\"pt-dropdown-icon-font\"\n            ></i>\n          </ng-container>\n\n          <span class=\"pt-dropdown-label\">{{ option.label }}</span>\n        </div>\n      </ng-container>\n    </ng-template>\n\n    <ng-template #placeholderTpl>\n      <span>{{ formField.placeholder || \"Select an option\" }}</span>\n    </ng-template>\n\n    <ng-template pTemplate=\"item\" let-option>\n      <div class=\"pt-dropdown-item\">\n        <ng-container *ngIf=\"getResolvedIcon(option) as iconMeta\">\n          <img\n            *ngIf=\"iconMeta.type === 'image'\"\n            [src]=\"iconMeta.imageUrl\"\n            [ngStyle]=\"iconMeta.imageStyle\"\n            class=\"pt-dropdown-icon-image\"\n          />\n\n          <i\n            *ngIf=\"iconMeta.type === 'font'\"\n            [ngClass]=\"iconMeta.fontIconClass\"\n            [ngStyle]=\"iconMeta.fontIconStyle\"\n            class=\"pt-dropdown-icon-font\"\n          ></i>\n        </ng-container>\n\n        <span class=\"pt-dropdown-label\">{{ option.label }}</span>\n      </div>\n    </ng-template>\n  </p-dropdown>\n\n  <div\n    *ngIf=\"\n      formGroup.get(formField.name)?.invalid &&\n      formGroup.get(formField.name)?.touched\n    \"\n  >\n    <small class=\"p-error\">{{ getErrorMessage() }}</small>\n  </div>\n</div>\n"]}
|
|
@@ -2302,13 +2302,14 @@ class PTDropdownComponent {
|
|
|
2302
2302
|
if (!this.formGroup || !this.formField?.name) {
|
|
2303
2303
|
return;
|
|
2304
2304
|
}
|
|
2305
|
+
const hasExplicitValue = this.hasExplicitFieldValue(this.formField.value);
|
|
2305
2306
|
const normalizedValue = this.normalizeValue(this.formField.value);
|
|
2306
2307
|
let control = this.formGroup.get(this.formField.name);
|
|
2307
2308
|
if (!control) {
|
|
2308
|
-
control = new FormControl(normalizedValue);
|
|
2309
|
+
control = new FormControl(hasExplicitValue ? normalizedValue : null);
|
|
2309
2310
|
this.formGroup.addControl(this.formField.name, control);
|
|
2310
2311
|
}
|
|
2311
|
-
else {
|
|
2312
|
+
else if (hasExplicitValue) {
|
|
2312
2313
|
control.setValue(normalizedValue, { emitEvent: false });
|
|
2313
2314
|
}
|
|
2314
2315
|
control.setValidators(this.getValidators());
|
|
@@ -2320,6 +2321,9 @@ class PTDropdownComponent {
|
|
|
2320
2321
|
}
|
|
2321
2322
|
control.updateValueAndValidity({ emitEvent: false });
|
|
2322
2323
|
}
|
|
2324
|
+
hasExplicitFieldValue(value) {
|
|
2325
|
+
return value !== null && value !== undefined && value !== '';
|
|
2326
|
+
}
|
|
2323
2327
|
normalizeValue(value) {
|
|
2324
2328
|
if (value === null || value === undefined || value === '') {
|
|
2325
2329
|
return null;
|