Skip to content

Commit

Permalink
fix(igxGrid): preventing a potential memory leak #3033
Browse files Browse the repository at this point in the history
  • Loading branch information
PavlovVasil committed Nov 23, 2018
1 parent 86bc910 commit 6d895e7
Showing 1 changed file with 28 additions and 8 deletions.
36 changes: 28 additions & 8 deletions projects/igniteui-angular/src/lib/grids/grid-base.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1988,6 +1988,22 @@ export abstract class IgxGridBaseComponent extends DisplayDensityBase implements
* @hidden
*/
protected _columnPinning = false;
/**
* @hidden
*/
protected __keydownListener = null;
/**
* @hidden
*/
protected __vScrollListener = null;
/**
* @hidden
*/
protected __hScrollListener = null;
/**
* @hidden
*/
protected _wheelListener = null;
protected _allowFiltering = false;
private _filteredData = null;
private resizeHandler;
Expand Down Expand Up @@ -2163,7 +2179,7 @@ export abstract class IgxGridBaseComponent extends DisplayDensityBase implements
public ngAfterViewInit() {
this.zone.runOutsideAngular(() => {
this.document.defaultView.addEventListener('resize', this.resizeHandler);
this.nativeElement.addEventListener('keydown', this.keydownHandler.bind(this));
this.__keydownListener = this.nativeElement.addEventListener('keydown', this.keydownHandler.bind(this));
});
this.calculateGridWidth();
this.initPinning();
Expand Down Expand Up @@ -2209,11 +2225,15 @@ export abstract class IgxGridBaseComponent extends DisplayDensityBase implements
);

this.zone.runOutsideAngular(() =>
this.verticalScrollContainer.getVerticalScroll().addEventListener('scroll', this.verticalScrollHandler.bind(this))
this.__vScrollListener = this.verticalScrollContainer
.getVerticalScroll()
.addEventListener('scroll', this.verticalScrollHandler.bind(this))
);

this.zone.runOutsideAngular(() =>
this.parentVirtDir.getHorizontalScroll().addEventListener('scroll', this.horizontalScrollHandler.bind(this))
this.__hScrollListener = this.parentVirtDir
.getHorizontalScroll()
.addEventListener('scroll', this.horizontalScrollHandler.bind(this))
);
this._horizontalForOfs = this._dataRowList.map(row => row.virtDirRow);
const vertScrDC = this.verticalScrollContainer.dc.instance._viewContainer.element.nativeElement;
Expand All @@ -2226,9 +2246,9 @@ export abstract class IgxGridBaseComponent extends DisplayDensityBase implements
public ngOnDestroy() {
this.zone.runOutsideAngular(() => {
this.document.defaultView.removeEventListener('resize', this.resizeHandler);
this.nativeElement.removeEventListener('keydown', this.keydownHandler);
this.verticalScrollContainer.getVerticalScroll().removeEventListener('scroll', this.verticalScrollHandler);
this.parentVirtDir.getHorizontalScroll().removeEventListener('scroll', this.horizontalScrollHandler);
this.nativeElement.removeEventListener('keydown', this.__keydownListener);
this.verticalScrollContainer.getVerticalScroll().removeEventListener('scroll', this.__vScrollListener);
this.parentVirtDir.getHorizontalScroll().removeEventListener('scroll', this.__hScrollListener);
const vertScrDC = this.verticalScrollContainer.dc.instance._viewContainer.element.nativeElement;
vertScrDC.removeEventListener('scroll', (evt) => { this.scrollHandler(evt); });
});
Expand Down Expand Up @@ -4341,15 +4361,15 @@ export abstract class IgxGridBaseComponent extends DisplayDensityBase implements
this.configureRowEditingOverlay(cell.rowID);
this.rowEditingOverlay.open(this.rowEditSettings);
this.rowEditPositioningStrategy.isTopInitialPosition = this.rowEditPositioningStrategy.isTop;
this.rowEditingOverlay.element.addEventListener('wheel', this.rowEditingWheelHandler.bind(this));
this._wheelListener = this.rowEditingOverlay.element.addEventListener('wheel', this.rowEditingWheelHandler.bind(this));
}

/**
* @hidden
*/
public closeRowEditingOverlay() {
this.gridAPI.set_edit_row_state(this.id, null);
this.rowEditingOverlay.element.removeEventListener('wheel', this.rowEditingWheelHandler);
this.rowEditingOverlay.element.removeEventListener('wheel', this._wheelListener);
this.rowEditPositioningStrategy.isTopInitialPosition = null;
this.rowEditingOverlay.close();
this.rowEditingOverlay.element.parentElement.style.display = '';
Expand Down

0 comments on commit 6d895e7

Please sign in to comment.