UNPKG

angular-odata

Version:

Client side OData typescript library for Angular

118 lines 15.2 kB
import { QueryOption } from '../../../types'; import { Objects, Types } from '../../../utils'; import { Expression } from './base'; import { FilterExpression } from './filter'; import { render, FieldFactory, RenderableFactory, resolve, } from './syntax'; export class CountField { field; values; constructor(field, values = {}) { this.field = field; this.values = values; } get [Symbol.toStringTag]() { return 'CountField'; } toJson() { return { field: this.field.toJson(), }; } render({ aliases, escape, prefix, parser, options, }) { const params = [ QueryOption.filter, QueryOption.search, ] .filter((key) => !Types.isEmpty(this.values[key])) .reduce((acc, key) => { let value = this.values[key]; if (Types.rawType(value).endsWith('Expression')) { value = value.render({ aliases, prefix, escape, parser: resolve([this.field], parser), options, }); } return Object.assign(acc, { [key]: value }); }, {}); let count = `${render(this.field, { aliases, escape, prefix, parser, options, })}/$count`; if (!Types.isEmpty(params)) { count = `${count}(${Object.keys(params) .map((key) => `$${key}=${params[key]}`) .join(';')})`; } return count; } filter(opts) { return this.option(QueryOption.filter, FilterExpression.factory(opts, this.values[QueryOption.filter])); } clone() { const values = Object.keys(this.values).reduce((acc, key) => Object.assign(acc, { [key]: Objects.clone(this.values[key]) }), {}); return new CountField(this.field.clone(), values); } resolve(parser) { return this.field.resolve(parser); } // Option Handler option(name, opts) { if (opts !== undefined) this.values[name] = opts; return this.values[name]; } } export class CountExpression extends Expression { constructor({ children, } = {}) { super({ children }); } get [Symbol.toStringTag]() { return 'CountExpression'; } static factory(opts, current) { return opts({ t: FieldFactory(), e: () => new CountExpression(), }, current); } _add(node) { this._children.push(node); return this; } toJson() { const json = super.toJson(); return Object.assign(json, {}); } static fromJson(json) { return new CountExpression({ children: json['children'].map((c) => RenderableFactory(c)), }); } render({ aliases, escape, prefix, parser, options, } = {}) { let content = this._children .map((n) => n.render({ aliases, escape, prefix, parser, options })) .join(`,`); return content; } clone() { return new CountExpression({ children: this._children.map((c) => c.clone()), }); } field(field, opts) { let countField = new CountField(field); if (opts !== undefined) opts({ t: FieldFactory(), f: countField, }); return this._add(countField); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"count.js","sourceRoot":"","sources":["../../../../../../../projects/angular-odata/src/lib/resources/query/expressions/count.ts"],"names":[],"mappings":"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","sourcesContent":["import { Parser, ParserOptions, QueryOption } from '../../../types';\nimport { Objects, Types } from '../../../utils';\nimport { QueryCustomType } from '../builder';\nimport { Expression } from './base';\nimport { FilterExpression, FilterExpressionBuilder } from './filter';\nimport {\n  render,\n  FieldFactory,\n  Renderable,\n  RenderableFactory,\n  resolve,\n} from './syntax';\n\nexport class CountField<T> implements Renderable {\n  constructor(\n    protected field: any,\n    private values: { [name: string]: any } = {},\n  ) {}\n\n  get [Symbol.toStringTag]() {\n    return 'CountField';\n  }\n\n  toJson() {\n    return {\n      field: this.field.toJson(),\n    };\n  }\n\n  render({\n    aliases,\n    escape,\n    prefix,\n    parser,\n    options,\n  }: {\n    aliases?: QueryCustomType[];\n    escape?: boolean;\n    prefix?: string;\n    parser?: Parser<T>;\n    options?: ParserOptions;\n  }): string {\n    const params: { [name: string]: string } = [\n      QueryOption.filter,\n      QueryOption.search,\n    ]\n      .filter((key) => !Types.isEmpty(this.values[key]))\n      .reduce((acc, key) => {\n        let value: any = this.values[key];\n        if (Types.rawType(value).endsWith('Expression')) {\n          value = (value as Expression<T>).render({\n            aliases,\n            prefix,\n            escape,\n            parser: resolve([this.field], parser),\n            options,\n          });\n        }\n        return Object.assign(acc, { [key]: value });\n      }, {});\n    let count = `${render(this.field, {\n      aliases,\n      escape,\n      prefix,\n      parser,\n      options,\n    })}/$count`;\n    if (!Types.isEmpty(params)) {\n      count = `${count}(${Object.keys(params)\n        .map((key) => `$${key}=${params[key]}`)\n        .join(';')})`;\n    }\n    return count;\n  }\n\n  filter(\n    opts: (\n      builder: FilterExpressionBuilder<T>,\n      current?: FilterExpression<T>,\n    ) => FilterExpression<T>,\n  ) {\n    return this.option(\n      QueryOption.filter,\n      FilterExpression.factory<T>(opts, this.values[QueryOption.filter]),\n    );\n  }\n\n  clone() {\n    const values = Object.keys(this.values).reduce(\n      (acc, key) =>\n        Object.assign(acc, { [key]: Objects.clone(this.values[key]) }),\n      {},\n    );\n    return new CountField<T>(this.field.clone(), values);\n  }\n\n  resolve(parser: any) {\n    return this.field.resolve(parser);\n  }\n\n  // Option Handler\n  private option<O>(name: QueryOption, opts?: O) {\n    if (opts !== undefined) this.values[name] = opts;\n    return this.values[name];\n  }\n}\n\nexport type CountExpressionBuilder<T> = {\n  t: Required<T>;\n  e: () => CountExpression<T>;\n};\nexport class CountExpression<T> extends Expression<T> {\n  constructor({\n    children,\n  }: {\n    children?: Renderable[];\n  } = {}) {\n    super({ children });\n  }\n\n  get [Symbol.toStringTag]() {\n    return 'CountExpression';\n  }\n\n  static factory<T>(\n    opts: (\n      builder: CountExpressionBuilder<T>,\n      current?: CountExpression<T>,\n    ) => CountExpression<T>,\n    current?: CountExpression<T>,\n  ): CountExpression<T> {\n    return opts(\n      {\n        t: FieldFactory<Required<T>>(),\n        e: () => new CountExpression<T>(),\n      },\n      current,\n    ) as CountExpression<T>;\n  }\n\n  private _add(node: Renderable): CountExpression<any> {\n    this._children.push(node);\n    return this;\n  }\n\n  override toJson() {\n    const json = super.toJson();\n    return Object.assign(json, {});\n  }\n\n  static fromJson<T>(json: { [name: string]: any }): CountExpression<T> {\n    return new CountExpression<T>({\n      children: json['children'].map((c: any) => RenderableFactory(c)),\n    });\n  }\n  render({\n    aliases,\n    escape,\n    prefix,\n    parser,\n    options,\n  }: {\n    aliases?: QueryCustomType[];\n    escape?: boolean;\n    prefix?: string;\n    parser?: Parser<T>;\n    options?: ParserOptions;\n  } = {}): string {\n    let content = this._children\n      .map((n) => n.render({ aliases, escape, prefix, parser, options }))\n      .join(`,`);\n    return content;\n  }\n\n  clone() {\n    return new CountExpression<T>({\n      children: this._children.map((c) => c.clone()),\n    });\n  }\n\n  field<F>(\n    field: F[],\n    opts?: (e: { t: F; f: CountField<F> }) => CountExpression<F>,\n  ): CountExpression<F> {\n    let countField = new CountField<F>(field);\n    if (opts !== undefined)\n      opts({\n        t: FieldFactory<Required<F>>(),\n        f: countField,\n      });\n    return this._add(countField);\n  }\n}\n"]}