@data-client/endpoint
Advanced tools
Comparing version 0.11.4 to 0.12.3
@@ -232,3 +232,2 @@ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/objectWithoutPropertiesLoose"; | ||
pk, | ||
schema, | ||
key | ||
@@ -330,2 +329,2 @@ } = options, | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["CREATE","EntitySchema","Base","options","EntityMixin","toString","key","toJSON","name","schema","pk","value","parent","args","prototype","call","shouldUpdate","existingMeta","incomingMeta","existing","incoming","shouldReorder","fetchedAt","merge","Object","assign","mergeWithStore","mergeMetaWithStore","fromJS","props","instance","createIfValid","validate","undefined","process","input","normalize","visit","addEntity","visitedEntities","storeEntities","processedEntity","id","Math","random","env","NODE_ENV","error","Error","JSON","stringify","status","entityType","some","entity","errorMessage","throwValidationError","push","keys","forEach","hasOwn","queryKey","getEntity","getIndex","queryKeyCandidate","denormalize","unvisit","defaults","defineProperty","writable","configurable","__defaults","staticProps","_objectWithoutPropertiesLoose","_excluded","enumerable","set","baseGet","get","document","CLS_MANGLE","indexFromParams","params","indexes","find","index","includes","indexName"],"sources":["../../src/schemas/EntitySchema.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\nimport { CREATE } from './special.js';\nimport type { Schema, GetIndex, GetEntity } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\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\n// TODO: Figure out what Schema must be for each key\ntype ValidSchemas<TInstance> = { [k in keyof TInstance]?: Schema };\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\nexport default function EntitySchema<TBase extends Constructor>(\n  Base: TBase,\n  options: EntityOptions<InstanceType<TBase>> = {},\n) {\n  /**\n   * Represents data that should be deduped by specifying a primary key.\n   * @see https://dataclient.io/rest/api/Entity\n   */\n  abstract class EntityMixin extends Base {\n    static toString() {\n      return this.key;\n    }\n\n    static toJSON() {\n      return {\n        name: this.name,\n        schema: this.schema,\n        key: this.key,\n      };\n    }\n\n    /** Defines nested entities */\n    declare static schema: { [k: string]: Schema };\n\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     * @see https://dataclient.io/docs/api/schema.Entity#pk\n     */\n    abstract pk(\n      parent?: any,\n      key?: string,\n      args?: readonly any[],\n    ): string | number | undefined;\n\n    /** Returns the globally unique identifier for the static Entity */\n    declare static key: string;\n    // default implementation in class static block at bottom of definition\n\n    /** Defines indexes to enable lookup by */\n    declare static indexes?: readonly string[];\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @see https://dataclient.io/docs/api/schema.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    static pk<T extends typeof EntityMixin>(\n      this: T,\n      value: Partial<AbstractInstanceType<T>>,\n      parent?: any,\n      key?: string,\n      args?: readonly any[],\n    ): string | number | undefined {\n      return this.prototype.pk.call(value, parent, key, args);\n    }\n\n    /** Return true to merge incoming data; false keeps existing entity\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#shouldUpdate\n     */\n    static shouldUpdate(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return true;\n    }\n\n    /** Determines the order of incoming entity vs entity already in store\\\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#shouldReorder\n     * @returns true if incoming entity should be first argument of merge()\n     */\n    static shouldReorder(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return incomingMeta.fetchedAt < existingMeta.fetchedAt;\n    }\n\n    /** Creates new instance copying over defined values of arguments\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#merge\n     */\n    static merge(existing: any, incoming: any) {\n      return {\n        ...existing,\n        ...incoming,\n      };\n    }\n\n    /** Run when an existing entity is found in the store\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#mergeWithStore\n     */\n    static mergeWithStore(\n      existingMeta: {\n        date: number;\n        fetchedAt: number;\n      },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      const shouldUpdate = this.shouldUpdate(\n        existingMeta,\n        incomingMeta,\n        existing,\n        incoming,\n      );\n\n      if (shouldUpdate) {\n        // distinct types are not mergeable (like delete symbol), so just replace\n        if (typeof incoming !== typeof existing) {\n          return incoming;\n        } else {\n          return (\n              this.shouldReorder(existingMeta, incomingMeta, existing, incoming)\n            ) ?\n              this.merge(incoming, existing)\n            : this.merge(existing, incoming);\n        }\n      } else {\n        return existing;\n      }\n    }\n\n    /** Run when an existing entity is found in the store\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#mergeMetaWithStore\n     */\n    static 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      return (\n          this.shouldReorder(existingMeta, incomingMeta, existing, incoming)\n        ) ?\n          existingMeta\n        : incomingMeta;\n    }\n\n    /** Factory method to convert from Plain JS Objects.\n     *\n     * @param [props] Plain Object of properties to assign.\n     */\n    static fromJS<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>> = {},\n    ): AbstractInstanceType<T> {\n      // we type guarded abstract case above, so ok to force typescript to allow constructor call\n      const instance = new (this as any)(props) as AbstractInstanceType<T>;\n      // we can't rely on constructors and override the defaults provided as property assignments\n      // all occur after the constructor\n      Object.assign(instance, props);\n      return instance;\n    }\n\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/docs/api/schema.Entity#createIfValid\n     */\n    static createIfValid<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>>,\n    ): AbstractInstanceType<T> | undefined {\n      if (this.validate(props)) {\n        return undefined as any;\n      }\n      return this.fromJS(props);\n    }\n\n    /** Do any transformations when first receiving input\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#process\n     */\n    static process(\n      input: any,\n      parent: any,\n      key: string | undefined,\n      args: any,\n    ): any {\n      return { ...input };\n    }\n\n    static normalize(\n      input: any,\n      parent: any,\n      key: string | undefined,\n      visit: (...args: any) => any,\n      addEntity: (...args: any) => any,\n      visitedEntities: Record<string | symbol, any>,\n      storeEntities: any,\n      args?: readonly any[],\n    ): any {\n      const processedEntity = this.process(input, parent, key, args);\n      let id = this.pk(processedEntity, parent, key, args);\n      if (id === undefined || id === '' || id === 'undefined') {\n        // create a random id if a valid one cannot be computed\n        // this is useful for optimistic creates that don't need real ids - just something to hold their place\n        id = `MISS-${Math.random()}`;\n        // 'creates' conceptually should allow missing PK to make optimistic creates easy\n        if (process.env.NODE_ENV !== 'production' && !visitedEntities[CREATE]) {\n          const error = new Error(\n            `Missing usable primary key when normalizing response.\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://dataclient.io/docs/guides/debugging\n  Learn more about primary keys: https://dataclient.io/rest/api/Entity#pk\n\n  Entity: ${this.key}\n  Value (processed): ${\n    processedEntity && JSON.stringify(processedEntity, null, 2)\n  }\n`,\n          );\n          (error as any).status = 400;\n          throw error;\n        }\n      } else {\n        id = `${id}`;\n      }\n      const entityType = this.key;\n\n      if (!(entityType in visitedEntities)) {\n        visitedEntities[entityType] = {};\n      }\n      if (!(id in visitedEntities[entityType])) {\n        visitedEntities[entityType][id] = [];\n      }\n      if (\n        visitedEntities[entityType][id].some((entity: any) => entity === input)\n      ) {\n        return id;\n      }\n      const errorMessage = this.validate(processedEntity);\n      throwValidationError(errorMessage);\n\n      visitedEntities[entityType][id].push(input);\n\n      Object.keys(this.schema).forEach(key => {\n        if (Object.hasOwn(processedEntity, key)) {\n          processedEntity[key] = visit(\n            processedEntity[key],\n            processedEntity,\n            key,\n            this.schema[key],\n            addEntity,\n            visitedEntities,\n            storeEntities,\n            args,\n          );\n        }\n      });\n\n      addEntity(this, processedEntity, id);\n      return id;\n    }\n\n    static validate(processedEntity: any): string | undefined {\n      return;\n    }\n\n    static queryKey(\n      args: readonly any[],\n      queryKey: any,\n      getEntity: GetEntity,\n      getIndex: GetIndex,\n    ): any {\n      if (!args[0]) return;\n      const id = queryKeyCandidate(this, args, getIndex);\n      // ensure this actually has entity or we shouldn't try to use it in our query\n      if (getEntity(this.key, id)) return id;\n    }\n\n    static denormalize<T extends typeof EntityMixin>(\n      this: T,\n      input: any,\n      args: any[],\n      unvisit: (input: any, schema: any) => any,\n    ): AbstractInstanceType<T> {\n      if (typeof input === 'symbol') {\n        return input as any;\n      }\n\n      // note: iteration order must be stable\n      for (const key of Object.keys(this.schema)) {\n        const schema = this.schema[key];\n        const value = unvisit(input[key], schema);\n\n        if (typeof value === 'symbol') {\n          // if default is not 'falsy', then this is required, so propagate INVALID symbol\n          if (this.defaults[key]) {\n            return value as any;\n          }\n          input[key] = undefined;\n        } else {\n          input[key] = value;\n        }\n      }\n      return input;\n    }\n\n    /** All instance defaults set */\n    static get defaults() {\n      // we use hasOwn because we don't want to use a parents' defaults\n      if (!Object.hasOwn(this, '__defaults'))\n        Object.defineProperty(this, '__defaults', {\n          value: new (this as any)(),\n          writable: true,\n          configurable: true,\n        });\n      return (this as any).__defaults;\n    }\n  }\n\n  const { pk, schema, key, ...staticProps } = options;\n  // remaining options\n  Object.assign(EntityMixin, staticProps);\n\n  if ('schema' in options) {\n    EntityMixin.schema = options.schema as any;\n  } else if (!(Base as any).schema) {\n    EntityMixin.schema = {};\n  }\n  if ('pk' in options) {\n    if (typeof options.pk === 'function') {\n      EntityMixin.prototype.pk = function (parent?: any, key?: string) {\n        return (options.pk as any)(this, parent, key);\n      };\n    } else {\n      EntityMixin.prototype.pk = function () {\n        return (this as any)[options.pk];\n      };\n    }\n    // default to 'id' field if the base class doesn't have a pk\n  } else if (typeof Base.prototype.pk !== 'function') {\n    EntityMixin.prototype.pk = function () {\n      return (this as any).id;\n    };\n  }\n  if ('key' in options) {\n    Object.defineProperty(EntityMixin, 'key', {\n      value: options.key,\n      configurable: true,\n      writable: true,\n      enumerable: true,\n    });\n  } else if (!('key' in Base)) {\n    // this allows assignment in strict-mode\n    // eslint-disable-next-line no-inner-declarations\n    function set(this: any, value: string) {\n      Object.defineProperty(this, 'key', {\n        value,\n        writable: true,\n        enumerable: true,\n        configurable: true,\n      });\n    }\n    const baseGet = function (this: { name: string }): string {\n      const name = this.name === 'EntityMixin' ? Base.name : this.name;\n      /* istanbul ignore next */\n      if (\n        process.env.NODE_ENV !== 'production' &&\n        (name === '' || name === 'EntityMixin' || name === '_temp')\n      )\n        throw new Error(\n          'Entity classes without a name must define `static key`\\nSee: https://dataclient.io/rest/api/Entity#key',\n        );\n      return name;\n    };\n    const get =\n      /* istanbul ignore if */\n      typeof document !== 'undefined' && (document as any).CLS_MANGLE ?\n        /* istanbul ignore next */ function (this: {\n          name: string;\n          key: string;\n        }): string {\n          (document as any).CLS_MANGLE?.(this);\n          Object.defineProperty(EntityMixin, 'key', {\n            get: baseGet,\n            set,\n            enumerable: true,\n            configurable: true,\n          });\n          return baseGet.call(this);\n        }\n      : baseGet;\n\n    Object.defineProperty(EntityMixin, 'key', {\n      get,\n      set,\n      enumerable: true,\n      configurable: true,\n    });\n  }\n\n  return EntityMixin as any;\n}\n\nfunction indexFromParams<I extends string>(\n  params: Readonly<object>,\n  indexes?: Readonly<I[]>,\n) {\n  if (!indexes) return undefined;\n  return indexes.find(index => Object.hasOwn(params, index));\n}\n\n// part of the reason for pulling this out is that all functions that throw are deoptimized\nfunction throwValidationError(errorMessage: string | undefined) {\n  if (errorMessage) {\n    const error = new Error(errorMessage);\n    (error as any).status = 400;\n    throw error;\n  }\n}\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/schema.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/schema.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/schema.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/schema.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/schema.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    visit: (...args: any) => any,\n    addEntity: (...args: any) => any,\n    visitedEntities: Record<string, 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: (input: any, schema: any) => any,\n  ): AbstractInstanceType<T>;\n  /** All instance defaults set */\n  readonly defaults: any;\n  //set(entity: any, key: string, value: any): void;\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\nfunction queryKeyCandidate(\n  schema: any,\n  args: readonly any[],\n  getIndex: GetIndex,\n) {\n  if (['string', 'number'].includes(typeof args[0])) {\n    return `${args[0]}`;\n  }\n  const id = schema.pk(args[0], undefined, '', args);\n  // Was able to infer the entity's primary key from params\n  if (id !== undefined && id !== '') return id;\n  // now attempt lookup in indexes\n  const indexName = indexFromParams(args[0], schema.indexes);\n  if (!indexName) return;\n  const value = (args[0] as Record<string, any>)[indexName];\n  return getIndex(schema.key, indexName, value)[value];\n}\n"],"mappings":"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","ignoreList":[]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["CREATE","EntitySchema","Base","options","EntityMixin","toString","key","toJSON","name","schema","pk","value","parent","args","prototype","call","shouldUpdate","existingMeta","incomingMeta","existing","incoming","shouldReorder","fetchedAt","merge","Object","assign","mergeWithStore","mergeMetaWithStore","fromJS","props","instance","createIfValid","validate","undefined","process","input","normalize","visit","addEntity","visitedEntities","storeEntities","processedEntity","id","Math","random","env","NODE_ENV","error","Error","JSON","stringify","status","entityType","some","entity","errorMessage","throwValidationError","push","keys","forEach","hasOwn","queryKey","getEntity","getIndex","queryKeyCandidate","denormalize","unvisit","defaults","defineProperty","writable","configurable","__defaults","staticProps","_objectWithoutPropertiesLoose","_excluded","enumerable","set","baseGet","get","document","CLS_MANGLE","indexFromParams","params","indexes","find","index","includes","indexName"],"sources":["../../src/schemas/EntitySchema.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\nimport { CREATE } from './special.js';\nimport type { Schema, GetIndex, GetEntity } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\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\n// TODO: Figure out what Schema must be for each key\ntype ValidSchemas<TInstance> = { [k in keyof TInstance]?: Schema };\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\nexport default function EntitySchema<TBase extends Constructor>(\n  Base: TBase,\n  options: EntityOptions<InstanceType<TBase>> = {},\n) {\n  /**\n   * Represents data that should be deduped by specifying a primary key.\n   * @see https://dataclient.io/rest/api/Entity\n   */\n  abstract class EntityMixin extends Base {\n    static toString() {\n      return this.key;\n    }\n\n    static toJSON() {\n      return {\n        name: this.name,\n        schema: this.schema,\n        key: this.key,\n      };\n    }\n\n    /** Defines nested entities */\n    declare static schema: { [k: string]: Schema };\n\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     * @see https://dataclient.io/docs/api/schema.Entity#pk\n     */\n    abstract pk(\n      parent?: any,\n      key?: string,\n      args?: readonly any[],\n    ): string | number | undefined;\n\n    /** Returns the globally unique identifier for the static Entity */\n    declare static key: string;\n    // default implementation in class static block at bottom of definition\n\n    /** Defines indexes to enable lookup by */\n    declare static indexes?: readonly string[];\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @see https://dataclient.io/docs/api/schema.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    static pk<T extends typeof EntityMixin>(\n      this: T,\n      value: Partial<AbstractInstanceType<T>>,\n      parent?: any,\n      key?: string,\n      args?: readonly any[],\n    ): string | number | undefined {\n      return this.prototype.pk.call(value, parent, key, args);\n    }\n\n    /** Return true to merge incoming data; false keeps existing entity\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#shouldUpdate\n     */\n    static shouldUpdate(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return true;\n    }\n\n    /** Determines the order of incoming entity vs entity already in store\\\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#shouldReorder\n     * @returns true if incoming entity should be first argument of merge()\n     */\n    static shouldReorder(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return incomingMeta.fetchedAt < existingMeta.fetchedAt;\n    }\n\n    /** Creates new instance copying over defined values of arguments\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#merge\n     */\n    static merge(existing: any, incoming: any) {\n      return {\n        ...existing,\n        ...incoming,\n      };\n    }\n\n    /** Run when an existing entity is found in the store\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#mergeWithStore\n     */\n    static mergeWithStore(\n      existingMeta: {\n        date: number;\n        fetchedAt: number;\n      },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      const shouldUpdate = this.shouldUpdate(\n        existingMeta,\n        incomingMeta,\n        existing,\n        incoming,\n      );\n\n      if (shouldUpdate) {\n        // distinct types are not mergeable (like delete symbol), so just replace\n        if (typeof incoming !== typeof existing) {\n          return incoming;\n        } else {\n          return (\n              this.shouldReorder(existingMeta, incomingMeta, existing, incoming)\n            ) ?\n              this.merge(incoming, existing)\n            : this.merge(existing, incoming);\n        }\n      } else {\n        return existing;\n      }\n    }\n\n    /** Run when an existing entity is found in the store\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#mergeMetaWithStore\n     */\n    static 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      return (\n          this.shouldReorder(existingMeta, incomingMeta, existing, incoming)\n        ) ?\n          existingMeta\n        : incomingMeta;\n    }\n\n    /** Factory method to convert from Plain JS Objects.\n     *\n     * @param [props] Plain Object of properties to assign.\n     */\n    static fromJS<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>> = {},\n    ): AbstractInstanceType<T> {\n      // we type guarded abstract case above, so ok to force typescript to allow constructor call\n      const instance = new (this as any)(props) as AbstractInstanceType<T>;\n      // we can't rely on constructors and override the defaults provided as property assignments\n      // all occur after the constructor\n      Object.assign(instance, props);\n      return instance;\n    }\n\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/docs/api/schema.Entity#createIfValid\n     */\n    static createIfValid<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>>,\n    ): AbstractInstanceType<T> | undefined {\n      if (this.validate(props)) {\n        return undefined as any;\n      }\n      return this.fromJS(props);\n    }\n\n    /** Do any transformations when first receiving input\n     *\n     * @see https://dataclient.io/docs/api/schema.Entity#process\n     */\n    static process(\n      input: any,\n      parent: any,\n      key: string | undefined,\n      args: any,\n    ): any {\n      return { ...input };\n    }\n\n    static normalize(\n      input: any,\n      parent: any,\n      key: string | undefined,\n      visit: (...args: any) => any,\n      addEntity: (...args: any) => any,\n      visitedEntities: Record<string | symbol, any>,\n      storeEntities: any,\n      args?: readonly any[],\n    ): any {\n      const processedEntity = this.process(input, parent, key, args);\n      let id = this.pk(processedEntity, parent, key, args);\n      if (id === undefined || id === '' || id === 'undefined') {\n        // create a random id if a valid one cannot be computed\n        // this is useful for optimistic creates that don't need real ids - just something to hold their place\n        id = `MISS-${Math.random()}`;\n        // 'creates' conceptually should allow missing PK to make optimistic creates easy\n        if (process.env.NODE_ENV !== 'production' && !visitedEntities[CREATE]) {\n          const error = new Error(\n            `Missing usable primary key when normalizing response.\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://dataclient.io/docs/guides/debugging\n  Learn more about primary keys: https://dataclient.io/rest/api/Entity#pk\n\n  Entity: ${this.key}\n  Value (processed): ${\n    processedEntity && JSON.stringify(processedEntity, null, 2)\n  }\n`,\n          );\n          (error as any).status = 400;\n          throw error;\n        }\n      } else {\n        id = `${id}`;\n      }\n      const entityType = this.key;\n\n      if (!(entityType in visitedEntities)) {\n        visitedEntities[entityType] = {};\n      }\n      if (!(id in visitedEntities[entityType])) {\n        visitedEntities[entityType][id] = [];\n      }\n      if (\n        visitedEntities[entityType][id].some((entity: any) => entity === input)\n      ) {\n        return id;\n      }\n      const errorMessage = this.validate(processedEntity);\n      throwValidationError(errorMessage);\n\n      visitedEntities[entityType][id].push(input);\n\n      Object.keys(this.schema).forEach(key => {\n        if (Object.hasOwn(processedEntity, key)) {\n          processedEntity[key] = visit(\n            processedEntity[key],\n            processedEntity,\n            key,\n            this.schema[key],\n            addEntity,\n            visitedEntities,\n            storeEntities,\n            args,\n          );\n        }\n      });\n\n      addEntity(this, processedEntity, id);\n      return id;\n    }\n\n    static validate(processedEntity: any): string | undefined {\n      return;\n    }\n\n    static queryKey(\n      args: readonly any[],\n      queryKey: any,\n      getEntity: GetEntity,\n      getIndex: GetIndex,\n    ): any {\n      if (!args[0]) return;\n      const id = queryKeyCandidate(this, args, getIndex);\n      // ensure this actually has entity or we shouldn't try to use it in our query\n      if (getEntity(this.key, id)) return id;\n    }\n\n    static denormalize<T extends typeof EntityMixin>(\n      this: T,\n      input: any,\n      args: any[],\n      unvisit: (input: any, schema: any) => any,\n    ): AbstractInstanceType<T> {\n      if (typeof input === 'symbol') {\n        return input as any;\n      }\n\n      // note: iteration order must be stable\n      for (const key of Object.keys(this.schema)) {\n        const schema = this.schema[key];\n        const value = unvisit(input[key], schema);\n\n        if (typeof value === 'symbol') {\n          // if default is not 'falsy', then this is required, so propagate INVALID symbol\n          if (this.defaults[key]) {\n            return value as any;\n          }\n          input[key] = undefined;\n        } else {\n          input[key] = value;\n        }\n      }\n      return input;\n    }\n\n    /** All instance defaults set */\n    static get defaults() {\n      // we use hasOwn because we don't want to use a parents' defaults\n      if (!Object.hasOwn(this, '__defaults'))\n        Object.defineProperty(this, '__defaults', {\n          value: new (this as any)(),\n          writable: true,\n          configurable: true,\n        });\n      return (this as any).__defaults;\n    }\n  }\n\n  const { pk, schema, key, ...staticProps } = options;\n  // remaining options\n  Object.assign(EntityMixin, staticProps);\n\n  if ('schema' in options) {\n    EntityMixin.schema = options.schema as any;\n  } else if (!(Base as any).schema) {\n    EntityMixin.schema = {};\n  }\n  if ('pk' in options) {\n    if (typeof options.pk === 'function') {\n      EntityMixin.prototype.pk = function (parent?: any, key?: string) {\n        return (options.pk as any)(this, parent, key);\n      };\n    } else {\n      EntityMixin.prototype.pk = function () {\n        return (this as any)[options.pk];\n      };\n    }\n    // default to 'id' field if the base class doesn't have a pk\n  } else if (typeof Base.prototype.pk !== 'function') {\n    EntityMixin.prototype.pk = function () {\n      return (this as any).id;\n    };\n  }\n  if ('key' in options) {\n    Object.defineProperty(EntityMixin, 'key', {\n      value: options.key,\n      configurable: true,\n      writable: true,\n      enumerable: true,\n    });\n  } else if (!('key' in Base)) {\n    // this allows assignment in strict-mode\n    // eslint-disable-next-line no-inner-declarations\n    function set(this: any, value: string) {\n      Object.defineProperty(this, 'key', {\n        value,\n        writable: true,\n        enumerable: true,\n        configurable: true,\n      });\n    }\n    const baseGet = function (this: { name: string }): string {\n      const name = this.name === 'EntityMixin' ? Base.name : this.name;\n      /* istanbul ignore next */\n      if (\n        process.env.NODE_ENV !== 'production' &&\n        (name === '' || name === 'EntityMixin' || name === '_temp')\n      )\n        throw new Error(\n          'Entity classes without a name must define `static key`\\nSee: https://dataclient.io/rest/api/Entity#key',\n        );\n      return name;\n    };\n    const get =\n      /* istanbul ignore if */\n      typeof document !== 'undefined' && (document as any).CLS_MANGLE ?\n        /* istanbul ignore next */ function (this: {\n          name: string;\n          key: string;\n        }): string {\n          (document as any).CLS_MANGLE?.(this);\n          Object.defineProperty(EntityMixin, 'key', {\n            get: baseGet,\n            set,\n            enumerable: true,\n            configurable: true,\n          });\n          return baseGet.call(this);\n        }\n      : baseGet;\n\n    Object.defineProperty(EntityMixin, 'key', {\n      get,\n      set,\n      enumerable: true,\n      configurable: true,\n    });\n  }\n\n  return EntityMixin as any;\n}\n\nfunction indexFromParams<I extends string>(\n  params: Readonly<object>,\n  indexes?: Readonly<I[]>,\n) {\n  if (!indexes) return undefined;\n  return indexes.find(index => Object.hasOwn(params, index));\n}\n\n// part of the reason for pulling this out is that all functions that throw are deoptimized\nfunction throwValidationError(errorMessage: string | undefined) {\n  if (errorMessage) {\n    const error = new Error(errorMessage);\n    (error as any).status = 400;\n    throw error;\n  }\n}\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/schema.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/schema.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/schema.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/schema.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/schema.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    visit: (...args: any) => any,\n    addEntity: (...args: any) => any,\n    visitedEntities: Record<string, 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: (input: any, schema: any) => any,\n  ): AbstractInstanceType<T>;\n  /** All instance defaults set */\n  readonly defaults: any;\n  //set(entity: any, key: string, value: any): void;\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\nfunction queryKeyCandidate(\n  schema: any,\n  args: readonly any[],\n  getIndex: GetIndex,\n) {\n  if (['string', 'number'].includes(typeof args[0])) {\n    return `${args[0]}`;\n  }\n  const id = schema.pk(args[0], undefined, '', args);\n  // Was able to infer the entity's primary key from params\n  if (id !== undefined && id !== '') return id;\n  // now attempt lookup in indexes\n  const indexName = indexFromParams(args[0], schema.indexes);\n  if (!indexName) return;\n  const value = (args[0] as Record<string, any>)[indexName];\n  return getIndex(schema.key, indexName, value)[value];\n}\n"],"mappings":"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","ignoreList":[]} |
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL1NuYXBzaG90SW50ZXJmYWNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRXJyb3JUeXBlcyB9IGZyb20gJy4vRXJyb3JUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlLCBRdWVyeWFibGUgfSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IERlbm9ybWFsaXplTnVsbGFibGUsIFNjaGVtYUFyZ3MgfSBmcm9tICcuL25vcm1hbC5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU25hcHNob3RJbnRlcmZhY2Uge1xuICAvKipcbiAgICogR2V0cyB0aGUgKGdsb2JhbGx5IHJlZmVyZW50aWFsbHkgc3RhYmxlKSByZXNwb25zZSBmb3IgYSBnaXZlbiBlbmRwb2ludC9hcmdzIHBhaXIgZnJvbSBzdGF0ZSBnaXZlbi5cbiAgICogQHNlZSBodHRwczovL2RhdGFjbGllbnQuaW8vZG9jcy9hcGkvU25hcHNob3QjZ2V0UmVzcG9uc2VcbiAgICovXG4gIGdldFJlc3BvbnNlPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gICAgZW5kcG9pbnQ6IEUsXG4gICAgLi4uYXJnczogcmVhZG9ubHkgW251bGxdXG4gICk6IHtcbiAgICBkYXRhOiBEZW5vcm1hbGl6ZU51bGxhYmxlPEVbJ3NjaGVtYSddPjtcbiAgICBleHBpcnlTdGF0dXM6IEV4cGlyeVN0YXR1c0ludGVyZmFjZTtcbiAgICBleHBpcmVzQXQ6IG51bWJlcjtcbiAgfTtcblxuICBnZXRSZXNwb25zZTxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XVxuICApOiB7XG4gICAgZGF0YTogRGVub3JtYWxpemVOdWxsYWJsZTxFWydzY2hlbWEnXT47XG4gICAgZXhwaXJ5U3RhdHVzOiBFeHBpcnlTdGF0dXNJbnRlcmZhY2U7XG4gICAgZXhwaXJlc0F0OiBudW1iZXI7XG4gIH07XG5cbiAgZ2V0UmVzcG9uc2U8XG4gICAgRSBleHRlbmRzIFBpY2s8RW5kcG9pbnRJbnRlcmZhY2UsICdrZXknIHwgJ3NjaGVtYScgfCAnaW52YWxpZElmU3RhbGUnPixcbiAgPihcbiAgICBlbmRwb2ludDogRSxcbiAgICAuLi5hcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFWydrZXknXT5dIHwgcmVhZG9ubHkgW251bGxdXG4gICk6IHtcbiAgICBkYXRhOiBEZW5vcm1hbGl6ZU51bGxhYmxlPEVbJ3NjaGVtYSddPjtcbiAgICBleHBpcnlTdGF0dXM6IEV4cGlyeVN0YXR1c0ludGVyZmFjZTtcbiAgICBleHBpcmVzQXQ6IG51bWJlcjtcbiAgfTtcblxuICAvKiogQHNlZSBodHRwczovL2RhdGFjbGllbnQuaW8vZG9jcy9hcGkvU25hcHNob3QjZ2V0RXJyb3IgKi9cbiAgZ2V0RXJyb3I6IDxcbiAgICBFIGV4dGVuZHMgUGljazxFbmRwb2ludEludGVyZmFjZSwgJ2tleSc+LFxuICAgIEFyZ3MgZXh0ZW5kcyByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFWydrZXknXT5dLFxuICA+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IEFyZ3NcbiAgKSA9PiBFcnJvclR5cGVzIHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBSZXRyaWV2ZWQgbWVtb2l6ZWQgdmFsdWUgZm9yIGFueSBRdWVyYWJsZSBzY2hlbWFcbiAgICogQHNlZSBodHRwczovL2RhdGFjbGllbnQuaW8vZG9jcy9hcGkvU25hcHNob3QjZ2V0XG4gICAqL1xuICBnZXQ8UyBleHRlbmRzIFF1ZXJ5YWJsZT4oXG4gICAgc2NoZW1hOiBTLFxuICAgIC4uLmFyZ3M6IFNjaGVtYUFyZ3M8Uz5cbiAgKTogRGVub3JtYWxpemVOdWxsYWJsZTxTPiB8IHVuZGVmaW5lZDtcblxuICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgcmVhZG9ubHkgYWJvcnQ6IEVycm9yO1xufVxuXG4vLyBsb29zZXIgdmVyc2lvbiB0byBhbGxvdyBmb3IgY3Jvc3MtcGFja2FnZSB2ZXJzaW9uIGNvbXBhdGliaWxpdHlcbmV4cG9ydCB0eXBlIEV4cGlyeVN0YXR1c0ludGVyZmFjZSA9IDEgfCAyIHwgMztcbiJdLCJtYXBwaW5ncyI6IiIsImlnbm9yZUxpc3QiOltdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL1NuYXBzaG90SW50ZXJmYWNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRXJyb3JUeXBlcyB9IGZyb20gJy4vRXJyb3JUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlLCBRdWVyeWFibGUgfSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IERlbm9ybWFsaXplTnVsbGFibGUsIFNjaGVtYUFyZ3MgfSBmcm9tICcuL25vcm1hbC5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU25hcHNob3RJbnRlcmZhY2Uge1xuICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgcmVhZG9ubHkgYWJvcnQ6IEVycm9yO1xuXG4gIC8qKlxuICAgKiBHZXRzIHRoZSAoZ2xvYmFsbHkgcmVmZXJlbnRpYWxseSBzdGFibGUpIHJlc3BvbnNlIGZvciBhIGdpdmVuIGVuZHBvaW50L2FyZ3MgcGFpciBmcm9tIHN0YXRlIGdpdmVuLlxuICAgKiBAc2VlIGh0dHBzOi8vZGF0YWNsaWVudC5pby9kb2NzL2FwaS9TbmFwc2hvdCNnZXRSZXNwb25zZVxuICAgKi9cbiAgZ2V0UmVzcG9uc2U8RSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlPihcbiAgICBlbmRwb2ludDogRSxcbiAgICAuLi5hcmdzOiByZWFkb25seSBbbnVsbF1cbiAgKToge1xuICAgIGRhdGE6IERlbm9ybWFsaXplTnVsbGFibGU8RVsnc2NoZW1hJ10+O1xuICAgIGV4cGlyeVN0YXR1czogRXhwaXJ5U3RhdHVzSW50ZXJmYWNlO1xuICAgIGV4cGlyZXNBdDogbnVtYmVyO1xuICB9O1xuXG4gIGdldFJlc3BvbnNlPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gICAgZW5kcG9pbnQ6IEUsXG4gICAgLi4uYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dXG4gICk6IHtcbiAgICBkYXRhOiBEZW5vcm1hbGl6ZU51bGxhYmxlPEVbJ3NjaGVtYSddPjtcbiAgICBleHBpcnlTdGF0dXM6IEV4cGlyeVN0YXR1c0ludGVyZmFjZTtcbiAgICBleHBpcmVzQXQ6IG51bWJlcjtcbiAgfTtcblxuICBnZXRSZXNwb25zZTxcbiAgICBFIGV4dGVuZHMgUGljazxFbmRwb2ludEludGVyZmFjZSwgJ2tleScgfCAnc2NoZW1hJyB8ICdpbnZhbGlkSWZTdGFsZSc+LFxuICA+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEVbJ2tleSddPl0gfCByZWFkb25seSBbbnVsbF1cbiAgKToge1xuICAgIGRhdGE6IERlbm9ybWFsaXplTnVsbGFibGU8RVsnc2NoZW1hJ10+O1xuICAgIGV4cGlyeVN0YXR1czogRXhwaXJ5U3RhdHVzSW50ZXJmYWNlO1xuICAgIGV4cGlyZXNBdDogbnVtYmVyO1xuICB9O1xuXG4gIC8qKiBAc2VlIGh0dHBzOi8vZGF0YWNsaWVudC5pby9kb2NzL2FwaS9TbmFwc2hvdCNnZXRFcnJvciAqL1xuICBnZXRFcnJvcjxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB8IHJlYWRvbmx5IFtudWxsXVxuICApOiBFcnJvclR5cGVzIHwgdW5kZWZpbmVkO1xuXG4gIGdldEVycm9yPEUgZXh0ZW5kcyBQaWNrPEVuZHBvaW50SW50ZXJmYWNlLCAna2V5Jz4+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEVbJ2tleSddPl0gfCByZWFkb25seSBbbnVsbF1cbiAgKTogRXJyb3JUeXBlcyB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogUmV0cmlldmVkIG1lbW9pemVkIHZhbHVlIGZvciBhbnkgUXVlcmFibGUgc2NoZW1hXG4gICAqIEBzZWUgaHR0cHM6Ly9kYXRhY2xpZW50LmlvL2RvY3MvYXBpL1NuYXBzaG90I2dldFxuICAgKi9cbiAgZ2V0PFMgZXh0ZW5kcyBRdWVyeWFibGU+KFxuICAgIHNjaGVtYTogUyxcbiAgICAuLi5hcmdzOiBTY2hlbWFBcmdzPFM+XG4gICk6IERlbm9ybWFsaXplTnVsbGFibGU8Uz4gfCB1bmRlZmluZWQ7XG59XG5cbi8vIGxvb3NlciB2ZXJzaW9uIHRvIGFsbG93IGZvciBjcm9zcy1wYWNrYWdlIHZlcnNpb24gY29tcGF0aWJpbGl0eVxuZXhwb3J0IHR5cGUgRXhwaXJ5U3RhdHVzSW50ZXJmYWNlID0gMSB8IDIgfCAzO1xuIl0sIm1hcHBpbmdzIjoiIiwiaWdub3JlTGlzdCI6W119 |
@@ -5,2 +5,4 @@ import type { ErrorTypes } from './ErrorTypes.js'; | ||
export interface SnapshotInterface { | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
/** | ||
@@ -26,3 +28,4 @@ * Gets the (globally referentially stable) response for a given endpoint/args pair from state given. | ||
/** @see https://dataclient.io/docs/api/Snapshot#getError */ | ||
getError: <E extends Pick<EndpointInterface, 'key'>, Args extends readonly [...Parameters<E['key']>]>(endpoint: E, ...args: Args) => ErrorTypes | undefined; | ||
getError<E extends EndpointInterface>(endpoint: E, ...args: readonly [...Parameters<E>] | readonly [null]): ErrorTypes | undefined; | ||
getError<E extends Pick<EndpointInterface, 'key'>>(endpoint: E, ...args: readonly [...Parameters<E['key']>] | readonly [null]): ErrorTypes | undefined; | ||
/** | ||
@@ -33,6 +36,4 @@ * Retrieved memoized value for any Querable schema | ||
get<S extends Queryable>(schema: S, ...args: SchemaArgs<S>): DenormalizeNullable<S> | undefined; | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
} | ||
export type ExpiryStatusInterface = 1 | 2 | 3; | ||
//# sourceMappingURL=SnapshotInterface.d.ts.map |
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL1NuYXBzaG90SW50ZXJmYWNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRXJyb3JUeXBlcyB9IGZyb20gJy4vRXJyb3JUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlLCBRdWVyeWFibGUgfSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IERlbm9ybWFsaXplTnVsbGFibGUsIFNjaGVtYUFyZ3MgfSBmcm9tICcuL25vcm1hbC5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU25hcHNob3RJbnRlcmZhY2Uge1xuICAvKipcbiAgICogR2V0cyB0aGUgKGdsb2JhbGx5IHJlZmVyZW50aWFsbHkgc3RhYmxlKSByZXNwb25zZSBmb3IgYSBnaXZlbiBlbmRwb2ludC9hcmdzIHBhaXIgZnJvbSBzdGF0ZSBnaXZlbi5cbiAgICogQHNlZSBodHRwczovL2RhdGFjbGllbnQuaW8vZG9jcy9hcGkvU25hcHNob3QjZ2V0UmVzcG9uc2VcbiAgICovXG4gIGdldFJlc3BvbnNlPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gICAgZW5kcG9pbnQ6IEUsXG4gICAgLi4uYXJnczogcmVhZG9ubHkgW251bGxdXG4gICk6IHtcbiAgICBkYXRhOiBEZW5vcm1hbGl6ZU51bGxhYmxlPEVbJ3NjaGVtYSddPjtcbiAgICBleHBpcnlTdGF0dXM6IEV4cGlyeVN0YXR1c0ludGVyZmFjZTtcbiAgICBleHBpcmVzQXQ6IG51bWJlcjtcbiAgfTtcblxuICBnZXRSZXNwb25zZTxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XVxuICApOiB7XG4gICAgZGF0YTogRGVub3JtYWxpemVOdWxsYWJsZTxFWydzY2hlbWEnXT47XG4gICAgZXhwaXJ5U3RhdHVzOiBFeHBpcnlTdGF0dXNJbnRlcmZhY2U7XG4gICAgZXhwaXJlc0F0OiBudW1iZXI7XG4gIH07XG5cbiAgZ2V0UmVzcG9uc2U8XG4gICAgRSBleHRlbmRzIFBpY2s8RW5kcG9pbnRJbnRlcmZhY2UsICdrZXknIHwgJ3NjaGVtYScgfCAnaW52YWxpZElmU3RhbGUnPixcbiAgPihcbiAgICBlbmRwb2ludDogRSxcbiAgICAuLi5hcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFWydrZXknXT5dIHwgcmVhZG9ubHkgW251bGxdXG4gICk6IHtcbiAgICBkYXRhOiBEZW5vcm1hbGl6ZU51bGxhYmxlPEVbJ3NjaGVtYSddPjtcbiAgICBleHBpcnlTdGF0dXM6IEV4cGlyeVN0YXR1c0ludGVyZmFjZTtcbiAgICBleHBpcmVzQXQ6IG51bWJlcjtcbiAgfTtcblxuICAvKiogQHNlZSBodHRwczovL2RhdGFjbGllbnQuaW8vZG9jcy9hcGkvU25hcHNob3QjZ2V0RXJyb3IgKi9cbiAgZ2V0RXJyb3I6IDxcbiAgICBFIGV4dGVuZHMgUGljazxFbmRwb2ludEludGVyZmFjZSwgJ2tleSc+LFxuICAgIEFyZ3MgZXh0ZW5kcyByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFWydrZXknXT5dLFxuICA+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IEFyZ3NcbiAgKSA9PiBFcnJvclR5cGVzIHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBSZXRyaWV2ZWQgbWVtb2l6ZWQgdmFsdWUgZm9yIGFueSBRdWVyYWJsZSBzY2hlbWFcbiAgICogQHNlZSBodHRwczovL2RhdGFjbGllbnQuaW8vZG9jcy9hcGkvU25hcHNob3QjZ2V0XG4gICAqL1xuICBnZXQ8UyBleHRlbmRzIFF1ZXJ5YWJsZT4oXG4gICAgc2NoZW1hOiBTLFxuICAgIC4uLmFyZ3M6IFNjaGVtYUFyZ3M8Uz5cbiAgKTogRGVub3JtYWxpemVOdWxsYWJsZTxTPiB8IHVuZGVmaW5lZDtcblxuICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgcmVhZG9ubHkgYWJvcnQ6IEVycm9yO1xufVxuXG4vLyBsb29zZXIgdmVyc2lvbiB0byBhbGxvdyBmb3IgY3Jvc3MtcGFja2FnZSB2ZXJzaW9uIGNvbXBhdGliaWxpdHlcbmV4cG9ydCB0eXBlIEV4cGlyeVN0YXR1c0ludGVyZmFjZSA9IDEgfCAyIHwgMztcbiJdLCJtYXBwaW5ncyI6IiIsImlnbm9yZUxpc3QiOltdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL1NuYXBzaG90SW50ZXJmYWNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRXJyb3JUeXBlcyB9IGZyb20gJy4vRXJyb3JUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlLCBRdWVyeWFibGUgfSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IERlbm9ybWFsaXplTnVsbGFibGUsIFNjaGVtYUFyZ3MgfSBmcm9tICcuL25vcm1hbC5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU25hcHNob3RJbnRlcmZhY2Uge1xuICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgcmVhZG9ubHkgYWJvcnQ6IEVycm9yO1xuXG4gIC8qKlxuICAgKiBHZXRzIHRoZSAoZ2xvYmFsbHkgcmVmZXJlbnRpYWxseSBzdGFibGUpIHJlc3BvbnNlIGZvciBhIGdpdmVuIGVuZHBvaW50L2FyZ3MgcGFpciBmcm9tIHN0YXRlIGdpdmVuLlxuICAgKiBAc2VlIGh0dHBzOi8vZGF0YWNsaWVudC5pby9kb2NzL2FwaS9TbmFwc2hvdCNnZXRSZXNwb25zZVxuICAgKi9cbiAgZ2V0UmVzcG9uc2U8RSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlPihcbiAgICBlbmRwb2ludDogRSxcbiAgICAuLi5hcmdzOiByZWFkb25seSBbbnVsbF1cbiAgKToge1xuICAgIGRhdGE6IERlbm9ybWFsaXplTnVsbGFibGU8RVsnc2NoZW1hJ10+O1xuICAgIGV4cGlyeVN0YXR1czogRXhwaXJ5U3RhdHVzSW50ZXJmYWNlO1xuICAgIGV4cGlyZXNBdDogbnVtYmVyO1xuICB9O1xuXG4gIGdldFJlc3BvbnNlPEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZT4oXG4gICAgZW5kcG9pbnQ6IEUsXG4gICAgLi4uYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dXG4gICk6IHtcbiAgICBkYXRhOiBEZW5vcm1hbGl6ZU51bGxhYmxlPEVbJ3NjaGVtYSddPjtcbiAgICBleHBpcnlTdGF0dXM6IEV4cGlyeVN0YXR1c0ludGVyZmFjZTtcbiAgICBleHBpcmVzQXQ6IG51bWJlcjtcbiAgfTtcblxuICBnZXRSZXNwb25zZTxcbiAgICBFIGV4dGVuZHMgUGljazxFbmRwb2ludEludGVyZmFjZSwgJ2tleScgfCAnc2NoZW1hJyB8ICdpbnZhbGlkSWZTdGFsZSc+LFxuICA+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEVbJ2tleSddPl0gfCByZWFkb25seSBbbnVsbF1cbiAgKToge1xuICAgIGRhdGE6IERlbm9ybWFsaXplTnVsbGFibGU8RVsnc2NoZW1hJ10+O1xuICAgIGV4cGlyeVN0YXR1czogRXhwaXJ5U3RhdHVzSW50ZXJmYWNlO1xuICAgIGV4cGlyZXNBdDogbnVtYmVyO1xuICB9O1xuXG4gIC8qKiBAc2VlIGh0dHBzOi8vZGF0YWNsaWVudC5pby9kb2NzL2FwaS9TbmFwc2hvdCNnZXRFcnJvciAqL1xuICBnZXRFcnJvcjxFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB8IHJlYWRvbmx5IFtudWxsXVxuICApOiBFcnJvclR5cGVzIHwgdW5kZWZpbmVkO1xuXG4gIGdldEVycm9yPEUgZXh0ZW5kcyBQaWNrPEVuZHBvaW50SW50ZXJmYWNlLCAna2V5Jz4+KFxuICAgIGVuZHBvaW50OiBFLFxuICAgIC4uLmFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEVbJ2tleSddPl0gfCByZWFkb25seSBbbnVsbF1cbiAgKTogRXJyb3JUeXBlcyB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogUmV0cmlldmVkIG1lbW9pemVkIHZhbHVlIGZvciBhbnkgUXVlcmFibGUgc2NoZW1hXG4gICAqIEBzZWUgaHR0cHM6Ly9kYXRhY2xpZW50LmlvL2RvY3MvYXBpL1NuYXBzaG90I2dldFxuICAgKi9cbiAgZ2V0PFMgZXh0ZW5kcyBRdWVyeWFibGU+KFxuICAgIHNjaGVtYTogUyxcbiAgICAuLi5hcmdzOiBTY2hlbWFBcmdzPFM+XG4gICk6IERlbm9ybWFsaXplTnVsbGFibGU8Uz4gfCB1bmRlZmluZWQ7XG59XG5cbi8vIGxvb3NlciB2ZXJzaW9uIHRvIGFsbG93IGZvciBjcm9zcy1wYWNrYWdlIHZlcnNpb24gY29tcGF0aWJpbGl0eVxuZXhwb3J0IHR5cGUgRXhwaXJ5U3RhdHVzSW50ZXJmYWNlID0gMSB8IDIgfCAzO1xuIl0sIm1hcHBpbmdzIjoiIiwiaWdub3JlTGlzdCI6W119 |
{ | ||
"name": "@data-client/endpoint", | ||
"version": "0.11.4", | ||
"version": "0.12.3", | ||
"description": "Declarative Network Interface Definitions", | ||
@@ -120,2 +120,3 @@ "homepage": "https://dataclient.io/docs/guides/custom-protocol", | ||
"author": "Nathaniel Tucker <me@ntucker.me> (https://github.com/ntucker)", | ||
"funding": "https://github.com/sponsors/ntucker", | ||
"license": "Apache-2.0", | ||
@@ -122,0 +123,0 @@ "repository": { |
@@ -57,3 +57,5 @@ // eslint-env jest | ||
}); | ||
beforeEach(() => (warnSpy = jest.spyOn(console, 'warn'))); | ||
beforeEach(() => | ||
(warnSpy = jest.spyOn(console, 'warn')).mockImplementation(() => {}), | ||
); | ||
@@ -60,0 +62,0 @@ test('should throw a custom error if data loads with string unexpected value', () => { |
@@ -63,3 +63,5 @@ // eslint-env jest | ||
}); | ||
beforeEach(() => (warnSpy = jest.spyOn(console, 'warn'))); | ||
beforeEach(() => | ||
(warnSpy = jest.spyOn(console, 'warn')).mockImplementation(() => {}), | ||
); | ||
@@ -66,0 +68,0 @@ test('normalizes an entity', () => { |
@@ -303,3 +303,5 @@ // eslint-env jest | ||
}); | ||
beforeEach(() => (warnSpy = jest.spyOn(console, 'warn'))); | ||
beforeEach(() => | ||
(warnSpy = jest.spyOn(console, 'warn')).mockImplementation(() => {}), | ||
); | ||
@@ -306,0 +308,0 @@ test('normalizes an entity', () => { |
@@ -20,2 +20,9 @@ // eslint-env jest | ||
}); | ||
let warnSpy; | ||
afterEach(() => { | ||
warnSpy.mockRestore(); | ||
}); | ||
beforeEach(() => | ||
(warnSpy = jest.spyOn(console, 'warn')).mockImplementation(() => {}), | ||
); | ||
@@ -64,2 +71,3 @@ describe(`${schema.Union.name} normalization`, () => { | ||
expect(normalize({ id: '3', notdefined: 'yep' }, union)).toMatchSnapshot(); | ||
expect(warnSpy.mock.calls).toMatchSnapshot(); | ||
}); | ||
@@ -340,2 +348,3 @@ }); | ||
).toMatchSnapshot(); | ||
expect(warnSpy.mock.calls).toMatchSnapshot(); | ||
}); | ||
@@ -357,2 +366,3 @@ | ||
).toMatchSnapshot(); | ||
expect(warnSpy.mock.calls).toMatchSnapshot(); | ||
}); | ||
@@ -359,0 +369,0 @@ |
@@ -30,2 +30,10 @@ // eslint-env jest | ||
describe(`${schema.Values.name} normalization`, () => { | ||
let warnSpy; | ||
afterEach(() => { | ||
warnSpy.mockRestore(); | ||
}); | ||
beforeEach(() => | ||
(warnSpy = jest.spyOn(console, 'warn')).mockImplementation(() => {}), | ||
); | ||
test('normalizes without schemaAttribute', () => { | ||
@@ -93,2 +101,3 @@ class MyEntity extends IDEntity { | ||
).toMatchSnapshot(); | ||
expect(warnSpy.mock.calls).toMatchSnapshot(); | ||
}); | ||
@@ -95,0 +104,0 @@ |
@@ -6,2 +6,5 @@ import type { ErrorTypes } from './ErrorTypes.js'; | ||
export interface SnapshotInterface { | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
/** | ||
@@ -41,10 +44,12 @@ * Gets the (globally referentially stable) response for a given endpoint/args pair from state given. | ||
/** @see https://dataclient.io/docs/api/Snapshot#getError */ | ||
getError: < | ||
E extends Pick<EndpointInterface, 'key'>, | ||
Args extends readonly [...Parameters<E['key']>], | ||
>( | ||
getError<E extends EndpointInterface>( | ||
endpoint: E, | ||
...args: Args | ||
) => ErrorTypes | undefined; | ||
...args: readonly [...Parameters<E>] | readonly [null] | ||
): ErrorTypes | undefined; | ||
getError<E extends Pick<EndpointInterface, 'key'>>( | ||
endpoint: E, | ||
...args: readonly [...Parameters<E['key']>] | readonly [null] | ||
): ErrorTypes | undefined; | ||
/** | ||
@@ -58,5 +63,2 @@ * Retrieved memoized value for any Querable schema | ||
): DenormalizeNullable<S> | undefined; | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
} | ||
@@ -63,0 +65,0 @@ |
@@ -5,2 +5,4 @@ import { ErrorTypes } from './ErrorTypes.js'; | ||
export interface SnapshotInterface { | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
/** | ||
@@ -34,5 +36,12 @@ * Gets the (globally referentially stable) response for a given endpoint/args pair from state given. | ||
/** @see https://dataclient.io/docs/api/Snapshot#getError */ | ||
getError: <E extends Pick<EndpointInterface, 'key'>, Args extends readonly [ | ||
getError<E extends EndpointInterface>(endpoint: E, ...args: readonly [ | ||
...Parameters<E> | ||
] | readonly [ | ||
null | ||
]): ErrorTypes | undefined; | ||
getError<E extends Pick<EndpointInterface, 'key'>>(endpoint: E, ...args: readonly [ | ||
...Parameters<E['key']> | ||
]>(endpoint: E, ...args: Args) => ErrorTypes | undefined; | ||
] | readonly [ | ||
null | ||
]): ErrorTypes | undefined; | ||
/** | ||
@@ -43,6 +52,4 @@ * Retrieved memoized value for any Querable schema | ||
get<S extends Queryable>(schema: S, ...args: SchemaArgs<S>): DenormalizeNullable<S> | undefined; | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
} | ||
export type ExpiryStatusInterface = 1 | 2 | 3; | ||
//# sourceMappingURL=SnapshotInterface.d.ts.map |
@@ -5,2 +5,4 @@ import type { ErrorTypes } from './ErrorTypes.js'; | ||
export interface SnapshotInterface { | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
/** | ||
@@ -34,5 +36,12 @@ * Gets the (globally referentially stable) response for a given endpoint/args pair from state given. | ||
/** @see https://dataclient.io/docs/api/Snapshot#getError */ | ||
getError: <E extends Pick<EndpointInterface, 'key'>, Args extends readonly [ | ||
getError<E extends EndpointInterface>(endpoint: E, ...args: readonly [ | ||
...Parameters<E> | ||
] | readonly [ | ||
null | ||
]): ErrorTypes | undefined; | ||
getError<E extends Pick<EndpointInterface, 'key'>>(endpoint: E, ...args: readonly [ | ||
...Parameters<E['key']> | ||
]>(endpoint: E, ...args: Args) => ErrorTypes | undefined; | ||
] | readonly [ | ||
null | ||
]): ErrorTypes | undefined; | ||
/** | ||
@@ -43,6 +52,4 @@ * Retrieved memoized value for any Querable schema | ||
get<S extends Queryable>(schema: S, ...args: SchemaArgs<S>): DenormalizeNullable<S> | undefined; | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
} | ||
export type ExpiryStatusInterface = 1 | 2 | 3; | ||
//# sourceMappingURL=SnapshotInterface.d.ts.map |
@@ -5,2 +5,4 @@ import type { ErrorTypes } from './ErrorTypes.js'; | ||
export interface SnapshotInterface { | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
/** | ||
@@ -34,5 +36,12 @@ * Gets the (globally referentially stable) response for a given endpoint/args pair from state given. | ||
/** @see https://dataclient.io/docs/api/Snapshot#getError */ | ||
getError: <E extends Pick<EndpointInterface, 'key'>, Args extends readonly [ | ||
getError<E extends EndpointInterface>(endpoint: E, ...args: readonly [ | ||
...Parameters<E> | ||
] | readonly [ | ||
null | ||
]): ErrorTypes | undefined; | ||
getError<E extends Pick<EndpointInterface, 'key'>>(endpoint: E, ...args: readonly [ | ||
...Parameters<E['key']> | ||
]>(endpoint: E, ...args: Args) => ErrorTypes | undefined; | ||
] | readonly [ | ||
null | ||
]): ErrorTypes | undefined; | ||
/** | ||
@@ -43,6 +52,4 @@ * Retrieved memoized value for any Querable schema | ||
get<S extends Queryable>(schema: S, ...args: SchemaArgs<S>): DenormalizeNullable<S> | undefined; | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
} | ||
export type ExpiryStatusInterface = 1 | 2 | 3; | ||
//# sourceMappingURL=SnapshotInterface.d.ts.map |
@@ -5,2 +5,4 @@ import type { ErrorTypes } from './ErrorTypes.js'; | ||
export interface SnapshotInterface { | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
/** | ||
@@ -34,5 +36,12 @@ * Gets the (globally referentially stable) response for a given endpoint/args pair from state given. | ||
/** @see https://dataclient.io/docs/api/Snapshot#getError */ | ||
getError: <E extends Pick<EndpointInterface, 'key'>, Args extends readonly [ | ||
getError<E extends EndpointInterface>(endpoint: E, ...args: readonly [ | ||
...Parameters<E> | ||
] | readonly [ | ||
null | ||
]): ErrorTypes | undefined; | ||
getError<E extends Pick<EndpointInterface, 'key'>>(endpoint: E, ...args: readonly [ | ||
...Parameters<E['key']> | ||
]>(endpoint: E, ...args: Args) => ErrorTypes | undefined; | ||
] | readonly [ | ||
null | ||
]): ErrorTypes | undefined; | ||
/** | ||
@@ -43,6 +52,4 @@ * Retrieved memoized value for any Querable schema | ||
get<S extends Queryable>(schema: S, ...args: SchemaArgs<S>): DenormalizeNullable<S> | undefined; | ||
readonly fetchedAt: number; | ||
readonly abort: Error; | ||
} | ||
export type ExpiryStatusInterface = 1 | 2 | 3; | ||
//# sourceMappingURL=SnapshotInterface.d.ts.map |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
1222327
18390