X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/547664ecb6ac881103fb9e94a51b2a2746b2c6ae..2a7fd99c212c33a1ec9911f8529fa5afc59a7bb2:/src/services/api/filter-builder.ts diff --git a/src/services/api/filter-builder.ts b/src/services/api/filter-builder.ts index d1a4fd08b6..bb97665a8c 100644 --- a/src/services/api/filter-builder.ts +++ b/src/services/api/filter-builder.ts @@ -9,7 +9,7 @@ export function joinFilters(...filters: string[]) { export class FilterBuilder { constructor(private filters = "") { } - public addEqual(field: string, value?: string | boolean | null, resourcePrefix?: string) { + public addEqual(field: string, value?: string | string[] | boolean | null, resourcePrefix?: string) { return this.addCondition(field, "=", value, "", "", resourcePrefix); } @@ -64,11 +64,27 @@ export class FilterBuilder { return this.addCondition("properties." + field, "exists", false, "", "", resourcePrefix); } - public addFullTextSearch(value: string) { - const terms = value.trim().split(/(\s+)/); + public addFullTextSearch(value: string, table?: string) { + const regex = /"[^"]*"/; + const matches: any[] = []; + + let match = value.match(regex); + + while (match) { + value = value.replace(match[0], ""); + matches.push(match[0].replace(/"/g, '')); + match = value.match(regex); + } + + let searchIn = 'any'; + if (table) { + searchIn = table + ".any"; + } + + const terms = value.trim().split(/(\s+)/).concat(matches); terms.forEach(term => { if (term !== " ") { - this.addCondition("any", "ilike", term, "%", "%"); + this.addCondition(searchIn, "ilike", term, "%", "%"); } }); return this;