X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/25dbcc4a5b95924e8a9d1d385ac0fe87f6c658bd..c75bda19a301c0a197dda696208ea10b6459c54a:/src/common/api/filter-builder.ts?ds=sidebyside diff --git a/src/common/api/filter-builder.ts b/src/common/api/filter-builder.ts index 3f8e323c..47772e24 100644 --- a/src/common/api/filter-builder.ts +++ b/src/common/api/filter-builder.ts @@ -2,34 +2,64 @@ // // SPDX-License-Identifier: AGPL-3.0 -export enum FilterField { - UUID = "uuid", - OWNER_UUID = "owner_uuid" -} +import * as _ from "lodash"; +import { Resource } from "./common-resource-service"; -export default class FilterBuilder { - private filters = ""; +export default class FilterBuilder { - private addCondition(field: FilterField, cond: string, value?: string) { - if (value) { - this.filters += `["${field}","${cond}","${value}"]`; - } - return this; + static create(resourcePrefix = "") { + return new FilterBuilder(resourcePrefix); } - public addEqual(field: FilterField, value?: string) { + constructor( + private resourcePrefix = "", + private filters = "") { } + + public addEqual(field: keyof T, value?: string) { return this.addCondition(field, "=", value); } - public addLike(field: FilterField, value?: string) { - return this.addCondition(field, "like", value); + public addLike(field: keyof T, value?: string) { + return this.addCondition(field, "like", value, "%", "%"); + } + + public addILike(field: keyof T, value?: string) { + return this.addCondition(field, "ilike", value, "%", "%"); + } + + public addIsA(field: keyof T, value?: string | string[]) { + return this.addCondition(field, "is_a", value); + } + + public addIn(field: keyof T, value?: string | string[]) { + return this.addCondition(field, "in", value); } - public addILike(field: FilterField, value?: string) { - return this.addCondition(field, "ilike", value); + public concat(filterBuilder: FilterBuilder) { + return new FilterBuilder(this.resourcePrefix, this.filters + (this.filters && filterBuilder.filters ? "," : "") + filterBuilder.getFilters()); } - public get() { + public getFilters() { + return this.filters; + } + + public serialize() { return "[" + this.filters + "]"; } + + private addCondition(field: keyof T, cond: string, value?: string | string[], prefix: string = "", postfix: string = "") { + if (value) { + value = typeof value === "string" + ? `"${prefix}${value}${postfix}"` + : `["${value.join(`","`)}"]`; + + const resourcePrefix = this.resourcePrefix + ? _.snakeCase(this.resourcePrefix) + "." + : ""; + + this.filters += `${this.filters ? "," : ""}["${resourcePrefix}${_.snakeCase(field.toString())}","${cond}",${value}]`; + } + return this; + } + }