primeng 20.0.0-rc.2 → 20.0.0-rc.3

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 (96) hide show
  1. package/autocomplete/index.d.ts +8 -7
  2. package/baseeditableholder/index.d.ts +14 -5
  3. package/basemodelholder/index.d.ts +12 -0
  4. package/cascadeselect/index.d.ts +7 -5
  5. package/checkbox/index.d.ts +9 -7
  6. package/colorpicker/index.d.ts +8 -7
  7. package/datepicker/index.d.ts +8 -7
  8. package/editor/index.d.ts +9 -8
  9. package/fesm2022/primeng-autocomplete.mjs +33 -35
  10. package/fesm2022/primeng-autocomplete.mjs.map +1 -1
  11. package/fesm2022/primeng-baseeditableholder.mjs +25 -7
  12. package/fesm2022/primeng-baseeditableholder.mjs.map +1 -1
  13. package/fesm2022/primeng-basemodelholder.mjs +25 -0
  14. package/fesm2022/primeng-basemodelholder.mjs.map +1 -0
  15. package/fesm2022/primeng-card.mjs +2 -2
  16. package/fesm2022/primeng-card.mjs.map +1 -1
  17. package/fesm2022/primeng-cascadeselect.mjs +21 -23
  18. package/fesm2022/primeng-cascadeselect.mjs.map +1 -1
  19. package/fesm2022/primeng-checkbox.mjs +13 -15
  20. package/fesm2022/primeng-checkbox.mjs.map +1 -1
  21. package/fesm2022/primeng-colorpicker.mjs +35 -37
  22. package/fesm2022/primeng-colorpicker.mjs.map +1 -1
  23. package/fesm2022/primeng-contextmenu.mjs +1 -9
  24. package/fesm2022/primeng-contextmenu.mjs.map +1 -1
  25. package/fesm2022/primeng-datepicker.mjs +41 -43
  26. package/fesm2022/primeng-datepicker.mjs.map +1 -1
  27. package/fesm2022/primeng-divider.mjs +2 -2
  28. package/fesm2022/primeng-divider.mjs.map +1 -1
  29. package/fesm2022/primeng-editor.mjs +8 -10
  30. package/fesm2022/primeng-editor.mjs.map +1 -1
  31. package/fesm2022/primeng-fileupload.mjs +4 -3
  32. package/fesm2022/primeng-fileupload.mjs.map +1 -1
  33. package/fesm2022/primeng-inputmask.mjs +23 -25
  34. package/fesm2022/primeng-inputmask.mjs.map +1 -1
  35. package/fesm2022/primeng-inputnumber.mjs +28 -30
  36. package/fesm2022/primeng-inputnumber.mjs.map +1 -1
  37. package/fesm2022/primeng-inputotp.mjs +26 -28
  38. package/fesm2022/primeng-inputotp.mjs.map +1 -1
  39. package/fesm2022/primeng-inputtext.mjs +11 -5
  40. package/fesm2022/primeng-inputtext.mjs.map +1 -1
  41. package/fesm2022/primeng-knob.mjs +22 -24
  42. package/fesm2022/primeng-knob.mjs.map +1 -1
  43. package/fesm2022/primeng-listbox.mjs +36 -38
  44. package/fesm2022/primeng-listbox.mjs.map +1 -1
  45. package/fesm2022/primeng-menubar.mjs +2 -2
  46. package/fesm2022/primeng-menubar.mjs.map +1 -1
  47. package/fesm2022/primeng-multiselect.mjs +38 -39
  48. package/fesm2022/primeng-multiselect.mjs.map +1 -1
  49. package/fesm2022/primeng-password.mjs +19 -21
  50. package/fesm2022/primeng-password.mjs.map +1 -1
  51. package/fesm2022/primeng-radiobutton.mjs +16 -18
  52. package/fesm2022/primeng-radiobutton.mjs.map +1 -1
  53. package/fesm2022/primeng-rating.mjs +14 -16
  54. package/fesm2022/primeng-rating.mjs.map +1 -1
  55. package/fesm2022/primeng-select.mjs +32 -34
  56. package/fesm2022/primeng-select.mjs.map +1 -1
  57. package/fesm2022/primeng-selectbutton.mjs +15 -17
  58. package/fesm2022/primeng-selectbutton.mjs.map +1 -1
  59. package/fesm2022/primeng-slider.mjs +28 -30
  60. package/fesm2022/primeng-slider.mjs.map +1 -1
  61. package/fesm2022/primeng-stepper.mjs +32 -7
  62. package/fesm2022/primeng-stepper.mjs.map +1 -1
  63. package/fesm2022/primeng-table.mjs +13 -21
  64. package/fesm2022/primeng-table.mjs.map +1 -1
  65. package/fesm2022/primeng-textarea.mjs +10 -5
  66. package/fesm2022/primeng-textarea.mjs.map +1 -1
  67. package/fesm2022/primeng-togglebutton.mjs +13 -15
  68. package/fesm2022/primeng-togglebutton.mjs.map +1 -1
  69. package/fesm2022/primeng-toggleswitch.mjs +14 -16
  70. package/fesm2022/primeng-toggleswitch.mjs.map +1 -1
  71. package/fesm2022/primeng-tree.mjs +1 -1
  72. package/fesm2022/primeng-tree.mjs.map +1 -1
  73. package/fesm2022/primeng-treeselect.mjs +16 -18
  74. package/fesm2022/primeng-treeselect.mjs.map +1 -1
  75. package/fesm2022/primeng-treetable.mjs +8 -8
  76. package/fesm2022/primeng-treetable.mjs.map +1 -1
  77. package/inputmask/index.d.ts +8 -7
  78. package/inputnumber/index.d.ts +8 -7
  79. package/inputotp/index.d.ts +7 -5
  80. package/inputtext/index.d.ts +10 -4
  81. package/knob/index.d.ts +7 -5
  82. package/listbox/index.d.ts +8 -7
  83. package/multiselect/index.d.ts +8 -7
  84. package/package.json +213 -209
  85. package/password/index.d.ts +7 -5
  86. package/radiobutton/index.d.ts +9 -7
  87. package/rating/index.d.ts +8 -7
  88. package/select/index.d.ts +8 -7
  89. package/selectbutton/index.d.ts +9 -8
  90. package/slider/index.d.ts +9 -8
  91. package/stepper/index.d.ts +4 -0
  92. package/table/index.d.ts +1 -5
  93. package/textarea/index.d.ts +9 -4
  94. package/togglebutton/index.d.ts +8 -7
  95. package/toggleswitch/index.d.ts +7 -5
  96. package/treeselect/index.d.ts +7 -5
@@ -50,7 +50,7 @@ const classes = {
50
50
  {
51
51
  'p-datepicker-panel p-component': true,
52
52
  'p-datepicker-panel-inline': instance.inline,
53
- 'p-disabled': instance.disabled(),
53
+ 'p-disabled': instance.$disabled(),
54
54
  'p-datepicker-timeonly': instance.timeOnly
55
55
  }
56
56
  ],
@@ -88,7 +88,7 @@ const classes = {
88
88
  return {
89
89
  'p-datepicker-day': true,
90
90
  'p-datepicker-day-selected': !instance.isRangeSelection() && instance.isSelected(date) && date.selectable,
91
- 'p-disabled': instance.disabled() || !date.selectable,
91
+ 'p-disabled': instance.$disabled() || !date.selectable,
92
92
  [selectedDayClass]: true
93
93
  };
94
94
  },
@@ -804,8 +804,6 @@ class DatePicker extends BaseInput {
804
804
  responsiveStyleElement;
805
805
  overlayVisible;
806
806
  $appendTo = computed(() => this.appendTo() || this.config.overlayAppendTo());
807
- onModelChange = () => { };
808
- onModelTouched = () => { };
809
807
  calendarElement;
810
808
  timePickerTimer;
811
809
  documentClickListener;
@@ -963,7 +961,7 @@ class DatePicker extends BaseInput {
963
961
  super.ngAfterViewInit();
964
962
  if (this.inline) {
965
963
  this.contentViewChild && this.contentViewChild.nativeElement.setAttribute(this.attributeSelector, '');
966
- if (!this.disabled() && !this.inline) {
964
+ if (!this.$disabled() && !this.inline) {
967
965
  this.initFocusableCell();
968
966
  if (this.numberOfMonths === 1) {
969
967
  if (this.contentViewChild && this.contentViewChild.nativeElement) {
@@ -1164,7 +1162,7 @@ class DatePicker extends BaseInput {
1164
1162
  }
1165
1163
  }
1166
1164
  navBackward(event) {
1167
- if (this.disabled()) {
1165
+ if (this.$disabled()) {
1168
1166
  event.preventDefault();
1169
1167
  return;
1170
1168
  }
@@ -1194,7 +1192,7 @@ class DatePicker extends BaseInput {
1194
1192
  }
1195
1193
  }
1196
1194
  navForward(event) {
1197
- if (this.disabled()) {
1195
+ if (this.$disabled()) {
1198
1196
  event.preventDefault();
1199
1197
  return;
1200
1198
  }
@@ -1254,7 +1252,7 @@ class DatePicker extends BaseInput {
1254
1252
  event.preventDefault();
1255
1253
  }
1256
1254
  onDateSelect(event, dateMeta) {
1257
- if (this.disabled() || !dateMeta.selectable) {
1255
+ if (this.$disabled() || !dateMeta.selectable) {
1258
1256
  event.preventDefault();
1259
1257
  return;
1260
1258
  }
@@ -1687,7 +1685,7 @@ class DatePicker extends BaseInput {
1687
1685
  this.onModelTouched();
1688
1686
  }
1689
1687
  onButtonClick(event, inputfield = this.inputfieldViewChild?.nativeElement) {
1690
- if (this.disabled()) {
1688
+ if (this.$disabled()) {
1691
1689
  return;
1692
1690
  }
1693
1691
  if (!this.overlayVisible) {
@@ -1719,7 +1717,7 @@ class DatePicker extends BaseInput {
1719
1717
  return this.currentView === 'month' ? this.currentYear : month.year;
1720
1718
  }
1721
1719
  switchViewButtonDisabled() {
1722
- return this.numberOfMonths > 1 || this.disabled();
1720
+ return this.numberOfMonths > 1 || this.$disabled();
1723
1721
  }
1724
1722
  onPrevButtonClick(event) {
1725
1723
  this.navigationState = { backward: true, button: true };
@@ -2220,7 +2218,7 @@ class DatePicker extends BaseInput {
2220
2218
  cell.tabIndex = '0';
2221
2219
  if (!this.preventFocus && (!this.navigationState || !this.navigationState.button)) {
2222
2220
  setTimeout(() => {
2223
- if (!this.disabled()) {
2221
+ if (!this.$disabled()) {
2224
2222
  cell.focus();
2225
2223
  }
2226
2224
  }, 1);
@@ -2395,19 +2393,19 @@ class DatePicker extends BaseInput {
2395
2393
  }
2396
2394
  }
2397
2395
  onTimePickerElementMouseDown(event, type, direction) {
2398
- if (!this.disabled()) {
2396
+ if (!this.$disabled()) {
2399
2397
  this.repeat(event, null, type, direction);
2400
2398
  event.preventDefault();
2401
2399
  }
2402
2400
  }
2403
2401
  onTimePickerElementMouseUp(event) {
2404
- if (!this.disabled()) {
2402
+ if (!this.$disabled()) {
2405
2403
  this.clearTimePickerTimer();
2406
2404
  this.updateTime();
2407
2405
  }
2408
2406
  }
2409
2407
  onTimePickerElementMouseLeave() {
2410
- if (!this.disabled() && this.timePickerTimer) {
2408
+ if (!this.$disabled() && this.timePickerTimer) {
2411
2409
  this.clearTimePickerTimer();
2412
2410
  this.updateTime();
2413
2411
  }
@@ -2801,28 +2799,6 @@ class DatePicker extends BaseInput {
2801
2799
  this.animationEndListener = null;
2802
2800
  }
2803
2801
  }
2804
- writeValue(value) {
2805
- this.value = value;
2806
- if (this.value && typeof this.value === 'string') {
2807
- try {
2808
- this.value = this.parseValueFromString(this.value);
2809
- }
2810
- catch {
2811
- if (this.keepInvalid) {
2812
- this.value = value;
2813
- }
2814
- }
2815
- }
2816
- this.updateInputfield();
2817
- this.updateUI();
2818
- this.cd.markForCheck();
2819
- }
2820
- registerOnChange(fn) {
2821
- this.onModelChange = fn;
2822
- }
2823
- registerOnTouched(fn) {
2824
- this.onModelTouched = fn;
2825
- }
2826
2802
  getDateFormat() {
2827
2803
  return this.dateFormat || this.getTranslation('dateFormat');
2828
2804
  }
@@ -3244,6 +3220,28 @@ class DatePicker extends BaseInput {
3244
3220
  this.unbindScrollListener();
3245
3221
  this.overlay = null;
3246
3222
  }
3223
+ /**
3224
+ * @override
3225
+ *
3226
+ * @see {@link BaseEditableHolder.writeControlValue}
3227
+ * Writes the value to the control.
3228
+ */
3229
+ writeControlValue(value) {
3230
+ this.value = value;
3231
+ if (this.value && typeof this.value === 'string') {
3232
+ try {
3233
+ this.value = this.parseValueFromString(this.value);
3234
+ }
3235
+ catch {
3236
+ if (this.keepInvalid) {
3237
+ this.value = value;
3238
+ }
3239
+ }
3240
+ }
3241
+ this.updateInputfield();
3242
+ this.updateUI();
3243
+ this.cd.markForCheck();
3244
+ }
3247
3245
  ngOnDestroy() {
3248
3246
  if (this.scrollHandler) {
3249
3247
  this.scrollHandler.destroy();
@@ -3287,7 +3285,7 @@ class DatePicker extends BaseInput {
3287
3285
  (blur)="onInputBlur($event)"
3288
3286
  [attr.required]="required() ? '' : undefined"
3289
3287
  [attr.readonly]="readonlyInput ? '' : undefined"
3290
- [attr.disabled]="disabled() ? '' : undefined"
3288
+ [attr.disabled]="$disabled() ? '' : undefined"
3291
3289
  (input)="onUserInput($event)"
3292
3290
  [ngStyle]="inputStyle"
3293
3291
  [class]="cn(cx('pcInputText'), inputStyleClass)"
@@ -3300,7 +3298,7 @@ class DatePicker extends BaseInput {
3300
3298
  [fluid]="hasFluid"
3301
3299
  [invalid]="invalid()"
3302
3300
  />
3303
- <ng-container *ngIf="showClear && !disabled() && value != null">
3301
+ <ng-container *ngIf="showClear && !$disabled() && value != null">
3304
3302
  <svg data-p-icon="times" *ngIf="!clearIconTemplate && !_clearIconTemplate" [class]="cx('clearIcon')" (click)="clear()" />
3305
3303
  <span *ngIf="clearIconTemplate || _clearIconTemplate" [class]="cx('clearIcon')" (click)="clear()">
3306
3304
  <ng-template *ngTemplateOutlet="clearIconTemplate || _clearIconTemplate"></ng-template>
@@ -3315,7 +3313,7 @@ class DatePicker extends BaseInput {
3315
3313
  *ngIf="showIcon && iconDisplay === 'button'"
3316
3314
  (click)="onButtonClick($event, inputfield)"
3317
3315
  [class]="cx('dropdown')"
3318
- [disabled]="disabled()"
3316
+ [disabled]="$disabled()"
3319
3317
  tabindex="0"
3320
3318
  >
3321
3319
  <span *ngIf="icon" [ngClass]="icon"></span>
@@ -3678,7 +3676,7 @@ class DatePicker extends BaseInput {
3678
3676
  <ng-content select="p-footer"></ng-content>
3679
3677
  <ng-container *ngTemplateOutlet="footerTemplate || _footerTemplate"></ng-container>
3680
3678
  </div>
3681
- `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "variant", "style", "styleClass", "badgeClass", "badgeSeverity", "ariaLabel", "buttonProps", "autofocus", "fluid"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: Ripple, selector: "[pRipple]" }, { kind: "component", type: ChevronLeftIcon, selector: "[data-p-icon=\"chevron-left\"]" }, { kind: "component", type: ChevronRightIcon, selector: "[data-p-icon=\"chevron-right\"]" }, { kind: "component", type: ChevronUpIcon, selector: "[data-p-icon=\"chevron-up\"]" }, { kind: "component", type: ChevronDownIcon, selector: "[data-p-icon=\"chevron-down\"]" }, { kind: "component", type: TimesIcon, selector: "[data-p-icon=\"times\"]" }, { kind: "component", type: CalendarIcon, selector: "[data-p-icon=\"calendar\"]" }, { kind: "directive", type: AutoFocus, selector: "[pAutoFocus]", inputs: ["pAutoFocus"] }, { kind: "directive", type: InputText, selector: "[pInputText]", inputs: ["pSize", "variant", "fluid"] }, { kind: "ngmodule", type: SharedModule }], animations: [
3679
+ `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "variant", "style", "styleClass", "badgeClass", "badgeSeverity", "ariaLabel", "buttonProps", "autofocus", "fluid"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "directive", type: Ripple, selector: "[pRipple]" }, { kind: "component", type: ChevronLeftIcon, selector: "[data-p-icon=\"chevron-left\"]" }, { kind: "component", type: ChevronRightIcon, selector: "[data-p-icon=\"chevron-right\"]" }, { kind: "component", type: ChevronUpIcon, selector: "[data-p-icon=\"chevron-up\"]" }, { kind: "component", type: ChevronDownIcon, selector: "[data-p-icon=\"chevron-down\"]" }, { kind: "component", type: TimesIcon, selector: "[data-p-icon=\"times\"]" }, { kind: "component", type: CalendarIcon, selector: "[data-p-icon=\"calendar\"]" }, { kind: "directive", type: AutoFocus, selector: "[pAutoFocus]", inputs: ["pAutoFocus"] }, { kind: "directive", type: InputText, selector: "[pInputText]", inputs: ["pSize", "variant", "fluid", "invalid"] }, { kind: "ngmodule", type: SharedModule }], animations: [
3682
3680
  trigger('overlayAnimation', [
3683
3681
  state('visibleTouchUI', style$1({
3684
3682
  transform: 'translate(-50%,-50%)',
@@ -3727,7 +3725,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.6", ngImpor
3727
3725
  (blur)="onInputBlur($event)"
3728
3726
  [attr.required]="required() ? '' : undefined"
3729
3727
  [attr.readonly]="readonlyInput ? '' : undefined"
3730
- [attr.disabled]="disabled() ? '' : undefined"
3728
+ [attr.disabled]="$disabled() ? '' : undefined"
3731
3729
  (input)="onUserInput($event)"
3732
3730
  [ngStyle]="inputStyle"
3733
3731
  [class]="cn(cx('pcInputText'), inputStyleClass)"
@@ -3740,7 +3738,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.6", ngImpor
3740
3738
  [fluid]="hasFluid"
3741
3739
  [invalid]="invalid()"
3742
3740
  />
3743
- <ng-container *ngIf="showClear && !disabled() && value != null">
3741
+ <ng-container *ngIf="showClear && !$disabled() && value != null">
3744
3742
  <svg data-p-icon="times" *ngIf="!clearIconTemplate && !_clearIconTemplate" [class]="cx('clearIcon')" (click)="clear()" />
3745
3743
  <span *ngIf="clearIconTemplate || _clearIconTemplate" [class]="cx('clearIcon')" (click)="clear()">
3746
3744
  <ng-template *ngTemplateOutlet="clearIconTemplate || _clearIconTemplate"></ng-template>
@@ -3755,7 +3753,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.6", ngImpor
3755
3753
  *ngIf="showIcon && iconDisplay === 'button'"
3756
3754
  (click)="onButtonClick($event, inputfield)"
3757
3755
  [class]="cx('dropdown')"
3758
- [disabled]="disabled()"
3756
+ [disabled]="$disabled()"
3759
3757
  tabindex="0"
3760
3758
  >
3761
3759
  <span *ngIf="icon" [ngClass]="icon"></span>