@data-client/endpoint
Version:
Declarative Network Interface Definitions
4 lines • 8.43 kB
JavaScript
import { default as Invalidate } from './schemas/Invalidate.js';
export { Invalidate };
export { EntityInterface } from './interface.js';
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["default","Invalidate","EntityInterface"],"sources":["../src/schemaTypes.ts"],"sourcesContent":["import type { schema } from './index.js';\nimport type {\n  SchemaSimple,\n  Schema,\n  PolymorphicInterface,\n  GetEntity,\n  CheckLoop,\n} from './interface.js';\nimport type { EntityMap } from './normal.js';\nimport { CollectionOptions } from './schemas/Collection.js';\nimport { default as Invalidate } from './schemas/Invalidate.js';\n\nexport { EntityMap, Invalidate };\n\nexport { EntityInterface } from './interface.js';\n\nexport type CollectionArrayAdder<S extends PolymorphicInterface> =\n  S extends (\n    {\n      // ensure we are an array type\n      denormalize(...args: any): any[];\n      // get what we are an array of\n      schema: infer T;\n    }\n  ) ?\n    // TODO: eventually we want to allow singular or list and infer the return based on arguments\n    T\n  : never;\n\nexport interface CollectionInterface<\n  S extends PolymorphicInterface = any,\n  Args extends any[] = any[],\n  Parent = any,\n> {\n  /** Constructs a custom creation schema for this collection\n   *\n   * @see https://dataclient.io/rest/api/Collection#addWith\n   */\n  addWith<P extends any[] = Args>(\n    merge: (existing: any, incoming: any) => any,\n    createCollectionFilter?: (\n      ...args: P\n    ) => (collectionKey: Record<string, string>) => boolean,\n  ): schema.Collection<S, P>;\n\n  readonly cacheWith: object;\n\n  readonly schema: S;\n  readonly key: string;\n\n  /**\n   * A unique identifier for each Collection\n   *\n   * Calls argsKey or nestKey depending on which are specified, and then serializes the result for the pk string.\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   * @see https://dataclient.io/docs/api/Collection#pk\n   */\n  pk(value: any, parent: any, key: string, args: any[]): string;\n  normalize(\n    input: any,\n    parent: Parent,\n    key: string,\n    args: any[],\n    visit: (...args: any) => any,\n    addEntity: (...args: any) => any,\n    getEntity: GetEntity,\n    checkLoop: CheckLoop,\n  ): string;\n\n  /** Creates new instance copying over defined values of arguments\n   *\n   * @see https://dataclient.io/docs/api/Collection#merge\n   */\n  merge(existing: any, incoming: any): any;\n\n  /** Determines the order of incoming Collection vs Collection already in store\n   *\n   * @see https://dataclient.io/docs/api/Collection#shouldReorder\n   * @returns true if incoming Collection should be first argument of merge()\n   */\n  shouldReorder(\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\n  /** Run when an existing Collection is found in the store\n   *\n   * @see https://dataclient.io/docs/api/Collection#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\n  mergeMetaWithStore(\n    existingMeta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): {\n    expiresAt: number;\n    date: number;\n    fetchedAt: number;\n  };\n\n  /** Builds a key access the Collection without endpoint results\n   *\n   * @see https://dataclient.io/rest/api/Collection#queryKey\n   */\n  queryKey(\n    args: Args,\n    queryKey: unknown,\n    getEntity: unknown,\n    getIndex: unknown,\n  ): any;\n\n  createIfValid: (value: any) => any | undefined;\n  denormalize(\n    input: any,\n    args: readonly any[],\n    unvisit: (schema: any, input: any) => any,\n  ): ReturnType<S['denormalize']>;\n\n  _denormalizeNullable(): ReturnType<S['_denormalizeNullable']>;\n  _normalizeNullable(): ReturnType<S['_normalizeNullable']>;\n\n  /** Schema to place at the *end* of this Collection\n   * @see https://dataclient.io/rest/api/Collection#push\n   */\n  push: CollectionArrayAdder<S>;\n\n  /** Schema to place at the *beginning* of this Collection\n   * @see https://dataclient.io/rest/api/Collection#unshift\n   */\n  unshift: CollectionArrayAdder<S>;\n\n  /** Schema to merge with a Values Collection\n   * @see https://dataclient.io/rest/api/Collection#assign\n   */\n  assign: S extends { denormalize(...args: any): Record<string, unknown> } ?\n    schema.Collection<S, Args, Parent>\n  : never;\n}\nexport type CollectionFromSchema<\n  S extends any[] | PolymorphicInterface = any,\n  Args extends any[] = DefaultArgs,\n  Parent = any,\n> = CollectionInterface<\n  S extends any[] ? schema.Array<S[number]> : S,\n  Args,\n  Parent\n>;\n\nexport interface CollectionConstructor {\n  /**\n   * Entities but for Arrays instead of classes\n   * @see https://dataclient.io/rest/api/Collection\n   */\n  new <\n    S extends SchemaSimple[] | PolymorphicInterface = any,\n    Args extends any[] = DefaultArgs,\n    Parent = any,\n  >(\n    schema: S,\n    options?: CollectionOptions<Args, Parent>,\n  ): CollectionFromSchema<S, Args, Parent>;\n  readonly prototype: CollectionInterface;\n}\n\nexport type StrategyFunction<T> = (value: any, parent: any, key: string) => T;\nexport type SchemaFunction<K = string, Args = any> = (\n  value: Args,\n  parent: any,\n  key: string,\n) => K;\nexport type MergeFunction = (entityA: any, entityB: any) => any;\nexport type SchemaAttributeFunction<S extends Schema> = (\n  value: any,\n  parent: any,\n  key: string,\n) => S;\nexport type UnionResult<Choices extends EntityMap> = {\n  id: string;\n  schema: keyof Choices;\n};\nexport type DefaultArgs =\n  | []\n  | [urlParams: Record<string, any>]\n  | [urlParams: Record<string, any>, body: any];\n"],"mappings":"AAUA,SAASA,OAAO,IAAIC,UAAU,QAAQ,yBAAyB;AAE/D,SAAoBA,UAAU;AAE9B,SAASC,eAAe,QAAQ,gBAAgB","ignoreList":[]}