igniteui-angular 18.2.9 → 18.2.10

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 (53) hide show
  1. package/esm2022/lib/core/i18n/grid-resources.mjs +3 -3
  2. package/esm2022/lib/grids/columns/column.component.mjs +5 -2
  3. package/esm2022/lib/grids/common/grid.interface.mjs +1 -1
  4. package/esm2022/lib/grids/filtering/excel-style/excel-style-custom-dialog.component.mjs +2 -1
  5. package/esm2022/lib/grids/filtering/excel-style/excel-style-filtering.component.mjs +3 -2
  6. package/esm2022/lib/grids/grid-base.directive.mjs +9 -3
  7. package/esm2022/lib/grids/hierarchical-grid/hierarchical-grid-base.directive.mjs +2 -1
  8. package/esm2022/lib/grids/pivot-grid/pivot-grid.component.mjs +1 -1
  9. package/esm2022/lib/grids/resizing/pivot-grid/pivot-resizer.component.mjs +3 -3
  10. package/esm2022/lib/grids/resizing/resizer.component.mjs +3 -3
  11. package/esm2022/lib/grids/resizing/resizer.directive.mjs +12 -3
  12. package/esm2022/lib/grids/resizing/resizing.service.mjs +4 -4
  13. package/fesm2022/igniteui-angular.mjs +36 -15
  14. package/fesm2022/igniteui-angular.mjs.map +1 -1
  15. package/lib/core/styles/components/checkbox/_checkbox-component.scss +8 -4
  16. package/lib/core/styles/components/checkbox/_checkbox-theme.scss +7 -1
  17. package/lib/core/styles/components/chip/_chip-theme.scss +1 -1
  18. package/lib/core/styles/components/combo/_combo-theme.scss +2 -2
  19. package/lib/core/styles/components/grid/_excel-filtering-theme.scss +3 -7
  20. package/lib/core/styles/components/grid/_grid-theme.scss +19 -15
  21. package/lib/core/styles/components/progress/_progress-theme.scss +55 -7
  22. package/lib/grids/common/grid.interface.d.ts +4 -0
  23. package/lib/grids/grid-base.directive.d.ts +5 -2
  24. package/lib/grids/pivot-grid/pivot-grid.component.d.ts +1 -1
  25. package/lib/grids/resizing/resizer.directive.d.ts +2 -0
  26. package/lib/grids/resizing/resizing.service.d.ts +2 -2
  27. package/package.json +1 -1
  28. package/styles/igniteui-angular-dark.css +1 -1
  29. package/styles/igniteui-angular.css +1 -1
  30. package/styles/igniteui-bootstrap-dark.css +1 -1
  31. package/styles/igniteui-bootstrap-light.css +1 -1
  32. package/styles/igniteui-dark-green.css +1 -1
  33. package/styles/igniteui-fluent-dark-excel.css +1 -1
  34. package/styles/igniteui-fluent-dark-word.css +1 -1
  35. package/styles/igniteui-fluent-dark.css +1 -1
  36. package/styles/igniteui-fluent-light-excel.css +1 -1
  37. package/styles/igniteui-fluent-light-word.css +1 -1
  38. package/styles/igniteui-fluent-light.css +1 -1
  39. package/styles/igniteui-indigo-dark.css +1 -1
  40. package/styles/igniteui-indigo-light.css +1 -1
  41. package/styles/maps/igniteui-angular-dark.css.map +1 -1
  42. package/styles/maps/igniteui-angular.css.map +1 -1
  43. package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
  44. package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
  45. package/styles/maps/igniteui-dark-green.css.map +1 -1
  46. package/styles/maps/igniteui-fluent-dark-excel.css.map +1 -1
  47. package/styles/maps/igniteui-fluent-dark-word.css.map +1 -1
  48. package/styles/maps/igniteui-fluent-dark.css.map +1 -1
  49. package/styles/maps/igniteui-fluent-light-excel.css.map +1 -1
  50. package/styles/maps/igniteui-fluent-light-word.css.map +1 -1
  51. package/styles/maps/igniteui-fluent-light.css.map +1 -1
  52. package/styles/maps/igniteui-indigo-dark.css.map +1 -1
  53. package/styles/maps/igniteui-indigo-light.css.map +1 -1
@@ -9,10 +9,10 @@ export class IgxPivotGridColumnResizerComponent extends IgxGridColumnResizerComp
9
9
  this.colResizingService = colResizingService;
10
10
  }
11
11
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxPivotGridColumnResizerComponent, deps: [{ token: i1.IgxPivotColumnResizingService }], target: i0.ɵɵFactoryTarget.Component }); }
12
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxPivotGridColumnResizerComponent, isStandalone: true, selector: "igx-pivot-grid-column-resizer", usesInheritance: true, ngImport: i0, template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event)\">\n</div>\n", dependencies: [{ kind: "directive", type: IgxColumnResizerDirective, selector: "[igxResizer]", inputs: ["restrictHResizeMin", "restrictHResizeMax", "restrictResizerTop"], outputs: ["resizeEnd", "resizeStart", "resize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
12
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxPivotGridColumnResizerComponent, isStandalone: true, selector: "igx-pivot-grid-column-resizer", usesInheritance: true, ngImport: i0, template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event, resizer.ratio)\">\n</div>\n", dependencies: [{ kind: "directive", type: IgxColumnResizerDirective, selector: "[igxResizer]", inputs: ["restrictHResizeMin", "restrictHResizeMax", "restrictResizerTop"], outputs: ["resizeEnd", "resizeStart", "resize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
13
13
  }
14
14
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxPivotGridColumnResizerComponent, decorators: [{
15
15
  type: Component,
16
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-pivot-grid-column-resizer', standalone: true, imports: [IgxColumnResizerDirective], template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event)\">\n</div>\n" }]
16
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-pivot-grid-column-resizer', standalone: true, imports: [IgxColumnResizerDirective], template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event, resizer.ratio)\">\n</div>\n" }]
17
17
  }], ctorParameters: () => [{ type: i1.IgxPivotColumnResizingService }] });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGl2b3QtcmVzaXplci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pZ25pdGV1aS1hbmd1bGFyL3NyYy9saWIvZ3JpZHMvcmVzaXppbmcvcGl2b3QtZ3JpZC9waXZvdC1yZXNpemVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2lnbml0ZXVpLWFuZ3VsYXIvc3JjL2xpYi9ncmlkcy9yZXNpemluZy9yZXNpemVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFckUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7OztBQVNqRSxNQUFNLE9BQU8sa0NBQW1DLFNBQVEsNkJBQTZCO0lBQ2pGLFlBQTRCLGtCQUFpRDtRQUN6RSxLQUFLLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQURGLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBK0I7SUFFN0UsQ0FBQzs4R0FIUSxrQ0FBa0M7a0dBQWxDLGtDQUFrQyxnSENaL0MsK1lBUUEsNENERWMseUJBQXlCOzsyRkFFMUIsa0NBQWtDO2tCQVA5QyxTQUFTO3NDQUNXLHVCQUF1QixDQUFDLE1BQU0sWUFDckMsK0JBQStCLGNBRTdCLElBQUksV0FDUCxDQUFDLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWd4R3JpZENvbHVtblJlc2l6ZXJDb21wb25lbnQgfSBmcm9tICcuLi9yZXNpemVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJZ3hQaXZvdENvbHVtblJlc2l6aW5nU2VydmljZSB9IGZyb20gJy4vcGl2b3QtcmVzaXppbmcuc2VydmljZSc7XG5pbXBvcnQgeyBJZ3hDb2x1bW5SZXNpemVyRGlyZWN0aXZlIH0gZnJvbSAnLi4vcmVzaXplci5kaXJlY3RpdmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBzZWxlY3RvcjogJ2lneC1waXZvdC1ncmlkLWNvbHVtbi1yZXNpemVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4uL3Jlc2l6ZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0lneENvbHVtblJlc2l6ZXJEaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIElneFBpdm90R3JpZENvbHVtblJlc2l6ZXJDb21wb25lbnQgZXh0ZW5kcyBJZ3hHcmlkQ29sdW1uUmVzaXplckNvbXBvbmVudCB7XG4gICAgY29uc3RydWN0b3IocHVibGljIG92ZXJyaWRlIGNvbFJlc2l6aW5nU2VydmljZTogSWd4UGl2b3RDb2x1bW5SZXNpemluZ1NlcnZpY2UpIHtcbiAgICAgICAgc3VwZXIoY29sUmVzaXppbmdTZXJ2aWNlKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiaWd4LWdyaWQtdGhfX3Jlc2l6ZS1saW5lXCJcbiAgICBbc3R5bGUubGVmdC5weF09XCItOTk5OTlcIiBpZ3hSZXNpemVyXG4gICAgW3N0eWxlLmhlaWdodC5weF09XCJjb2xSZXNpemluZ1NlcnZpY2UucmVzaXplckhlaWdodFwiXG4gICAgW3Jlc3RyaWN0SFJlc2l6ZU1heF09XCJjb2xSZXNpemluZ1NlcnZpY2UucmVzdHJpY3RSZXNpemVNYXhcIlxuICAgIFtyZXN0cmljdEhSZXNpemVNaW5dPVwiY29sUmVzaXppbmdTZXJ2aWNlLnJlc3RyaWN0UmVzaXplTWluXCJcbiAgICBbcmVzdHJpY3RSZXNpemVyVG9wXT1cInJlc3RyaWN0UmVzaXplclRvcFwiXG4gICAgKHJlc2l6ZUVuZCk9XCJjb2xSZXNpemluZ1NlcnZpY2UucmVzaXplQ29sdW1uKCRldmVudClcIj5cbjwvZGl2PlxuIl19
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGl2b3QtcmVzaXplci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pZ25pdGV1aS1hbmd1bGFyL3NyYy9saWIvZ3JpZHMvcmVzaXppbmcvcGl2b3QtZ3JpZC9waXZvdC1yZXNpemVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2lnbml0ZXVpLWFuZ3VsYXIvc3JjL2xpYi9ncmlkcy9yZXNpemluZy9yZXNpemVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFckUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sc0JBQXNCLENBQUM7OztBQVNqRSxNQUFNLE9BQU8sa0NBQW1DLFNBQVEsNkJBQTZCO0lBQ2pGLFlBQTRCLGtCQUFpRDtRQUN6RSxLQUFLLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQURGLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBK0I7SUFFN0UsQ0FBQzs4R0FIUSxrQ0FBa0M7a0dBQWxDLGtDQUFrQyxnSENaL0MsOFpBUUEsNENERWMseUJBQXlCOzsyRkFFMUIsa0NBQWtDO2tCQVA5QyxTQUFTO3NDQUNXLHVCQUF1QixDQUFDLE1BQU0sWUFDckMsK0JBQStCLGNBRTdCLElBQUksV0FDUCxDQUFDLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWd4R3JpZENvbHVtblJlc2l6ZXJDb21wb25lbnQgfSBmcm9tICcuLi9yZXNpemVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJZ3hQaXZvdENvbHVtblJlc2l6aW5nU2VydmljZSB9IGZyb20gJy4vcGl2b3QtcmVzaXppbmcuc2VydmljZSc7XG5pbXBvcnQgeyBJZ3hDb2x1bW5SZXNpemVyRGlyZWN0aXZlIH0gZnJvbSAnLi4vcmVzaXplci5kaXJlY3RpdmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBzZWxlY3RvcjogJ2lneC1waXZvdC1ncmlkLWNvbHVtbi1yZXNpemVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4uL3Jlc2l6ZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0lneENvbHVtblJlc2l6ZXJEaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIElneFBpdm90R3JpZENvbHVtblJlc2l6ZXJDb21wb25lbnQgZXh0ZW5kcyBJZ3hHcmlkQ29sdW1uUmVzaXplckNvbXBvbmVudCB7XG4gICAgY29uc3RydWN0b3IocHVibGljIG92ZXJyaWRlIGNvbFJlc2l6aW5nU2VydmljZTogSWd4UGl2b3RDb2x1bW5SZXNpemluZ1NlcnZpY2UpIHtcbiAgICAgICAgc3VwZXIoY29sUmVzaXppbmdTZXJ2aWNlKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiaWd4LWdyaWQtdGhfX3Jlc2l6ZS1saW5lXCJcbiAgICBbc3R5bGUubGVmdC5weF09XCItOTk5OTlcIiBpZ3hSZXNpemVyXG4gICAgW3N0eWxlLmhlaWdodC5weF09XCJjb2xSZXNpemluZ1NlcnZpY2UucmVzaXplckhlaWdodFwiXG4gICAgW3Jlc3RyaWN0SFJlc2l6ZU1heF09XCJjb2xSZXNpemluZ1NlcnZpY2UucmVzdHJpY3RSZXNpemVNYXhcIlxuICAgIFtyZXN0cmljdEhSZXNpemVNaW5dPVwiY29sUmVzaXppbmdTZXJ2aWNlLnJlc3RyaWN0UmVzaXplTWluXCJcbiAgICBbcmVzdHJpY3RSZXNpemVyVG9wXT1cInJlc3RyaWN0UmVzaXplclRvcFwiXG4gICAgKHJlc2l6ZUVuZCk9XCJjb2xSZXNpemluZ1NlcnZpY2UucmVzaXplQ29sdW1uKCRldmVudCwgcmVzaXplci5yYXRpbylcIj5cbjwvZGl2PlxuIl19
@@ -7,15 +7,15 @@ export class IgxGridColumnResizerComponent {
7
7
  this.colResizingService = colResizingService;
8
8
  }
9
9
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxGridColumnResizerComponent, deps: [{ token: i1.IgxColumnResizingService }], target: i0.ɵɵFactoryTarget.Component }); }
10
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxGridColumnResizerComponent, isStandalone: true, selector: "igx-grid-column-resizer", inputs: { restrictResizerTop: "restrictResizerTop" }, viewQueries: [{ propertyName: "resizer", first: true, predicate: IgxColumnResizerDirective, descendants: true, static: true }], ngImport: i0, template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event)\">\n</div>\n", dependencies: [{ kind: "directive", type: IgxColumnResizerDirective, selector: "[igxResizer]", inputs: ["restrictHResizeMin", "restrictHResizeMax", "restrictResizerTop"], outputs: ["resizeEnd", "resizeStart", "resize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
10
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxGridColumnResizerComponent, isStandalone: true, selector: "igx-grid-column-resizer", inputs: { restrictResizerTop: "restrictResizerTop" }, viewQueries: [{ propertyName: "resizer", first: true, predicate: IgxColumnResizerDirective, descendants: true, static: true }], ngImport: i0, template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event, resizer.ratio)\">\n</div>\n", dependencies: [{ kind: "directive", type: IgxColumnResizerDirective, selector: "[igxResizer]", inputs: ["restrictHResizeMin", "restrictHResizeMax", "restrictResizerTop"], outputs: ["resizeEnd", "resizeStart", "resize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
11
11
  }
12
12
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxGridColumnResizerComponent, decorators: [{
13
13
  type: Component,
14
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-grid-column-resizer', standalone: true, imports: [IgxColumnResizerDirective], template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event)\">\n</div>\n" }]
14
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-grid-column-resizer', standalone: true, imports: [IgxColumnResizerDirective], template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event, resizer.ratio)\">\n</div>\n" }]
15
15
  }], ctorParameters: () => [{ type: i1.IgxColumnResizingService }], propDecorators: { restrictResizerTop: [{
16
16
  type: Input
17
17
  }], resizer: [{
18
18
  type: ViewChild,
19
19
  args: [IgxColumnResizerDirective, { static: true }]
20
20
  }] } });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzaXplci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pZ25pdGV1aS1hbmd1bGFyL3NyYy9saWIvZ3JpZHMvcmVzaXppbmcvcmVzaXplci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pZ25pdGV1aS1hbmd1bGFyL3NyYy9saWIvZ3JpZHMvcmVzaXppbmcvcmVzaXplci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7OztBQVNoRSxNQUFNLE9BQU8sNkJBQTZCO0lBT3RDLFlBQW1CLGtCQUE0QztRQUE1Qyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQTBCO0lBQUksQ0FBQzs4R0FQM0QsNkJBQTZCO2tHQUE3Qiw2QkFBNkIsa0xBSTNCLHlCQUF5Qiw4RENmeEMsK1lBUUEsNENEQ2MseUJBQXlCOzsyRkFFMUIsNkJBQTZCO2tCQVB6QyxTQUFTO3NDQUNXLHVCQUF1QixDQUFDLE1BQU0sWUFDckMseUJBQXlCLGNBRXZCLElBQUksV0FDUCxDQUFDLHlCQUF5QixDQUFDOzZGQUk3QixrQkFBa0I7c0JBRHhCLEtBQUs7Z0JBSUMsT0FBTztzQkFEYixTQUFTO3VCQUFDLHlCQUF5QixFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElneENvbHVtblJlc2l6aW5nU2VydmljZSB9IGZyb20gJy4vcmVzaXppbmcuc2VydmljZSc7XG5pbXBvcnQgeyBJZ3hDb2x1bW5SZXNpemVyRGlyZWN0aXZlIH0gZnJvbSAnLi9yZXNpemVyLmRpcmVjdGl2ZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHNlbGVjdG9yOiAnaWd4LWdyaWQtY29sdW1uLXJlc2l6ZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9yZXNpemVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtJZ3hDb2x1bW5SZXNpemVyRGlyZWN0aXZlXVxufSlcbmV4cG9ydCBjbGFzcyBJZ3hHcmlkQ29sdW1uUmVzaXplckNvbXBvbmVudCB7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgcmVzdHJpY3RSZXNpemVyVG9wOiBudW1iZXI7XG5cbiAgICBAVmlld0NoaWxkKElneENvbHVtblJlc2l6ZXJEaXJlY3RpdmUsIHsgc3RhdGljOiB0cnVlIH0pXG4gICAgcHVibGljIHJlc2l6ZXI6IElneENvbHVtblJlc2l6ZXJEaXJlY3RpdmU7XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgY29sUmVzaXppbmdTZXJ2aWNlOiBJZ3hDb2x1bW5SZXNpemluZ1NlcnZpY2UpIHsgfVxufVxuIiwiPGRpdiBjbGFzcz1cImlneC1ncmlkLXRoX19yZXNpemUtbGluZVwiXG4gICAgW3N0eWxlLmxlZnQucHhdPVwiLTk5OTk5XCIgaWd4UmVzaXplclxuICAgIFtzdHlsZS5oZWlnaHQucHhdPVwiY29sUmVzaXppbmdTZXJ2aWNlLnJlc2l6ZXJIZWlnaHRcIlxuICAgIFtyZXN0cmljdEhSZXNpemVNYXhdPVwiY29sUmVzaXppbmdTZXJ2aWNlLnJlc3RyaWN0UmVzaXplTWF4XCJcbiAgICBbcmVzdHJpY3RIUmVzaXplTWluXT1cImNvbFJlc2l6aW5nU2VydmljZS5yZXN0cmljdFJlc2l6ZU1pblwiXG4gICAgW3Jlc3RyaWN0UmVzaXplclRvcF09XCJyZXN0cmljdFJlc2l6ZXJUb3BcIlxuICAgIChyZXNpemVFbmQpPVwiY29sUmVzaXppbmdTZXJ2aWNlLnJlc2l6ZUNvbHVtbigkZXZlbnQpXCI+XG48L2Rpdj5cbiJdfQ==
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzaXplci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pZ25pdGV1aS1hbmd1bGFyL3NyYy9saWIvZ3JpZHMvcmVzaXppbmcvcmVzaXplci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pZ25pdGV1aS1hbmd1bGFyL3NyYy9saWIvZ3JpZHMvcmVzaXppbmcvcmVzaXplci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7OztBQVNoRSxNQUFNLE9BQU8sNkJBQTZCO0lBT3RDLFlBQW1CLGtCQUE0QztRQUE1Qyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQTBCO0lBQUksQ0FBQzs4R0FQM0QsNkJBQTZCO2tHQUE3Qiw2QkFBNkIsa0xBSTNCLHlCQUF5Qiw4RENmeEMsOFpBUUEsNENEQ2MseUJBQXlCOzsyRkFFMUIsNkJBQTZCO2tCQVB6QyxTQUFTO3NDQUNXLHVCQUF1QixDQUFDLE1BQU0sWUFDckMseUJBQXlCLGNBRXZCLElBQUksV0FDUCxDQUFDLHlCQUF5QixDQUFDOzZGQUk3QixrQkFBa0I7c0JBRHhCLEtBQUs7Z0JBSUMsT0FBTztzQkFEYixTQUFTO3VCQUFDLHlCQUF5QixFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElneENvbHVtblJlc2l6aW5nU2VydmljZSB9IGZyb20gJy4vcmVzaXppbmcuc2VydmljZSc7XG5pbXBvcnQgeyBJZ3hDb2x1bW5SZXNpemVyRGlyZWN0aXZlIH0gZnJvbSAnLi9yZXNpemVyLmRpcmVjdGl2ZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHNlbGVjdG9yOiAnaWd4LWdyaWQtY29sdW1uLXJlc2l6ZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9yZXNpemVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtJZ3hDb2x1bW5SZXNpemVyRGlyZWN0aXZlXVxufSlcbmV4cG9ydCBjbGFzcyBJZ3hHcmlkQ29sdW1uUmVzaXplckNvbXBvbmVudCB7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgcmVzdHJpY3RSZXNpemVyVG9wOiBudW1iZXI7XG5cbiAgICBAVmlld0NoaWxkKElneENvbHVtblJlc2l6ZXJEaXJlY3RpdmUsIHsgc3RhdGljOiB0cnVlIH0pXG4gICAgcHVibGljIHJlc2l6ZXI6IElneENvbHVtblJlc2l6ZXJEaXJlY3RpdmU7XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgY29sUmVzaXppbmdTZXJ2aWNlOiBJZ3hDb2x1bW5SZXNpemluZ1NlcnZpY2UpIHsgfVxufVxuIiwiPGRpdiBjbGFzcz1cImlneC1ncmlkLXRoX19yZXNpemUtbGluZVwiXG4gICAgW3N0eWxlLmxlZnQucHhdPVwiLTk5OTk5XCIgaWd4UmVzaXplclxuICAgIFtzdHlsZS5oZWlnaHQucHhdPVwiY29sUmVzaXppbmdTZXJ2aWNlLnJlc2l6ZXJIZWlnaHRcIlxuICAgIFtyZXN0cmljdEhSZXNpemVNYXhdPVwiY29sUmVzaXppbmdTZXJ2aWNlLnJlc3RyaWN0UmVzaXplTWF4XCJcbiAgICBbcmVzdHJpY3RIUmVzaXplTWluXT1cImNvbFJlc2l6aW5nU2VydmljZS5yZXN0cmljdFJlc2l6ZU1pblwiXG4gICAgW3Jlc3RyaWN0UmVzaXplclRvcF09XCJyZXN0cmljdFJlc2l6ZXJUb3BcIlxuICAgIChyZXNpemVFbmQpPVwiY29sUmVzaXppbmdTZXJ2aWNlLnJlc2l6ZUNvbHVtbigkZXZlbnQsIHJlc2l6ZXIucmF0aW8pXCI+XG48L2Rpdj5cbiJdfQ==
@@ -8,6 +8,9 @@ import * as i0 from "@angular/core";
8
8
  * @internal
9
9
  */
10
10
  export class IgxColumnResizerDirective {
11
+ get ratio() {
12
+ return this._ratio;
13
+ }
11
14
  constructor(element, document, zone) {
12
15
  this.element = element;
13
16
  this.document = document;
@@ -18,9 +21,10 @@ export class IgxColumnResizerDirective {
18
21
  this.resizeStart = new Subject();
19
22
  // eslint-disable-next-line @angular-eslint/no-output-native
20
23
  this.resize = new Subject();
24
+ this._ratio = 1;
21
25
  this._destroy = new Subject();
22
26
  this.resizeStart.pipe(takeUntil(this._destroy), map((event) => event.clientX), switchMap((offset) => this.resize
23
- .pipe(takeUntil(this._destroy), takeUntil(this.resizeEnd), map((event) => event.clientX - offset))))
27
+ .pipe(takeUntil(this._destroy), takeUntil(this.resizeEnd), map((event) => (event.clientX - offset) / (this._ratio)))))
24
28
  .subscribe((pos) => {
25
29
  const left = this._left + pos;
26
30
  const min = this._left - this.restrictHResizeMin;
@@ -63,7 +67,12 @@ export class IgxColumnResizerDirective {
63
67
  onMousedown(event) {
64
68
  event.preventDefault();
65
69
  const parent = this.element.nativeElement.parentElement.parentElement;
66
- this.left = this._left = event.clientX - parent.getBoundingClientRect().left;
70
+ const parentRectWidth = parent.getBoundingClientRect().width;
71
+ const parentComputedWidth = parseFloat(window.getComputedStyle(parent).width);
72
+ if (Math.abs(parentRectWidth - parentComputedWidth) > 1) {
73
+ this._ratio = parentRectWidth / parentComputedWidth;
74
+ }
75
+ this.left = this._left = (event.clientX - parent.getBoundingClientRect().left) / this._ratio;
67
76
  this.top = event.target.getBoundingClientRect().top - parent.getBoundingClientRect().top;
68
77
  this.resizeStart.next(event);
69
78
  }
@@ -96,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
96
105
  }], resize: [{
97
106
  type: Output
98
107
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizer.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/resizing/resizer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Inject,\n    Input,\n    NgZone,\n    Output,\n    OnInit,\n    OnDestroy,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { Subject, fromEvent, animationFrameScheduler, interval } from 'rxjs';\nimport { map, switchMap, takeUntil, throttle } from 'rxjs/operators';\n\n/**\n * @hidden\n * @internal\n */\n@Directive({\n    selector: '[igxResizer]',\n    standalone: true\n})\nexport class IgxColumnResizerDirective implements OnInit, OnDestroy {\n\n    @Input()\n    public restrictHResizeMin: number = Number.MIN_SAFE_INTEGER;\n\n    @Input()\n    public restrictHResizeMax: number = Number.MAX_SAFE_INTEGER;\n\n    @Input()\n    public restrictResizerTop: number;\n\n    @Output()\n    public resizeEnd = new Subject<MouseEvent>();\n\n    @Output()\n    public resizeStart = new Subject<MouseEvent>();\n\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public resize = new Subject<any>();\n\n    private _left: number;\n    private _destroy = new Subject<boolean>();\n\n    constructor(\n        public element: ElementRef<HTMLElement>,\n        @Inject(DOCUMENT) public document,\n        public zone: NgZone\n    ) {\n\n        this.resizeStart.pipe(\n            takeUntil<MouseEvent>(this._destroy),\n            map((event) => event.clientX),\n            switchMap((offset) => this.resize\n                .pipe(\n                    takeUntil(this._destroy),\n                    takeUntil<MouseEvent>(this.resizeEnd),\n                    map((event) => event.clientX - offset),\n                ))\n        )\n            .subscribe((pos) => {\n                const left = this._left + pos;\n                const min = this._left - this.restrictHResizeMin;\n                const max = this._left + this.restrictHResizeMax;\n\n                this.left = left < min ? min : left;\n\n                if (left > max) {\n                    this.left = max;\n                }\n            });\n\n    }\n\n    public ngOnInit() {\n        this.zone.runOutsideAngular(() => {\n            fromEvent(this.document.defaultView, 'mousemove')\n                .pipe(\n                    takeUntil<MouseEvent>(this._destroy),\n                    throttle(() => interval(0, animationFrameScheduler)),\n                )\n                .subscribe((res) => this.onMousemove(res));\n\n            fromEvent(this.document.defaultView, 'mouseup')\n                .pipe(takeUntil<MouseEvent>(this._destroy))\n                .subscribe((res) => this.onMouseup(res));\n        });\n    }\n\n    public ngOnDestroy() {\n        this._destroy.next(true);\n        this._destroy.complete();\n    }\n\n    public set left(val: number) {\n        requestAnimationFrame(() => this.element.nativeElement.style.left = val + 'px');\n    }\n\n    public set top(val: number) {\n        if (this.restrictResizerTop != undefined) {\n            requestAnimationFrame(() => this.element.nativeElement.style.top = this.restrictResizerTop + 'px');\n        } else {\n            requestAnimationFrame(() => this.element.nativeElement.style.top = val + 'px');\n        }\n    }\n\n    public onMouseup(event: MouseEvent) {\n        this.resizeEnd.next(event);\n        this.resizeEnd.complete();\n    }\n\n    public onMousedown(event: MouseEvent) {\n        event.preventDefault();\n        const parent = this.element.nativeElement.parentElement.parentElement;\n\n        this.left = this._left = event.clientX - parent.getBoundingClientRect().left;\n        this.top = (event.target as HTMLElement).getBoundingClientRect().top - parent.getBoundingClientRect().top;\n\n        this.resizeStart.next(event);\n    }\n\n    public onMousemove(event: MouseEvent) {\n        event.preventDefault();\n        this.resize.next(event);\n    }\n}\n"]}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizer.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/resizing/resizer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Inject,\n    Input,\n    NgZone,\n    Output,\n    OnInit,\n    OnDestroy,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { Subject, fromEvent, animationFrameScheduler, interval } from 'rxjs';\nimport { map, switchMap, takeUntil, throttle } from 'rxjs/operators';\n\n/**\n * @hidden\n * @internal\n */\n@Directive({\n    selector: '[igxResizer]',\n    standalone: true\n})\nexport class IgxColumnResizerDirective implements OnInit, OnDestroy {\n\n    @Input()\n    public restrictHResizeMin: number = Number.MIN_SAFE_INTEGER;\n\n    @Input()\n    public restrictHResizeMax: number = Number.MAX_SAFE_INTEGER;\n\n    @Input()\n    public restrictResizerTop: number;\n\n    @Output()\n    public resizeEnd = new Subject<MouseEvent>();\n\n    @Output()\n    public resizeStart = new Subject<MouseEvent>();\n\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public resize = new Subject<any>();\n\n    private _left: number;\n    private _ratio: number = 1;\n    private _destroy = new Subject<boolean>();\n\n    public get ratio(): number {\n        return this._ratio;\n    }\n\n    constructor(\n        public element: ElementRef<HTMLElement>,\n        @Inject(DOCUMENT) public document,\n        public zone: NgZone\n    ) {\n\n        this.resizeStart.pipe(\n            takeUntil<MouseEvent>(this._destroy),\n            map((event) => event.clientX),\n            switchMap((offset) => this.resize\n                .pipe(\n                    takeUntil(this._destroy),\n                    takeUntil<MouseEvent>(this.resizeEnd),\n                    map((event) => (event.clientX - offset) / (this._ratio)),\n                ))\n        )\n            .subscribe((pos) => {\n                const left = this._left + pos;\n                const min = this._left - this.restrictHResizeMin;\n                const max = this._left + this.restrictHResizeMax;\n\n                this.left = left < min ? min : left;\n\n                if (left > max) {\n                    this.left = max;\n                }\n            });\n\n    }\n\n    public ngOnInit() {\n        this.zone.runOutsideAngular(() => {\n            fromEvent(this.document.defaultView, 'mousemove')\n                .pipe(\n                    takeUntil<MouseEvent>(this._destroy),\n                    throttle(() => interval(0, animationFrameScheduler)),\n                )\n                .subscribe((res) => this.onMousemove(res));\n\n            fromEvent(this.document.defaultView, 'mouseup')\n                .pipe(takeUntil<MouseEvent>(this._destroy))\n                .subscribe((res) => this.onMouseup(res));\n        });\n    }\n\n    public ngOnDestroy() {\n        this._destroy.next(true);\n        this._destroy.complete();\n    }\n\n    public set left(val: number) {\n        requestAnimationFrame(() => this.element.nativeElement.style.left = val + 'px');\n    }\n\n    public set top(val: number) {\n        if (this.restrictResizerTop != undefined) {\n            requestAnimationFrame(() => this.element.nativeElement.style.top = this.restrictResizerTop + 'px');\n        } else {\n            requestAnimationFrame(() => this.element.nativeElement.style.top = val + 'px');\n        }\n    }\n\n    public onMouseup(event: MouseEvent) {\n        this.resizeEnd.next(event);\n        this.resizeEnd.complete();\n    }\n\n    public onMousedown(event: MouseEvent) {\n        event.preventDefault();\n        const parent = this.element.nativeElement.parentElement.parentElement;\n        const parentRectWidth = parent.getBoundingClientRect().width;\n        const parentComputedWidth = parseFloat(window.getComputedStyle(parent).width);\n        if (Math.abs(parentRectWidth - parentComputedWidth) > 1) {\n            this._ratio = parentRectWidth / parentComputedWidth;\n        }\n        this.left = this._left = (event.clientX - parent.getBoundingClientRect().left) / this._ratio;\n        this.top = (event.target as HTMLElement).getBoundingClientRect().top - parent.getBoundingClientRect().top;\n\n        this.resizeStart.next(event);\n    }\n\n    public onMousemove(event: MouseEvent) {\n        event.preventDefault();\n        this.resize.next(event);\n    }\n}\n"]}
@@ -20,7 +20,7 @@ export class IgxColumnResizingService {
20
20
  * @hidden
21
21
  */
22
22
  getColumnHeaderRenderedWidth() {
23
- return this.column.headerCell.nativeElement.getBoundingClientRect().width;
23
+ return parseFloat(window.getComputedStyle(this.column.headerCell.nativeElement).width);
24
24
  }
25
25
  /**
26
26
  * @hidden
@@ -76,9 +76,9 @@ export class IgxColumnResizingService {
76
76
  /**
77
77
  * Resizes the column regaridng to the column minWidth and maxWidth.
78
78
  */
79
- resizeColumn(event) {
79
+ resizeColumn(event, ratio = 1) {
80
80
  this.showResizer = false;
81
- const diff = event.clientX - this.startResizePos;
81
+ const diff = (event.clientX - this.startResizePos) / ratio;
82
82
  const colWidth = this.column.width;
83
83
  const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;
84
84
  let currentColWidth = parseFloat(colWidth);
@@ -201,4 +201,4 @@ export class IgxColumnResizingService {
201
201
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxColumnResizingService, decorators: [{
202
202
  type: Injectable
203
203
  }], ctorParameters: () => [{ type: i0.NgZone }] });
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizing.service.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/resizing/resizing.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { ColumnType } from '../common/grid.interface';\n\n/**\n * @hidden\n * @internal\n */\n@Injectable()\nexport class IgxColumnResizingService {\n\n    /**\n     * @hidden\n     */\n    public startResizePos: number;\n    /**\n     * Indicates that a column is currently being resized.\n     */\n    public isColumnResizing: boolean;\n    /**\n     * @hidden\n     */\n    public resizeCursor = 'col-resize';\n    /**\n     * @hidden\n     */\n     public showResizer = false;\n    /**\n     * The column being resized.\n     */\n    public column: ColumnType;\n\n    constructor(private zone: NgZone) { }\n\n    /**\n     * @hidden\n     */\n    public getColumnHeaderRenderedWidth() {\n        return this.column.headerCell.nativeElement.getBoundingClientRect().width;\n    }\n\n    /**\n     * @hidden\n     */\n    public get resizerHeight(): number {\n        let height = this.column.grid.getVisibleContentHeight();\n\n        // Column height multiplier in case there are Column Layouts. The resizer height need to take into account rowStart.\n        let columnHeightMultiplier = 1;\n        if (this.column.columnLayoutChild) {\n            columnHeightMultiplier = this.column.grid.multiRowLayoutRowSize - this.column.rowStart + 1;\n        }\n\n        if (this.column.level !== 0) {\n            height -= this.column.topLevelParent.headerGroup.height - this.column.headerGroup.height * columnHeightMultiplier;\n        }\n\n        return height;\n    }\n\n    /**\n     * Returns the minimal possible width to which the column can be resized.\n     */\n    public get restrictResizeMin(): number {\n        const actualWidth = this.getColumnHeaderRenderedWidth();\n        const minWidth = this.column.minWidthPx < actualWidth ? this.column.minWidthPx : actualWidth;\n\n        return actualWidth - minWidth;\n    }\n\n    /**\n     * Returns the maximal possible width to which the column can be resized.\n     */\n    public get restrictResizeMax(): number {\n        const actualWidth = this.getColumnHeaderRenderedWidth();\n        const maxWidth = this.column.maxWidthPx;\n        if (this.column.maxWidth) {\n            return maxWidth - actualWidth;\n        } else {\n            return Number.MAX_SAFE_INTEGER;\n        }\n    }\n\n    /**\n     * Autosizes the column to the longest currently visible cell value, including the header cell.\n     * If the column has a predifined maxWidth and the autosized column width will become bigger than it,\n     * then the column is sized to its maxWidth.\n     */\n    public autosizeColumnOnDblClick() {\n        const currentColWidth = this.getColumnHeaderRenderedWidth();\n        this.column.width = this.column.getAutoSize();\n\n        this.zone.run(() => { });\n\n        this.column.grid.columnResized.emit({\n            column: this.column,\n            prevWidth: currentColWidth.toString(),\n            newWidth: this.column.width\n        });\n    }\n\n    /**\n     * Resizes the column regaridng to the column minWidth and maxWidth.\n     */\n    public resizeColumn(event: MouseEvent) {\n        this.showResizer = false;\n        const diff = event.clientX - this.startResizePos;\n\n        const colWidth = this.column.width;\n        const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;\n        let currentColWidth = parseFloat(colWidth);\n        const actualWidth = this.getColumnHeaderRenderedWidth();\n        currentColWidth = Number.isNaN(currentColWidth) ? parseFloat(actualWidth as any) : currentColWidth;\n\n        if (this.column.grid.hasColumnLayouts) {\n            this.resizeColumnLayoutFor(this.column, diff);\n        } else if (isPercentageWidth) {\n            this._handlePercentageResize(diff, this.column);\n        } else {\n            this._handlePixelResize(diff, this.column);\n        }\n\n\n        this.zone.run(() => { });\n\n        if (currentColWidth !== parseFloat(this.column.width)) {\n            this.column.grid.columnResized.emit({\n                column: this.column,\n                prevWidth: isPercentageWidth ? currentColWidth + '%' : currentColWidth + 'px',\n                newWidth: this.column.width\n            });\n        }\n\n        this.isColumnResizing = false;\n    }\n\n    protected _handlePixelResize(diff: number, column: ColumnType) {\n        const currentColWidth = parseFloat(column.width);\n        const colMinWidth = column.minWidthPx;\n        const colMaxWidth = column.maxWidthPx;\n        if (currentColWidth + diff < colMinWidth) {\n            column.width = colMinWidth + 'px';\n        } else if (colMaxWidth && (currentColWidth + diff > colMaxWidth)) {\n            column.width = colMaxWidth + 'px';\n        } else {\n            column.width = (currentColWidth + diff) + 'px';\n        }\n    }\n\n    protected _handlePercentageResize(diff: number, column: ColumnType) {\n        const currentPercentWidth = parseFloat(column.width);\n        const gridAvailableSize = column.grid.calcWidth;\n\n        const diffPercentage = (diff / gridAvailableSize) * 100;\n        const colMinWidth = column.minWidthPercent;\n        const colMaxWidth = column.maxWidthPercent;\n\n        if (currentPercentWidth + diffPercentage < colMinWidth) {\n            column.width = colMinWidth + '%';\n        } else if (colMaxWidth && (currentPercentWidth + diffPercentage > colMaxWidth)) {\n            column.width = colMaxWidth + '%';\n        } else {\n            column.width = (currentPercentWidth + diffPercentage) + '%';\n        }\n    }\n\n    protected getColMinWidth(column: ColumnType) {\n        let currentColWidth = parseFloat(column.width);\n        const actualWidth = column.headerCell.nativeElement.getBoundingClientRect().width;\n        currentColWidth = Number.isNaN(currentColWidth) || (currentColWidth < actualWidth) ? actualWidth : currentColWidth;\n\n        const actualMinWidth = parseFloat(column.minWidth);\n        return actualMinWidth < currentColWidth ? actualMinWidth : currentColWidth;\n    }\n\n    protected resizeColumnLayoutFor(column: ColumnType, diff: number) {\n        const relativeColumns = column.getResizableColUnderEnd();\n        const combinedSpan = relativeColumns.reduce((acc, col) => acc + col.spanUsed, 0);\n\n        // Resize first those who might reach min/max width\n        let columnsToResize = [...relativeColumns];\n        let updatedDiff = diff;\n        let updatedCombinedSpan = combinedSpan;\n        let setMinMaxCols = false;\n        do {\n            // Cycle them until there are not ones that reach min/max size, because the diff accumulates after each cycle.\n            // This is because we can have at first 2 cols reaching min width and then after\n            // recalculating the diff there might be 1 more that reaches min width.\n            setMinMaxCols = false;\n            let newCombinedSpan = updatedCombinedSpan;\n            const newColsToResize = [];\n            columnsToResize.forEach((col) => {\n                const currentResizeWidth = parseFloat(col.target.calcWidth);\n                const resizeScaled = (diff / updatedCombinedSpan) * col.target.gridColumnSpan;\n                const colWidth = col.target.width;\n                const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;\n\n                const minWidth = col.target.minWidthPx;\n                const maxWidth = col.target.maxWidthPx;\n                if (currentResizeWidth + resizeScaled < minWidth) {\n                    col.target.width = isPercentageWidth ? col.target.minWidthPercent + '%' : minWidth + 'px';\n                    updatedDiff += (currentResizeWidth - minWidth);\n                    newCombinedSpan -= col.spanUsed;\n                    setMinMaxCols = true;\n                } else if (maxWidth && (currentResizeWidth + resizeScaled > maxWidth)) {\n                    col.target.width = isPercentageWidth ? col.target.maxWidthPercent + '%' : col.target.maxWidthPx + 'px';\n                    updatedDiff -= (maxWidth - currentResizeWidth);\n                    newCombinedSpan -= col.spanUsed;\n                    setMinMaxCols = true;\n                } else {\n                    // Save new ones that can be resized\n                    newColsToResize.push(col);\n                }\n            });\n\n            updatedCombinedSpan = newCombinedSpan;\n            columnsToResize = newColsToResize;\n        } while (setMinMaxCols);\n\n        // Those left that don't reach min/max size resize them normally.\n        columnsToResize.forEach((col) => {\n            const resizeScaled = (updatedDiff / updatedCombinedSpan) * col.target.gridColumnSpan;\n            const colWidth = col.target.width;\n            const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;\n            if (isPercentageWidth) {\n                this._handlePercentageResize(resizeScaled, col.target);\n            } else {\n                this._handlePixelResize(resizeScaled, col.target);\n            }\n        });\n    }\n}\n"]}
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizing.service.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/resizing/resizing.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { ColumnType } from '../common/grid.interface';\n\n/**\n * @hidden\n * @internal\n */\n@Injectable()\nexport class IgxColumnResizingService {\n\n    /**\n     * @hidden\n     */\n    public startResizePos: number;\n    /**\n     * Indicates that a column is currently being resized.\n     */\n    public isColumnResizing: boolean;\n    /**\n     * @hidden\n     */\n    public resizeCursor = 'col-resize';\n    /**\n     * @hidden\n     */\n     public showResizer = false;\n    /**\n     * The column being resized.\n     */\n    public column: ColumnType;\n\n    constructor(private zone: NgZone) { }\n\n    /**\n     * @hidden\n     */\n    public getColumnHeaderRenderedWidth() {\n        return parseFloat(window.getComputedStyle(this.column.headerCell.nativeElement).width);\n    }\n\n    /**\n     * @hidden\n     */\n    public get resizerHeight(): number {\n        let height = this.column.grid.getVisibleContentHeight();\n\n        // Column height multiplier in case there are Column Layouts. The resizer height need to take into account rowStart.\n        let columnHeightMultiplier = 1;\n        if (this.column.columnLayoutChild) {\n            columnHeightMultiplier = this.column.grid.multiRowLayoutRowSize - this.column.rowStart + 1;\n        }\n\n        if (this.column.level !== 0) {\n            height -= this.column.topLevelParent.headerGroup.height - this.column.headerGroup.height * columnHeightMultiplier;\n        }\n\n        return height;\n    }\n\n    /**\n     * Returns the minimal possible width to which the column can be resized.\n     */\n    public get restrictResizeMin(): number {\n        const actualWidth = this.getColumnHeaderRenderedWidth();\n        const minWidth = this.column.minWidthPx < actualWidth ? this.column.minWidthPx : actualWidth;\n\n        return actualWidth - minWidth;\n    }\n\n    /**\n     * Returns the maximal possible width to which the column can be resized.\n     */\n    public get restrictResizeMax(): number {\n        const actualWidth = this.getColumnHeaderRenderedWidth();\n        const maxWidth = this.column.maxWidthPx;\n        if (this.column.maxWidth) {\n            return maxWidth - actualWidth;\n        } else {\n            return Number.MAX_SAFE_INTEGER;\n        }\n    }\n\n    /**\n     * Autosizes the column to the longest currently visible cell value, including the header cell.\n     * If the column has a predifined maxWidth and the autosized column width will become bigger than it,\n     * then the column is sized to its maxWidth.\n     */\n    public autosizeColumnOnDblClick() {\n        const currentColWidth = this.getColumnHeaderRenderedWidth();\n        this.column.width = this.column.getAutoSize();\n\n        this.zone.run(() => { });\n\n        this.column.grid.columnResized.emit({\n            column: this.column,\n            prevWidth: currentColWidth.toString(),\n            newWidth: this.column.width\n        });\n    }\n\n    /**\n     * Resizes the column regaridng to the column minWidth and maxWidth.\n     */\n    public resizeColumn(event: MouseEvent, ratio: number = 1) {\n        this.showResizer = false;\n        const diff = (event.clientX - this.startResizePos) / ratio;\n\n        const colWidth = this.column.width;\n        const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;\n        let currentColWidth = parseFloat(colWidth);\n        const actualWidth = this.getColumnHeaderRenderedWidth();\n        currentColWidth = Number.isNaN(currentColWidth) ? parseFloat(actualWidth as any) : currentColWidth;\n\n        if (this.column.grid.hasColumnLayouts) {\n            this.resizeColumnLayoutFor(this.column, diff);\n        } else if (isPercentageWidth) {\n            this._handlePercentageResize(diff, this.column);\n        } else {\n            this._handlePixelResize(diff, this.column);\n        }\n\n\n        this.zone.run(() => { });\n\n        if (currentColWidth !== parseFloat(this.column.width)) {\n            this.column.grid.columnResized.emit({\n                column: this.column,\n                prevWidth: isPercentageWidth ? currentColWidth + '%' : currentColWidth + 'px',\n                newWidth: this.column.width\n            });\n        }\n\n        this.isColumnResizing = false;\n    }\n\n    protected _handlePixelResize(diff: number, column: ColumnType) {\n        const currentColWidth = parseFloat(column.width);\n        const colMinWidth = column.minWidthPx;\n        const colMaxWidth = column.maxWidthPx;\n        if (currentColWidth + diff < colMinWidth) {\n            column.width = colMinWidth + 'px';\n        } else if (colMaxWidth && (currentColWidth + diff > colMaxWidth)) {\n            column.width = colMaxWidth + 'px';\n        } else {\n            column.width = (currentColWidth + diff) + 'px';\n        }\n    }\n\n    protected _handlePercentageResize(diff: number, column: ColumnType) {\n        const currentPercentWidth = parseFloat(column.width);\n        const gridAvailableSize = column.grid.calcWidth;\n\n        const diffPercentage = (diff / gridAvailableSize) * 100;\n        const colMinWidth = column.minWidthPercent;\n        const colMaxWidth = column.maxWidthPercent;\n\n        if (currentPercentWidth + diffPercentage < colMinWidth) {\n            column.width = colMinWidth + '%';\n        } else if (colMaxWidth && (currentPercentWidth + diffPercentage > colMaxWidth)) {\n            column.width = colMaxWidth + '%';\n        } else {\n            column.width = (currentPercentWidth + diffPercentage) + '%';\n        }\n    }\n\n    protected getColMinWidth(column: ColumnType) {\n        let currentColWidth = parseFloat(column.width);\n        const actualWidth = column.headerCell.nativeElement.getBoundingClientRect().width;\n        currentColWidth = Number.isNaN(currentColWidth) || (currentColWidth < actualWidth) ? actualWidth : currentColWidth;\n\n        const actualMinWidth = parseFloat(column.minWidth);\n        return actualMinWidth < currentColWidth ? actualMinWidth : currentColWidth;\n    }\n\n    protected resizeColumnLayoutFor(column: ColumnType, diff: number) {\n        const relativeColumns = column.getResizableColUnderEnd();\n        const combinedSpan = relativeColumns.reduce((acc, col) => acc + col.spanUsed, 0);\n\n        // Resize first those who might reach min/max width\n        let columnsToResize = [...relativeColumns];\n        let updatedDiff = diff;\n        let updatedCombinedSpan = combinedSpan;\n        let setMinMaxCols = false;\n        do {\n            // Cycle them until there are not ones that reach min/max size, because the diff accumulates after each cycle.\n            // This is because we can have at first 2 cols reaching min width and then after\n            // recalculating the diff there might be 1 more that reaches min width.\n            setMinMaxCols = false;\n            let newCombinedSpan = updatedCombinedSpan;\n            const newColsToResize = [];\n            columnsToResize.forEach((col) => {\n                const currentResizeWidth = parseFloat(col.target.calcWidth);\n                const resizeScaled = (diff / updatedCombinedSpan) * col.target.gridColumnSpan;\n                const colWidth = col.target.width;\n                const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;\n\n                const minWidth = col.target.minWidthPx;\n                const maxWidth = col.target.maxWidthPx;\n                if (currentResizeWidth + resizeScaled < minWidth) {\n                    col.target.width = isPercentageWidth ? col.target.minWidthPercent + '%' : minWidth + 'px';\n                    updatedDiff += (currentResizeWidth - minWidth);\n                    newCombinedSpan -= col.spanUsed;\n                    setMinMaxCols = true;\n                } else if (maxWidth && (currentResizeWidth + resizeScaled > maxWidth)) {\n                    col.target.width = isPercentageWidth ? col.target.maxWidthPercent + '%' : col.target.maxWidthPx + 'px';\n                    updatedDiff -= (maxWidth - currentResizeWidth);\n                    newCombinedSpan -= col.spanUsed;\n                    setMinMaxCols = true;\n                } else {\n                    // Save new ones that can be resized\n                    newColsToResize.push(col);\n                }\n            });\n\n            updatedCombinedSpan = newCombinedSpan;\n            columnsToResize = newColsToResize;\n        } while (setMinMaxCols);\n\n        // Those left that don't reach min/max size resize them normally.\n        columnsToResize.forEach((col) => {\n            const resizeScaled = (updatedDiff / updatedCombinedSpan) * col.target.gridColumnSpan;\n            const colWidth = col.target.width;\n            const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;\n            if (isPercentageWidth) {\n                this._handlePercentageResize(resizeScaled, col.target);\n            } else {\n                this._handlePixelResize(resizeScaled, col.target);\n            }\n        });\n    }\n}\n"]}
@@ -44743,7 +44743,10 @@ class IgxColumnComponent {
44743
44743
  const colWidth = this.width;
44744
44744
  const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;
44745
44745
  const isAutoWidth = colWidth && typeof colWidth === 'string' && colWidth === 'fit-content';
44746
- if (isPercentageWidth) {
44746
+ if (isPercentageWidth && this.grid.isColumnWidthSum) {
44747
+ this._calcWidth = this.grid.minColumnWidth;
44748
+ }
44749
+ else if (isPercentageWidth) {
44747
44750
  this._calcWidth = Math.floor(parseFloat(colWidth) / 100 * this.grid.calcWidth);
44748
44751
  }
44749
44752
  else if (!colWidth || isAutoWidth && !this.autoSize) {
@@ -49462,8 +49465,8 @@ const GridResourceStringsEN = {
49462
49465
  igx_grid_excel_custom_dialog_add: 'add filter',
49463
49466
  igx_grid_excel_custom_dialog_clear: 'Clear filter',
49464
49467
  igx_grid_excel_custom_dialog_header: 'Custom auto-filter on column: ',
49465
- igx_grid_excel_cancel: 'cancel',
49466
- igx_grid_excel_apply: 'apply',
49468
+ igx_grid_excel_cancel: 'Cancel',
49469
+ igx_grid_excel_apply: 'Apply',
49467
49470
  igx_grid_excel_search_placeholder: 'Search',
49468
49471
  igx_grid_excel_select_all: 'Select All',
49469
49472
  igx_grid_excel_select_all_search_results: 'Select all search results',
@@ -50087,6 +50090,7 @@ class IgxExcelStyleCustomDialogComponent {
50087
50090
  }
50088
50091
  onClearButtonClick() {
50089
50092
  this.filteringService.clearFilter(this.column.field);
50093
+ this.selectedOperator = null;
50090
50094
  this.createInitialExpressionUIElement();
50091
50095
  this.cdr.detectChanges();
50092
50096
  }
@@ -55079,7 +55083,8 @@ class IgxGridExcelStyleFilteringComponent extends BaseFilteringComponent {
55079
55083
  this.filterValues = this.generateFilterValues();
55080
55084
  this.generateListData();
55081
55085
  this.expressionsList.forEach(expr => {
55082
- if (this.column.dataType === GridColumnDataType.String && this.column.filteringIgnoreCase && expr.expression.searchVal) {
55086
+ if (this.column.dataType === GridColumnDataType.String && this.column.filteringIgnoreCase
55087
+ && expr.expression.searchVal && expr.expression.searchVal instanceof Set) {
55083
55088
  this.modifyExpression(expr);
55084
55089
  }
55085
55090
  });
@@ -55984,7 +55989,7 @@ class IgxColumnResizingService {
55984
55989
  * @hidden
55985
55990
  */
55986
55991
  getColumnHeaderRenderedWidth() {
55987
- return this.column.headerCell.nativeElement.getBoundingClientRect().width;
55992
+ return parseFloat(window.getComputedStyle(this.column.headerCell.nativeElement).width);
55988
55993
  }
55989
55994
  /**
55990
55995
  * @hidden
@@ -56040,9 +56045,9 @@ class IgxColumnResizingService {
56040
56045
  /**
56041
56046
  * Resizes the column regaridng to the column minWidth and maxWidth.
56042
56047
  */
56043
- resizeColumn(event) {
56048
+ resizeColumn(event, ratio = 1) {
56044
56049
  this.showResizer = false;
56045
- const diff = event.clientX - this.startResizePos;
56050
+ const diff = (event.clientX - this.startResizePos) / ratio;
56046
56051
  const colWidth = this.column.width;
56047
56052
  const isPercentageWidth = colWidth && typeof colWidth === 'string' && colWidth.indexOf('%') !== -1;
56048
56053
  let currentColWidth = parseFloat(colWidth);
@@ -60356,6 +60361,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
60356
60361
  * @internal
60357
60362
  */
60358
60363
  class IgxColumnResizerDirective {
60364
+ get ratio() {
60365
+ return this._ratio;
60366
+ }
60359
60367
  constructor(element, document, zone) {
60360
60368
  this.element = element;
60361
60369
  this.document = document;
@@ -60366,9 +60374,10 @@ class IgxColumnResizerDirective {
60366
60374
  this.resizeStart = new Subject();
60367
60375
  // eslint-disable-next-line @angular-eslint/no-output-native
60368
60376
  this.resize = new Subject();
60377
+ this._ratio = 1;
60369
60378
  this._destroy = new Subject();
60370
60379
  this.resizeStart.pipe(takeUntil(this._destroy), map((event) => event.clientX), switchMap((offset) => this.resize
60371
- .pipe(takeUntil(this._destroy), takeUntil(this.resizeEnd), map((event) => event.clientX - offset))))
60380
+ .pipe(takeUntil(this._destroy), takeUntil(this.resizeEnd), map((event) => (event.clientX - offset) / (this._ratio)))))
60372
60381
  .subscribe((pos) => {
60373
60382
  const left = this._left + pos;
60374
60383
  const min = this._left - this.restrictHResizeMin;
@@ -60411,7 +60420,12 @@ class IgxColumnResizerDirective {
60411
60420
  onMousedown(event) {
60412
60421
  event.preventDefault();
60413
60422
  const parent = this.element.nativeElement.parentElement.parentElement;
60414
- this.left = this._left = event.clientX - parent.getBoundingClientRect().left;
60423
+ const parentRectWidth = parent.getBoundingClientRect().width;
60424
+ const parentComputedWidth = parseFloat(window.getComputedStyle(parent).width);
60425
+ if (Math.abs(parentRectWidth - parentComputedWidth) > 1) {
60426
+ this._ratio = parentRectWidth / parentComputedWidth;
60427
+ }
60428
+ this.left = this._left = (event.clientX - parent.getBoundingClientRect().left) / this._ratio;
60415
60429
  this.top = event.target.getBoundingClientRect().top - parent.getBoundingClientRect().top;
60416
60430
  this.resizeStart.next(event);
60417
60431
  }
@@ -60450,11 +60464,11 @@ class IgxGridColumnResizerComponent {
60450
60464
  this.colResizingService = colResizingService;
60451
60465
  }
60452
60466
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxGridColumnResizerComponent, deps: [{ token: IgxColumnResizingService }], target: i0.ɵɵFactoryTarget.Component }); }
60453
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxGridColumnResizerComponent, isStandalone: true, selector: "igx-grid-column-resizer", inputs: { restrictResizerTop: "restrictResizerTop" }, viewQueries: [{ propertyName: "resizer", first: true, predicate: IgxColumnResizerDirective, descendants: true, static: true }], ngImport: i0, template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event)\">\n</div>\n", dependencies: [{ kind: "directive", type: IgxColumnResizerDirective, selector: "[igxResizer]", inputs: ["restrictHResizeMin", "restrictHResizeMax", "restrictResizerTop"], outputs: ["resizeEnd", "resizeStart", "resize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
60467
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxGridColumnResizerComponent, isStandalone: true, selector: "igx-grid-column-resizer", inputs: { restrictResizerTop: "restrictResizerTop" }, viewQueries: [{ propertyName: "resizer", first: true, predicate: IgxColumnResizerDirective, descendants: true, static: true }], ngImport: i0, template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event, resizer.ratio)\">\n</div>\n", dependencies: [{ kind: "directive", type: IgxColumnResizerDirective, selector: "[igxResizer]", inputs: ["restrictHResizeMin", "restrictHResizeMax", "restrictResizerTop"], outputs: ["resizeEnd", "resizeStart", "resize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
60454
60468
  }
60455
60469
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxGridColumnResizerComponent, decorators: [{
60456
60470
  type: Component,
60457
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-grid-column-resizer', standalone: true, imports: [IgxColumnResizerDirective], template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event)\">\n</div>\n" }]
60471
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-grid-column-resizer', standalone: true, imports: [IgxColumnResizerDirective], template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event, resizer.ratio)\">\n</div>\n" }]
60458
60472
  }], ctorParameters: () => [{ type: IgxColumnResizingService }], propDecorators: { restrictResizerTop: [{
60459
60473
  type: Input
60460
60474
  }], resizer: [{
@@ -64165,6 +64179,10 @@ class IgxGridBaseDirective {
64165
64179
  * @hidden @internal
64166
64180
  */
64167
64181
  this.filteringPipeTrigger = 0;
64182
+ /**
64183
+ * @hidden @internal
64184
+ */
64185
+ this.isColumnWidthSum = false;
64168
64186
  /**
64169
64187
  * @hidden @internal
64170
64188
  */
@@ -64293,7 +64311,6 @@ class IgxGridBaseDirective {
64293
64311
  this._rowSelectionMode = GridSelectionMode.none;
64294
64312
  this._selectRowOnClick = true;
64295
64313
  this._columnSelectionMode = GridSelectionMode.none;
64296
- this.isColumnWidthSum = false;
64297
64314
  this.rowEditPositioningStrategy = new RowEditPositionStrategy({
64298
64315
  horizontalDirection: HorizontalAlignment.Right,
64299
64316
  verticalDirection: VerticalAlignment.Bottom,
@@ -67106,8 +67123,11 @@ class IgxGridBaseDirective {
67106
67123
  width = this.nativeElement.offsetWidth;
67107
67124
  }
67108
67125
  if (this.width === null || !width) {
67109
- width = this.getColumnWidthSum();
67110
67126
  this.isColumnWidthSum = true;
67127
+ width = this.getColumnWidthSum();
67128
+ }
67129
+ else {
67130
+ this.isColumnWidthSum = false;
67111
67131
  }
67112
67132
  if (this.hasVerticalScroll() && this.width !== null) {
67113
67133
  width -= this.scrollSize;
@@ -74641,11 +74661,11 @@ class IgxPivotGridColumnResizerComponent extends IgxGridColumnResizerComponent {
74641
74661
  this.colResizingService = colResizingService;
74642
74662
  }
74643
74663
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxPivotGridColumnResizerComponent, deps: [{ token: IgxPivotColumnResizingService }], target: i0.ɵɵFactoryTarget.Component }); }
74644
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxPivotGridColumnResizerComponent, isStandalone: true, selector: "igx-pivot-grid-column-resizer", usesInheritance: true, ngImport: i0, template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event)\">\n</div>\n", dependencies: [{ kind: "directive", type: IgxColumnResizerDirective, selector: "[igxResizer]", inputs: ["restrictHResizeMin", "restrictHResizeMax", "restrictResizerTop"], outputs: ["resizeEnd", "resizeStart", "resize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
74664
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxPivotGridColumnResizerComponent, isStandalone: true, selector: "igx-pivot-grid-column-resizer", usesInheritance: true, ngImport: i0, template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event, resizer.ratio)\">\n</div>\n", dependencies: [{ kind: "directive", type: IgxColumnResizerDirective, selector: "[igxResizer]", inputs: ["restrictHResizeMin", "restrictHResizeMax", "restrictResizerTop"], outputs: ["resizeEnd", "resizeStart", "resize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
74645
74665
  }
74646
74666
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxPivotGridColumnResizerComponent, decorators: [{
74647
74667
  type: Component,
74648
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-pivot-grid-column-resizer', standalone: true, imports: [IgxColumnResizerDirective], template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event)\">\n</div>\n" }]
74668
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-pivot-grid-column-resizer', standalone: true, imports: [IgxColumnResizerDirective], template: "<div class=\"igx-grid-th__resize-line\"\n [style.left.px]=\"-99999\" igxResizer\n [style.height.px]=\"colResizingService.resizerHeight\"\n [restrictHResizeMax]=\"colResizingService.restrictResizeMax\"\n [restrictHResizeMin]=\"colResizingService.restrictResizeMin\"\n [restrictResizerTop]=\"restrictResizerTop\"\n (resizeEnd)=\"colResizingService.resizeColumn($event, resizer.ratio)\">\n</div>\n" }]
74649
74669
  }], ctorParameters: () => [{ type: IgxPivotColumnResizingService }] });
74650
74670
 
74651
74671
  class DefaultPivotGridRecordSortingStrategy extends DefaultSortingStrategy {
@@ -83435,6 +83455,7 @@ class IgxHierarchicalGridBaseDirective extends IgxGridBaseDirective {
83435
83455
  const columns = [];
83436
83456
  const topLevelCols = cols.filter(c => c.level === 0);
83437
83457
  topLevelCols.forEach((col) => {
83458
+ col.grid = this;
83438
83459
  const ref = this._createColumn(col);
83439
83460
  ref.changeDetectorRef.detectChanges();
83440
83461
  columns.push(ref.instance);