X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/e1605f7c93aeb41ae31e0dd88a9afd8709136b62..547664ecb6ac881103fb9e94a51b2a2746b2c6ae:/src/services/api/filter-builder.ts diff --git a/src/services/api/filter-builder.ts b/src/services/api/filter-builder.ts index 4b3db9fa..d1a4fd08 100644 --- a/src/services/api/filter-builder.ts +++ b/src/services/api/filter-builder.ts @@ -2,10 +2,8 @@ // // SPDX-License-Identifier: AGPL-3.0 -import * as _ from "lodash"; - -export function joinFilters(filters0?: string, filters1?: string) { - return [filters0, filters1].filter(s => s).join(","); +export function joinFilters(...filters: string[]) { + return filters.filter(s => s).join(","); } export class FilterBuilder { @@ -15,6 +13,10 @@ export class FilterBuilder { return this.addCondition(field, "=", value, "", "", resourcePrefix); } + public addDistinct(field: string, value?: string | boolean | null, resourcePrefix?: string) { + return this.addCondition(field, "!=", value, "", "", resourcePrefix); + } + public addLike(field: string, value?: string, resourcePrefix?: string) { return this.addCondition(field, "like", value, "%", "%", resourcePrefix); } @@ -23,6 +25,10 @@ export class FilterBuilder { return this.addCondition(field, "ilike", value, "%", "%", resourcePrefix); } + public addContains(field: string, value?: string, resourcePrefix?: string) { + return this.addCondition(field, "contains", value, "", "", resourcePrefix); + } + public addIsA(field: string, value?: string | string[], resourcePrefix?: string) { return this.addCondition(field, "is_a", value, "", "", resourcePrefix); } @@ -54,6 +60,19 @@ export class FilterBuilder { public addExists(value?: string, resourcePrefix?: string) { return this.addCondition("properties", "exists", value, "", "", resourcePrefix); } + public addDoesNotExist(field: string, resourcePrefix?: string) { + return this.addCondition("properties." + field, "exists", false, "", "", resourcePrefix); + } + + public addFullTextSearch(value: string) { + const terms = value.trim().split(/(\s+)/); + terms.forEach(term => { + if (term !== " ") { + this.addCondition("any", "ilike", term, "%", "%"); + } + }); + return this; + } public getFilters() { return this.filters; @@ -73,9 +92,7 @@ export class FilterBuilder { ? resourcePrefix + "." : ""; - const fld = field.indexOf('properties.') < 0 ? _.snakeCase(field) : field; - - this.filters += `${this.filters ? "," : ""}["${resPrefix}${fld}","${cond}",${value}]`; + this.filters += `${this.filters ? "," : ""}["${resPrefix}${field}","${cond}",${value}]`; } return this; }