diff --git a/src/app/components/table/table.ts b/src/app/components/table/table.ts index cb7b0610d56..ae589055d50 100644 --- a/src/app/components/table/table.ts +++ b/src/app/components/table/table.ts @@ -5326,6 +5326,8 @@ export class ColumnFilter implements AfterContentInit { overlayId: any; + applyHasBeenClicked: boolean = false; + get fieldConstraints(): FilterMetadata[] | undefined | null { return this.dt.filters ? this.dt.filters[this.field] : null; } @@ -5572,6 +5574,10 @@ export class ColumnFilter implements AfterContentInit { } onEscape() { + if (this.hasFilterNotBeenApplied()) { + this.clearFilter(); + } + this.applyHasBeenClicked = false; this.overlayVisible = false; this.icon?.nativeElement.focus(); } @@ -5672,6 +5678,10 @@ export class ColumnFilter implements AfterContentInit { return false; } + hasFilterNotBeenApplied(): boolean { + return this.hasFilter() && !this.applyHasBeenClicked; + } + isOutsideClicked(event: any): boolean { return !( DomHandler.hasClass(this.overlay?.nextElementSibling, 'p-overlay') || @@ -5746,6 +5756,10 @@ export class ColumnFilter implements AfterContentInit { } hide() { + if (this.hasFilterNotBeenApplied()) { + this.clearFilter(); + } + this.applyHasBeenClicked = false; this.overlayVisible = false; this.cd.markForCheck(); } @@ -5758,12 +5772,14 @@ export class ColumnFilter implements AfterContentInit { } clearFilter() { + this.applyHasBeenClicked = false; this.initFieldFilterConstraint(); this.dt._filter(); if (this.hideOnClear) this.hide(); } applyFilter() { + this.applyHasBeenClicked = true; this.dt._filter(); this.hide(); }