Add debounce to pg parameters search filter (#14140)

* Add debounce to pg parameters search filter

* Update tsconfig
This commit is contained in:
Charles Gagnon
2021-02-02 16:15:31 -08:00
committed by GitHub
parent 661e7c361d
commit 86a5cb27b7
3 changed files with 45 additions and 6 deletions

View File

@@ -295,3 +295,35 @@ export async function tryExecuteAction<T>(action: () => T | PromiseLike<T>): Pro
}
return { result, error };
}
function decorate(decorator: (fn: Function, key: string) => Function): Function {
return (_target: any, key: string, descriptor: any) => {
let fnKey: string | null = null;
let fn: Function | null = null;
if (typeof descriptor.value === 'function') {
fnKey = 'value';
fn = descriptor.value;
} else if (typeof descriptor.get === 'function') {
fnKey = 'get';
fn = descriptor.get;
}
if (!fn || !fnKey) {
throw new Error('not supported');
}
descriptor[fnKey] = decorator(fn, key);
};
}
export function debounce(delay: number): Function {
return decorate((fn, key) => {
const timerKey = `$debounce$${key}`;
return function (this: any, ...args: any[]) {
clearTimeout(this[timerKey]);
this[timerKey] = setTimeout(() => fn.apply(this, args), delay);
};
});
}

View File

@@ -11,6 +11,7 @@ import { UserCancelledError } from '../../../common/api';
import { IconPathHelper, cssStyles } from '../../../constants';
import { DashboardPage } from '../../components/dashboardPage';
import { EngineSettingsModel, PostgresModel } from '../../../models/postgresModel';
import { debounce } from '../../../common/utils';
export type ParametersModel = {
parameterName: string,
@@ -358,13 +359,18 @@ export class PostgresParametersPage extends DashboardPage {
this.disposables.push(
this.searchBox.onTextChanged(() => {
this.onSearchFilter();
})
);
}
@debounce(500)
private onSearchFilter(): void {
if (!this.searchBox!.value) {
this.parametersTable.data = this._parameters.map(p => [p.parameterName, p.valueContainer, p.description, p.resetButton]);
} else {
this.filterParameters(this.searchBox!.value);
}
})
);
}
private filterParameters(search: string): void {
@@ -375,7 +381,7 @@ export class PostgresParametersPage extends DashboardPage {
private handleOnTextChanged(component: azdata.InputBoxComponent, currentValue: string | undefined): boolean {
if (!component.valid) {
// If invalid value retun false and enable discard button
// If invalid value return false and enable discard button
this.discardButton!.enabled = true;
return false;
} else if (component.value === currentValue) {

View File

@@ -2,6 +2,7 @@
"extends": "../shared.tsconfig.json",
"compileOnSave": true,
"compilerOptions": {
"experimentalDecorators": true,
"outDir": "./out",
"lib": [
"es6",