ng-prime-tools 1.0.30 → 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.
Files changed (25) hide show
  1. package/README.md +4 -0
  2. package/esm2022/lib/models/button.model.mjs +1 -1
  3. package/esm2022/lib/pt-advanced-prime-table/date-utility.service.mjs +43 -0
  4. package/esm2022/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.mjs +107 -39
  5. package/esm2022/lib/pt-advanced-prime-table/pt-advanced-prime-table.module.mjs +7 -3
  6. package/esm2022/lib/pt-advanced-prime-table/public-api.mjs +2 -1
  7. package/esm2022/lib/pt-button/pt-button.component.mjs +44 -16
  8. package/esm2022/lib/pt-dialog/pt-dialog.component.mjs +164 -129
  9. package/fesm2022/ng-prime-tools.mjs +424 -250
  10. package/fesm2022/ng-prime-tools.mjs.map +1 -1
  11. package/lib/models/button.model.d.ts +1 -0
  12. package/lib/models/button.model.d.ts.map +1 -1
  13. package/lib/pt-advanced-prime-table/date-utility.service.d.ts +8 -0
  14. package/lib/pt-advanced-prime-table/date-utility.service.d.ts.map +1 -0
  15. package/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.d.ts +17 -3
  16. package/lib/pt-advanced-prime-table/pt-advanced-prime-table.component.d.ts.map +1 -1
  17. package/lib/pt-advanced-prime-table/pt-advanced-prime-table.module.d.ts +2 -1
  18. package/lib/pt-advanced-prime-table/pt-advanced-prime-table.module.d.ts.map +1 -1
  19. package/lib/pt-advanced-prime-table/public-api.d.ts +1 -0
  20. package/lib/pt-advanced-prime-table/public-api.d.ts.map +1 -1
  21. package/lib/pt-button/pt-button.component.d.ts +7 -1
  22. package/lib/pt-button/pt-button.component.d.ts.map +1 -1
  23. package/lib/pt-dialog/pt-dialog.component.d.ts +18 -1
  24. package/lib/pt-dialog/pt-dialog.component.d.ts.map +1 -1
  25. package/package.json +1 -1
@@ -13,6 +13,7 @@ import { IconFieldModule } from 'primeng/iconfield';
13
13
  import { InputIconModule } from 'primeng/inputicon';
14
14
  import { CustomDatePipe } from '../pipes/custom-date.pipe';
15
15
  import { ProgressSpinnerModule } from 'primeng/progressspinner';
16
+ import { PTMultiSelectModule } from '../pt-multi-select';
16
17
  import * as i0 from "@angular/core";
17
18
  export class PTAdvancedPrimeTableModule {
18
19
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTAdvancedPrimeTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
@@ -27,7 +28,8 @@ export class PTAdvancedPrimeTableModule {
27
28
  CustomCurrencyPipe,
28
29
  IconFieldModule,
29
30
  InputIconModule,
30
- ProgressSpinnerModule], exports: [PTAdvancedPrimeTableComponent] }); }
31
+ ProgressSpinnerModule,
32
+ PTMultiSelectModule], exports: [PTAdvancedPrimeTableComponent] }); }
31
33
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTAdvancedPrimeTableModule, imports: [CommonModule,
32
34
  TableModule,
33
35
  InputTextModule,
@@ -38,7 +40,8 @@ export class PTAdvancedPrimeTableModule {
38
40
  TagModule,
39
41
  IconFieldModule,
40
42
  InputIconModule,
41
- ProgressSpinnerModule] }); }
43
+ ProgressSpinnerModule,
44
+ PTMultiSelectModule] }); }
42
45
  }
43
46
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTAdvancedPrimeTableModule, decorators: [{
44
47
  type: NgModule,
@@ -57,8 +60,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
57
60
  IconFieldModule,
58
61
  InputIconModule,
59
62
  ProgressSpinnerModule,
63
+ PTMultiSelectModule,
60
64
  ],
61
65
  exports: [PTAdvancedPrimeTableComponent],
62
66
  }]
63
67
  }] });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtYWR2YW5jZWQtcHJpbWUtdGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9wdC1hZHZhbmNlZC1wcmltZS10YWJsZS9wdC1hZHZhbmNlZC1wcmltZS10YWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNwRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDbEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN4QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFvQmhFLE1BQU0sT0FBTywwQkFBMEI7K0dBQTFCLDBCQUEwQjtnSEFBMUIsMEJBQTBCLGlCQWpCdEIsNkJBQTZCLEVBQUUsY0FBYyxhQUUxRCxZQUFZO1lBQ1osV0FBVztZQUNYLGVBQWU7WUFDZixZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVc7WUFDWCxpQkFBaUI7WUFDakIsU0FBUztZQUNULGtCQUFrQjtZQUNsQixlQUFlO1lBQ2YsZUFBZTtZQUNmLHFCQUFxQixhQUViLDZCQUE2QjtnSEFFNUIsMEJBQTBCLFlBZm5DLFlBQVk7WUFDWixXQUFXO1lBQ1gsZUFBZTtZQUNmLFlBQVk7WUFDWixjQUFjO1lBQ2QsV0FBVztZQUNYLGlCQUFpQjtZQUNqQixTQUFTO1lBRVQsZUFBZTtZQUNmLGVBQWU7WUFDZixxQkFBcUI7OzRGQUlaLDBCQUEwQjtrQkFsQnRDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsNkJBQTZCLEVBQUUsY0FBYyxDQUFDO29CQUM3RCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsWUFBWTt3QkFDWixjQUFjO3dCQUNkLFdBQVc7d0JBQ1gsaUJBQWlCO3dCQUNqQixTQUFTO3dCQUNULGtCQUFrQjt3QkFDbEIsZUFBZTt3QkFDZixlQUFlO3dCQUNmLHFCQUFxQjtxQkFDdEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsNkJBQTZCLENBQUM7aUJBQ3pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFBUQWR2YW5jZWRQcmltZVRhYmxlQ29tcG9uZW50IH0gZnJvbSAnLi9wdC1hZHZhbmNlZC1wcmltZS10YWJsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQnV0dG9uTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9idXR0b24nO1xuaW1wb3J0IHsgQ2FsZW5kYXJNb2R1bGUgfSBmcm9tICdwcmltZW5nL2NhbGVuZGFyJztcbmltcG9ydCB7IElucHV0VGV4dE1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvaW5wdXR0ZXh0JztcbmltcG9ydCB7IE11bHRpU2VsZWN0TW9kdWxlIH0gZnJvbSAncHJpbWVuZy9tdWx0aXNlbGVjdCc7XG5pbXBvcnQgeyBUYWJsZU1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvdGFibGUnO1xuaW1wb3J0IHsgVGFnTW9kdWxlIH0gZnJvbSAncHJpbWVuZy90YWcnO1xuaW1wb3J0IHsgQ3VzdG9tQ3VycmVuY3lQaXBlIH0gZnJvbSAnLi4vcGlwZXMvY3VzdG9tLWN1cnJlbmN5JztcbmltcG9ydCB7IEljb25GaWVsZE1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvaWNvbmZpZWxkJztcbmltcG9ydCB7IElucHV0SWNvbk1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvaW5wdXRpY29uJztcbmltcG9ydCB7IEN1c3RvbURhdGVQaXBlIH0gZnJvbSAnLi4vcGlwZXMvY3VzdG9tLWRhdGUucGlwZSc7XG5pbXBvcnQgeyBQcm9ncmVzc1NwaW5uZXJNb2R1bGUgfSBmcm9tICdwcmltZW5nL3Byb2dyZXNzc3Bpbm5lcic7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1BUQWR2YW5jZWRQcmltZVRhYmxlQ29tcG9uZW50LCBDdXN0b21EYXRlUGlwZV0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgVGFibGVNb2R1bGUsXG4gICAgSW5wdXRUZXh0TW9kdWxlLFxuICAgIEJ1dHRvbk1vZHVsZSxcbiAgICBDYWxlbmRhck1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBNdWx0aVNlbGVjdE1vZHVsZSxcbiAgICBUYWdNb2R1bGUsXG4gICAgQ3VzdG9tQ3VycmVuY3lQaXBlLFxuICAgIEljb25GaWVsZE1vZHVsZSxcbiAgICBJbnB1dEljb25Nb2R1bGUsXG4gICAgUHJvZ3Jlc3NTcGlubmVyTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbUFRBZHZhbmNlZFByaW1lVGFibGVDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBQVEFkdmFuY2VkUHJpbWVUYWJsZU1vZHVsZSB7fVxuIl19
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtYWR2YW5jZWQtcHJpbWUtdGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9wdC1hZHZhbmNlZC1wcmltZS10YWJsZS9wdC1hZHZhbmNlZC1wcmltZS10YWJsZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNwRixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDbEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN4QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7QUFxQnpELE1BQU0sT0FBTywwQkFBMEI7K0dBQTFCLDBCQUEwQjtnSEFBMUIsMEJBQTBCLGlCQWxCdEIsNkJBQTZCLEVBQUUsY0FBYyxhQUUxRCxZQUFZO1lBQ1osV0FBVztZQUNYLGVBQWU7WUFDZixZQUFZO1lBQ1osY0FBYztZQUNkLFdBQVc7WUFDWCxpQkFBaUI7WUFDakIsU0FBUztZQUNULGtCQUFrQjtZQUNsQixlQUFlO1lBQ2YsZUFBZTtZQUNmLHFCQUFxQjtZQUNyQixtQkFBbUIsYUFFWCw2QkFBNkI7Z0hBRTVCLDBCQUEwQixZQWhCbkMsWUFBWTtZQUNaLFdBQVc7WUFDWCxlQUFlO1lBQ2YsWUFBWTtZQUNaLGNBQWM7WUFDZCxXQUFXO1lBQ1gsaUJBQWlCO1lBQ2pCLFNBQVM7WUFFVCxlQUFlO1lBQ2YsZUFBZTtZQUNmLHFCQUFxQjtZQUNyQixtQkFBbUI7OzRGQUlWLDBCQUEwQjtrQkFuQnRDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsNkJBQTZCLEVBQUUsY0FBYyxDQUFDO29CQUM3RCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGVBQWU7d0JBQ2YsWUFBWTt3QkFDWixjQUFjO3dCQUNkLFdBQVc7d0JBQ1gsaUJBQWlCO3dCQUNqQixTQUFTO3dCQUNULGtCQUFrQjt3QkFDbEIsZUFBZTt3QkFDZixlQUFlO3dCQUNmLHFCQUFxQjt3QkFDckIsbUJBQW1CO3FCQUNwQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztpQkFDekMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUFRBZHZhbmNlZFByaW1lVGFibGVDb21wb25lbnQgfSBmcm9tICcuL3B0LWFkdmFuY2VkLXByaW1lLXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBCdXR0b25Nb2R1bGUgfSBmcm9tICdwcmltZW5nL2J1dHRvbic7XG5pbXBvcnQgeyBDYWxlbmRhck1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvY2FsZW5kYXInO1xuaW1wb3J0IHsgSW5wdXRUZXh0TW9kdWxlIH0gZnJvbSAncHJpbWVuZy9pbnB1dHRleHQnO1xuaW1wb3J0IHsgTXVsdGlTZWxlY3RNb2R1bGUgfSBmcm9tICdwcmltZW5nL211bHRpc2VsZWN0JztcbmltcG9ydCB7IFRhYmxlTW9kdWxlIH0gZnJvbSAncHJpbWVuZy90YWJsZSc7XG5pbXBvcnQgeyBUYWdNb2R1bGUgfSBmcm9tICdwcmltZW5nL3RhZyc7XG5pbXBvcnQgeyBDdXN0b21DdXJyZW5jeVBpcGUgfSBmcm9tICcuLi9waXBlcy9jdXN0b20tY3VycmVuY3knO1xuaW1wb3J0IHsgSWNvbkZpZWxkTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9pY29uZmllbGQnO1xuaW1wb3J0IHsgSW5wdXRJY29uTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9pbnB1dGljb24nO1xuaW1wb3J0IHsgQ3VzdG9tRGF0ZVBpcGUgfSBmcm9tICcuLi9waXBlcy9jdXN0b20tZGF0ZS5waXBlJztcbmltcG9ydCB7IFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvcHJvZ3Jlc3NzcGlubmVyJztcbmltcG9ydCB7IFBUTXVsdGlTZWxlY3RNb2R1bGUgfSBmcm9tICcuLi9wdC1tdWx0aS1zZWxlY3QnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtQVEFkdmFuY2VkUHJpbWVUYWJsZUNvbXBvbmVudCwgQ3VzdG9tRGF0ZVBpcGVdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIFRhYmxlTW9kdWxlLFxuICAgIElucHV0VGV4dE1vZHVsZSxcbiAgICBCdXR0b25Nb2R1bGUsXG4gICAgQ2FsZW5kYXJNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgTXVsdGlTZWxlY3RNb2R1bGUsXG4gICAgVGFnTW9kdWxlLFxuICAgIEN1c3RvbUN1cnJlbmN5UGlwZSxcbiAgICBJY29uRmllbGRNb2R1bGUsXG4gICAgSW5wdXRJY29uTW9kdWxlLFxuICAgIFByb2dyZXNzU3Bpbm5lck1vZHVsZSxcbiAgICBQVE11bHRpU2VsZWN0TW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbUFRBZHZhbmNlZFByaW1lVGFibGVDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBQVEFkdmFuY2VkUHJpbWVUYWJsZU1vZHVsZSB7fVxuIl19
@@ -1,3 +1,4 @@
1
1
  export * from './pt-advanced-prime-table.component';
2
2
  export * from './pt-advanced-prime-table.module';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvcHQtYWR2YW5jZWQtcHJpbWUtdGFibGUvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3B0LWFkdmFuY2VkLXByaW1lLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3B0LWFkdmFuY2VkLXByaW1lLXRhYmxlLm1vZHVsZSc7XG4iXX0=
3
+ export * from './date-utility.service';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvcHQtYWR2YW5jZWQtcHJpbWUtdGFibGUvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHQtYWR2YW5jZWQtcHJpbWUtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcHQtYWR2YW5jZWQtcHJpbWUtdGFibGUubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0ZS11dGlsaXR5LnNlcnZpY2UnO1xuIl19
@@ -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 && this.buttonConfig) {
70
- const isDisabled = this.buttonConfig.disabled;
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
- this.renderer.setStyle(buttonElement, 'width', this.buttonConfig.width || 'auto');
75
- this.renderer.setStyle(buttonElement, 'height', this.buttonConfig.height || 'auto');
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"]}