@data-client/endpoint
Version:
Declarative Network Interface Definitions
2 lines • 9.79 kB
JavaScript
export {};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../../src/schemas/EntityTypes.ts"],"sourcesContent":["import type { Schema, GetEntity, GetIndex } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\n\n/**\n * Entity defines a single (globally) unique object.\n * @see https://dataclient.io/rest/api/EntityMixin\n */\nexport interface IEntityClass<TBase extends Constructor = any> {\n  toJSON(): {\n    name: string;\n    schema: {\n      [k: string]: Schema;\n    };\n    key: string;\n  };\n  /** Defines nested entities\n   *\n   * @see https://dataclient.io/rest/api/Entity#schema\n   */\n  schema: {\n    [k: string]: Schema;\n  };\n  /** Returns the globally unique identifier for the static Entity\n   *\n   * @see https://dataclient.io/rest/api/Entity#key\n   */\n  key: string;\n  /** Defines indexes to enable lookup by\n   *\n   * @see https://dataclient.io/rest/api/Entity#indexes\n   */\n  indexes?: readonly string[] | undefined;\n  /**\n   * A unique identifier for each Entity\n   *\n   * @see https://dataclient.io/rest/api/Entity#pk\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   * @param [args] ...args sent to Endpoint\n   */\n  pk<\n    T extends (abstract new (\n      ...args: any[]\n    ) => IEntityInstance & InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n    args?: any[],\n  ): string | number | undefined;\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://dataclient.io/docs/api/Entity#shouldUpdate\n   */\n  shouldUpdate(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Determines the order of incoming entity vs entity already in store\n   *\n   * @see https://dataclient.io/docs/api/Entity#shouldReorder\n   * @returns true if incoming entity should be first argument of merge()\n   */\n  shouldReorder(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Creates new instance copying over defined values of arguments\n   *\n   * @see https://dataclient.io/docs/api/Entity#merge\n   */\n  merge(existing: any, incoming: any): any;\n  /** Run when an existing entity is found in the store\n   *\n   * @see https://dataclient.io/docs/api/Entity#mergeWithStore\n   */\n  mergeWithStore(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): any;\n  /** Run when an existing entity is found in the store\n   *\n   * @see https://dataclient.io/docs/api/Entity#mergeMetaWithStore\n   */\n  mergeMetaWithStore(\n    existingMeta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: { expiresAt: number; date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ): {\n    expiresAt: number;\n    date: number;\n    fetchedAt: number;\n  };\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  fromJS<\n    T extends (abstract new (\n      ...args: any[]\n    ) => IEntityInstance & InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T>;\n  /** Called when denormalizing an entity to create an instance when 'valid'\n   *\n   * @param [props] Plain Object of properties to assign.\n   * @see https://dataclient.io/rest/api/Entity#createIfValid\n   */\n  createIfValid<\n    T extends (abstract new (\n      ...args: any[]\n    ) => IEntityInstance & InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> | undefined;\n  /** Do any transformations when first receiving input\n   *\n   * @see https://dataclient.io/rest/api/Entity#process\n   */\n  process(input: any, parent: any, key: string | undefined, args: any[]): any;\n  normalize(\n    input: any,\n    parent: any,\n    key: string | undefined,\n    args: any[],\n    visit: (...args: any) => any,\n    addEntity: (...args: any) => any,\n    getEntity: (...args: any) => any,\n    checkLoop: (...args: any) => any,\n  ): any;\n  /** Do any transformations when first receiving input\n   *\n   * @see https://dataclient.io/rest/api/Entity#validate\n   */\n  validate(processedEntity: any): string | undefined;\n  /** Builds a key access the entity without endpoint results\n   *\n   * @see https://dataclient.io/rest/api/Entity#queryKey\n   */\n  queryKey(\n    args: readonly any[],\n    queryKey: any,\n    getEntity: GetEntity,\n    getIndex: GetIndex,\n  ): any;\n  denormalize<\n    T extends (abstract new (\n      ...args: any[]\n    ) => IEntityInstance & InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    input: any,\n    args: readonly any[],\n    unvisit: (schema: any, input: any) => any,\n  ): AbstractInstanceType<T>;\n  /** All instance defaults set */\n  readonly defaults: any;\n}\nexport interface IEntityInstance {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   * @param [args] ...args sent to Endpoint\n   */\n  pk(\n    parent?: any,\n    key?: string,\n    args?: readonly any[],\n  ): string | number | undefined;\n}\n\nexport type Constructor = abstract new (...args: any[]) => {};\nexport type IDClass = abstract new (...args: any[]) => {\n  id: string | number | undefined;\n};\nexport type PKClass = abstract new (...args: any[]) => {\n  pk(\n    parent?: any,\n    key?: string,\n    args?: readonly any[],\n  ): string | number | undefined;\n};\n// TODO: Figure out what Schema must be for each key\ntype ValidSchemas<TInstance> = {\n  [k in keyof TInstance]?: Schema;\n};\n\nexport type EntityOptions<TInstance extends {}> = {\n  readonly schema?: ValidSchemas<TInstance>;\n  readonly pk?:\n    | ((\n        value: TInstance,\n        parent?: any,\n        key?: string,\n      ) => string | number | undefined)\n    | keyof TInstance;\n  readonly key?: string;\n} & {\n  readonly [K in Extract<\n    keyof IEntityClass,\n    | 'process'\n    | 'merge'\n    | 'expiresAt'\n    | 'createIfValid'\n    | 'mergeWithStore'\n    | 'validate'\n    | 'shouldReorder'\n    | 'shouldUpdate'\n  >]?: IEntityClass<abstract new (...args: any[]) => TInstance>[K];\n};\n\nexport interface RequiredPKOptions<TInstance extends {}>\n  extends EntityOptions<TInstance> {\n  readonly pk:\n    | ((\n        value: TInstance,\n        parent?: any,\n        key?: string,\n      ) => string | number | undefined)\n    | keyof TInstance;\n}\n"],"mappings":"","ignoreList":[]}