UNPKG

angular-odata

Version:

Client side OData typescript library for Angular

149 lines 21.1 kB
import { PATH_SEPARATOR } from '../../constants'; import { PathSegment } from '../../types'; import { Objects } from '../../utils'; import { buildPathAndQuery, raw } from '../query'; import { SegmentHandler } from './handlers'; function pathSegmentsBuilder(segment, escape = false, parser, options) { if (segment.name === PathSegment.function) { let [path, params] = segment.parameters ? buildPathAndQuery({ func: { [segment.path]: segment.parameters }, escape, }) : buildPathAndQuery({ func: segment.path, escape }); if (path.startsWith(PATH_SEPARATOR)) { path = path.slice(1); } // HACK: Remove parenthesis if (path.endsWith('()') && options?.nonParenthesisForEmptyParameterFunction) { path = path.substring(0, path.length - 2); } return [path, params]; } else { //TODO: Parser key let key = segment.key; // HACK: Check guid string if (typeof key === 'string' && /^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$/.test(key)) { key = raw(key); } let [path, params] = key ? buildPathAndQuery({ key, escape }) : ['', {}]; return [segment.path + path, params]; } } export const pathAndParamsFromSegments = (segments, { escape, parser, options, } = {}) => { const result = segments.reduce((acc, segment) => { const [path, params] = pathSegmentsBuilder(segment, escape, parser, options); acc.paths.push(path); acc.params = Object.assign(acc.params, params); return acc; }, { paths: [], params: {} }); return [result.paths.join(PATH_SEPARATOR), result.params]; }; export class ODataPathSegments { _segments; constructor(segments) { this._segments = segments || []; } pathAndParams({ escape, parser, options, } = {}) { return pathAndParamsFromSegments(this._segments, { escape, parser, options, }); } types({ key = false } = {}) { return this.segments({ key }) .map((s) => s.outgoingType()) .filter((t) => t !== undefined); } keys(values) { const segments = this.segments({ key: true }); if (values !== undefined) { segments.forEach((segment, index) => { const key = values[index]; if (key === undefined) { segment.clearKey(); } else { segment.key(key); } }); } return segments.map((s) => s.key()); } toString({ escape } = {}) { const [path, params] = this.pathAndParams({ escape }); return (path + Object.entries(params) .filter(([, value]) => value) .map(([key, value]) => `${key}=${value}`) .join('&')); } toJson() { return this._segments.map((s) => { let json = { name: s.name, path: s.path, }; if (s.incomingType !== undefined) json.incomingType = s.incomingType; if (s.outgoingType !== undefined) json.outgoingType = s.outgoingType; if (s.key !== undefined) json.key = s.key; if (s.parameters !== undefined) json.parameters = s.parameters; return json; }); } static fromJson(json) { return new ODataPathSegments(json.map((s) => ({ name: s.name, path: s.path, type: s.type, key: s.key, parameters: s.parameters, }))); } clone() { const segments = Objects.clone(this._segments); return new ODataPathSegments(segments); } find(predicate) { //Backward Find return [...this._segments].reverse().find(predicate); } segments({ key = false } = {}) { let segments = [...this._segments]; if (key) segments = segments.filter((s) => [ PathSegment.entitySet, PathSegment.navigationProperty, PathSegment.property, ].indexOf(s.name) !== -1); return segments.map((s) => new SegmentHandler(s)); } first({ key = false } = {}) { const segments = this.segments({ key }); return segments.length > 0 ? segments[0] : undefined; } last({ key = false } = {}) { const segments = this.segments({ key }); return segments.length > 0 ? segments[segments.length - 1] : undefined; } add(name, path) { const segment = { name, path }; this._segments.push(segment); return new SegmentHandler(segment); } get(name) { let segment = this.find((s) => s.name === name); if (segment === undefined) throw Error(`No Segment for name ${name} was found`); return new SegmentHandler(segment); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"segments.js","sourceRoot":"","sources":["../../../../../../projects/angular-odata/src/lib/resources/path/segments.ts"],"names":[],"mappings":"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","sourcesContent":["import { PATH_SEPARATOR } from '../../constants';\nimport { Parser, ParserOptions, PathSegment } from '../../types';\nimport { Objects } from '../../utils';\nimport { buildPathAndQuery, raw } from '../query';\nimport { EntityKey } from '../resource';\nimport { SegmentHandler } from './handlers';\n\nexport type ODataSegment = {\n  name: PathSegment;\n  path: string;\n  outgoingType?: string;\n  incomingType?: string;\n  bindingType?: string;\n  key?: any;\n  parameters?: any;\n};\n\nfunction pathSegmentsBuilder(\n  segment: ODataSegment,\n  escape: boolean = false,\n  parser?: Parser<any>,\n  options?: ParserOptions,\n): [string, { [name: string]: any }] {\n  if (segment.name === PathSegment.function) {\n    let [path, params] = segment.parameters\n      ? buildPathAndQuery({\n          func: { [segment.path]: segment.parameters },\n          escape,\n        })\n      : buildPathAndQuery({ func: segment.path, escape });\n    if (path.startsWith(PATH_SEPARATOR)) {\n      path = path.slice(1);\n    }\n    // HACK: Remove parenthesis\n    if (\n      path.endsWith('()') &&\n      options?.nonParenthesisForEmptyParameterFunction\n    ) {\n      path = path.substring(0, path.length - 2);\n    }\n\n    return [path, params];\n  } else {\n    //TODO: Parser key\n    let key = segment.key;\n    // HACK: Check guid string\n    if (\n      typeof key === 'string' &&\n      /^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$/.test(\n        key,\n      )\n    ) {\n      key = raw(key);\n    }\n    let [path, params] = key ? buildPathAndQuery({ key, escape }) : ['', {}];\n    return [segment.path + path, params];\n  }\n}\n\nexport const pathAndParamsFromSegments = (\n  segments: ODataSegment[],\n  {\n    escape,\n    parser,\n    options,\n  }: {\n    escape?: boolean;\n    parser?: Parser<any>;\n    options?: ParserOptions;\n  } = {},\n): [string, { [name: string]: any }] => {\n  const result = segments.reduce(\n    (acc, segment) => {\n      const [path, params] = pathSegmentsBuilder(\n        segment,\n        escape,\n        parser,\n        options,\n      );\n      acc.paths.push(path);\n      acc.params = Object.assign(acc.params, params);\n      return acc;\n    },\n    { paths: [] as string[], params: {} as { [name: string]: any } },\n  );\n  return [result.paths.join(PATH_SEPARATOR), result.params];\n};\n\nexport class ODataPathSegments {\n  private _segments: ODataSegment[];\n\n  constructor(segments?: ODataSegment[]) {\n    this._segments = segments || [];\n  }\n\n  pathAndParams({\n    escape,\n    parser,\n    options,\n  }: {\n    escape?: boolean;\n    parser?: Parser<any>;\n    options?: ParserOptions;\n  } = {}): [string, { [name: string]: any }] {\n    return pathAndParamsFromSegments(this._segments, {\n      escape,\n      parser,\n      options,\n    });\n  }\n\n  types({ key = false }: { key?: boolean } = {}): string[] {\n    return this.segments({ key })\n      .map((s) => s.outgoingType())\n      .filter((t) => t !== undefined) as string[];\n  }\n\n  keys(values?: (EntityKey<any> | undefined)[]) {\n    const segments = this.segments({ key: true });\n    if (values !== undefined) {\n      segments.forEach((segment, index) => {\n        const key = values[index];\n        if (key === undefined) {\n          segment.clearKey();\n        } else {\n          segment.key(key);\n        }\n      });\n    }\n    return segments.map((s) => s.key() as EntityKey<any> | undefined);\n  }\n\n  toString({ escape }: { escape?: boolean } = {}): string {\n    const [path, params] = this.pathAndParams({ escape });\n    return (\n      path +\n      Object.entries(params)\n        .filter(([, value]) => value)\n        .map(([key, value]) => `${key}=${value}`)\n        .join('&')\n    );\n  }\n\n  toJson() {\n    return this._segments.map((s) => {\n      let json = {\n        name: s.name as string,\n        path: s.path,\n      } as any;\n      if (s.incomingType !== undefined) json.incomingType = s.incomingType;\n      if (s.outgoingType !== undefined) json.outgoingType = s.outgoingType;\n      if (s.key !== undefined) json.key = s.key;\n      if (s.parameters !== undefined) json.parameters = s.parameters;\n      return json;\n    });\n  }\n\n  static fromJson(json: { [name: string]: any }[]): ODataPathSegments {\n    return new ODataPathSegments(\n      json.map((s: any) => ({\n        name: s.name,\n        path: s.path,\n        type: s.type,\n        key: s.key,\n        parameters: s.parameters,\n      })),\n    );\n  }\n\n  clone() {\n    const segments = Objects.clone(this._segments);\n    return new ODataPathSegments(segments);\n  }\n\n  find(predicate: (segment: ODataSegment) => boolean) {\n    //Backward Find\n    return [...this._segments].reverse().find(predicate);\n  }\n\n  segments({ key = false }: { key?: boolean } = {}) {\n    let segments = [...this._segments];\n    if (key)\n      segments = segments.filter(\n        (s) =>\n          [\n            PathSegment.entitySet,\n            PathSegment.navigationProperty,\n            PathSegment.property,\n          ].indexOf(s.name) !== -1,\n      );\n    return segments.map((s) => new SegmentHandler(s));\n  }\n\n  first({ key = false }: { key?: boolean } = {}) {\n    const segments = this.segments({ key });\n    return segments.length > 0 ? segments[0] : undefined;\n  }\n\n  last({ key = false }: { key?: boolean } = {}) {\n    const segments = this.segments({ key });\n    return segments.length > 0 ? segments[segments.length - 1] : undefined;\n  }\n\n  add(name: string, path: string) {\n    const segment = { name, path } as ODataSegment;\n    this._segments.push(segment);\n    return new SegmentHandler(segment);\n  }\n\n  get(name: string) {\n    let segment = this.find((s) => s.name === name);\n    if (segment === undefined)\n      throw Error(`No Segment for name ${name} was found`);\n    return new SegmentHandler(segment);\n  }\n}\n"]}