@rest-hooks/core
Advanced tools
Comparing version 4.4.0-next.0 to 4.4.0
@@ -289,2 +289,2 @@ import { WeakEntityMap, ExpiryStatus, denormalizeCached, isEntity } from '@rest-hooks/normalizr'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["WeakEntityMap","ExpiryStatus","denormalizeCached","isEntity","inferResults","validateInference","createInvalidate","createInvalidateAll","createReceive","createReset","createUnsubscription","createSubscription","initialState","selectMeta","unsetDispatch","action","Error","unsetState","Controller","constructor","dispatch","getState","globalCache","entities","results","invalidate","endpoint","args","Promise","resolve","invalidateAll","options","key","testKey","resetEntireStore","setResponse","rest","response","length","slice","receive","setError","error","receiveError","meta","subscribe","unsubscribe","snapshot","state","fetchedAt","Snapshot","getError","undefined","errorPolicy","getResponse","isActive","cacheResults","schema","expiresAt","invalidResults","indexes","data","expiryStatus","Valid","Infinity","schemaHasEntity","invalidated","Invalid","invalidIfStale","InvalidIfStale","process","env","NODE_ENV","Array","isArray","paths","invalidDenormalize","entityExpiresAt","entityMeta","pk","_entityMeta$key","_entityMeta$key$pk","entityExpiry","nestedSchema","Object","values","some","x","controller"],"sources":["../../src/controller/BaseController.ts"],"sourcesContent":["import type {\n  ErrorTypes,\n  SnapshotInterface,\n  DenormalizeCache,\n  Schema,\n} from '@rest-hooks/normalizr';\nimport {\n  WeakEntityMap,\n  ExpiryStatus,\n  EndpointInterface,\n  FetchFunction,\n  ResolveType,\n  DenormalizeNullable,\n  Path,\n  denormalizeCached,\n  isEntity,\n} from '@rest-hooks/normalizr';\nimport { inferResults, validateInference } from '@rest-hooks/normalizr';\n\nimport createInvalidate from './createInvalidate.js';\nimport createInvalidateAll from './createInvalidateAll.js';\nimport createReceive from './createReceive.js';\nimport createReset from './createReset.js';\nimport {\n  createUnsubscription,\n  createSubscription,\n} from './createSubscription.js';\nimport type { EndpointUpdateFunction } from './types.js';\nimport { initialState } from '../state/reducer/createReducer.js';\nimport selectMeta from '../state/selectMeta.js';\nimport type {\n  ActionTypes as BroadActionTypes,\n  CombinedActionTypes,\n  State,\n} from '../types.js';\n\nexport type GenericDispatch = (value: any) => Promise<void>;\nexport type CompatibleDispatch = (value: CombinedActionTypes) => Promise<void>;\ntype PreviousDispatch = (value: BroadActionTypes) => Promise<void>;\n\ninterface ConstructorProps<D extends GenericDispatch = CompatibleDispatch> {\n  dispatch?: D;\n  getState?: () => State<unknown>;\n  globalCache?: DenormalizeCache;\n}\n\nconst unsetDispatch = (action: unknown): Promise<void> => {\n  throw new Error(\n    `Dispatching while constructing your middleware is not allowed. ` +\n      `Other middleware would not be applied to this dispatch.`,\n  );\n};\nconst unsetState = (): State<unknown> => {\n  // This is only the value until it is set by the CacheProvider\n  /* istanbul ignore next */\n  return initialState;\n};\n\n/**\n * Imperative control of Rest Hooks store\n * @see https://resthooks.io/docs/api/Controller\n */\nexport default class Controller<\n  D extends GenericDispatch = CompatibleDispatch,\n> {\n  /**\n   * Dispatches an action to Rest Hooks reducer.\n   *\n   * @see https://resthooks.io/docs/api/Controller#dispatch\n   */\n  declare readonly dispatch: D;\n  /**\n   * Gets the latest state snapshot that is fully committed.\n   *\n   * This can be useful for imperative use-cases like event handlers.\n   * This should *not* be used to render; instead useSuspense() or useCache()\n   * @see https://resthooks.io/docs/api/Controller#getState\n   */\n  declare readonly getState: () => State<unknown>;\n  declare readonly globalCache: DenormalizeCache;\n\n  constructor({\n    dispatch = unsetDispatch as any,\n    getState = unsetState,\n    globalCache = {\n      entities: {},\n      results: {},\n    },\n  }: ConstructorProps<D> = {}) {\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.globalCache = globalCache;\n  }\n\n  /*************** Action Dispatchers ***************/\n\n  /**\n   * Forces refetching and suspense on useSuspense with the same Endpoint and parameters.\n   * @see https://resthooks.io/docs/api/Controller#invalidate\n   */\n  invalidate = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createInvalidate(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /**\n   * Forces refetching and suspense on useSuspense on all matching endpoint result keys.\n   * @see https://resthooks.io/docs/api/Controller#invalidateAll\n   */\n  invalidateAll = (options: { testKey: (key: string) => boolean }) =>\n    this.dispatch(createInvalidateAll((key: string) => options.testKey(key)));\n\n  /**\n   * Resets the entire Rest Hooks cache. All inflight requests will not resolve.\n   * @see https://resthooks.io/docs/api/Controller#resetEntireStore\n   */\n  resetEntireStore = (): Promise<void> => this.dispatch(createReset());\n\n  /**\n   * Stores response in cache for given Endpoint and args.\n   * @see https://resthooks.io/docs/api/Controller#set\n   */\n  setResponse = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    const response: ResolveType<E> = rest[rest.length - 1];\n    const action = createReceive(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n    });\n    return this.dispatch(action);\n  };\n\n  // TODO: deprecate\n  /**\n   * Another name for setResponse\n   * @see https://resthooks.io/docs/api/Controller#setResponse\n   */\n  /* istanbul ignore next */ receive = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    /* istanbul ignore next */\n    return this.setResponse(endpoint, ...rest);\n  };\n\n  /**\n   * Stores the result of Endpoint and args as the error provided.\n   * @see https://resthooks.io/docs/api/Controller#setError\n   */\n  setError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    const response: Error = rest[rest.length - 1];\n    const action = createReceive(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n      error: true,\n    });\n    return this.dispatch(action);\n  };\n\n  // TODO: deprecate\n  /**\n   * Another name for setError\n   * @see https://resthooks.io/docs/api/Controller#setError\n   */\n  /* istanbul ignore next */ receiveError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    /* istanbul ignore next */\n    return this.setError(endpoint, ...rest);\n  };\n\n  /**\n   * Resolves an inflight fetch. `fetchedAt` should `fetch`'s `createdAt`\n   * @see https://resthooks.io/docs/api/Controller#resolve\n   */\n  resolve = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    meta:\n      | {\n          args: readonly [...Parameters<E>];\n          response: Error;\n          fetchedAt: number;\n          error: true;\n        }\n      | {\n          args: readonly [...Parameters<E>];\n          response: any;\n          fetchedAt: number;\n          error?: false;\n        },\n  ): Promise<void> => {\n    return this.dispatch(createReceive(endpoint, meta as any));\n  };\n\n  /**\n   * Marks a new subscription to a given Endpoint.\n   * @see https://resthooks.io/docs/api/Controller#subscribe\n   */\n  subscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createSubscription(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /**\n   * Marks completion of subscription to a given Endpoint.\n   * @see https://resthooks.io/docs/api/Controller#unsubscribe\n   */\n  unsubscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createUnsubscription(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /*************** More ***************/\n\n  /* TODO:\n  abort = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): Promise<void>\n  */\n\n  /**\n   * Gets a snapshot (https://resthooks.io/docs/api/Snapshot)\n   * @see https://resthooks.io/docs/api/Controller#snapshot\n   */\n  snapshot = (state: State<unknown>, fetchedAt?: number): SnapshotInterface => {\n    return new Snapshot(this, state, fetchedAt);\n  };\n\n  /**\n   * Gets the error, if any, for a given endpoint. Returns undefined for no errors.\n   * @see https://resthooks.io/docs/api/Controller#getError\n   */\n  getError = <\n    E extends Pick<EndpointInterface, 'key'>,\n    Args extends readonly [...Parameters<E['key']>] | readonly [null],\n  >(\n    endpoint: E,\n    ...rest: [...Args, State<unknown>]\n  ): ErrorTypes | undefined => {\n    if (rest[0] === null) return;\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;\n    const key = endpoint.key(...args);\n\n    const meta = selectMeta(state, key);\n    const results = state.results[key];\n\n    if (results !== undefined && meta?.errorPolicy === 'soft') return;\n\n    return meta?.error as any;\n  };\n\n  /**\n   * Gets the (globally referentially stable) response for a given endpoint/args pair from state given.\n   * @see https://resthooks.io/docs/api/Controller#getResponse\n   */\n  getResponse = <\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n    Args extends readonly [...Parameters<E['key']>] | readonly [null],\n  >(\n    endpoint: E,\n    ...rest: [...Args, State<unknown>]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } => {\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;\n    const isActive = args.length !== 1 || args[0] !== null;\n    const key = isActive ? endpoint.key(...args) : '';\n    const cacheResults = isActive ? state.results[key] : undefined;\n    const schema = endpoint.schema;\n    const meta = selectMeta(state, key);\n    let expiresAt = meta?.expiresAt;\n\n    let invalidResults = false;\n    let results;\n    if (cacheResults === undefined && endpoint.schema !== undefined) {\n      results = inferResults(\n        endpoint.schema,\n        args,\n        state.indexes,\n        state.entities,\n      );\n      invalidResults = !validateInference(results);\n      if (!expiresAt && invalidResults) expiresAt = 1;\n    } else {\n      results = cacheResults;\n    }\n\n    if (!isActive) {\n      return {\n        data: results as any,\n        expiryStatus: ExpiryStatus.Valid,\n        expiresAt: Infinity,\n      };\n    }\n\n    if (!endpoint.schema || !schemaHasEntity(endpoint.schema)) {\n      return {\n        data: results,\n        expiryStatus: meta?.invalidated\n          ? ExpiryStatus.Invalid\n          : cacheResults && !endpoint.invalidIfStale\n          ? ExpiryStatus.Valid\n          : ExpiryStatus.InvalidIfStale,\n        expiresAt: expiresAt || 0,\n      } as {\n        data: DenormalizeNullable<E['schema']>;\n        expiryStatus: ExpiryStatus;\n        expiresAt: number;\n      };\n    }\n\n    // Warn users with bad configurations\n    /* istanbul ignore next */\n    if (process.env.NODE_ENV !== 'production' && schema && isEntity(schema)) {\n      if (Array.isArray(results)) {\n        throw new Error(\n          `fetch key ${key} has list results when single result is expected`,\n        );\n      }\n      if (typeof results === 'object') {\n        throw new Error(\n          `fetch key ${key} has object results when entity's primary key (string) result is expected`,\n        );\n      }\n    }\n\n    if (!this.globalCache.results[key])\n      this.globalCache.results[key] = new WeakEntityMap();\n\n    // second argument is false if any entities are missing\n    // eslint-disable-next-line prefer-const\n    const { data, paths } = denormalizeCached(\n      results,\n      schema,\n      state.entities,\n      this.globalCache.entities,\n      this.globalCache.results[key],\n      args,\n    ) as { data: DenormalizeNullable<E['schema']>; paths: Path[] };\n    const invalidDenormalize = typeof data === 'symbol';\n\n    // fallback to entity expiry time\n    if (!expiresAt) {\n      expiresAt = entityExpiresAt(paths, state.entityMeta);\n    }\n\n    // https://resthooks.io/docs/concepts/expiry-policy#expiry-status\n    // we don't track the difference between stale or fresh because that is tied to triggering\n    // conditions\n    const expiryStatus =\n      meta?.invalidated || (invalidDenormalize && !meta?.error)\n        ? ExpiryStatus.Invalid\n        : invalidDenormalize || endpoint.invalidIfStale || invalidResults\n        ? ExpiryStatus.InvalidIfStale\n        : ExpiryStatus.Valid;\n\n    return { data, expiryStatus, expiresAt };\n  };\n}\n\n// benchmark: https://www.measurethat.net/Benchmarks/Show/24691/0/min-reducer-vs-imperative-with-paths\n// earliest expiry dictates age\nfunction entityExpiresAt(\n  paths: Path[],\n  entityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number; // This is only the value until it is set by the CacheProvider\n      };\n    };\n  },\n) {\n  let expiresAt = Infinity;\n  for (const { pk, key } of paths) {\n    const entityExpiry = entityMeta[key]?.[pk]?.expiresAt;\n    // expiresAt will always resolve to false with any comparison\n    if (entityExpiry < expiresAt) expiresAt = entityExpiry;\n  }\n  return expiresAt;\n}\n\n/** Determine whether the schema has any entities.\n *\n * Without entities, denormalization is not needed, and results should not be inferred.\n */\nfunction schemaHasEntity(schema: Schema): boolean {\n  if (isEntity(schema)) return true;\n  if (Array.isArray(schema))\n    return schema.length !== 0 && schemaHasEntity(schema[0]);\n  if (schema && (typeof schema === 'object' || typeof schema === 'function')) {\n    const nestedSchema =\n      'schema' in schema ? (schema.schema as Record<string, Schema>) : schema;\n    if (typeof nestedSchema === 'function') {\n      return schemaHasEntity(nestedSchema);\n    }\n    return Object.values(nestedSchema).some(x => schemaHasEntity(x));\n  }\n  return false;\n}\n\nexport type { ErrorTypes };\n\nclass Snapshot<T = unknown> implements SnapshotInterface {\n  private state: State<T>;\n  private controller: Controller;\n  readonly fetchedAt: number;\n\n  constructor(controller: Controller, state: State<T>, fetchedAt = 0) {\n    this.state = state;\n    this.controller = controller;\n    this.fetchedAt = fetchedAt;\n  }\n\n  /*************** Data Access ***************/\n  /** @see https://resthooks.io/docs/api/Snapshot#getResponse */\n  getResponse = <\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n    Args extends readonly [...Parameters<E['key']>],\n  >(\n    endpoint: E,\n    ...args: Args\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } => {\n    return this.controller.getResponse(endpoint, ...args, this.state);\n  };\n\n  /** @see https://resthooks.io/docs/api/Snapshot#getError */\n  getError = <\n    E extends Pick<EndpointInterface, 'key'>,\n    Args extends readonly [...Parameters<E['key']>],\n  >(\n    endpoint: E,\n    ...args: Args\n  ): ErrorTypes | undefined => {\n    return this.controller.getError(endpoint, ...args, this.state);\n  };\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["WeakEntityMap","ExpiryStatus","denormalizeCached","isEntity","inferResults","validateInference","createInvalidate","createInvalidateAll","createReceive","createReset","createUnsubscription","createSubscription","initialState","selectMeta","unsetDispatch","action","Error","unsetState","Controller","constructor","dispatch","getState","globalCache","entities","results","invalidate","endpoint","args","Promise","resolve","invalidateAll","options","key","testKey","resetEntireStore","setResponse","rest","response","length","slice","receive","setError","error","receiveError","meta","subscribe","unsubscribe","snapshot","state","fetchedAt","Snapshot","getError","undefined","errorPolicy","getResponse","isActive","cacheResults","schema","expiresAt","invalidResults","indexes","data","expiryStatus","Valid","Infinity","schemaHasEntity","invalidated","Invalid","invalidIfStale","InvalidIfStale","process","env","NODE_ENV","Array","isArray","paths","invalidDenormalize","entityExpiresAt","entityMeta","pk","_entityMeta$key","_entityMeta$key$pk","entityExpiry","nestedSchema","Object","values","some","x","controller"],"sources":["../../src/controller/BaseController.ts"],"sourcesContent":["import type {\n  ErrorTypes,\n  SnapshotInterface,\n  DenormalizeCache,\n  Schema,\n} from '@rest-hooks/normalizr';\nimport {\n  WeakEntityMap,\n  ExpiryStatus,\n  EndpointInterface,\n  FetchFunction,\n  ResolveType,\n  DenormalizeNullable,\n  Path,\n  denormalizeCached,\n  isEntity,\n} from '@rest-hooks/normalizr';\nimport { inferResults, validateInference } from '@rest-hooks/normalizr';\n\nimport createInvalidate from './createInvalidate.js';\nimport createInvalidateAll from './createInvalidateAll.js';\nimport createReceive from './createReceive.js';\nimport createReset from './createReset.js';\nimport {\n  createUnsubscription,\n  createSubscription,\n} from './createSubscription.js';\nimport type { EndpointUpdateFunction } from './types.js';\nimport { initialState } from '../state/reducer/createReducer.js';\nimport selectMeta from '../state/selectMeta.js';\nimport type {\n  ActionTypes as BroadActionTypes,\n  CombinedActionTypes,\n  State,\n} from '../types.js';\n\nexport type GenericDispatch = (value: any) => Promise<void>;\nexport type CompatibleDispatch = (value: CombinedActionTypes) => Promise<void>;\ntype PreviousDispatch = (value: BroadActionTypes) => Promise<void>;\n\ninterface ConstructorProps<D extends GenericDispatch = CompatibleDispatch> {\n  dispatch?: D;\n  getState?: () => State<unknown>;\n  globalCache?: DenormalizeCache;\n}\n\nconst unsetDispatch = (action: unknown): Promise<void> => {\n  throw new Error(\n    `Dispatching while constructing your middleware is not allowed. ` +\n      `Other middleware would not be applied to this dispatch.`,\n  );\n};\nconst unsetState = (): State<unknown> => {\n  // This is only the value until it is set by the CacheProvider\n  /* istanbul ignore next */\n  return initialState;\n};\n\n/**\n * Imperative control of Rest Hooks store\n * @see https://resthooks.io/docs/api/Controller\n */\nexport default class Controller<\n  D extends GenericDispatch = CompatibleDispatch,\n> {\n  /**\n   * Dispatches an action to Rest Hooks reducer.\n   *\n   * @see https://resthooks.io/docs/api/Controller#dispatch\n   */\n  declare readonly dispatch: D;\n  /**\n   * Gets the latest state snapshot that is fully committed.\n   *\n   * This can be useful for imperative use-cases like event handlers.\n   * This should *not* be used to render; instead useSuspense() or useCache()\n   * @see https://resthooks.io/docs/api/Controller#getState\n   */\n  declare readonly getState: () => State<unknown>;\n  declare readonly globalCache: DenormalizeCache;\n\n  constructor({\n    dispatch = unsetDispatch as any,\n    getState = unsetState,\n    globalCache = {\n      entities: {},\n      results: {},\n    },\n  }: ConstructorProps<D> = {}) {\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.globalCache = globalCache;\n  }\n\n  /*************** Action Dispatchers ***************/\n\n  /**\n   * Forces refetching and suspense on useSuspense with the same Endpoint and parameters.\n   * @see https://resthooks.io/docs/api/Controller#invalidate\n   */\n  invalidate = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createInvalidate(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /**\n   * Forces refetching and suspense on useSuspense on all matching endpoint result keys.\n   * @see https://resthooks.io/docs/api/Controller#invalidateAll\n   */\n  invalidateAll = (options: { testKey: (key: string) => boolean }) =>\n    this.dispatch(createInvalidateAll((key: string) => options.testKey(key)));\n\n  /**\n   * Resets the entire Rest Hooks cache. All inflight requests will not resolve.\n   * @see https://resthooks.io/docs/api/Controller#resetEntireStore\n   */\n  resetEntireStore = (): Promise<void> => this.dispatch(createReset());\n\n  /**\n   * Stores response in cache for given Endpoint and args.\n   * @see https://resthooks.io/docs/api/Controller#set\n   */\n  setResponse = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    const response: ResolveType<E> = rest[rest.length - 1];\n    const action = createReceive(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n    });\n    return this.dispatch(action);\n  };\n\n  // TODO: deprecate\n  /**\n   * Another name for setResponse\n   * @see https://resthooks.io/docs/api/Controller#setResponse\n   */\n  /* istanbul ignore next */ receive = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    /* istanbul ignore next */\n    return this.setResponse(endpoint, ...rest);\n  };\n\n  /**\n   * Stores the result of Endpoint and args as the error provided.\n   * @see https://resthooks.io/docs/api/Controller#setError\n   */\n  setError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    const response: Error = rest[rest.length - 1];\n    const action = createReceive(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n      error: true,\n    });\n    return this.dispatch(action);\n  };\n\n  // TODO: deprecate\n  /**\n   * Another name for setError\n   * @see https://resthooks.io/docs/api/Controller#setError\n   */\n  /* istanbul ignore next */ receiveError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    /* istanbul ignore next */\n    return this.setError(endpoint, ...rest);\n  };\n\n  /**\n   * Resolves an inflight fetch. `fetchedAt` should `fetch`'s `createdAt`\n   * @see https://resthooks.io/docs/api/Controller#resolve\n   */\n  resolve = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    meta:\n      | {\n          args: readonly [...Parameters<E>];\n          response: Error;\n          fetchedAt: number;\n          error: true;\n        }\n      | {\n          args: readonly [...Parameters<E>];\n          response: any;\n          fetchedAt: number;\n          error?: false;\n        },\n  ): Promise<void> => {\n    return this.dispatch(createReceive(endpoint, meta as any));\n  };\n\n  /**\n   * Marks a new subscription to a given Endpoint.\n   * @see https://resthooks.io/docs/api/Controller#subscribe\n   */\n  subscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createSubscription(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /**\n   * Marks completion of subscription to a given Endpoint.\n   * @see https://resthooks.io/docs/api/Controller#unsubscribe\n   */\n  unsubscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createUnsubscription(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /*************** More ***************/\n\n  /* TODO:\n  abort = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): Promise<void>\n  */\n\n  /**\n   * Gets a snapshot (https://resthooks.io/docs/api/Snapshot)\n   * @see https://resthooks.io/docs/api/Controller#snapshot\n   */\n  snapshot = (state: State<unknown>, fetchedAt?: number): SnapshotInterface => {\n    return new Snapshot(this, state, fetchedAt);\n  };\n\n  /**\n   * Gets the error, if any, for a given endpoint. Returns undefined for no errors.\n   * @see https://resthooks.io/docs/api/Controller#getError\n   */\n  getError = <\n    E extends Pick<EndpointInterface, 'key'>,\n    Args extends readonly [...Parameters<E['key']>] | readonly [null],\n  >(\n    endpoint: E,\n    ...rest: [...Args, State<unknown>]\n  ): ErrorTypes | undefined => {\n    if (rest[0] === null) return;\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;\n    const key = endpoint.key(...args);\n\n    const meta = selectMeta(state, key);\n    const results = state.results[key];\n\n    if (results !== undefined && meta?.errorPolicy === 'soft') return;\n\n    return meta?.error as any;\n  };\n\n  /**\n   * Gets the (globally referentially stable) response for a given endpoint/args pair from state given.\n   * @see https://resthooks.io/docs/api/Controller#getResponse\n   */\n  getResponse = <\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n    Args extends readonly [...Parameters<E['key']>] | readonly [null],\n  >(\n    endpoint: E,\n    ...rest: [...Args, State<unknown>]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } => {\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;\n    const isActive = args.length !== 1 || args[0] !== null;\n    const key = isActive ? endpoint.key(...args) : '';\n    const cacheResults = isActive ? state.results[key] : undefined;\n    const schema = endpoint.schema;\n    const meta = selectMeta(state, key);\n    let expiresAt = meta?.expiresAt;\n\n    let invalidResults = false;\n    let results;\n    if (cacheResults === undefined && endpoint.schema !== undefined) {\n      results = inferResults(\n        endpoint.schema,\n        args,\n        state.indexes,\n        state.entities,\n      );\n      invalidResults = !validateInference(results);\n      if (!expiresAt && invalidResults) expiresAt = 1;\n    } else {\n      results = cacheResults;\n    }\n\n    if (!isActive) {\n      return {\n        data: results as any,\n        expiryStatus: ExpiryStatus.Valid,\n        expiresAt: Infinity,\n      };\n    }\n\n    if (!endpoint.schema || !schemaHasEntity(endpoint.schema)) {\n      return {\n        data: results,\n        expiryStatus: meta?.invalidated\n          ? ExpiryStatus.Invalid\n          : cacheResults && !endpoint.invalidIfStale\n          ? ExpiryStatus.Valid\n          : ExpiryStatus.InvalidIfStale,\n        expiresAt: expiresAt || 0,\n      } as {\n        data: DenormalizeNullable<E['schema']>;\n        expiryStatus: ExpiryStatus;\n        expiresAt: number;\n      };\n    }\n\n    // Warn users with bad configurations\n    /* istanbul ignore next */\n    if (process.env.NODE_ENV !== 'production' && schema && isEntity(schema)) {\n      if (Array.isArray(results)) {\n        throw new Error(\n          `fetch key ${key} has list results when single result is expected`,\n        );\n      }\n      if (typeof results === 'object') {\n        throw new Error(\n          `fetch key ${key} has object results when entity's primary key (string) result is expected`,\n        );\n      }\n    }\n\n    if (!this.globalCache.results[key])\n      this.globalCache.results[key] = new WeakEntityMap();\n\n    // second argument is false if any entities are missing\n    // eslint-disable-next-line prefer-const\n    const { data, paths } = denormalizeCached(\n      results,\n      schema,\n      state.entities,\n      this.globalCache.entities,\n      this.globalCache.results[key],\n      args,\n    ) as { data: DenormalizeNullable<E['schema']>; paths: Path[] };\n    const invalidDenormalize = typeof data === 'symbol';\n\n    // fallback to entity expiry time\n    if (!expiresAt) {\n      expiresAt = entityExpiresAt(paths, state.entityMeta);\n    }\n\n    // https://resthooks.io/docs/concepts/expiry-policy#expiry-status\n    // we don't track the difference between stale or fresh because that is tied to triggering\n    // conditions\n    const expiryStatus =\n      meta?.invalidated || (invalidDenormalize && !meta?.error)\n        ? ExpiryStatus.Invalid\n        : invalidDenormalize || endpoint.invalidIfStale || invalidResults\n        ? ExpiryStatus.InvalidIfStale\n        : ExpiryStatus.Valid;\n\n    return { data, expiryStatus, expiresAt };\n  };\n}\n\n// benchmark: https://www.measurethat.net/Benchmarks/Show/24691/0/min-reducer-vs-imperative-with-paths\n// earliest expiry dictates age\nfunction entityExpiresAt(\n  paths: Path[],\n  entityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number; // This is only the value until it is set by the CacheProvider\n      };\n    };\n  },\n) {\n  let expiresAt = Infinity;\n  for (const { pk, key } of paths) {\n    const entityExpiry = entityMeta[key]?.[pk]?.expiresAt;\n    // expiresAt will always resolve to false with any comparison\n    if (entityExpiry < expiresAt) expiresAt = entityExpiry;\n  }\n  return expiresAt;\n}\n\n/** Determine whether the schema has any entities.\n *\n * Without entities, denormalization is not needed, and results should not be inferred.\n */\nfunction schemaHasEntity(schema: Schema): boolean {\n  if (isEntity(schema)) return true;\n  if (Array.isArray(schema))\n    return schema.length !== 0 && schemaHasEntity(schema[0]);\n  if (schema && (typeof schema === 'object' || typeof schema === 'function')) {\n    const nestedSchema =\n      'schema' in schema ? (schema.schema as Record<string, Schema>) : schema;\n    if (typeof nestedSchema === 'function') {\n      return schemaHasEntity(nestedSchema);\n    }\n    return Object.values(nestedSchema).some(x => schemaHasEntity(x));\n  }\n  return false;\n}\n\nexport type { ErrorTypes };\n\nclass Snapshot<T = unknown> implements SnapshotInterface {\n  private state: State<T>;\n  private controller: Controller;\n  readonly fetchedAt: number;\n\n  constructor(controller: Controller, state: State<T>, fetchedAt = 0) {\n    this.state = state;\n    this.controller = controller;\n    this.fetchedAt = fetchedAt;\n  }\n\n  /*************** Data Access ***************/\n  /** @see https://resthooks.io/docs/api/Snapshot#getResponse */\n  getResponse = <\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n    Args extends readonly [...Parameters<E['key']>],\n  >(\n    endpoint: E,\n    ...args: Args\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } => {\n    return this.controller.getResponse(endpoint, ...args, this.state);\n  };\n\n  /** @see https://resthooks.io/docs/api/Snapshot#getError */\n  getError = <\n    E extends Pick<EndpointInterface, 'key'>,\n    Args extends readonly [...Parameters<E['key']>],\n  >(\n    endpoint: E,\n    ...args: Args\n  ): ErrorTypes | undefined => {\n    return this.controller.getError(endpoint, ...args, this.state);\n  };\n}\n"],"mappings":"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"} |
@@ -42,2 +42,2 @@ import { FETCH_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJlbmRwb2ludCIsImFyZ3MiLCJrZXkiLCJyZXNvbHZlIiwicmVqZWN0IiwicHJvbWlzZSIsIlByb21pc2UiLCJhIiwiYiIsIm1ldGEiLCJzY2hlbWEiLCJ0eXBlIiwic2lkZUVmZmVjdCIsInRocm90dGxlIiwib3B0aW9ucyIsImNyZWF0ZWRBdCIsIkRhdGUiLCJub3ciLCJ1cGRhdGUiLCJvcHRpbWlzdGljVXBkYXRlIiwib3B0aW1pc3RpY1Jlc3BvbnNlIiwicGF5bG9hZCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cm9sbGVyL2NyZWF0ZUZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW5kcG9pbnRJbnRlcmZhY2UgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi90eXBlcy5qcyc7XG5pbXBvcnQgeyBGRVRDSF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUge1xuICBDb21wYXRpYmxlRmV0Y2hBY3Rpb24sXG4gIENvbXBhdGlibGVGZXRjaE1ldGEsXG59IGZyb20gJy4uL2NvbXBhdGlibGVBY3Rpb25zLmpzJztcblxuLyoqXG4gKiBSZXF1ZXN0aW5nIGEgZmV0Y2ggdG8gYmVnaW5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlRmV0Y2g8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZSAmIHsgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPiB9LFxuPihcbiAgZW5kcG9pbnQ6IEUsXG4gIHsgYXJncyB9OiB7IGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB9LFxuKTogQ29tcGF0aWJsZUZldGNoQWN0aW9uPEU+IHtcbiAgY29uc3Qga2V5ID0gZW5kcG9pbnQua2V5KC4uLmFyZ3MpO1xuICBsZXQgcmVzb2x2ZTogKHZhbHVlPzogYW55IHwgUHJvbWlzZUxpa2U8YW55PikgPT4gdm9pZCA9IDAgYXMgYW55O1xuICBsZXQgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZTxhbnk+KChhLCBiKSA9PiB7XG4gICAgW3Jlc29sdmUsIHJlamVjdF0gPSBbYSwgYl07XG4gIH0pO1xuICBjb25zdCBtZXRhOiBDb21wYXRpYmxlRmV0Y2hNZXRhID0ge1xuICAgIHNjaGVtYTogZW5kcG9pbnQuc2NoZW1hLFxuICAgIHR5cGU6IGVuZHBvaW50LnNpZGVFZmZlY3QgPyAoJ211dGF0ZScgYXMgY29uc3QpIDogKCdyZWFkJyBhcyBjb25zdCksXG4gICAgYXJncyxcbiAgICBrZXksXG4gICAgdGhyb3R0bGU6ICFlbmRwb2ludC5zaWRlRWZmZWN0LFxuICAgIG9wdGlvbnM6IGVuZHBvaW50LFxuICAgIHJlc29sdmUsXG4gICAgcmVqZWN0LFxuICAgIHByb21pc2UsXG4gICAgY3JlYXRlZEF0OiBEYXRlLm5vdygpLFxuICB9O1xuXG4gIGlmIChlbmRwb2ludC51cGRhdGUpIHtcbiAgICBtZXRhLnVwZGF0ZSA9IGVuZHBvaW50LnVwZGF0ZTtcbiAgfVxuXG4gIC8vIFRPRE86IFJlbW92ZSBvbmNlIEVPTCBvbiB0aGlzIGRlcHJlY2F0ZWQgcGllY2VcbiAgLyogaXN0YW5idWwgaWdub3JlIGlmICovXG4gIGlmIChlbmRwb2ludC5vcHRpbWlzdGljVXBkYXRlKSB7XG4gICAgbWV0YS5vcHRpbWlzdGljUmVzcG9uc2UgPSBlbmRwb2ludC5vcHRpbWlzdGljVXBkYXRlKC4uLmFyZ3MpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBGRVRDSF9UWVBFLFxuICAgIHBheWxvYWQ6ICgpID0+IGVuZHBvaW50KC4uLmFyZ3MpIGFzIGFueSxcbiAgICBtZXRhLFxuICAgIGVuZHBvaW50LFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFHQSxTQUFTQSxVQUFVLFFBQVEsbUJBQW1CO0FBTTlDO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsV0FBV0EsQ0FHakNDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQ3JCO0VBQzFCLE1BQU1DLEdBQUcsR0FBR0YsUUFBUSxDQUFDRSxHQUFHLENBQUMsR0FBR0QsSUFBSSxDQUFDO0VBQ2pDLElBQUlFLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQXlCLEdBQUc7SUFDaENDLE1BQU0sRUFBRVYsUUFBUSxDQUFDVSxNQUFNO0lBQ3ZCQyxJQUFJLEVBQUVYLFFBQVEsQ0FBQ1ksVUFBVSxHQUFJLFFBQVEsR0FBYyxNQUFnQjtJQUNuRVgsSUFBSTtJQUNKQyxHQUFHO0lBQ0hXLFFBQVEsRUFBRSxDQUFDYixRQUFRLENBQUNZLFVBQVU7SUFDOUJFLE9BQU8sRUFBRWQsUUFBUTtJQUNqQkcsT0FBTztJQUNQQyxNQUFNO0lBQ05DLE9BQU87SUFDUFUsU0FBUyxFQUFFQyxJQUFJLENBQUNDLEdBQUc7RUFDckIsQ0FBQztFQUVELElBQUlqQixRQUFRLENBQUNrQixNQUFNLEVBQUU7SUFDbkJULElBQUksQ0FBQ1MsTUFBTSxHQUFHbEIsUUFBUSxDQUFDa0IsTUFBTTtFQUMvQjs7RUFFQTtFQUNBO0VBQ0EsSUFBSWxCLFFBQVEsQ0FBQ21CLGdCQUFnQixFQUFFO0lBQzdCVixJQUFJLENBQUNXLGtCQUFrQixHQUFHcEIsUUFBUSxDQUFDbUIsZ0JBQWdCLENBQUMsR0FBR2xCLElBQUksQ0FBQztFQUM5RDtFQUVBLE9BQU87SUFDTFUsSUFBSSxFQUFFYixVQUFVO0lBQ2hCdUIsT0FBTyxFQUFFQSxDQUFBLEtBQU1yQixRQUFRLENBQUMsR0FBR0MsSUFBSSxDQUFRO0lBQ3ZDUSxJQUFJO0lBQ0pUO0VBQ0YsQ0FBQztBQUNIIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJlbmRwb2ludCIsImFyZ3MiLCJrZXkiLCJyZXNvbHZlIiwicmVqZWN0IiwicHJvbWlzZSIsIlByb21pc2UiLCJhIiwiYiIsIm1ldGEiLCJzY2hlbWEiLCJ0eXBlIiwic2lkZUVmZmVjdCIsInRocm90dGxlIiwib3B0aW9ucyIsImNyZWF0ZWRBdCIsIkRhdGUiLCJub3ciLCJ1cGRhdGUiLCJvcHRpbWlzdGljVXBkYXRlIiwib3B0aW1pc3RpY1Jlc3BvbnNlIiwicGF5bG9hZCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cm9sbGVyL2NyZWF0ZUZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW5kcG9pbnRJbnRlcmZhY2UgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi90eXBlcy5qcyc7XG5pbXBvcnQgeyBGRVRDSF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUge1xuICBDb21wYXRpYmxlRmV0Y2hBY3Rpb24sXG4gIENvbXBhdGlibGVGZXRjaE1ldGEsXG59IGZyb20gJy4uL2NvbXBhdGlibGVBY3Rpb25zLmpzJztcblxuLyoqXG4gKiBSZXF1ZXN0aW5nIGEgZmV0Y2ggdG8gYmVnaW5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlRmV0Y2g8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZSAmIHsgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPiB9LFxuPihcbiAgZW5kcG9pbnQ6IEUsXG4gIHsgYXJncyB9OiB7IGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB9LFxuKTogQ29tcGF0aWJsZUZldGNoQWN0aW9uPEU+IHtcbiAgY29uc3Qga2V5ID0gZW5kcG9pbnQua2V5KC4uLmFyZ3MpO1xuICBsZXQgcmVzb2x2ZTogKHZhbHVlPzogYW55IHwgUHJvbWlzZUxpa2U8YW55PikgPT4gdm9pZCA9IDAgYXMgYW55O1xuICBsZXQgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZTxhbnk+KChhLCBiKSA9PiB7XG4gICAgW3Jlc29sdmUsIHJlamVjdF0gPSBbYSwgYl07XG4gIH0pO1xuICBjb25zdCBtZXRhOiBDb21wYXRpYmxlRmV0Y2hNZXRhID0ge1xuICAgIHNjaGVtYTogZW5kcG9pbnQuc2NoZW1hLFxuICAgIHR5cGU6IGVuZHBvaW50LnNpZGVFZmZlY3QgPyAoJ211dGF0ZScgYXMgY29uc3QpIDogKCdyZWFkJyBhcyBjb25zdCksXG4gICAgYXJncyxcbiAgICBrZXksXG4gICAgdGhyb3R0bGU6ICFlbmRwb2ludC5zaWRlRWZmZWN0LFxuICAgIG9wdGlvbnM6IGVuZHBvaW50LFxuICAgIHJlc29sdmUsXG4gICAgcmVqZWN0LFxuICAgIHByb21pc2UsXG4gICAgY3JlYXRlZEF0OiBEYXRlLm5vdygpLFxuICB9O1xuXG4gIGlmIChlbmRwb2ludC51cGRhdGUpIHtcbiAgICBtZXRhLnVwZGF0ZSA9IGVuZHBvaW50LnVwZGF0ZTtcbiAgfVxuXG4gIC8vIFRPRE86IFJlbW92ZSBvbmNlIEVPTCBvbiB0aGlzIGRlcHJlY2F0ZWQgcGllY2VcbiAgLyogaXN0YW5idWwgaWdub3JlIGlmICovXG4gIGlmIChlbmRwb2ludC5vcHRpbWlzdGljVXBkYXRlKSB7XG4gICAgbWV0YS5vcHRpbWlzdGljUmVzcG9uc2UgPSBlbmRwb2ludC5vcHRpbWlzdGljVXBkYXRlKC4uLmFyZ3MpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBGRVRDSF9UWVBFLFxuICAgIHBheWxvYWQ6ICgpID0+IGVuZHBvaW50KC4uLmFyZ3MpIGFzIGFueSxcbiAgICBtZXRhLFxuICAgIGVuZHBvaW50LFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFHQSxTQUFTQSxVQUFVLFFBQVEsbUJBQW1CO0FBTTlDO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsV0FBV0EsQ0FHakNDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQ3JCO0VBQzFCLE1BQU1DLEdBQUcsR0FBR0YsUUFBUSxDQUFDRSxHQUFHLENBQUMsR0FBR0QsSUFBSSxDQUFDO0VBQ2pDLElBQUlFLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQXlCLEdBQUc7SUFDaENDLE1BQU0sRUFBRVYsUUFBUSxDQUFDVSxNQUFNO0lBQ3ZCQyxJQUFJLEVBQUVYLFFBQVEsQ0FBQ1ksVUFBVSxHQUFJLFFBQVEsR0FBYyxNQUFnQjtJQUNuRVgsSUFBSTtJQUNKQyxHQUFHO0lBQ0hXLFFBQVEsRUFBRSxDQUFDYixRQUFRLENBQUNZLFVBQVU7SUFDOUJFLE9BQU8sRUFBRWQsUUFBUTtJQUNqQkcsT0FBTztJQUNQQyxNQUFNO0lBQ05DLE9BQU87SUFDUFUsU0FBUyxFQUFFQyxJQUFJLENBQUNDLEdBQUcsQ0FBQztFQUN0QixDQUFDO0VBRUQsSUFBSWpCLFFBQVEsQ0FBQ2tCLE1BQU0sRUFBRTtJQUNuQlQsSUFBSSxDQUFDUyxNQUFNLEdBQUdsQixRQUFRLENBQUNrQixNQUFNO0VBQy9COztFQUVBO0VBQ0E7RUFDQSxJQUFJbEIsUUFBUSxDQUFDbUIsZ0JBQWdCLEVBQUU7SUFDN0JWLElBQUksQ0FBQ1csa0JBQWtCLEdBQUdwQixRQUFRLENBQUNtQixnQkFBZ0IsQ0FBQyxHQUFHbEIsSUFBSSxDQUFDO0VBQzlEO0VBRUEsT0FBTztJQUNMVSxJQUFJLEVBQUViLFVBQVU7SUFDaEJ1QixPQUFPLEVBQUVBLENBQUEsS0FBTXJCLFFBQVEsQ0FBQyxHQUFHQyxJQUFJLENBQVE7SUFDdkNRLElBQUk7SUFDSlQ7RUFDRixDQUFDO0FBQ0gifQ== |
@@ -33,2 +33,2 @@ import { OPTIMISTIC_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPUFRJTUlTVElDX1RZUEUiLCJjcmVhdGVPcHRpbWlzdGljIiwiZW5kcG9pbnQiLCJhcmdzIiwiZmV0Y2hlZEF0IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZGF0YUV4cGlyeUxlbmd0aCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwibm93IiwiRGF0ZSIsIm1ldGEiLCJkYXRlIiwiZXhwaXJlc0F0Iiwic2NoZW1hIiwia2V5IiwidXBkYXRlIiwiZXJyb3JQb2xpY3kiLCJhY3Rpb24iLCJ0eXBlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2xsZXIvY3JlYXRlT3B0aW1pc3RpYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQHJlc3QtaG9va3Mvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgRW5kcG9pbnRVcGRhdGVGdW5jdGlvbiB9IGZyb20gJy4vdHlwZXMuanMnO1xuaW1wb3J0IHsgT1BUSU1JU1RJQ19UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHsgT3B0aW1pc3RpY0FjdGlvbiB9IGZyb20gJy4uL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVPcHRpbWlzdGljPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gIH06IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl07XG4gICAgZmV0Y2hlZEF0OiBudW1iZXI7XG4gIH0sXG4pOiBPcHRpbWlzdGljQWN0aW9uPEU+IHtcbiAgY29uc3QgZXhwaXJ5TGVuZ3RoOiBudW1iZXIgPSBlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwO1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZXhwaXJ5TGVuZ3RoIDwgMCkge1xuICAgIHRocm93IG5ldyBFcnJvcignTmVnYXRpdmUgZXhwaXJ5IGxlbmd0aCBhcmUgbm90IGFsbG93ZWQuJyk7XG4gIH1cbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgLy8gVE9ETzogVXNlIGNvcnJlY3QgdHlwZSBvbmNlIHdlIG5vIGxvbmdlciBuZWVkIGJhY2tjb21wYXRcbiAgY29uc3QgbWV0YTogYW55ID0ge1xuICAgIGFyZ3MsXG4gICAgZmV0Y2hlZEF0LFxuICAgIGRhdGU6IG5vdyxcbiAgICBleHBpcmVzQXQ6IG5vdyArIGV4cGlyeUxlbmd0aCxcbiAgICAvLyBGb3IgbGVnYWN5IHN1cHBvcnQ7IFRPRE86IHJlbW92ZVxuICAgIHNjaGVtYTogZW5kcG9pbnQuc2NoZW1hLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICB9O1xuICAvLyBGb3IgbGVnYWN5IHN1cHBvcnQ7IFRPRE86IHJlbW92ZVxuICBpZiAoZW5kcG9pbnQudXBkYXRlKSBtZXRhLnVwZGF0ZSA9IGVuZHBvaW50LnVwZGF0ZTtcbiAgaWYgKGVuZHBvaW50LmVycm9yUG9saWN5KSBtZXRhLmVycm9yUG9saWN5ID0gZW5kcG9pbnQuZXJyb3JQb2xpY3k7XG5cbiAgY29uc3QgYWN0aW9uOiBPcHRpbWlzdGljQWN0aW9uPEU+ID0ge1xuICAgIHR5cGU6IE9QVElNSVNUSUNfVFlQRSxcbiAgICBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xuICByZXR1cm4gYWN0aW9uO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFHQSxTQUFTQSxlQUFlLFFBQVEsbUJBQW1CO0FBR25ELGVBQWUsU0FBU0MsZ0JBQWdCQSxDQUt0Q0MsUUFBVyxFQUNYO0VBQ0VDLElBQUk7RUFDSkM7QUFJRixDQUFDLEVBQ29CO0VBQUEsSUFBQUMscUJBQUE7RUFDckIsTUFBTUMsWUFBb0IsSUFBQUQscUJBQUEsR0FBR0gsUUFBUSxDQUFDSyxnQkFBZ0IsWUFBQUYscUJBQUEsR0FBSSxLQUFLO0VBQy9EO0VBQ0EsSUFBSUcsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlKLFlBQVksR0FBRyxDQUFDLEVBQUU7SUFDOUQsTUFBTSxJQUFJSyxLQUFLLENBQUMseUNBQXlDLENBQUM7RUFDNUQ7RUFDQSxNQUFNQyxHQUFHLEdBQUdDLElBQUksQ0FBQ0QsR0FBRyxFQUFFO0VBQ3RCO0VBQ0EsTUFBTUUsSUFBUyxHQUFHO0lBQ2hCWCxJQUFJO0lBQ0pDLFNBQVM7SUFDVFcsSUFBSSxFQUFFSCxHQUFHO0lBQ1RJLFNBQVMsRUFBRUosR0FBRyxHQUFHTixZQUFZO0lBQzdCO0lBQ0FXLE1BQU0sRUFBRWYsUUFBUSxDQUFDZSxNQUFNO0lBQ3ZCQyxHQUFHLEVBQUVoQixRQUFRLENBQUNnQixHQUFHLENBQUMsR0FBR2YsSUFBSTtFQUMzQixDQUFDO0VBQ0Q7RUFDQSxJQUFJRCxRQUFRLENBQUNpQixNQUFNLEVBQUVMLElBQUksQ0FBQ0ssTUFBTSxHQUFHakIsUUFBUSxDQUFDaUIsTUFBTTtFQUNsRCxJQUFJakIsUUFBUSxDQUFDa0IsV0FBVyxFQUFFTixJQUFJLENBQUNNLFdBQVcsR0FBR2xCLFFBQVEsQ0FBQ2tCLFdBQVc7RUFFakUsTUFBTUMsTUFBMkIsR0FBRztJQUNsQ0MsSUFBSSxFQUFFdEIsZUFBZTtJQUNyQkUsUUFBUTtJQUNSWTtFQUNGLENBQUM7RUFDRCxPQUFPTyxNQUFNO0FBQ2YifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPUFRJTUlTVElDX1RZUEUiLCJjcmVhdGVPcHRpbWlzdGljIiwiZW5kcG9pbnQiLCJhcmdzIiwiZmV0Y2hlZEF0IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZGF0YUV4cGlyeUxlbmd0aCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwibm93IiwiRGF0ZSIsIm1ldGEiLCJkYXRlIiwiZXhwaXJlc0F0Iiwic2NoZW1hIiwia2V5IiwidXBkYXRlIiwiZXJyb3JQb2xpY3kiLCJhY3Rpb24iLCJ0eXBlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2xsZXIvY3JlYXRlT3B0aW1pc3RpYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQHJlc3QtaG9va3Mvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgRW5kcG9pbnRVcGRhdGVGdW5jdGlvbiB9IGZyb20gJy4vdHlwZXMuanMnO1xuaW1wb3J0IHsgT1BUSU1JU1RJQ19UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHsgT3B0aW1pc3RpY0FjdGlvbiB9IGZyb20gJy4uL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVPcHRpbWlzdGljPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gIH06IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl07XG4gICAgZmV0Y2hlZEF0OiBudW1iZXI7XG4gIH0sXG4pOiBPcHRpbWlzdGljQWN0aW9uPEU+IHtcbiAgY29uc3QgZXhwaXJ5TGVuZ3RoOiBudW1iZXIgPSBlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwO1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZXhwaXJ5TGVuZ3RoIDwgMCkge1xuICAgIHRocm93IG5ldyBFcnJvcignTmVnYXRpdmUgZXhwaXJ5IGxlbmd0aCBhcmUgbm90IGFsbG93ZWQuJyk7XG4gIH1cbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgLy8gVE9ETzogVXNlIGNvcnJlY3QgdHlwZSBvbmNlIHdlIG5vIGxvbmdlciBuZWVkIGJhY2tjb21wYXRcbiAgY29uc3QgbWV0YTogYW55ID0ge1xuICAgIGFyZ3MsXG4gICAgZmV0Y2hlZEF0LFxuICAgIGRhdGU6IG5vdyxcbiAgICBleHBpcmVzQXQ6IG5vdyArIGV4cGlyeUxlbmd0aCxcbiAgICAvLyBGb3IgbGVnYWN5IHN1cHBvcnQ7IFRPRE86IHJlbW92ZVxuICAgIHNjaGVtYTogZW5kcG9pbnQuc2NoZW1hLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICB9O1xuICAvLyBGb3IgbGVnYWN5IHN1cHBvcnQ7IFRPRE86IHJlbW92ZVxuICBpZiAoZW5kcG9pbnQudXBkYXRlKSBtZXRhLnVwZGF0ZSA9IGVuZHBvaW50LnVwZGF0ZTtcbiAgaWYgKGVuZHBvaW50LmVycm9yUG9saWN5KSBtZXRhLmVycm9yUG9saWN5ID0gZW5kcG9pbnQuZXJyb3JQb2xpY3k7XG5cbiAgY29uc3QgYWN0aW9uOiBPcHRpbWlzdGljQWN0aW9uPEU+ID0ge1xuICAgIHR5cGU6IE9QVElNSVNUSUNfVFlQRSxcbiAgICBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xuICByZXR1cm4gYWN0aW9uO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFHQSxTQUFTQSxlQUFlLFFBQVEsbUJBQW1CO0FBR25ELGVBQWUsU0FBU0MsZ0JBQWdCQSxDQUt0Q0MsUUFBVyxFQUNYO0VBQ0VDLElBQUk7RUFDSkM7QUFJRixDQUFDLEVBQ29CO0VBQUEsSUFBQUMscUJBQUE7RUFDckIsTUFBTUMsWUFBb0IsSUFBQUQscUJBQUEsR0FBR0gsUUFBUSxDQUFDSyxnQkFBZ0IsWUFBQUYscUJBQUEsR0FBSSxLQUFLO0VBQy9EO0VBQ0EsSUFBSUcsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlKLFlBQVksR0FBRyxDQUFDLEVBQUU7SUFDOUQsTUFBTSxJQUFJSyxLQUFLLENBQUMseUNBQXlDLENBQUM7RUFDNUQ7RUFDQSxNQUFNQyxHQUFHLEdBQUdDLElBQUksQ0FBQ0QsR0FBRyxDQUFDLENBQUM7RUFDdEI7RUFDQSxNQUFNRSxJQUFTLEdBQUc7SUFDaEJYLElBQUk7SUFDSkMsU0FBUztJQUNUVyxJQUFJLEVBQUVILEdBQUc7SUFDVEksU0FBUyxFQUFFSixHQUFHLEdBQUdOLFlBQVk7SUFDN0I7SUFDQVcsTUFBTSxFQUFFZixRQUFRLENBQUNlLE1BQU07SUFDdkJDLEdBQUcsRUFBRWhCLFFBQVEsQ0FBQ2dCLEdBQUcsQ0FBQyxHQUFHZixJQUFJO0VBQzNCLENBQUM7RUFDRDtFQUNBLElBQUlELFFBQVEsQ0FBQ2lCLE1BQU0sRUFBRUwsSUFBSSxDQUFDSyxNQUFNLEdBQUdqQixRQUFRLENBQUNpQixNQUFNO0VBQ2xELElBQUlqQixRQUFRLENBQUNrQixXQUFXLEVBQUVOLElBQUksQ0FBQ00sV0FBVyxHQUFHbEIsUUFBUSxDQUFDa0IsV0FBVztFQUVqRSxNQUFNQyxNQUEyQixHQUFHO0lBQ2xDQyxJQUFJLEVBQUV0QixlQUFlO0lBQ3JCRSxRQUFRO0lBQ1JZO0VBQ0YsQ0FBQztFQUNELE9BQU9PLE1BQU07QUFDZiJ9 |
@@ -36,2 +36,2 @@ import { SET_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfVFlQRSIsImNyZWF0ZVJlY2VpdmUiLCJlbmRwb2ludCIsImFyZ3MiLCJmZXRjaGVkQXQiLCJyZXNwb25zZSIsImVycm9yIiwiX2VuZHBvaW50JGVycm9yRXhwaXJ5IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZXJyb3JFeHBpcnlMZW5ndGgiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiRXJyb3IiLCJub3ciLCJEYXRlIiwibWV0YSIsImRhdGUiLCJleHBpcmVzQXQiLCJzY2hlbWEiLCJrZXkiLCJ1cGRhdGUiLCJlcnJvclBvbGljeSIsImFjdGlvbiIsInR5cGUiLCJwYXlsb2FkIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2xsZXIvY3JlYXRlUmVjZWl2ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlLCBSZXNvbHZlVHlwZSB9IGZyb20gJ0ByZXN0LWhvb2tzL25vcm1hbGl6cic7XG5cbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuL3R5cGVzLmpzJztcbmltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUge1xuICBDb21wYXRpYmxlUmVjZWl2ZUFjdGlvbixcbiAgQ29tcGF0aWJsZVJlY2VpdmVNZXRhLFxufSBmcm9tICcuLi9jb21wYXRpYmxlQWN0aW9ucy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlY2VpdmU8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZSAmIHtcbiAgICB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+O1xuICB9LFxuPihcbiAgZW5kcG9pbnQ6IEUsXG4gIG9wdGlvbnM6IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl07XG4gICAgcmVzcG9uc2U6IEVycm9yO1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcjogdHJ1ZTtcbiAgfSxcbik6IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWNlaXZlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICBvcHRpb25zOiB7XG4gICAgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dO1xuICAgIHJlc3BvbnNlOiBSZXNvbHZlVHlwZTxFPjtcbiAgICBmZXRjaGVkQXQ/OiBudW1iZXI7XG4gICAgZXJyb3I/OiBmYWxzZTtcbiAgfSxcbik6IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWNlaXZlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgcmVzcG9uc2UsXG4gICAgZXJyb3IgPSBmYWxzZSxcbiAgfToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogYW55O1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcj86IGJvb2xlYW47XG4gIH0sXG4pOiBDb21wYXRpYmxlUmVjZWl2ZUFjdGlvbjxFPiB7XG4gIGNvbnN0IGV4cGlyeUxlbmd0aDogbnVtYmVyID0gZXJyb3JcbiAgICA/IGVuZHBvaW50LmVycm9yRXhwaXJ5TGVuZ3RoID8/IDEwMDBcbiAgICA6IGVuZHBvaW50LmRhdGFFeHBpcnlMZW5ndGggPz8gNjAwMDA7XG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGlmIChwcm9jZXNzLmVudi5OT0RFX0VOViA9PT0gJ2RldmVsb3BtZW50JyAmJiBleHBpcnlMZW5ndGggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBleHBpcnkgbGVuZ3RoIGFyZSBub3QgYWxsb3dlZC4nKTtcbiAgfVxuICBjb25zdCBub3cgPSBEYXRlLm5vdygpO1xuICBjb25zdCBtZXRhOiBDb21wYXRpYmxlUmVjZWl2ZU1ldGEgPSB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQ6IGZldGNoZWRBdCA/PyBub3csXG4gICAgZGF0ZTogbm93LFxuICAgIGV4cGlyZXNBdDogbm93ICsgZXhwaXJ5TGVuZ3RoLFxuICAgIC8vIEZvciBsZWdhY3kgc3VwcG9ydDsgVE9ETzogcmVtb3ZlXG4gICAgc2NoZW1hOiBlbmRwb2ludC5zY2hlbWEsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gIH07XG4gIC8vIEZvciBsZWdhY3kgc3VwcG9ydDsgVE9ETzogcmVtb3ZlXG4gIGlmIChlbmRwb2ludC51cGRhdGUpIG1ldGEudXBkYXRlID0gZW5kcG9pbnQudXBkYXRlO1xuICBpZiAoZW5kcG9pbnQuZXJyb3JQb2xpY3kpIG1ldGEuZXJyb3JQb2xpY3kgPSBlbmRwb2ludC5lcnJvclBvbGljeTtcblxuICBjb25zdCBhY3Rpb246IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+ID0ge1xuICAgIHR5cGU6IFNFVF9UWVBFLFxuICAgIHBheWxvYWQ6IHJlc3BvbnNlLFxuICAgIGVuZHBvaW50OiBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xuICBpZiAoZXJyb3IpIChhY3Rpb24gYXMgYW55KS5lcnJvciA9IHRydWU7XG4gIHJldHVybiBhY3Rpb247XG59XG4iXSwibWFwcGluZ3MiOiJBQUdBLFNBQVNBLFFBQVEsUUFBUSxtQkFBbUI7QUFrQzVDLGVBQWUsU0FBU0MsYUFBYUEsQ0FLbkNDLFFBQVcsRUFDWDtFQUNFQyxJQUFJO0VBQ0pDLFNBQVM7RUFDVEMsUUFBUTtFQUNSQyxLQUFLLEdBQUc7QUFNVixDQUFDLEVBQzJCO0VBQUEsSUFBQUMscUJBQUEsRUFBQUMscUJBQUE7RUFDNUIsTUFBTUMsWUFBb0IsR0FBR0gsS0FBSyxJQUFBQyxxQkFBQSxHQUM5QkwsUUFBUSxDQUFDUSxpQkFBaUIsWUFBQUgscUJBQUEsR0FBSSxJQUFJLElBQUFDLHFCQUFBLEdBQ2xDTixRQUFRLENBQUNTLGdCQUFnQixZQUFBSCxxQkFBQSxHQUFJLEtBQUs7RUFDdEM7RUFDQSxJQUFJSSxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsSUFBSUwsWUFBWSxHQUFHLENBQUMsRUFBRTtJQUM5RCxNQUFNLElBQUlNLEtBQUssQ0FBQyx5Q0FBeUMsQ0FBQztFQUM1RDtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLEVBQUU7RUFDdEIsTUFBTUUsSUFBMkIsR0FBRztJQUNsQ2YsSUFBSTtJQUNKQyxTQUFTLEVBQUVBLFNBQVMsV0FBVEEsU0FBUyxHQUFJWSxHQUFHO0lBQzNCRyxJQUFJLEVBQUVILEdBQUc7SUFDVEksU0FBUyxFQUFFSixHQUFHLEdBQUdQLFlBQVk7SUFDN0I7SUFDQVksTUFBTSxFQUFFbkIsUUFBUSxDQUFDbUIsTUFBTTtJQUN2QkMsR0FBRyxFQUFFcEIsUUFBUSxDQUFDb0IsR0FBRyxDQUFDLEdBQUduQixJQUFJO0VBQzNCLENBQUM7RUFDRDtFQUNBLElBQUlELFFBQVEsQ0FBQ3FCLE1BQU0sRUFBRUwsSUFBSSxDQUFDSyxNQUFNLEdBQUdyQixRQUFRLENBQUNxQixNQUFNO0VBQ2xELElBQUlyQixRQUFRLENBQUNzQixXQUFXLEVBQUVOLElBQUksQ0FBQ00sV0FBVyxHQUFHdEIsUUFBUSxDQUFDc0IsV0FBVztFQUVqRSxNQUFNQyxNQUFrQyxHQUFHO0lBQ3pDQyxJQUFJLEVBQUUxQixRQUFRO0lBQ2QyQixPQUFPLEVBQUV0QixRQUFRO0lBQ2pCSCxRQUFRLEVBQUVBLFFBQVE7SUFDbEJnQjtFQUNGLENBQUM7RUFDRCxJQUFJWixLQUFLLEVBQUdtQixNQUFNLENBQVNuQixLQUFLLEdBQUcsSUFBSTtFQUN2QyxPQUFPbUIsTUFBTTtBQUNmIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfVFlQRSIsImNyZWF0ZVJlY2VpdmUiLCJlbmRwb2ludCIsImFyZ3MiLCJmZXRjaGVkQXQiLCJyZXNwb25zZSIsImVycm9yIiwiX2VuZHBvaW50JGVycm9yRXhwaXJ5IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZXJyb3JFeHBpcnlMZW5ndGgiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiRXJyb3IiLCJub3ciLCJEYXRlIiwibWV0YSIsImRhdGUiLCJleHBpcmVzQXQiLCJzY2hlbWEiLCJrZXkiLCJ1cGRhdGUiLCJlcnJvclBvbGljeSIsImFjdGlvbiIsInR5cGUiLCJwYXlsb2FkIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2xsZXIvY3JlYXRlUmVjZWl2ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlLCBSZXNvbHZlVHlwZSB9IGZyb20gJ0ByZXN0LWhvb2tzL25vcm1hbGl6cic7XG5cbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuL3R5cGVzLmpzJztcbmltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUge1xuICBDb21wYXRpYmxlUmVjZWl2ZUFjdGlvbixcbiAgQ29tcGF0aWJsZVJlY2VpdmVNZXRhLFxufSBmcm9tICcuLi9jb21wYXRpYmxlQWN0aW9ucy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlY2VpdmU8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZSAmIHtcbiAgICB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+O1xuICB9LFxuPihcbiAgZW5kcG9pbnQ6IEUsXG4gIG9wdGlvbnM6IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl07XG4gICAgcmVzcG9uc2U6IEVycm9yO1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcjogdHJ1ZTtcbiAgfSxcbik6IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWNlaXZlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICBvcHRpb25zOiB7XG4gICAgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dO1xuICAgIHJlc3BvbnNlOiBSZXNvbHZlVHlwZTxFPjtcbiAgICBmZXRjaGVkQXQ/OiBudW1iZXI7XG4gICAgZXJyb3I/OiBmYWxzZTtcbiAgfSxcbik6IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWNlaXZlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgcmVzcG9uc2UsXG4gICAgZXJyb3IgPSBmYWxzZSxcbiAgfToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogYW55O1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcj86IGJvb2xlYW47XG4gIH0sXG4pOiBDb21wYXRpYmxlUmVjZWl2ZUFjdGlvbjxFPiB7XG4gIGNvbnN0IGV4cGlyeUxlbmd0aDogbnVtYmVyID0gZXJyb3JcbiAgICA/IGVuZHBvaW50LmVycm9yRXhwaXJ5TGVuZ3RoID8/IDEwMDBcbiAgICA6IGVuZHBvaW50LmRhdGFFeHBpcnlMZW5ndGggPz8gNjAwMDA7XG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGlmIChwcm9jZXNzLmVudi5OT0RFX0VOViA9PT0gJ2RldmVsb3BtZW50JyAmJiBleHBpcnlMZW5ndGggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBleHBpcnkgbGVuZ3RoIGFyZSBub3QgYWxsb3dlZC4nKTtcbiAgfVxuICBjb25zdCBub3cgPSBEYXRlLm5vdygpO1xuICBjb25zdCBtZXRhOiBDb21wYXRpYmxlUmVjZWl2ZU1ldGEgPSB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQ6IGZldGNoZWRBdCA/PyBub3csXG4gICAgZGF0ZTogbm93LFxuICAgIGV4cGlyZXNBdDogbm93ICsgZXhwaXJ5TGVuZ3RoLFxuICAgIC8vIEZvciBsZWdhY3kgc3VwcG9ydDsgVE9ETzogcmVtb3ZlXG4gICAgc2NoZW1hOiBlbmRwb2ludC5zY2hlbWEsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gIH07XG4gIC8vIEZvciBsZWdhY3kgc3VwcG9ydDsgVE9ETzogcmVtb3ZlXG4gIGlmIChlbmRwb2ludC51cGRhdGUpIG1ldGEudXBkYXRlID0gZW5kcG9pbnQudXBkYXRlO1xuICBpZiAoZW5kcG9pbnQuZXJyb3JQb2xpY3kpIG1ldGEuZXJyb3JQb2xpY3kgPSBlbmRwb2ludC5lcnJvclBvbGljeTtcblxuICBjb25zdCBhY3Rpb246IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+ID0ge1xuICAgIHR5cGU6IFNFVF9UWVBFLFxuICAgIHBheWxvYWQ6IHJlc3BvbnNlLFxuICAgIGVuZHBvaW50OiBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xuICBpZiAoZXJyb3IpIChhY3Rpb24gYXMgYW55KS5lcnJvciA9IHRydWU7XG4gIHJldHVybiBhY3Rpb247XG59XG4iXSwibWFwcGluZ3MiOiJBQUdBLFNBQVNBLFFBQVEsUUFBUSxtQkFBbUI7QUFrQzVDLGVBQWUsU0FBU0MsYUFBYUEsQ0FLbkNDLFFBQVcsRUFDWDtFQUNFQyxJQUFJO0VBQ0pDLFNBQVM7RUFDVEMsUUFBUTtFQUNSQyxLQUFLLEdBQUc7QUFNVixDQUFDLEVBQzJCO0VBQUEsSUFBQUMscUJBQUEsRUFBQUMscUJBQUE7RUFDNUIsTUFBTUMsWUFBb0IsR0FBR0gsS0FBSyxJQUFBQyxxQkFBQSxHQUM5QkwsUUFBUSxDQUFDUSxpQkFBaUIsWUFBQUgscUJBQUEsR0FBSSxJQUFJLElBQUFDLHFCQUFBLEdBQ2xDTixRQUFRLENBQUNTLGdCQUFnQixZQUFBSCxxQkFBQSxHQUFJLEtBQUs7RUFDdEM7RUFDQSxJQUFJSSxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsSUFBSUwsWUFBWSxHQUFHLENBQUMsRUFBRTtJQUM5RCxNQUFNLElBQUlNLEtBQUssQ0FBQyx5Q0FBeUMsQ0FBQztFQUM1RDtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLENBQUMsQ0FBQztFQUN0QixNQUFNRSxJQUEyQixHQUFHO0lBQ2xDZixJQUFJO0lBQ0pDLFNBQVMsRUFBRUEsU0FBUyxXQUFUQSxTQUFTLEdBQUlZLEdBQUc7SUFDM0JHLElBQUksRUFBRUgsR0FBRztJQUNUSSxTQUFTLEVBQUVKLEdBQUcsR0FBR1AsWUFBWTtJQUM3QjtJQUNBWSxNQUFNLEVBQUVuQixRQUFRLENBQUNtQixNQUFNO0lBQ3ZCQyxHQUFHLEVBQUVwQixRQUFRLENBQUNvQixHQUFHLENBQUMsR0FBR25CLElBQUk7RUFDM0IsQ0FBQztFQUNEO0VBQ0EsSUFBSUQsUUFBUSxDQUFDcUIsTUFBTSxFQUFFTCxJQUFJLENBQUNLLE1BQU0sR0FBR3JCLFFBQVEsQ0FBQ3FCLE1BQU07RUFDbEQsSUFBSXJCLFFBQVEsQ0FBQ3NCLFdBQVcsRUFBRU4sSUFBSSxDQUFDTSxXQUFXLEdBQUd0QixRQUFRLENBQUNzQixXQUFXO0VBRWpFLE1BQU1DLE1BQWtDLEdBQUc7SUFDekNDLElBQUksRUFBRTFCLFFBQVE7SUFDZDJCLE9BQU8sRUFBRXRCLFFBQVE7SUFDakJILFFBQVEsRUFBRUEsUUFBUTtJQUNsQmdCO0VBQ0YsQ0FBQztFQUNELElBQUlaLEtBQUssRUFBR21CLE1BQU0sQ0FBU25CLEtBQUssR0FBRyxJQUFJO0VBQ3ZDLE9BQU9tQixNQUFNO0FBQ2YifQ== |
@@ -8,2 +8,2 @@ import { RESET_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRVNFVF9UWVBFIiwiY3JlYXRlUmVzZXQiLCJ0eXBlIiwiZGF0ZSIsIkRhdGUiLCJub3ciXSwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udHJvbGxlci9jcmVhdGVSZXNldC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSRVNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBSZXNldEFjdGlvbiB9IGZyb20gJy4uL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZXNldCgpOiBSZXNldEFjdGlvbiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVTRVRfVFlQRSxcbiAgICBkYXRlOiBEYXRlLm5vdygpLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFVLFFBQVEsbUJBQW1CO0FBRzlDLGVBQWUsU0FBU0MsV0FBV0EsQ0FBQSxFQUFnQjtFQUNqRCxPQUFPO0lBQ0xDLElBQUksRUFBRUYsVUFBVTtJQUNoQkcsSUFBSSxFQUFFQyxJQUFJLENBQUNDLEdBQUc7RUFDaEIsQ0FBQztBQUNIIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRVNFVF9UWVBFIiwiY3JlYXRlUmVzZXQiLCJ0eXBlIiwiZGF0ZSIsIkRhdGUiLCJub3ciXSwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udHJvbGxlci9jcmVhdGVSZXNldC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSRVNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBSZXNldEFjdGlvbiB9IGZyb20gJy4uL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZXNldCgpOiBSZXNldEFjdGlvbiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVTRVRfVFlQRSxcbiAgICBkYXRlOiBEYXRlLm5vdygpLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFVLFFBQVEsbUJBQW1CO0FBRzlDLGVBQWUsU0FBU0MsV0FBV0EsQ0FBQSxFQUFnQjtFQUNqRCxPQUFPO0lBQ0xDLElBQUksRUFBRUYsVUFBVTtJQUNoQkcsSUFBSSxFQUFFQyxJQUFJLENBQUNDLEdBQUcsQ0FBQztFQUNqQixDQUFDO0FBQ0gifQ== |
@@ -23,2 +23,2 @@ export default function applyManager(managers, controller) { | ||
/* These should be compatible with redux */ | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseU1hbmFnZXIiLCJtYW5hZ2VycyIsImNvbnRyb2xsZXIiLCJtYXAiLCJtYW5hZ2VyIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIiwiQVBJIiwiT2JqZWN0IiwiY3JlYXRlIiwidmFsdWUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9hcHBseU1hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBSZWR1Y2VyLCBEaXNwYXRjaCwgUmVkdWNlclN0YXRlIH0gZnJvbSAnLi4vbWlkZGxld2FyZVR5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5TWFuYWdlcihcbiAgbWFuYWdlcnM6IE1hbmFnZXJbXSxcbiAgY29udHJvbGxlcjogQ29udHJvbGxlcixcbik6IE1pZGRsZXdhcmVbXSB7XG4gIHJldHVybiBtYW5hZ2Vycy5tYXAobWFuYWdlciA9PiB7XG4gICAgY29uc3QgbWlkZGxld2FyZSA9IG1hbmFnZXIuZ2V0TWlkZGxld2FyZSgpO1xuICAgIHJldHVybiAoeyBkaXNwYXRjaCwgZ2V0U3RhdGUgfSkgPT4ge1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5kaXNwYXRjaCA9IGRpc3BhdGNoO1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5nZXRTdGF0ZSA9IGdldFN0YXRlO1xuICAgICAgLy8gdGhpcyBpcyBuZWVkZWQgZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5IGFzIHdlIGFkZGVkICdjb250cm9sbGVyJyBwcm9wIHByZXZpb3VzbHlcbiAgICAgIGNvbnN0IEFQSSA9IE9iamVjdC5jcmVhdGUoY29udHJvbGxlciwge1xuICAgICAgICBjb250cm9sbGVyOiB7IHZhbHVlOiBjb250cm9sbGVyIH0sXG4gICAgICB9KTtcbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKEFQSSk7XG4gICAgfTtcbiAgfSk7XG59XG5cbi8qIFRoZXNlIHNob3VsZCBiZSBjb21wYXRpYmxlIHdpdGggcmVkdXggKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWlkZGxld2FyZUFQSTxcbiAgUiBleHRlbmRzIFJlZHVjZXI8YW55LCBhbnk+ID0gUmVkdWNlcjxhbnksIGFueT4sXG4+IHtcbiAgZ2V0U3RhdGU6ICgpID0+IFJlZHVjZXJTdGF0ZTxSPjtcbiAgZGlzcGF0Y2g6IERpc3BhdGNoPFI+O1xufVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4+KHtcbiAgZGlzcGF0Y2gsXG59OiBNaWRkbGV3YXJlQVBJPFI+KSA9PiAobmV4dDogRGlzcGF0Y2g8Uj4pID0+IERpc3BhdGNoPFI+O1xuIl0sIm1hcHBpbmdzIjoiQUFJQSxlQUFlLFNBQVNBLFlBQVlBLENBQ2xDQyxRQUFtQixFQUNuQkMsVUFBc0IsRUFDUjtFQUNkLE9BQU9ELFFBQVEsQ0FBQ0UsR0FBRyxDQUFDQyxPQUFPLElBQUk7SUFDN0IsTUFBTUMsVUFBVSxHQUFHRCxPQUFPLENBQUNFLGFBQWEsRUFBRTtJQUMxQyxPQUFPLENBQUM7TUFBRUMsUUFBUTtNQUFFQztJQUFTLENBQUMsS0FBSztNQUNoQ04sVUFBVSxDQUFTSyxRQUFRLEdBQUdBLFFBQVE7TUFDdENMLFVBQVUsQ0FBU00sUUFBUSxHQUFHQSxRQUFRO01BQ3ZDO01BQ0EsTUFBTUMsR0FBRyxHQUFHQyxNQUFNLENBQUNDLE1BQU0sQ0FBQ1QsVUFBVSxFQUFFO1FBQ3BDQSxVQUFVLEVBQUU7VUFBRVUsS0FBSyxFQUFFVjtRQUFXO01BQ2xDLENBQUMsQ0FBQztNQUNGO01BQ0EsT0FBT0csVUFBVSxDQUFDSSxHQUFHLENBQUM7SUFDeEIsQ0FBQztFQUNILENBQUMsQ0FBQztBQUNKOztBQUVBIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseU1hbmFnZXIiLCJtYW5hZ2VycyIsImNvbnRyb2xsZXIiLCJtYXAiLCJtYW5hZ2VyIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIiwiQVBJIiwiT2JqZWN0IiwiY3JlYXRlIiwidmFsdWUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9hcHBseU1hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBSZWR1Y2VyLCBEaXNwYXRjaCwgUmVkdWNlclN0YXRlIH0gZnJvbSAnLi4vbWlkZGxld2FyZVR5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5TWFuYWdlcihcbiAgbWFuYWdlcnM6IE1hbmFnZXJbXSxcbiAgY29udHJvbGxlcjogQ29udHJvbGxlcixcbik6IE1pZGRsZXdhcmVbXSB7XG4gIHJldHVybiBtYW5hZ2Vycy5tYXAobWFuYWdlciA9PiB7XG4gICAgY29uc3QgbWlkZGxld2FyZSA9IG1hbmFnZXIuZ2V0TWlkZGxld2FyZSgpO1xuICAgIHJldHVybiAoeyBkaXNwYXRjaCwgZ2V0U3RhdGUgfSkgPT4ge1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5kaXNwYXRjaCA9IGRpc3BhdGNoO1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5nZXRTdGF0ZSA9IGdldFN0YXRlO1xuICAgICAgLy8gdGhpcyBpcyBuZWVkZWQgZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5IGFzIHdlIGFkZGVkICdjb250cm9sbGVyJyBwcm9wIHByZXZpb3VzbHlcbiAgICAgIGNvbnN0IEFQSSA9IE9iamVjdC5jcmVhdGUoY29udHJvbGxlciwge1xuICAgICAgICBjb250cm9sbGVyOiB7IHZhbHVlOiBjb250cm9sbGVyIH0sXG4gICAgICB9KTtcbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKEFQSSk7XG4gICAgfTtcbiAgfSk7XG59XG5cbi8qIFRoZXNlIHNob3VsZCBiZSBjb21wYXRpYmxlIHdpdGggcmVkdXggKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWlkZGxld2FyZUFQSTxcbiAgUiBleHRlbmRzIFJlZHVjZXI8YW55LCBhbnk+ID0gUmVkdWNlcjxhbnksIGFueT4sXG4+IHtcbiAgZ2V0U3RhdGU6ICgpID0+IFJlZHVjZXJTdGF0ZTxSPjtcbiAgZGlzcGF0Y2g6IERpc3BhdGNoPFI+O1xufVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4+KHtcbiAgZGlzcGF0Y2gsXG59OiBNaWRkbGV3YXJlQVBJPFI+KSA9PiAobmV4dDogRGlzcGF0Y2g8Uj4pID0+IERpc3BhdGNoPFI+O1xuIl0sIm1hcHBpbmdzIjoiQUFJQSxlQUFlLFNBQVNBLFlBQVlBLENBQ2xDQyxRQUFtQixFQUNuQkMsVUFBc0IsRUFDUjtFQUNkLE9BQU9ELFFBQVEsQ0FBQ0UsR0FBRyxDQUFDQyxPQUFPLElBQUk7SUFDN0IsTUFBTUMsVUFBVSxHQUFHRCxPQUFPLENBQUNFLGFBQWEsQ0FBQyxDQUFDO0lBQzFDLE9BQU8sQ0FBQztNQUFFQyxRQUFRO01BQUVDO0lBQVMsQ0FBQyxLQUFLO01BQ2hDTixVQUFVLENBQVNLLFFBQVEsR0FBR0EsUUFBUTtNQUN0Q0wsVUFBVSxDQUFTTSxRQUFRLEdBQUdBLFFBQVE7TUFDdkM7TUFDQSxNQUFNQyxHQUFHLEdBQUdDLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDVCxVQUFVLEVBQUU7UUFDcENBLFVBQVUsRUFBRTtVQUFFVSxLQUFLLEVBQUVWO1FBQVc7TUFDbEMsQ0FBQyxDQUFDO01BQ0Y7TUFDQSxPQUFPRyxVQUFVLENBQUNJLEdBQUcsQ0FBQztJQUN4QixDQUFDO0VBQ0gsQ0FBQyxDQUFDO0FBQ0o7O0FBRUEifQ== |
@@ -73,2 +73,2 @@ var _globalThis$document; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZWR1Y2VyIiwiSEFTSU5UTCIsIkludGwiLCJERUZBVUxUX0NPTkZJRyIsIm5hbWUiLCJfZ2xvYmFsVGhpcyRkb2N1bWVudCIsImdsb2JhbFRoaXMiLCJkb2N1bWVudCIsInRpdGxlIiwiYXV0b1BhdXNlIiwic2VyaWFsaXplIiwib3B0aW9ucyIsInVuZGVmaW5lZCIsInJlcGxhY2VyIiwia2V5IiwidmFsdWUiLCJpc0Zpbml0ZSIsImVuZHNXaXRoIiwiRGF0ZVRpbWVGb3JtYXQiLCJob3VyIiwibWludXRlIiwic2Vjb25kIiwiZnJhY3Rpb25hbFNlY29uZERpZ2l0cyIsImZvcm1hdCIsIkRldlRvb2xzTWFuYWdlciIsImNvbnN0cnVjdG9yIiwiY29uZmlnIiwic2tpcExvZ2dpbmciLCJkZXZUb29scyIsIndpbmRvdyIsIl9fUkVEVVhfREVWVE9PTFNfRVhURU5TSU9OX18iLCJjb25uZWN0IiwiT2JqZWN0IiwiYXNzaWduIiwibWlkZGxld2FyZSIsImNvbnRyb2xsZXIiLCJyZWR1Y2VyIiwibmV4dCIsImFjdGlvbiIsInJldCIsInRoZW4iLCJzdGF0ZSIsImdldFN0YXRlIiwic2VuZCIsIm9wdGltaXN0aWMiLCJyZWR1Y2UiLCJpbml0IiwiY2xlYW51cCIsImdldE1pZGRsZXdhcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9EZXZ0b29sc01hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBEZXZUb29sc0NvbmZpZyB9IGZyb20gJy4vZGV2dG9vbHNUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IE1pZGRsZXdhcmUgfSBmcm9tICcuL0xvZ291dE1hbmFnZXIuanMnO1xuaW1wb3J0IGNyZWF0ZVJlZHVjZXIgZnJvbSAnLi4vc3RhdGUvcmVkdWNlci9jcmVhdGVSZWR1Y2VyLmpzJztcbmltcG9ydCB0eXBlIHsgTWFuYWdlciwgU3RhdGUsIEFjdGlvblR5cGVzIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgdHlwZSB7IERldlRvb2xzQ29uZmlnIH07XG5cbmNvbnN0IEhBU0lOVEwgPSB0eXBlb2YgSW50bCAhPT0gJ3VuZGVmaW5lZCc7XG5jb25zdCBERUZBVUxUX0NPTkZJRyA9IHtcbiAgbmFtZTogYFJlc3QgSG9va3M6ICR7Z2xvYmFsVGhpcy5kb2N1bWVudD8udGl0bGV9YCxcbiAgYXV0b1BhdXNlOiB0cnVlLFxuICBzZXJpYWxpemU6IHtcbiAgICBvcHRpb25zOiB1bmRlZmluZWQsXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZXBsYWNlcjogSEFTSU5UTFxuICAgICAgPyAoa2V5OiBzdHJpbmcgfCBudW1iZXIgfCBzeW1ib2wsIHZhbHVlOiB1bmtub3duKSA9PiB7XG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJyAmJlxuICAgICAgICAgICAgdHlwZW9mIGtleSA9PT0gJ3N0cmluZycgJiZcbiAgICAgICAgICAgIGlzRmluaXRlKHZhbHVlKSAmJlxuICAgICAgICAgICAgKGtleSA9PT0gJ2RhdGUnIHx8IGtleS5lbmRzV2l0aCgnQXQnKSlcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIHJldHVybiBJbnRsLkRhdGVUaW1lRm9ybWF0KCdlbi1VUycsIHtcbiAgICAgICAgICAgICAgaG91cjogJ251bWVyaWMnLFxuICAgICAgICAgICAgICBtaW51dGU6ICdudW1lcmljJyxcbiAgICAgICAgICAgICAgc2Vjb25kOiAnbnVtZXJpYycsXG4gICAgICAgICAgICAgIGZyYWN0aW9uYWxTZWNvbmREaWdpdHM6IDMsXG4gICAgICAgICAgICB9KS5mb3JtYXQodmFsdWUpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH1cbiAgICAgIDogdW5kZWZpbmVkLFxuICB9LFxufTtcblxuLyoqIEludGVncmF0ZXMgd2l0aCBodHRwczovL2dpdGh1Yi5jb20vcmVkdXhqcy9yZWR1eC1kZXZ0b29sc1xuICpcbiAqIE9wdGlvbnM6IGh0dHBzOi8vZ2l0aHViLmNvbS9yZWR1eGpzL3JlZHV4LWRldnRvb2xzL2Jsb2IvbWFpbi9leHRlbnNpb24vZG9jcy9BUEkvQXJndW1lbnRzLm1kXG4gKlxuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9kb2NzL2FwaS9EZXZUb29sc01hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRGV2VG9vbHNNYW5hZ2VyIGltcGxlbWVudHMgTWFuYWdlciB7XG4gIHByb3RlY3RlZCBkZWNsYXJlIG1pZGRsZXdhcmU6IE1pZGRsZXdhcmU7XG4gIHByb3RlY3RlZCBkZWNsYXJlIGRldlRvb2xzOiB1bmRlZmluZWQgfCBhbnk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgY29uZmlnPzogRGV2VG9vbHNDb25maWcsXG4gICAgc2tpcExvZ2dpbmc/OiAoYWN0aW9uOiBBY3Rpb25UeXBlcykgPT4gYm9vbGVhbixcbiAgKSB7XG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICB0aGlzLmRldlRvb2xzID1cbiAgICAgIHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmXG4gICAgICAod2luZG93IGFzIGFueSkuX19SRURVWF9ERVZUT09MU19FWFRFTlNJT05fXyAmJlxuICAgICAgKHdpbmRvdyBhcyBhbnkpLl9fUkVEVVhfREVWVE9PTFNfRVhURU5TSU9OX18uY29ubmVjdCh7XG4gICAgICAgIC4uLkRFRkFVTFRfQ09ORklHLFxuICAgICAgICBjb25maWcsXG4gICAgICB9KTtcblxuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqL1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgaWYgKHRoaXMuZGV2VG9vbHMpIHtcbiAgICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4ge1xuICAgICAgICBjb25zdCByZWR1Y2VyID0gY3JlYXRlUmVkdWNlcihjb250cm9sbGVyIGFzIGFueSk7XG4gICAgICAgIHJldHVybiBuZXh0ID0+IGFjdGlvbiA9PiB7XG4gICAgICAgICAgY29uc3QgcmV0ID0gbmV4dChhY3Rpb24pO1xuICAgICAgICAgIHJldC50aGVuKCgpID0+IHtcbiAgICAgICAgICAgIGlmIChza2lwTG9nZ2luZz8uKGFjdGlvbikpIHJldHVybjtcbiAgICAgICAgICAgIGNvbnN0IHN0YXRlID0gY29udHJvbGxlci5nZXRTdGF0ZSgpO1xuICAgICAgICAgICAgdGhpcy5kZXZUb29scy5zZW5kKFxuICAgICAgICAgICAgICBhY3Rpb24sXG4gICAgICAgICAgICAgIHN0YXRlLm9wdGltaXN0aWMucmVkdWNlKHJlZHVjZXIsIHN0YXRlKSxcbiAgICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAgICAnUkVTVF9IT09LUycsXG4gICAgICAgICAgICApO1xuICAgICAgICAgIH0pO1xuICAgICAgICAgIHJldHVybiByZXQ7XG4gICAgICAgIH07XG4gICAgICB9O1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1pZGRsZXdhcmUgPSAoKSA9PiBuZXh0ID0+IGFjdGlvbiA9PiBuZXh0KGFjdGlvbik7XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIGluaXRpYWwgc3RhdGUgaXMgcmVhZHkgKi9cbiAgaW5pdChzdGF0ZTogU3RhdGU8YW55Pikge1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqL1xuICAgIGlmICh0aGlzLmRldlRvb2xzKSB0aGlzLmRldlRvb2xzLmluaXQoc3RhdGUpO1xuICB9XG5cbiAgLyoqIEVuc3VyZXMgYWxsIHN1YnNjcmlwdGlvbnMgYXJlIGNsZWFuZWQgdXAuICovXG4gIGNsZWFudXAoKSB7fVxuXG4gIC8qKiBBdHRhY2hlcyBNYW5hZ2VyIHRvIHN0b3JlXG4gICAqXG4gICAqL1xuICBnZXRNaWRkbGV3YXJlKCkge1xuICAgIHJldHVybiB0aGlzLm1pZGRsZXdhcmU7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IjtBQUVBLE9BQU9BLGFBQWEsTUFBTSxtQ0FBbUM7QUFL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 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZWR1Y2VyIiwiSEFTSU5UTCIsIkludGwiLCJERUZBVUxUX0NPTkZJRyIsIm5hbWUiLCJfZ2xvYmFsVGhpcyRkb2N1bWVudCIsImdsb2JhbFRoaXMiLCJkb2N1bWVudCIsInRpdGxlIiwiYXV0b1BhdXNlIiwic2VyaWFsaXplIiwib3B0aW9ucyIsInVuZGVmaW5lZCIsInJlcGxhY2VyIiwia2V5IiwidmFsdWUiLCJpc0Zpbml0ZSIsImVuZHNXaXRoIiwiRGF0ZVRpbWVGb3JtYXQiLCJob3VyIiwibWludXRlIiwic2Vjb25kIiwiZnJhY3Rpb25hbFNlY29uZERpZ2l0cyIsImZvcm1hdCIsIkRldlRvb2xzTWFuYWdlciIsImNvbnN0cnVjdG9yIiwiY29uZmlnIiwic2tpcExvZ2dpbmciLCJkZXZUb29scyIsIndpbmRvdyIsIl9fUkVEVVhfREVWVE9PTFNfRVhURU5TSU9OX18iLCJjb25uZWN0IiwiT2JqZWN0IiwiYXNzaWduIiwibWlkZGxld2FyZSIsImNvbnRyb2xsZXIiLCJyZWR1Y2VyIiwibmV4dCIsImFjdGlvbiIsInJldCIsInRoZW4iLCJzdGF0ZSIsImdldFN0YXRlIiwic2VuZCIsIm9wdGltaXN0aWMiLCJyZWR1Y2UiLCJpbml0IiwiY2xlYW51cCIsImdldE1pZGRsZXdhcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9EZXZ0b29sc01hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBEZXZUb29sc0NvbmZpZyB9IGZyb20gJy4vZGV2dG9vbHNUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IE1pZGRsZXdhcmUgfSBmcm9tICcuL0xvZ291dE1hbmFnZXIuanMnO1xuaW1wb3J0IGNyZWF0ZVJlZHVjZXIgZnJvbSAnLi4vc3RhdGUvcmVkdWNlci9jcmVhdGVSZWR1Y2VyLmpzJztcbmltcG9ydCB0eXBlIHsgTWFuYWdlciwgU3RhdGUsIEFjdGlvblR5cGVzIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgdHlwZSB7IERldlRvb2xzQ29uZmlnIH07XG5cbmNvbnN0IEhBU0lOVEwgPSB0eXBlb2YgSW50bCAhPT0gJ3VuZGVmaW5lZCc7XG5jb25zdCBERUZBVUxUX0NPTkZJRyA9IHtcbiAgbmFtZTogYFJlc3QgSG9va3M6ICR7Z2xvYmFsVGhpcy5kb2N1bWVudD8udGl0bGV9YCxcbiAgYXV0b1BhdXNlOiB0cnVlLFxuICBzZXJpYWxpemU6IHtcbiAgICBvcHRpb25zOiB1bmRlZmluZWQsXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZXBsYWNlcjogSEFTSU5UTFxuICAgICAgPyAoa2V5OiBzdHJpbmcgfCBudW1iZXIgfCBzeW1ib2wsIHZhbHVlOiB1bmtub3duKSA9PiB7XG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJyAmJlxuICAgICAgICAgICAgdHlwZW9mIGtleSA9PT0gJ3N0cmluZycgJiZcbiAgICAgICAgICAgIGlzRmluaXRlKHZhbHVlKSAmJlxuICAgICAgICAgICAgKGtleSA9PT0gJ2RhdGUnIHx8IGtleS5lbmRzV2l0aCgnQXQnKSlcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIHJldHVybiBJbnRsLkRhdGVUaW1lRm9ybWF0KCdlbi1VUycsIHtcbiAgICAgICAgICAgICAgaG91cjogJ251bWVyaWMnLFxuICAgICAgICAgICAgICBtaW51dGU6ICdudW1lcmljJyxcbiAgICAgICAgICAgICAgc2Vjb25kOiAnbnVtZXJpYycsXG4gICAgICAgICAgICAgIGZyYWN0aW9uYWxTZWNvbmREaWdpdHM6IDMsXG4gICAgICAgICAgICB9KS5mb3JtYXQodmFsdWUpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH1cbiAgICAgIDogdW5kZWZpbmVkLFxuICB9LFxufTtcblxuLyoqIEludGVncmF0ZXMgd2l0aCBodHRwczovL2dpdGh1Yi5jb20vcmVkdXhqcy9yZWR1eC1kZXZ0b29sc1xuICpcbiAqIE9wdGlvbnM6IGh0dHBzOi8vZ2l0aHViLmNvbS9yZWR1eGpzL3JlZHV4LWRldnRvb2xzL2Jsb2IvbWFpbi9leHRlbnNpb24vZG9jcy9BUEkvQXJndW1lbnRzLm1kXG4gKlxuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9kb2NzL2FwaS9EZXZUb29sc01hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRGV2VG9vbHNNYW5hZ2VyIGltcGxlbWVudHMgTWFuYWdlciB7XG4gIHByb3RlY3RlZCBkZWNsYXJlIG1pZGRsZXdhcmU6IE1pZGRsZXdhcmU7XG4gIHByb3RlY3RlZCBkZWNsYXJlIGRldlRvb2xzOiB1bmRlZmluZWQgfCBhbnk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgY29uZmlnPzogRGV2VG9vbHNDb25maWcsXG4gICAgc2tpcExvZ2dpbmc/OiAoYWN0aW9uOiBBY3Rpb25UeXBlcykgPT4gYm9vbGVhbixcbiAgKSB7XG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICB0aGlzLmRldlRvb2xzID1cbiAgICAgIHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmXG4gICAgICAod2luZG93IGFzIGFueSkuX19SRURVWF9ERVZUT09MU19FWFRFTlNJT05fXyAmJlxuICAgICAgKHdpbmRvdyBhcyBhbnkpLl9fUkVEVVhfREVWVE9PTFNfRVhURU5TSU9OX18uY29ubmVjdCh7XG4gICAgICAgIC4uLkRFRkFVTFRfQ09ORklHLFxuICAgICAgICBjb25maWcsXG4gICAgICB9KTtcblxuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqL1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgaWYgKHRoaXMuZGV2VG9vbHMpIHtcbiAgICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4ge1xuICAgICAgICBjb25zdCByZWR1Y2VyID0gY3JlYXRlUmVkdWNlcihjb250cm9sbGVyIGFzIGFueSk7XG4gICAgICAgIHJldHVybiBuZXh0ID0+IGFjdGlvbiA9PiB7XG4gICAgICAgICAgY29uc3QgcmV0ID0gbmV4dChhY3Rpb24pO1xuICAgICAgICAgIHJldC50aGVuKCgpID0+IHtcbiAgICAgICAgICAgIGlmIChza2lwTG9nZ2luZz8uKGFjdGlvbikpIHJldHVybjtcbiAgICAgICAgICAgIGNvbnN0IHN0YXRlID0gY29udHJvbGxlci5nZXRTdGF0ZSgpO1xuICAgICAgICAgICAgdGhpcy5kZXZUb29scy5zZW5kKFxuICAgICAgICAgICAgICBhY3Rpb24sXG4gICAgICAgICAgICAgIHN0YXRlLm9wdGltaXN0aWMucmVkdWNlKHJlZHVjZXIsIHN0YXRlKSxcbiAgICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAgICAnUkVTVF9IT09LUycsXG4gICAgICAgICAgICApO1xuICAgICAgICAgIH0pO1xuICAgICAgICAgIHJldHVybiByZXQ7XG4gICAgICAgIH07XG4gICAgICB9O1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1pZGRsZXdhcmUgPSAoKSA9PiBuZXh0ID0+IGFjdGlvbiA9PiBuZXh0KGFjdGlvbik7XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIGluaXRpYWwgc3RhdGUgaXMgcmVhZHkgKi9cbiAgaW5pdChzdGF0ZTogU3RhdGU8YW55Pikge1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqL1xuICAgIGlmICh0aGlzLmRldlRvb2xzKSB0aGlzLmRldlRvb2xzLmluaXQoc3RhdGUpO1xuICB9XG5cbiAgLyoqIEVuc3VyZXMgYWxsIHN1YnNjcmlwdGlvbnMgYXJlIGNsZWFuZWQgdXAuICovXG4gIGNsZWFudXAoKSB7fVxuXG4gIC8qKiBBdHRhY2hlcyBNYW5hZ2VyIHRvIHN0b3JlXG4gICAqXG4gICAqL1xuICBnZXRNaWRkbGV3YXJlKCkge1xuICAgIHJldHVybiB0aGlzLm1pZGRsZXdhcmU7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IjtBQUVBLE9BQU9BLGFBQWEsTUFBTSxtQ0FBbUM7QUFL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 |
@@ -34,2 +34,2 @@ import { SET_TYPE } from '../actionTypes.js'; | ||
// this further restricts the types to be future compatible | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfVFlQRSIsIkxvZ291dE1hbmFnZXIiLCJjb25zdHJ1Y3RvciIsImhhbmRsZUxvZ291dCIsInNob3VsZExvZ291dCIsIm1pZGRsZXdhcmUiLCJjb250cm9sbGVyIiwibmV4dCIsImFjdGlvbiIsInR5cGUiLCJlcnJvciIsInBheWxvYWQiLCJjbGVhbnVwIiwiZ2V0TWlkZGxld2FyZSIsInN0YXR1cyIsInJlc2V0RW50aXJlU3RvcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9Mb2dvdXRNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB7IFVua25vd25FcnJvciB9IGZyb20gJy4uL2luZGV4LmpzJztcbmltcG9ydCB0eXBlIHsgQ29tYmluZWRBY3Rpb25UeXBlcyB9IGZyb20gJy4uL3R5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbi8qKiBIYW5kbGluZyBuZXR3b3JrIHVuYXV0aG9yaXplZCBpbmRpY2F0b3JzIGxpa2UgSFRUUCA0MDFcbiAqXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL2RvY3MvYXBpL0xvZ291dE1hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTG9nb3V0TWFuYWdlciBpbXBsZW1lbnRzIE1hbmFnZXI8Q29tYmluZWRBY3Rpb25UeXBlcz4ge1xuICBwcm90ZWN0ZWQgZGVjbGFyZSBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlO1xuXG4gIGNvbnN0cnVjdG9yKHsgaGFuZGxlTG9nb3V0LCBzaG91bGRMb2dvdXQgfTogUHJvcHMgPSB7fSkge1xuICAgIGlmIChoYW5kbGVMb2dvdXQpIHRoaXMuaGFuZGxlTG9nb3V0ID0gaGFuZGxlTG9nb3V0O1xuICAgIGlmIChzaG91bGRMb2dvdXQpIHRoaXMuc2hvdWxkTG9nb3V0ID0gc2hvdWxkTG9nb3V0O1xuICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4gbmV4dCA9PiBhc3luYyBhY3Rpb24gPT4ge1xuICAgICAgYXdhaXQgbmV4dChhY3Rpb24pO1xuICAgICAgaWYgKFxuICAgICAgICBhY3Rpb24udHlwZSA9PT0gU0VUX1RZUEUgJiZcbiAgICAgICAgYWN0aW9uLmVycm9yICYmXG4gICAgICAgIHRoaXMuc2hvdWxkTG9nb3V0KGFjdGlvbi5wYXlsb2FkKVxuICAgICAgKSB7XG4gICAgICAgIHRoaXMuaGFuZGxlTG9nb3V0KGNvbnRyb2xsZXIpO1xuICAgICAgfVxuICAgIH07XG4gIH1cblxuICBjbGVhbnVwKCkge31cblxuICBnZXRNaWRkbGV3YXJlKCkge1xuICAgIHJldHVybiB0aGlzLm1pZGRsZXdhcmU7XG4gIH1cblxuICBwcm90ZWN0ZWQgc2hvdWxkTG9nb3V0KGVycm9yOiBVbmtub3duRXJyb3IpIHtcbiAgICAvLyA0MDEgaW5kaWNhdGVzIHJlYXV0aG9yaXphdGlvbiBpcyBuZWVkZWRcbiAgICByZXR1cm4gZXJyb3Iuc3RhdHVzID09PSA0MDE7XG4gIH1cblxuICBoYW5kbGVMb2dvdXQoY29udHJvbGxlcjogQ29udHJvbGxlcjxEaXNwYXRjaD4pIHtcbiAgICBjb250cm9sbGVyLnJlc2V0RW50aXJlU3RvcmUoKTtcbiAgfVxufVxuXG50eXBlIERpc3BhdGNoID0gKHZhbHVlOiBDb21iaW5lZEFjdGlvblR5cGVzKSA9PiBQcm9taXNlPHZvaWQ+O1xuXG4vLyB0aGlzIGZ1cnRoZXIgcmVzdHJpY3RzIHRoZSB0eXBlcyB0byBiZSBmdXR1cmUgY29tcGF0aWJsZVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxDIGV4dGVuZHMgQ29udHJvbGxlcjxEaXNwYXRjaD4+KFxuICBjb250cm9sbGVyOiBDLFxuKSA9PiAobmV4dDogQ1snZGlzcGF0Y2gnXSkgPT4gQ1snZGlzcGF0Y2gnXTtcblxudHlwZSBIYW5kbGVMb2dvdXQgPSAoY29udHJvbGxlcjogQ29udHJvbGxlcjxEaXNwYXRjaD4pID0+IHZvaWQ7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGhhbmRsZUxvZ291dD86IEhhbmRsZUxvZ291dDtcbiAgc2hvdWxkTG9nb3V0PzogKGVycm9yOiBVbmtub3duRXJyb3IpID0+IGJvb2xlYW47XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFFBQVEsUUFBUSxtQkFBbUI7QUFNNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLE1BQU1DLGFBQWEsQ0FBeUM7RUFHekVDLFdBQVdBLENBQUM7SUFBRUMsWUFBWTtJQUFFQztFQUFvQixDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUU7SUFDdEQsSUFBSUQsWUFBWSxFQUFFLElBQUksQ0FBQ0EsWUFBWSxHQUFHQSxZQUFZO0lBQ2xELElBQUlDLFlBQVksRUFBRSxJQUFJLENBQUNBLFlBQVksR0FBR0EsWUFBWTtJQUNsRCxJQUFJLENBQUNDLFVBQVUsR0FBR0MsVUFBVSxJQUFJQyxJQUFJLElBQUksTUFBTUMsTUFBTSxJQUFJO01BQ3RELE1BQU1ELElBQUksQ0FBQ0MsTUFBTSxDQUFDO01BQ2xCLElBQ0VBLE1BQU0sQ0FBQ0MsSUFBSSxLQUFLVCxRQUFRLElBQ3hCUSxNQUFNLENBQUNFLEtBQUssSUFDWixJQUFJLENBQUNOLFlBQVksQ0FBQ0ksTUFBTSxDQUFDRyxPQUFPLENBQUMsRUFDakM7UUFDQSxJQUFJLENBQUNSLFlBQVksQ0FBQ0csVUFBVSxDQUFDO01BQy9CO0lBQ0YsQ0FBQztFQUNIO0VBRUFNLE9BQU9BLENBQUEsRUFBRyxDQUFDO0VBRVhDLGFBQWFBLENBQUEsRUFBRztJQUNkLE9BQU8sSUFBSSxDQUFDUixVQUFVO0VBQ3hCO0VBRVVELFlBQVlBLENBQUNNLEtBQW1CLEVBQUU7SUFDMUM7SUFDQSxPQUFPQSxLQUFLLENBQUNJLE1BQU0sS0FBSyxHQUFHO0VBQzdCO0VBRUFYLFlBQVlBLENBQUNHLFVBQWdDLEVBQUU7SUFDN0NBLFVBQVUsQ0FBQ1MsZ0JBQWdCLEVBQUU7RUFDL0I7QUFDRjs7QUFJQSJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfVFlQRSIsIkxvZ291dE1hbmFnZXIiLCJjb25zdHJ1Y3RvciIsImhhbmRsZUxvZ291dCIsInNob3VsZExvZ291dCIsIm1pZGRsZXdhcmUiLCJjb250cm9sbGVyIiwibmV4dCIsImFjdGlvbiIsInR5cGUiLCJlcnJvciIsInBheWxvYWQiLCJjbGVhbnVwIiwiZ2V0TWlkZGxld2FyZSIsInN0YXR1cyIsInJlc2V0RW50aXJlU3RvcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9Mb2dvdXRNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB7IFVua25vd25FcnJvciB9IGZyb20gJy4uL2luZGV4LmpzJztcbmltcG9ydCB0eXBlIHsgQ29tYmluZWRBY3Rpb25UeXBlcyB9IGZyb20gJy4uL3R5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbi8qKiBIYW5kbGluZyBuZXR3b3JrIHVuYXV0aG9yaXplZCBpbmRpY2F0b3JzIGxpa2UgSFRUUCA0MDFcbiAqXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL2RvY3MvYXBpL0xvZ291dE1hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTG9nb3V0TWFuYWdlciBpbXBsZW1lbnRzIE1hbmFnZXI8Q29tYmluZWRBY3Rpb25UeXBlcz4ge1xuICBwcm90ZWN0ZWQgZGVjbGFyZSBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlO1xuXG4gIGNvbnN0cnVjdG9yKHsgaGFuZGxlTG9nb3V0LCBzaG91bGRMb2dvdXQgfTogUHJvcHMgPSB7fSkge1xuICAgIGlmIChoYW5kbGVMb2dvdXQpIHRoaXMuaGFuZGxlTG9nb3V0ID0gaGFuZGxlTG9nb3V0O1xuICAgIGlmIChzaG91bGRMb2dvdXQpIHRoaXMuc2hvdWxkTG9nb3V0ID0gc2hvdWxkTG9nb3V0O1xuICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4gbmV4dCA9PiBhc3luYyBhY3Rpb24gPT4ge1xuICAgICAgYXdhaXQgbmV4dChhY3Rpb24pO1xuICAgICAgaWYgKFxuICAgICAgICBhY3Rpb24udHlwZSA9PT0gU0VUX1RZUEUgJiZcbiAgICAgICAgYWN0aW9uLmVycm9yICYmXG4gICAgICAgIHRoaXMuc2hvdWxkTG9nb3V0KGFjdGlvbi5wYXlsb2FkKVxuICAgICAgKSB7XG4gICAgICAgIHRoaXMuaGFuZGxlTG9nb3V0KGNvbnRyb2xsZXIpO1xuICAgICAgfVxuICAgIH07XG4gIH1cblxuICBjbGVhbnVwKCkge31cblxuICBnZXRNaWRkbGV3YXJlKCkge1xuICAgIHJldHVybiB0aGlzLm1pZGRsZXdhcmU7XG4gIH1cblxuICBwcm90ZWN0ZWQgc2hvdWxkTG9nb3V0KGVycm9yOiBVbmtub3duRXJyb3IpIHtcbiAgICAvLyA0MDEgaW5kaWNhdGVzIHJlYXV0aG9yaXphdGlvbiBpcyBuZWVkZWRcbiAgICByZXR1cm4gZXJyb3Iuc3RhdHVzID09PSA0MDE7XG4gIH1cblxuICBoYW5kbGVMb2dvdXQoY29udHJvbGxlcjogQ29udHJvbGxlcjxEaXNwYXRjaD4pIHtcbiAgICBjb250cm9sbGVyLnJlc2V0RW50aXJlU3RvcmUoKTtcbiAgfVxufVxuXG50eXBlIERpc3BhdGNoID0gKHZhbHVlOiBDb21iaW5lZEFjdGlvblR5cGVzKSA9PiBQcm9taXNlPHZvaWQ+O1xuXG4vLyB0aGlzIGZ1cnRoZXIgcmVzdHJpY3RzIHRoZSB0eXBlcyB0byBiZSBmdXR1cmUgY29tcGF0aWJsZVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxDIGV4dGVuZHMgQ29udHJvbGxlcjxEaXNwYXRjaD4+KFxuICBjb250cm9sbGVyOiBDLFxuKSA9PiAobmV4dDogQ1snZGlzcGF0Y2gnXSkgPT4gQ1snZGlzcGF0Y2gnXTtcblxudHlwZSBIYW5kbGVMb2dvdXQgPSAoY29udHJvbGxlcjogQ29udHJvbGxlcjxEaXNwYXRjaD4pID0+IHZvaWQ7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGhhbmRsZUxvZ291dD86IEhhbmRsZUxvZ291dDtcbiAgc2hvdWxkTG9nb3V0PzogKGVycm9yOiBVbmtub3duRXJyb3IpID0+IGJvb2xlYW47XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFFBQVEsUUFBUSxtQkFBbUI7QUFNNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLE1BQU1DLGFBQWEsQ0FBeUM7RUFHekVDLFdBQVdBLENBQUM7SUFBRUMsWUFBWTtJQUFFQztFQUFvQixDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUU7SUFDdEQsSUFBSUQsWUFBWSxFQUFFLElBQUksQ0FBQ0EsWUFBWSxHQUFHQSxZQUFZO0lBQ2xELElBQUlDLFlBQVksRUFBRSxJQUFJLENBQUNBLFlBQVksR0FBR0EsWUFBWTtJQUNsRCxJQUFJLENBQUNDLFVBQVUsR0FBR0MsVUFBVSxJQUFJQyxJQUFJLElBQUksTUFBTUMsTUFBTSxJQUFJO01BQ3RELE1BQU1ELElBQUksQ0FBQ0MsTUFBTSxDQUFDO01BQ2xCLElBQ0VBLE1BQU0sQ0FBQ0MsSUFBSSxLQUFLVCxRQUFRLElBQ3hCUSxNQUFNLENBQUNFLEtBQUssSUFDWixJQUFJLENBQUNOLFlBQVksQ0FBQ0ksTUFBTSxDQUFDRyxPQUFPLENBQUMsRUFDakM7UUFDQSxJQUFJLENBQUNSLFlBQVksQ0FBQ0csVUFBVSxDQUFDO01BQy9CO0lBQ0YsQ0FBQztFQUNIO0VBRUFNLE9BQU9BLENBQUEsRUFBRyxDQUFDO0VBRVhDLGFBQWFBLENBQUEsRUFBRztJQUNkLE9BQU8sSUFBSSxDQUFDUixVQUFVO0VBQ3hCO0VBRVVELFlBQVlBLENBQUNNLEtBQW1CLEVBQUU7SUFDMUM7SUFDQSxPQUFPQSxLQUFLLENBQUNJLE1BQU0sS0FBSyxHQUFHO0VBQzdCO0VBRUFYLFlBQVlBLENBQUNHLFVBQWdDLEVBQUU7SUFDN0NBLFVBQVUsQ0FBQ1MsZ0JBQWdCLENBQUMsQ0FBQztFQUMvQjtBQUNGOztBQUlBIn0= |
@@ -291,2 +291,2 @@ import { SET_TYPE, FETCH_TYPE, RESET_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SET_TYPE","FETCH_TYPE","RESET_TYPE","Controller","initialState","createReceive","createReceiveError","RIC","ResetError","Error","constructor","name","NetworkManager","dataExpiryLength","errorExpiryLength","fetched","Object","create","resolvers","rejectors","fetchedAt","getState","controller","middleware","dispatch","next","action","_action$endpoint","type","handleFetch","meta","optimisticResponse","undefined","endpoint","getOptimisticResponse","Promise","resolve","then","key","_controller$getState$","error","handleReceive","assign","clearAll","k","skipLogging","init","cleanupDate","cleanup","Date","now","allSettled","fetches","values","length","clear","catch","getLastReset","lastReset","valueOf","Infinity","fetch","payload","throttle","reject","createdAt","getTime","deferedFetch","promise","resolvePromise","data","process","env","NODE_ENV","isNaN","console","args","response","_action$meta$options$","_action$meta$options","options","_action$meta$options$2","_action$meta$options2","promiseHandler","getMiddleware","timeout"],"sources":["../../src/manager/NetworkManager.ts"],"sourcesContent":["import { SET_TYPE, FETCH_TYPE, RESET_TYPE } from '../actionTypes.js';\nimport Controller from '../controller/Controller.js';\nimport { initialState } from '../internal.js';\nimport {\n  createReceive,\n  createReceiveError,\n} from '../state/legacy-actions/index.js';\nimport RIC from '../state/RIC.js';\nimport type {\n  FetchAction,\n  ReceiveAction,\n  Manager,\n  ActionTypes,\n  MiddlewareAPI,\n  Middleware,\n  State,\n} from '../types.js';\n\nexport class ResetError extends Error {\n  name = 'ResetError';\n\n  constructor() {\n    super('Aborted due to RESET');\n  }\n}\n\n/** Handles all async network dispatches\n *\n * Dedupes concurrent requests by keeping track of all fetches in flight\n * and returning existing promises for requests already in flight.\n *\n * Interfaces with store via a redux-compatible middleware.\n *\n * @see https://resthooks.io/docs/api/NetworkManager\n */\nexport default class NetworkManager implements Manager {\n  protected fetched: { [k: string]: Promise<any> } = Object.create(null);\n  protected resolvers: { [k: string]: (value?: any) => void } = {};\n  protected rejectors: { [k: string]: (value?: any) => void } = {};\n  protected fetchedAt: { [k: string]: number } = {};\n  declare readonly dataExpiryLength: number;\n  declare readonly errorExpiryLength: number;\n  protected declare middleware: Middleware;\n  protected getState: () => State<unknown> = () => initialState;\n  protected controller: Controller = new Controller();\n  declare cleanupDate?: number;\n\n  constructor(dataExpiryLength = 60000, errorExpiryLength = 1000) {\n    this.dataExpiryLength = dataExpiryLength;\n    this.errorExpiryLength = errorExpiryLength;\n\n    this.middleware = <C extends MiddlewareAPI>({\n      dispatch,\n      getState,\n      controller,\n    }: C) => {\n      this.getState = getState;\n      this.controller = controller;\n      return (next: C['dispatch']): C['dispatch'] =>\n        (action): Promise<void> => {\n          switch (action.type) {\n            case FETCH_TYPE:\n              this.handleFetch(action, dispatch, controller);\n              // This is the only case that causes any state change\n              // It's important to intercept other fetches as we don't want to trigger reducers during\n              // render - so we need to stop 'readonly' fetches which can be triggered in render\n              if (\n                action.meta.optimisticResponse !== undefined ||\n                action.endpoint?.getOptimisticResponse !== undefined\n              ) {\n                return next(action);\n              }\n              return Promise.resolve();\n            case SET_TYPE:\n              // only receive after new state is computed\n              return next(action).then(() => {\n                if (action.meta.key in this.fetched) {\n                  // Note: meta *must* be set by reducer so this should be safe\n                  const error =\n                    controller.getState().meta[action.meta.key]?.error;\n                  // processing errors result in state meta having error, so we should reject the promise\n                  if (error) {\n                    // TODO: use only new action types\n                    this.handleReceive(createReceiveError(error, action.meta));\n                  } else {\n                    this.handleReceive(action);\n                  }\n                }\n              });\n            case RESET_TYPE: {\n              const rejectors = { ...this.rejectors };\n\n              this.clearAll();\n              return next(action).then(() => {\n                // there could be external listeners to the promise\n                // this must happen after commit so our own rejector knows not to dispatch an error based on this\n                for (const k in rejectors) {\n                  rejectors[k](new ResetError());\n                }\n              });\n            }\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Used by DevtoolsManager to determine whether to log an action */\n  skipLogging(action: ActionTypes) {\n    /* istanbul ignore next */\n    return action.type === FETCH_TYPE && action.meta.key in this.fetched;\n  }\n\n  /** On mount */\n  init() {\n    delete this.cleanupDate;\n  }\n\n  /** Ensures all promises are completed by rejecting remaining. */\n  cleanup() {\n    // ensure no dispatches after unmount\n    // this must be reversible (done in init) so useEffect() remains symmetric\n    this.cleanupDate = Date.now();\n  }\n\n  allSettled() {\n    const fetches = Object.values(this.fetched);\n    if (fetches.length) return Promise.allSettled(fetches);\n  }\n\n  /** Clear all promise state */\n  protected clearAll() {\n    for (const k in this.rejectors) {\n      this.clear(k);\n    }\n  }\n\n  /** Clear promise state for a given key */\n  protected clear(key: string) {\n    this.fetched[key].catch(() => {});\n    delete this.resolvers[key];\n    delete this.rejectors[key];\n    delete this.fetched[key];\n    delete this.fetchedAt[key];\n  }\n\n  protected getLastReset() {\n    if (this.cleanupDate) return this.cleanupDate;\n    const lastReset = this.controller.getState().lastReset;\n    if (lastReset instanceof Date) return lastReset.valueOf();\n    if (typeof lastReset !== 'number') return -Infinity;\n    return lastReset;\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/fetch' action.\n   *\n   * Will then start a promise for a key and potentially start the network\n   * fetch.\n   *\n   * Uses throttle only when instructed by action meta. This is valuable\n   * for ensures mutation requests always go through.\n   */\n  protected handleFetch(\n    action: FetchAction,\n    dispatch: (action: any) => Promise<void>,\n    controller: Controller,\n  ) {\n    const fetch = action.payload;\n    const { key, throttle, resolve, reject } = action.meta;\n    // TODO(breaking): remove support for Date type in 'Receive' action\n    const createdAt =\n      typeof action.meta.createdAt !== 'number'\n        ? action.meta.createdAt.getTime()\n        : action.meta.createdAt;\n\n    const deferedFetch = () => {\n      let promise = fetch();\n      const resolvePromise = (\n        promise: Promise<string | number | object | null>,\n      ) =>\n        promise\n          .then(data => {\n            resolve(data);\n            return data;\n          })\n          .catch(error => {\n            reject(error);\n            throw error;\n          });\n      // schedule non-throttled resolutions in a microtask before receive\n      // this enables users awaiting their fetch to trigger any react updates needed to deal\n      // with upcoming changes because of the fetch (for instance avoiding suspense if something is deleted)\n      if (!throttle && action.endpoint) {\n        promise = resolvePromise(promise);\n      }\n      promise = promise\n        .then(data => {\n          let lastReset = this.getLastReset();\n\n          /* istanbul ignore else */\n          if (process.env.NODE_ENV !== 'production' && isNaN(lastReset)) {\n            console.error(\n              'state.lastReset is NaN. Only positive timestamps are valid.',\n            );\n            lastReset = 0;\n          }\n\n          // don't update state with promises started before last clear\n          if (createdAt >= lastReset) {\n            // we still check for controller in case someone didn't have type protection since this didn't always exist\n            if (action.endpoint && this.controller) {\n              this.controller.resolve(action.endpoint, {\n                args: action.meta.args as any,\n                response: data,\n                fetchedAt: createdAt,\n              });\n            } else {\n              // TODO(breaking): is this branch still possible? remove in next major update\n              // does this throw if the reducer fails? - no because reducer is wrapped in try/catch\n              this.controller.dispatch(\n                createReceive(data, {\n                  ...action.meta,\n                  fetchedAt: createdAt,\n                  dataExpiryLength:\n                    action.meta.options?.dataExpiryLength ??\n                    this.dataExpiryLength,\n                }),\n              );\n            }\n          }\n          return data;\n        })\n        .catch(error => {\n          const lastReset = this.getLastReset();\n          // don't update state with promises started before last clear\n          if (createdAt >= lastReset) {\n            if (action.endpoint && this.controller) {\n              this.controller.resolve(action.endpoint, {\n                args: action.meta.args as any,\n                response: error,\n                fetchedAt: createdAt,\n                error: true,\n              });\n            } else {\n              this.controller.dispatch(\n                createReceiveError(error, {\n                  ...action.meta,\n                  errorExpiryLength:\n                    action.meta.options?.errorExpiryLength ??\n                    this.errorExpiryLength,\n                  fetchedAt: createdAt,\n                }),\n              );\n            }\n          }\n          throw error;\n        });\n      // legacy behavior schedules resolution after dispatch\n      if (!throttle && !action.endpoint) {\n        promise = resolvePromise(promise);\n      }\n      return promise;\n    };\n\n    if (throttle) {\n      return this.throttle(key, deferedFetch, createdAt)\n        .then(data => resolve(data))\n        .catch(error => reject(error));\n    } else {\n      return deferedFetch().catch(() => {});\n    }\n  }\n\n  /** Called when middleware intercepts a receive action.\n   *\n   * Will resolve the promise associated with receive key.\n   */\n  protected handleReceive(action: ReceiveAction) {\n    // this can still turn out to be untrue since this is async\n    if (action.meta.key in this.fetched) {\n      let promiseHandler: (value?: any) => void;\n      if (action.error) {\n        promiseHandler = this.rejectors[action.meta.key];\n      } else {\n        promiseHandler = this.resolvers[action.meta.key];\n      }\n      promiseHandler(action.payload);\n      // since we're resolved we no longer need to keep track of this promise\n      this.clear(action.meta.key);\n    }\n  }\n\n  /** Attaches NetworkManager to store\n   *\n   * Intercepts 'rest-hooks/fetch' actions to start requests.\n   *\n   * Resolve/rejects a request when matching 'rest-hooks/receive' event\n   * is seen.\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n\n  /** Ensures only one request for a given key is in flight at any time\n   *\n   * Uses key to either retrieve in-flight promise, or if not\n   * create a new promise and call fetch.\n   *\n   * Note: The new promise is not actually tied to fetch at all,\n   * but is resolved when the expected 'recieve' action is processed.\n   * This ensures promises are resolved only once their data is processed\n   * by the reducer.\n   */\n  protected throttle(\n    key: string,\n    fetch: () => Promise<any>,\n    createdAt: number,\n  ) {\n    const lastReset = this.getLastReset();\n    // we're already fetching so reuse the promise\n    // fetches after reset do not count\n    if (key in this.fetched && this.fetchedAt[key] > lastReset) {\n      return this.fetched[key];\n    }\n\n    this.fetched[key] = new Promise((resolve, reject) => {\n      this.resolvers[key] = resolve;\n      this.rejectors[key] = reject;\n    });\n    this.fetchedAt[key] = createdAt;\n\n    // since our real promise is resolved via the wrapReducer(),\n    // we should just stop all errors here.\n    // TODO: decouple this from useFetcher() (that's what's dispatching the error the resolves in here)\n    RIC(\n      () => {\n        fetch().catch(() => null);\n      },\n      { timeout: 500 },\n    );\n\n    return this.fetched[key];\n  }\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SET_TYPE","FETCH_TYPE","RESET_TYPE","Controller","initialState","createReceive","createReceiveError","RIC","ResetError","Error","constructor","name","NetworkManager","dataExpiryLength","errorExpiryLength","fetched","Object","create","resolvers","rejectors","fetchedAt","getState","controller","middleware","dispatch","next","action","_action$endpoint","type","handleFetch","meta","optimisticResponse","undefined","endpoint","getOptimisticResponse","Promise","resolve","then","key","_controller$getState$","error","handleReceive","assign","clearAll","k","skipLogging","init","cleanupDate","cleanup","Date","now","allSettled","fetches","values","length","clear","catch","getLastReset","lastReset","valueOf","Infinity","fetch","payload","throttle","reject","createdAt","getTime","deferedFetch","promise","resolvePromise","data","process","env","NODE_ENV","isNaN","console","args","response","_action$meta$options$","_action$meta$options","options","_action$meta$options$2","_action$meta$options2","promiseHandler","getMiddleware","timeout"],"sources":["../../src/manager/NetworkManager.ts"],"sourcesContent":["import { SET_TYPE, FETCH_TYPE, RESET_TYPE } from '../actionTypes.js';\nimport Controller from '../controller/Controller.js';\nimport { initialState } from '../internal.js';\nimport {\n  createReceive,\n  createReceiveError,\n} from '../state/legacy-actions/index.js';\nimport RIC from '../state/RIC.js';\nimport type {\n  FetchAction,\n  ReceiveAction,\n  Manager,\n  ActionTypes,\n  MiddlewareAPI,\n  Middleware,\n  State,\n} from '../types.js';\n\nexport class ResetError extends Error {\n  name = 'ResetError';\n\n  constructor() {\n    super('Aborted due to RESET');\n  }\n}\n\n/** Handles all async network dispatches\n *\n * Dedupes concurrent requests by keeping track of all fetches in flight\n * and returning existing promises for requests already in flight.\n *\n * Interfaces with store via a redux-compatible middleware.\n *\n * @see https://resthooks.io/docs/api/NetworkManager\n */\nexport default class NetworkManager implements Manager {\n  protected fetched: { [k: string]: Promise<any> } = Object.create(null);\n  protected resolvers: { [k: string]: (value?: any) => void } = {};\n  protected rejectors: { [k: string]: (value?: any) => void } = {};\n  protected fetchedAt: { [k: string]: number } = {};\n  declare readonly dataExpiryLength: number;\n  declare readonly errorExpiryLength: number;\n  protected declare middleware: Middleware;\n  protected getState: () => State<unknown> = () => initialState;\n  protected controller: Controller = new Controller();\n  declare cleanupDate?: number;\n\n  constructor(dataExpiryLength = 60000, errorExpiryLength = 1000) {\n    this.dataExpiryLength = dataExpiryLength;\n    this.errorExpiryLength = errorExpiryLength;\n\n    this.middleware = <C extends MiddlewareAPI>({\n      dispatch,\n      getState,\n      controller,\n    }: C) => {\n      this.getState = getState;\n      this.controller = controller;\n      return (next: C['dispatch']): C['dispatch'] =>\n        (action): Promise<void> => {\n          switch (action.type) {\n            case FETCH_TYPE:\n              this.handleFetch(action, dispatch, controller);\n              // This is the only case that causes any state change\n              // It's important to intercept other fetches as we don't want to trigger reducers during\n              // render - so we need to stop 'readonly' fetches which can be triggered in render\n              if (\n                action.meta.optimisticResponse !== undefined ||\n                action.endpoint?.getOptimisticResponse !== undefined\n              ) {\n                return next(action);\n              }\n              return Promise.resolve();\n            case SET_TYPE:\n              // only receive after new state is computed\n              return next(action).then(() => {\n                if (action.meta.key in this.fetched) {\n                  // Note: meta *must* be set by reducer so this should be safe\n                  const error =\n                    controller.getState().meta[action.meta.key]?.error;\n                  // processing errors result in state meta having error, so we should reject the promise\n                  if (error) {\n                    // TODO: use only new action types\n                    this.handleReceive(createReceiveError(error, action.meta));\n                  } else {\n                    this.handleReceive(action);\n                  }\n                }\n              });\n            case RESET_TYPE: {\n              const rejectors = { ...this.rejectors };\n\n              this.clearAll();\n              return next(action).then(() => {\n                // there could be external listeners to the promise\n                // this must happen after commit so our own rejector knows not to dispatch an error based on this\n                for (const k in rejectors) {\n                  rejectors[k](new ResetError());\n                }\n              });\n            }\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Used by DevtoolsManager to determine whether to log an action */\n  skipLogging(action: ActionTypes) {\n    /* istanbul ignore next */\n    return action.type === FETCH_TYPE && action.meta.key in this.fetched;\n  }\n\n  /** On mount */\n  init() {\n    delete this.cleanupDate;\n  }\n\n  /** Ensures all promises are completed by rejecting remaining. */\n  cleanup() {\n    // ensure no dispatches after unmount\n    // this must be reversible (done in init) so useEffect() remains symmetric\n    this.cleanupDate = Date.now();\n  }\n\n  allSettled() {\n    const fetches = Object.values(this.fetched);\n    if (fetches.length) return Promise.allSettled(fetches);\n  }\n\n  /** Clear all promise state */\n  protected clearAll() {\n    for (const k in this.rejectors) {\n      this.clear(k);\n    }\n  }\n\n  /** Clear promise state for a given key */\n  protected clear(key: string) {\n    this.fetched[key].catch(() => {});\n    delete this.resolvers[key];\n    delete this.rejectors[key];\n    delete this.fetched[key];\n    delete this.fetchedAt[key];\n  }\n\n  protected getLastReset() {\n    if (this.cleanupDate) return this.cleanupDate;\n    const lastReset = this.controller.getState().lastReset;\n    if (lastReset instanceof Date) return lastReset.valueOf();\n    if (typeof lastReset !== 'number') return -Infinity;\n    return lastReset;\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/fetch' action.\n   *\n   * Will then start a promise for a key and potentially start the network\n   * fetch.\n   *\n   * Uses throttle only when instructed by action meta. This is valuable\n   * for ensures mutation requests always go through.\n   */\n  protected handleFetch(\n    action: FetchAction,\n    dispatch: (action: any) => Promise<void>,\n    controller: Controller,\n  ) {\n    const fetch = action.payload;\n    const { key, throttle, resolve, reject } = action.meta;\n    // TODO(breaking): remove support for Date type in 'Receive' action\n    const createdAt =\n      typeof action.meta.createdAt !== 'number'\n        ? action.meta.createdAt.getTime()\n        : action.meta.createdAt;\n\n    const deferedFetch = () => {\n      let promise = fetch();\n      const resolvePromise = (\n        promise: Promise<string | number | object | null>,\n      ) =>\n        promise\n          .then(data => {\n            resolve(data);\n            return data;\n          })\n          .catch(error => {\n            reject(error);\n            throw error;\n          });\n      // schedule non-throttled resolutions in a microtask before receive\n      // this enables users awaiting their fetch to trigger any react updates needed to deal\n      // with upcoming changes because of the fetch (for instance avoiding suspense if something is deleted)\n      if (!throttle && action.endpoint) {\n        promise = resolvePromise(promise);\n      }\n      promise = promise\n        .then(data => {\n          let lastReset = this.getLastReset();\n\n          /* istanbul ignore else */\n          if (process.env.NODE_ENV !== 'production' && isNaN(lastReset)) {\n            console.error(\n              'state.lastReset is NaN. Only positive timestamps are valid.',\n            );\n            lastReset = 0;\n          }\n\n          // don't update state with promises started before last clear\n          if (createdAt >= lastReset) {\n            // we still check for controller in case someone didn't have type protection since this didn't always exist\n            if (action.endpoint && this.controller) {\n              this.controller.resolve(action.endpoint, {\n                args: action.meta.args as any,\n                response: data,\n                fetchedAt: createdAt,\n              });\n            } else {\n              // TODO(breaking): is this branch still possible? remove in next major update\n              // does this throw if the reducer fails? - no because reducer is wrapped in try/catch\n              this.controller.dispatch(\n                createReceive(data, {\n                  ...action.meta,\n                  fetchedAt: createdAt,\n                  dataExpiryLength:\n                    action.meta.options?.dataExpiryLength ??\n                    this.dataExpiryLength,\n                }),\n              );\n            }\n          }\n          return data;\n        })\n        .catch(error => {\n          const lastReset = this.getLastReset();\n          // don't update state with promises started before last clear\n          if (createdAt >= lastReset) {\n            if (action.endpoint && this.controller) {\n              this.controller.resolve(action.endpoint, {\n                args: action.meta.args as any,\n                response: error,\n                fetchedAt: createdAt,\n                error: true,\n              });\n            } else {\n              this.controller.dispatch(\n                createReceiveError(error, {\n                  ...action.meta,\n                  errorExpiryLength:\n                    action.meta.options?.errorExpiryLength ??\n                    this.errorExpiryLength,\n                  fetchedAt: createdAt,\n                }),\n              );\n            }\n          }\n          throw error;\n        });\n      // legacy behavior schedules resolution after dispatch\n      if (!throttle && !action.endpoint) {\n        promise = resolvePromise(promise);\n      }\n      return promise;\n    };\n\n    if (throttle) {\n      return this.throttle(key, deferedFetch, createdAt)\n        .then(data => resolve(data))\n        .catch(error => reject(error));\n    } else {\n      return deferedFetch().catch(() => {});\n    }\n  }\n\n  /** Called when middleware intercepts a receive action.\n   *\n   * Will resolve the promise associated with receive key.\n   */\n  protected handleReceive(action: ReceiveAction) {\n    // this can still turn out to be untrue since this is async\n    if (action.meta.key in this.fetched) {\n      let promiseHandler: (value?: any) => void;\n      if (action.error) {\n        promiseHandler = this.rejectors[action.meta.key];\n      } else {\n        promiseHandler = this.resolvers[action.meta.key];\n      }\n      promiseHandler(action.payload);\n      // since we're resolved we no longer need to keep track of this promise\n      this.clear(action.meta.key);\n    }\n  }\n\n  /** Attaches NetworkManager to store\n   *\n   * Intercepts 'rest-hooks/fetch' actions to start requests.\n   *\n   * Resolve/rejects a request when matching 'rest-hooks/receive' event\n   * is seen.\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n\n  /** Ensures only one request for a given key is in flight at any time\n   *\n   * Uses key to either retrieve in-flight promise, or if not\n   * create a new promise and call fetch.\n   *\n   * Note: The new promise is not actually tied to fetch at all,\n   * but is resolved when the expected 'recieve' action is processed.\n   * This ensures promises are resolved only once their data is processed\n   * by the reducer.\n   */\n  protected throttle(\n    key: string,\n    fetch: () => Promise<any>,\n    createdAt: number,\n  ) {\n    const lastReset = this.getLastReset();\n    // we're already fetching so reuse the promise\n    // fetches after reset do not count\n    if (key in this.fetched && this.fetchedAt[key] > lastReset) {\n      return this.fetched[key];\n    }\n\n    this.fetched[key] = new Promise((resolve, reject) => {\n      this.resolvers[key] = resolve;\n      this.rejectors[key] = reject;\n    });\n    this.fetchedAt[key] = createdAt;\n\n    // since our real promise is resolved via the wrapReducer(),\n    // we should just stop all errors here.\n    // TODO: decouple this from useFetcher() (that's what's dispatching the error the resolves in here)\n    RIC(\n      () => {\n        fetch().catch(() => null);\n      },\n      { timeout: 500 },\n    );\n\n    return this.fetched[key];\n  }\n}\n"],"mappings":"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"} |
@@ -159,2 +159,2 @@ import DefaultConnectionListener from './DefaultConnectionListener.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","createFetch","PollingSubscription","constructor","key","schema","fetch","frequency","getState","dispatch","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","Math","max","lastFetchTime","addOfflineListener","undefined","Error","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","endpoint","dataExpiryLength","errorExpiryLength","errorPolicy","action","args","meta","promise","catch","e","setInterval","_this$getState$meta$t","_this$getState$meta$t2","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface, Schema } from '@rest-hooks/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport { Subscription, SubscriptionInit } from './SubscriptionManager.js';\nimport createFetch from '../controller/createFetch.js';\nimport type { State, Dispatch } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://resthooks.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  protected declare readonly schema: Schema | undefined;\n  protected declare readonly fetch: () => Promise<any>;\n  protected declare readonly key: string;\n  protected declare frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  protected declare dispatch: Dispatch<any>;\n  protected declare getState: () => State<unknown>;\n  protected declare intervalId?: ReturnType<typeof setInterval>;\n  protected declare lastIntervalId?: ReturnType<typeof setInterval>;\n  protected declare startId?: ReturnType<typeof setTimeout>;\n  private declare connectionListener: ConnectionListener;\n\n  constructor(\n    { key, schema, fetch, frequency, getState }: SubscriptionInit,\n    dispatch: Dispatch<any>,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (frequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.schema = schema;\n    this.fetch = fetch;\n    this.frequency = frequency;\n    this.key = key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const endpoint: EndpointInterface = () => this.fetch();\n    (endpoint as any).schema = this.schema;\n    endpoint.key = () => this.key;\n    (endpoint as any).dataExpiryLength = this.frequency / 2;\n    (endpoint as any).errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    const action = createFetch(endpoint, { args: [] });\n    // stop any errors here from bubbling\n    (action.meta.promise as Promise<any>).catch(e => null);\n    this.dispatch(action);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(() => {\n      if (this.startId) {\n        delete this.startId;\n        this.update();\n        this.run();\n      } else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n        );\n      }\n    }, Math.max(0, this.lastFetchTime() - now + this.frequency));\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","createFetch","PollingSubscription","constructor","key","schema","fetch","frequency","getState","dispatch","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","Math","max","lastFetchTime","addOfflineListener","undefined","Error","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","endpoint","dataExpiryLength","errorExpiryLength","errorPolicy","action","args","meta","promise","catch","e","setInterval","_this$getState$meta$t","_this$getState$meta$t2","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface, Schema } from '@rest-hooks/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport { Subscription, SubscriptionInit } from './SubscriptionManager.js';\nimport createFetch from '../controller/createFetch.js';\nimport type { State, Dispatch } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://resthooks.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  protected declare readonly schema: Schema | undefined;\n  protected declare readonly fetch: () => Promise<any>;\n  protected declare readonly key: string;\n  protected declare frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  protected declare dispatch: Dispatch<any>;\n  protected declare getState: () => State<unknown>;\n  protected declare intervalId?: ReturnType<typeof setInterval>;\n  protected declare lastIntervalId?: ReturnType<typeof setInterval>;\n  protected declare startId?: ReturnType<typeof setTimeout>;\n  private declare connectionListener: ConnectionListener;\n\n  constructor(\n    { key, schema, fetch, frequency, getState }: SubscriptionInit,\n    dispatch: Dispatch<any>,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (frequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.schema = schema;\n    this.fetch = fetch;\n    this.frequency = frequency;\n    this.key = key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const endpoint: EndpointInterface = () => this.fetch();\n    (endpoint as any).schema = this.schema;\n    endpoint.key = () => this.key;\n    (endpoint as any).dataExpiryLength = this.frequency / 2;\n    (endpoint as any).errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    const action = createFetch(endpoint, { args: [] });\n    // stop any errors here from bubbling\n    (action.meta.promise as Promise<any>).catch(e => null);\n    this.dispatch(action);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(() => {\n      if (this.startId) {\n        delete this.startId;\n        this.update();\n        this.run();\n      } else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n        );\n      }\n    }, Math.max(0, this.lastFetchTime() - now + this.frequency));\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"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"} |
@@ -117,2 +117,2 @@ import { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SUBSCRIBE_TYPE","UNSUBSCRIBE_TYPE","SubscriptionManager","constructor","Subscription","subscriptions","middleware","dispatch","getState","next","action","type","handleSubscribe","e","console","error","Promise","resolve","handleUnsubscribe","cleanup","key","options","endpoint","args","meta","schema","fetch","frequency","pollFrequency","_action$meta$options","add","_action$meta$options2","empty","remove","process","env","NODE_ENV","getMiddleware"],"sources":["../../src/manager/SubscriptionManager.ts"],"sourcesContent":["import type { Schema } from '@rest-hooks/normalizr';\n\nimport { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../actionTypes.js';\nimport type {\n  Manager,\n  State,\n  MiddlewareAPI,\n  Middleware,\n  Dispatch,\n  UnsubscribeAction,\n  SubscribeAction,\n} from '../types.js';\n\ntype Actions = UnsubscribeAction | SubscribeAction;\n\n/** Properties sent to Subscription constructor */\nexport interface SubscriptionInit {\n  schema?: Schema | undefined;\n  fetch: () => Promise<any>;\n  key: string;\n  getState: () => State<unknown>;\n  frequency?: number | undefined;\n}\n\n/** Interface handling a single resource subscription */\nexport interface Subscription {\n  add(frequency?: number): void;\n  remove(frequency?: number): boolean;\n  cleanup(): void;\n}\n\n/** The static class that constructs Subscription */\nexport interface SubscriptionConstructable {\n  new (init: SubscriptionInit, dispatch: Dispatch<any>): Subscription;\n}\n\n/** Handles subscription actions -> fetch or receive actions\n *\n * Constructor takes a SubscriptionConstructable class to control how\n * subscriptions are handled. (e.g., polling, websockets)\n *\n * @see https://resthooks.io/docs/api/SubscriptionManager\n */\nexport default class SubscriptionManager<S extends SubscriptionConstructable>\n  implements Manager\n{\n  protected subscriptions: {\n    [key: string]: InstanceType<S>;\n  } = {};\n\n  protected declare readonly Subscription: S;\n  protected declare middleware: Middleware;\n\n  constructor(Subscription: S) {\n    this.Subscription = Subscription;\n\n    this.middleware = <C extends MiddlewareAPI>({ dispatch, getState }: C) => {\n      return (next: C['dispatch']): C['dispatch'] =>\n        action => {\n          switch (action.type) {\n            case SUBSCRIBE_TYPE:\n              try {\n                this.handleSubscribe(action, dispatch, getState);\n              } catch (e) {\n                console.error(e);\n              }\n              return Promise.resolve();\n            case UNSUBSCRIBE_TYPE:\n              this.handleUnsubscribe(action, dispatch);\n              return Promise.resolve();\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {\n    for (const key in this.subscriptions) {\n      this.subscriptions[key].cleanup();\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/subscribe' action.\n   *\n   */\n  protected handleSubscribe(\n    action: SubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n    getState: () => State<unknown>,\n  ) {\n    let options: SubscriptionInit;\n    if (action.endpoint) {\n      const { endpoint } = action;\n      const { args } = action.meta;\n      options = {\n        schema: endpoint.schema,\n        fetch: () => endpoint(...args),\n        frequency: endpoint.pollFrequency,\n        key: endpoint.key(...args),\n        getState,\n      };\n    } else {\n      options = {\n        key: action.meta.key,\n        frequency: action.meta.options?.pollFrequency,\n        schema: action.meta.schema,\n        fetch: action.meta.fetch,\n        getState,\n      };\n    }\n\n    if (options.key in this.subscriptions) {\n      this.subscriptions[options.key].add(options.frequency);\n    } else {\n      this.subscriptions[options.key] = new this.Subscription(\n        options,\n        dispatch,\n      ) as InstanceType<S>;\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/unsubscribe' action.\n   *\n   */\n  protected handleUnsubscribe(\n    action: UnsubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n  ) {\n    const key = action.meta.key;\n    const frequency = action.meta.options?.pollFrequency;\n\n    /* istanbul ignore else */\n    if (key in this.subscriptions) {\n      const empty = this.subscriptions[key].remove(frequency);\n      if (empty) {\n        delete this.subscriptions[key];\n      }\n    } else if (process.env.NODE_ENV !== 'production') {\n      console.error(`Mismatched unsubscribe: ${key} is not subscribed`);\n    }\n  }\n\n  /** Attaches Manager to store\n   *\n   * Intercepts 'rest-hooks/subscribe'/'rest-hooks/unsubscribe' to register resources that\n   * need to be kept up to date.\n   *\n   * Will possibly dispatch 'rest-hooks/fetch' or 'rest-hooks/receive' to keep resources fresh\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SUBSCRIBE_TYPE","UNSUBSCRIBE_TYPE","SubscriptionManager","constructor","Subscription","subscriptions","middleware","dispatch","getState","next","action","type","handleSubscribe","e","console","error","Promise","resolve","handleUnsubscribe","cleanup","key","options","endpoint","args","meta","schema","fetch","frequency","pollFrequency","_action$meta$options","add","_action$meta$options2","empty","remove","process","env","NODE_ENV","getMiddleware"],"sources":["../../src/manager/SubscriptionManager.ts"],"sourcesContent":["import type { Schema } from '@rest-hooks/normalizr';\n\nimport { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../actionTypes.js';\nimport type {\n  Manager,\n  State,\n  MiddlewareAPI,\n  Middleware,\n  Dispatch,\n  UnsubscribeAction,\n  SubscribeAction,\n} from '../types.js';\n\ntype Actions = UnsubscribeAction | SubscribeAction;\n\n/** Properties sent to Subscription constructor */\nexport interface SubscriptionInit {\n  schema?: Schema | undefined;\n  fetch: () => Promise<any>;\n  key: string;\n  getState: () => State<unknown>;\n  frequency?: number | undefined;\n}\n\n/** Interface handling a single resource subscription */\nexport interface Subscription {\n  add(frequency?: number): void;\n  remove(frequency?: number): boolean;\n  cleanup(): void;\n}\n\n/** The static class that constructs Subscription */\nexport interface SubscriptionConstructable {\n  new (init: SubscriptionInit, dispatch: Dispatch<any>): Subscription;\n}\n\n/** Handles subscription actions -> fetch or receive actions\n *\n * Constructor takes a SubscriptionConstructable class to control how\n * subscriptions are handled. (e.g., polling, websockets)\n *\n * @see https://resthooks.io/docs/api/SubscriptionManager\n */\nexport default class SubscriptionManager<S extends SubscriptionConstructable>\n  implements Manager\n{\n  protected subscriptions: {\n    [key: string]: InstanceType<S>;\n  } = {};\n\n  protected declare readonly Subscription: S;\n  protected declare middleware: Middleware;\n\n  constructor(Subscription: S) {\n    this.Subscription = Subscription;\n\n    this.middleware = <C extends MiddlewareAPI>({ dispatch, getState }: C) => {\n      return (next: C['dispatch']): C['dispatch'] =>\n        action => {\n          switch (action.type) {\n            case SUBSCRIBE_TYPE:\n              try {\n                this.handleSubscribe(action, dispatch, getState);\n              } catch (e) {\n                console.error(e);\n              }\n              return Promise.resolve();\n            case UNSUBSCRIBE_TYPE:\n              this.handleUnsubscribe(action, dispatch);\n              return Promise.resolve();\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {\n    for (const key in this.subscriptions) {\n      this.subscriptions[key].cleanup();\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/subscribe' action.\n   *\n   */\n  protected handleSubscribe(\n    action: SubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n    getState: () => State<unknown>,\n  ) {\n    let options: SubscriptionInit;\n    if (action.endpoint) {\n      const { endpoint } = action;\n      const { args } = action.meta;\n      options = {\n        schema: endpoint.schema,\n        fetch: () => endpoint(...args),\n        frequency: endpoint.pollFrequency,\n        key: endpoint.key(...args),\n        getState,\n      };\n    } else {\n      options = {\n        key: action.meta.key,\n        frequency: action.meta.options?.pollFrequency,\n        schema: action.meta.schema,\n        fetch: action.meta.fetch,\n        getState,\n      };\n    }\n\n    if (options.key in this.subscriptions) {\n      this.subscriptions[options.key].add(options.frequency);\n    } else {\n      this.subscriptions[options.key] = new this.Subscription(\n        options,\n        dispatch,\n      ) as InstanceType<S>;\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/unsubscribe' action.\n   *\n   */\n  protected handleUnsubscribe(\n    action: UnsubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n  ) {\n    const key = action.meta.key;\n    const frequency = action.meta.options?.pollFrequency;\n\n    /* istanbul ignore else */\n    if (key in this.subscriptions) {\n      const empty = this.subscriptions[key].remove(frequency);\n      if (empty) {\n        delete this.subscriptions[key];\n      }\n    } else if (process.env.NODE_ENV !== 'production') {\n      console.error(`Mismatched unsubscribe: ${key} is not subscribed`);\n    }\n  }\n\n  /** Attaches Manager to store\n   *\n   * Intercepts 'rest-hooks/subscribe'/'rest-hooks/unsubscribe' to register resources that\n   * need to be kept up to date.\n   *\n   * Will possibly dispatch 'rest-hooks/fetch' or 'rest-hooks/receive' to keep resources fresh\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"AAEA,SAASA,cAAc,EAAEC,gBAAgB,QAAQ,mBAAmB;;AAapE;;AASA;;AAOA;;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,MAAMC,mBAAmB,CAExC;EAQEC,WAAWA,CAACC,YAAe,EAAE;IAAA,KAPnBC,aAAa,GAEnB,CAAC,CAAC;IAMJ,IAAI,CAACD,YAAY,GAAGA,YAAY;IAEhC,IAAI,CAACE,UAAU,GAAG,CAA0B;MAAEC,QAAQ;MAAEC;IAAY,CAAC,KAAK;MACxE,OAAQC,IAAmB,IACzBC,MAAM,IAAI;QACR,QAAQA,MAAM,CAACC,IAAI;UACjB,KAAKX,cAAc;YACjB,IAAI;cACF,IAAI,CAACY,eAAe,CAACF,MAAM,EAAEH,QAAQ,EAAEC,QAAQ,CAAC;YAClD,CAAC,CAAC,OAAOK,CAAC,EAAE;cACVC,OAAO,CAACC,KAAK,CAACF,CAAC,CAAC;YAClB;YACA,OAAOG,OAAO,CAACC,OAAO,CAAC,CAAC;UAC1B,KAAKhB,gBAAgB;YACnB,IAAI,CAACiB,iBAAiB,CAACR,MAAM,EAAEH,QAAQ,CAAC;YACxC,OAAOS,OAAO,CAACC,OAAO,CAAC,CAAC;UAC1B;YACE,OAAOR,IAAI,CAACC,MAAM,CAAC;QACvB;MACF,CAAC;IACL,CAAC;EACH;;EAEA;EACAS,OAAOA,CAAA,EAAG;IACR,KAAK,MAAMC,GAAG,IAAI,IAAI,CAACf,aAAa,EAAE;MACpC,IAAI,CAACA,aAAa,CAACe,GAAG,CAAC,CAACD,OAAO,CAAC,CAAC;IACnC;EACF;;EAEA;AACF;AACA;EACYP,eAAeA,CACvBF,MAAuB,EACvBH,QAAwC,EACxCC,QAA8B,EAC9B;IACA,IAAIa,OAAyB;IAC7B,IAAIX,MAAM,CAACY,QAAQ,EAAE;MACnB,MAAM;QAAEA;MAAS,CAAC,GAAGZ,MAAM;MAC3B,MAAM;QAAEa;MAAK,CAAC,GAAGb,MAAM,CAACc,IAAI;MAC5BH,OAAO,GAAG;QACRI,MAAM,EAAEH,QAAQ,CAACG,MAAM;QACvBC,KAAK,EAAEA,CAAA,KAAMJ,QAAQ,CAAC,GAAGC,IAAI,CAAC;QAC9BI,SAAS,EAAEL,QAAQ,CAACM,aAAa;QACjCR,GAAG,EAAEE,QAAQ,CAACF,GAAG,CAAC,GAAGG,IAAI,CAAC;QAC1Bf;MACF,CAAC;IACH,CAAC,MAAM;MAAA,IAAAqB,oBAAA;MACLR,OAAO,GAAG;QACRD,GAAG,EAAEV,MAAM,CAACc,IAAI,CAACJ,GAAG;QACpBO,SAAS,GAAAE,oBAAA,GAAEnB,MAAM,CAACc,IAAI,CAACH,OAAO,qBAAnBQ,oBAAA,CAAqBD,aAAa;QAC7CH,MAAM,EAAEf,MAAM,CAACc,IAAI,CAACC,MAAM;QAC1BC,KAAK,EAAEhB,MAAM,CAACc,IAAI,CAACE,KAAK;QACxBlB;MACF,CAAC;IACH;IAEA,IAAIa,OAAO,CAACD,GAAG,IAAI,IAAI,CAACf,aAAa,EAAE;MACrC,IAAI,CAACA,aAAa,CAACgB,OAAO,CAACD,GAAG,CAAC,CAACU,GAAG,CAACT,OAAO,CAACM,SAAS,CAAC;IACxD,CAAC,MAAM;MACL,IAAI,CAACtB,aAAa,CAACgB,OAAO,CAACD,GAAG,CAAC,GAAG,IAAI,IAAI,CAAChB,YAAY,CACrDiB,OAAO,EACPd,QACF,CAAoB;IACtB;EACF;;EAEA;AACF;AACA;EACYW,iBAAiBA,CACzBR,MAAyB,EACzBH,QAAwC,EACxC;IAAA,IAAAwB,qBAAA;IACA,MAAMX,GAAG,GAAGV,MAAM,CAACc,IAAI,CAACJ,GAAG;IAC3B,MAAMO,SAAS,IAAAI,qBAAA,GAAGrB,MAAM,CAACc,IAAI,CAACH,OAAO,qBAAnBU,qBAAA,CAAqBH,aAAa;;IAEpD;IACA,IAAIR,GAAG,IAAI,IAAI,CAACf,aAAa,EAAE;MAC7B,MAAM2B,KAAK,GAAG,IAAI,CAAC3B,aAAa,CAACe,GAAG,CAAC,CAACa,MAAM,CAACN,SAAS,CAAC;MACvD,IAAIK,KAAK,EAAE;QACT,OAAO,IAAI,CAAC3B,aAAa,CAACe,GAAG,CAAC;MAChC;IACF,CAAC,MAAM,IAAIc,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;MAChDtB,OAAO,CAACC,KAAK,CAAE,2BAA0BK,GAAI,oBAAmB,CAAC;IACnE;EACF;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEiB,aAAaA,CAAA,EAAG;IACd,OAAO,IAAI,CAAC/B,UAAU;EACxB;AACF"} |
@@ -24,2 +24,2 @@ import { denormalize } from '@rest-hooks/normalizr'; | ||
export * from '../controller/BaseController.js'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZW5vcm1hbGl6ZSIsIkJhc2VDb250cm9sbGVyIiwiY3JlYXRlRmV0Y2giLCJDb250cm9sbGVyIiwiY29uc3RydWN0b3IiLCJfYXJncyIsImZldGNoIiwiZW5kcG9pbnQiLCJhcmdzIiwiYWN0aW9uIiwiZGlzcGF0Y2giLCJzY2hlbWEiLCJtZXRhIiwicHJvbWlzZSIsInRoZW4iLCJpbnB1dCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZXh0L0NvbnRyb2xsZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgRGVub3JtYWxpemUgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuaW1wb3J0IHsgZGVub3JtYWxpemUgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgQmFzZUNvbnRyb2xsZXIsIHtcbiAgQ29tcGF0aWJsZURpc3BhdGNoLFxuICBHZW5lcmljRGlzcGF0Y2gsXG59IGZyb20gJy4uL2NvbnRyb2xsZXIvQmFzZUNvbnRyb2xsZXIuanMnO1xuaW1wb3J0IGNyZWF0ZUZldGNoIGZyb20gJy4uL2NvbnRyb2xsZXIvY3JlYXRlRmV0Y2guanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi4vY29udHJvbGxlci90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbnRyb2xsZXI8XG4gIEQgZXh0ZW5kcyBHZW5lcmljRGlzcGF0Y2ggPSBDb21wYXRpYmxlRGlzcGF0Y2gsXG4+IGV4dGVuZHMgQmFzZUNvbnRyb2xsZXI8RD4ge1xuICAvKipcbiAgICogRmV0Y2hlcyB0aGUgZW5kcG9pbnQgd2l0aCBnaXZlbiBhcmdzLCB1cGRhdGluZyB0aGUgUmVzdCBIb29rcyBjYWNoZSB3aXRoIHRoZSByZXNwb25zZSBvciBlcnJvciB1cG9uIGNvbXBsZXRpb24uXG4gICAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvQ29udHJvbGxlciNmZXRjaFxuICAgKi9cbiAgZmV0Y2ggPSA8XG4gICAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYgeyB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+IH0sXG4gID4oXG4gICAgZW5kcG9pbnQ6IEUsXG4gICAgLi4uYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dXG4gICk6IEVbJ3NjaGVtYSddIGV4dGVuZHMgdW5kZWZpbmVkIHwgbnVsbFxuICAgID8gUmV0dXJuVHlwZTxFPlxuICAgIDogUHJvbWlzZTxEZW5vcm1hbGl6ZTxFWydzY2hlbWEnXT4+ID0+IHtcbiAgICBjb25zdCBhY3Rpb24gPSBjcmVhdGVGZXRjaChlbmRwb2ludCwge1xuICAgICAgYXJncyxcbiAgICB9KTtcbiAgICB0aGlzLmRpc3BhdGNoKGFjdGlvbik7XG5cbiAgICBpZiAoZW5kcG9pbnQuc2NoZW1hKSB7XG4gICAgICByZXR1cm4gYWN0aW9uLm1ldGEucHJvbWlzZS50aGVuKGlucHV0ID0+XG4gICAgICAgIGRlbm9ybWFsaXplKGlucHV0LCBlbmRwb2ludC5zY2hlbWEsIHt9LCBhcmdzKSxcbiAgICAgICkgYXMgYW55O1xuICAgIH1cbiAgICByZXR1cm4gYWN0aW9uLm1ldGEucHJvbWlzZSBhcyBhbnk7XG4gIH07XG59XG5leHBvcnQgKiBmcm9tICcuLi9jb250cm9sbGVyL0Jhc2VDb250cm9sbGVyLmpzJztcbiJdLCJtYXBwaW5ncyI6IkFBQ0EsU0FBU0EsV0FBVyxRQUFRLHVCQUF1QjtBQUVuRCxPQUFPQyxjQUFjLE1BR2QsaUNBQWlDO0FBQ3hDLE9BQU9DLFdBQVcsTUFBTSw4QkFBOEI7QUFHdEQsZUFBZSxNQUFNQyxVQUFVLFNBRXJCRixjQUFjLENBQUk7RUFBQUcsWUFBQSxHQUFBQyxLQUFBO0lBQUEsU0FBQUEsS0FBQTtJQUMxQjtBQUNGO0FBQ0E7QUFDQTtJQUhFLEtBSUFDLEtBQUssR0FBRyxDQUdOQyxRQUFXLEVBQ1gsR0FBR0MsSUFBaUMsS0FHRztNQUN2QyxNQUFNQyxNQUFNLEdBQUdQLFdBQVcsQ0FBQ0ssUUFBUSxFQUFFO1FBQ25DQztNQUNGLENBQUMsQ0FBQztNQUNGLElBQUksQ0FBQ0UsUUFBUSxDQUFDRCxNQUFNLENBQUM7TUFFckIsSUFBSUYsUUFBUSxDQUFDSSxNQUFNLEVBQUU7UUFDbkIsT0FBT0YsTUFBTSxDQUFDRyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsSUFBSSxDQUFDQyxLQUFLLElBQ25DZixXQUFXLENBQUNlLEtBQUssRUFBRVIsUUFBUSxDQUFDSSxNQUFNLEVBQUUsQ0FBQyxDQUFDLEVBQUVILElBQUksQ0FBQyxDQUM5QztNQUNIO01BQ0EsT0FBT0MsTUFBTSxDQUFDRyxJQUFJLENBQUNDLE9BQU87SUFDNUIsQ0FBQztFQUFBO0FBQ0g7QUFDQSxjQUFjLGlDQUFpQyJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZW5vcm1hbGl6ZSIsIkJhc2VDb250cm9sbGVyIiwiY3JlYXRlRmV0Y2giLCJDb250cm9sbGVyIiwiY29uc3RydWN0b3IiLCJfYXJncyIsImZldGNoIiwiZW5kcG9pbnQiLCJhcmdzIiwiYWN0aW9uIiwiZGlzcGF0Y2giLCJzY2hlbWEiLCJtZXRhIiwicHJvbWlzZSIsInRoZW4iLCJpbnB1dCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZXh0L0NvbnRyb2xsZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgRGVub3JtYWxpemUgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuaW1wb3J0IHsgZGVub3JtYWxpemUgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgQmFzZUNvbnRyb2xsZXIsIHtcbiAgQ29tcGF0aWJsZURpc3BhdGNoLFxuICBHZW5lcmljRGlzcGF0Y2gsXG59IGZyb20gJy4uL2NvbnRyb2xsZXIvQmFzZUNvbnRyb2xsZXIuanMnO1xuaW1wb3J0IGNyZWF0ZUZldGNoIGZyb20gJy4uL2NvbnRyb2xsZXIvY3JlYXRlRmV0Y2guanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi4vY29udHJvbGxlci90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbnRyb2xsZXI8XG4gIEQgZXh0ZW5kcyBHZW5lcmljRGlzcGF0Y2ggPSBDb21wYXRpYmxlRGlzcGF0Y2gsXG4+IGV4dGVuZHMgQmFzZUNvbnRyb2xsZXI8RD4ge1xuICAvKipcbiAgICogRmV0Y2hlcyB0aGUgZW5kcG9pbnQgd2l0aCBnaXZlbiBhcmdzLCB1cGRhdGluZyB0aGUgUmVzdCBIb29rcyBjYWNoZSB3aXRoIHRoZSByZXNwb25zZSBvciBlcnJvciB1cG9uIGNvbXBsZXRpb24uXG4gICAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvQ29udHJvbGxlciNmZXRjaFxuICAgKi9cbiAgZmV0Y2ggPSA8XG4gICAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYgeyB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+IH0sXG4gID4oXG4gICAgZW5kcG9pbnQ6IEUsXG4gICAgLi4uYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dXG4gICk6IEVbJ3NjaGVtYSddIGV4dGVuZHMgdW5kZWZpbmVkIHwgbnVsbFxuICAgID8gUmV0dXJuVHlwZTxFPlxuICAgIDogUHJvbWlzZTxEZW5vcm1hbGl6ZTxFWydzY2hlbWEnXT4+ID0+IHtcbiAgICBjb25zdCBhY3Rpb24gPSBjcmVhdGVGZXRjaChlbmRwb2ludCwge1xuICAgICAgYXJncyxcbiAgICB9KTtcbiAgICB0aGlzLmRpc3BhdGNoKGFjdGlvbik7XG5cbiAgICBpZiAoZW5kcG9pbnQuc2NoZW1hKSB7XG4gICAgICByZXR1cm4gYWN0aW9uLm1ldGEucHJvbWlzZS50aGVuKGlucHV0ID0+XG4gICAgICAgIGRlbm9ybWFsaXplKGlucHV0LCBlbmRwb2ludC5zY2hlbWEsIHt9LCBhcmdzKSxcbiAgICAgICkgYXMgYW55O1xuICAgIH1cbiAgICByZXR1cm4gYWN0aW9uLm1ldGEucHJvbWlzZSBhcyBhbnk7XG4gIH07XG59XG5leHBvcnQgKiBmcm9tICcuLi9jb250cm9sbGVyL0Jhc2VDb250cm9sbGVyLmpzJztcbiJdLCJtYXBwaW5ncyI6IkFBQ0EsU0FBU0EsV0FBVyxRQUFRLHVCQUF1QjtBQUVuRCxPQUFPQyxjQUFjLE1BR2QsaUNBQWlDO0FBQ3hDLE9BQU9DLFdBQVcsTUFBTSw4QkFBOEI7QUFHdEQsZUFBZSxNQUFNQyxVQUFVLFNBRXJCRixjQUFjLENBQUk7RUFBQUcsWUFBQSxHQUFBQyxLQUFBO0lBQUEsU0FBQUEsS0FBQTtJQUMxQjtBQUNGO0FBQ0E7QUFDQTtJQUhFLEtBSUFDLEtBQUssR0FBRyxDQUdOQyxRQUFXLEVBQ1gsR0FBR0MsSUFBaUMsS0FHRztNQUN2QyxNQUFNQyxNQUFNLEdBQUdQLFdBQVcsQ0FBQ0ssUUFBUSxFQUFFO1FBQ25DQztNQUNGLENBQUMsQ0FBQztNQUNGLElBQUksQ0FBQ0UsUUFBUSxDQUFDRCxNQUFNLENBQUM7TUFFckIsSUFBSUYsUUFBUSxDQUFDSSxNQUFNLEVBQUU7UUFDbkIsT0FBT0YsTUFBTSxDQUFDRyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsSUFBSSxDQUFDQyxLQUFLLElBQ25DZixXQUFXLENBQUNlLEtBQUssRUFBRVIsUUFBUSxDQUFDSSxNQUFNLEVBQUUsQ0FBQyxDQUFDLEVBQUVILElBQUksQ0FDOUMsQ0FBQztNQUNIO01BQ0EsT0FBT0MsTUFBTSxDQUFDRyxJQUFJLENBQUNDLE9BQU87SUFDNUIsQ0FBQztFQUFBO0FBQ0g7QUFDQSxjQUFjLGlDQUFpQyJ9 |
export default function applyUpdatersToResults(results, result, updaters) { | ||
return Object.assign({}, results, Object.fromEntries(Object.entries(updaters).map(([fetchKey, updater]) => [fetchKey, updater(result, results[fetchKey])]))); | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseVVwZGF0ZXJzVG9SZXN1bHRzIiwicmVzdWx0cyIsInJlc3VsdCIsInVwZGF0ZXJzIiwiT2JqZWN0IiwiYXNzaWduIiwiZnJvbUVudHJpZXMiLCJlbnRyaWVzIiwibWFwIiwiZmV0Y2hLZXkiLCJ1cGRhdGVyIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3N0YXRlL2FwcGx5VXBkYXRlcnNUb1Jlc3VsdHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBTY2hlbWEsIE5vcm1hbGl6ZSwgVXBkYXRlRnVuY3Rpb24gfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG50eXBlIFJlc3VsdFN0YXRlRnJvbVVwZGF0ZUZ1bmN0aW9uczxcbiAgU291cmNlU2NoZW1hIGV4dGVuZHMgU2NoZW1hLFxuICBVcGRhdGVGdW5jdGlvbnMgZXh0ZW5kcyB7XG4gICAgW2tleTogc3RyaW5nXTogVXBkYXRlRnVuY3Rpb248U291cmNlU2NoZW1hLCBhbnk+O1xuICB9LFxuPiA9IHsgW0sgaW4ga2V5b2YgVXBkYXRlRnVuY3Rpb25zXTogYW55IH07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5VXBkYXRlcnNUb1Jlc3VsdHM8XG4gIFNvdXJjZVNjaGVtYSBleHRlbmRzIFNjaGVtYSxcbiAgVXBkYXRlRnVuY3Rpb25zIGV4dGVuZHMge1xuICAgIFtrZXk6IHN0cmluZ106IFVwZGF0ZUZ1bmN0aW9uPFNvdXJjZVNjaGVtYSwgYW55PjtcbiAgfSxcbj4oXG4gIHJlc3VsdHM6IFJlc3VsdFN0YXRlRnJvbVVwZGF0ZUZ1bmN0aW9uczxTb3VyY2VTY2hlbWEsIFVwZGF0ZUZ1bmN0aW9ucz4sXG4gIHJlc3VsdDogTm9ybWFsaXplPFNvdXJjZVNjaGVtYT4sXG4gIHVwZGF0ZXJzOiBVcGRhdGVGdW5jdGlvbnMsXG4pIHtcbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHRzLFxuICAgIC4uLk9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgIE9iamVjdC5lbnRyaWVzKHVwZGF0ZXJzKS5tYXAoKFtmZXRjaEtleSwgdXBkYXRlcl0pID0+IFtcbiAgICAgICAgZmV0Y2hLZXksXG4gICAgICAgIHVwZGF0ZXIocmVzdWx0LCByZXN1bHRzW2ZldGNoS2V5XSksXG4gICAgICBdKSxcbiAgICApLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFTQSxlQUFlLFNBQVNBLHNCQUFzQkEsQ0FNNUNDLE9BQXNFLEVBQ3RFQyxNQUErQixFQUMvQkMsUUFBeUIsRUFDekI7RUFDQSxPQUFBQyxNQUFBLENBQUFDLE1BQUEsS0FDS0osT0FBTyxFQUNQRyxNQUFNLENBQUNFLFdBQVcsQ0FDbkJGLE1BQU0sQ0FBQ0csT0FBTyxDQUFDSixRQUFRLENBQUMsQ0FBQ0ssR0FBRyxDQUFDLENBQUMsQ0FBQ0MsUUFBUSxFQUFFQyxPQUFPLENBQUMsS0FBSyxDQUNwREQsUUFBUSxFQUNSQyxPQUFPLENBQUNSLE1BQU0sRUFBRUQsT0FBTyxDQUFDUSxRQUFRLENBQUMsQ0FBQyxDQUNuQyxDQUFDLENBQ0g7QUFFTCJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseVVwZGF0ZXJzVG9SZXN1bHRzIiwicmVzdWx0cyIsInJlc3VsdCIsInVwZGF0ZXJzIiwiT2JqZWN0IiwiYXNzaWduIiwiZnJvbUVudHJpZXMiLCJlbnRyaWVzIiwibWFwIiwiZmV0Y2hLZXkiLCJ1cGRhdGVyIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3N0YXRlL2FwcGx5VXBkYXRlcnNUb1Jlc3VsdHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBTY2hlbWEsIE5vcm1hbGl6ZSwgVXBkYXRlRnVuY3Rpb24gfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG50eXBlIFJlc3VsdFN0YXRlRnJvbVVwZGF0ZUZ1bmN0aW9uczxcbiAgU291cmNlU2NoZW1hIGV4dGVuZHMgU2NoZW1hLFxuICBVcGRhdGVGdW5jdGlvbnMgZXh0ZW5kcyB7XG4gICAgW2tleTogc3RyaW5nXTogVXBkYXRlRnVuY3Rpb248U291cmNlU2NoZW1hLCBhbnk+O1xuICB9LFxuPiA9IHsgW0sgaW4ga2V5b2YgVXBkYXRlRnVuY3Rpb25zXTogYW55IH07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5VXBkYXRlcnNUb1Jlc3VsdHM8XG4gIFNvdXJjZVNjaGVtYSBleHRlbmRzIFNjaGVtYSxcbiAgVXBkYXRlRnVuY3Rpb25zIGV4dGVuZHMge1xuICAgIFtrZXk6IHN0cmluZ106IFVwZGF0ZUZ1bmN0aW9uPFNvdXJjZVNjaGVtYSwgYW55PjtcbiAgfSxcbj4oXG4gIHJlc3VsdHM6IFJlc3VsdFN0YXRlRnJvbVVwZGF0ZUZ1bmN0aW9uczxTb3VyY2VTY2hlbWEsIFVwZGF0ZUZ1bmN0aW9ucz4sXG4gIHJlc3VsdDogTm9ybWFsaXplPFNvdXJjZVNjaGVtYT4sXG4gIHVwZGF0ZXJzOiBVcGRhdGVGdW5jdGlvbnMsXG4pIHtcbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHRzLFxuICAgIC4uLk9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgIE9iamVjdC5lbnRyaWVzKHVwZGF0ZXJzKS5tYXAoKFtmZXRjaEtleSwgdXBkYXRlcl0pID0+IFtcbiAgICAgICAgZmV0Y2hLZXksXG4gICAgICAgIHVwZGF0ZXIocmVzdWx0LCByZXN1bHRzW2ZldGNoS2V5XSksXG4gICAgICBdKSxcbiAgICApLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFTQSxlQUFlLFNBQVNBLHNCQUFzQkEsQ0FNNUNDLE9BQXNFLEVBQ3RFQyxNQUErQixFQUMvQkMsUUFBeUIsRUFDekI7RUFDQSxPQUFBQyxNQUFBLENBQUFDLE1BQUEsS0FDS0osT0FBTyxFQUNQRyxNQUFNLENBQUNFLFdBQVcsQ0FDbkJGLE1BQU0sQ0FBQ0csT0FBTyxDQUFDSixRQUFRLENBQUMsQ0FBQ0ssR0FBRyxDQUFDLENBQUMsQ0FBQ0MsUUFBUSxFQUFFQyxPQUFPLENBQUMsS0FBSyxDQUNwREQsUUFBUSxFQUNSQyxPQUFPLENBQUNSLE1BQU0sRUFBRUQsT0FBTyxDQUFDUSxRQUFRLENBQUMsQ0FBQyxDQUNuQyxDQUNILENBQUM7QUFFTCJ9 |
@@ -62,2 +62,2 @@ // TODO(breaking): remove file - not used | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJmZXRjaFNoYXBlIiwicGFyYW1zIiwiYm9keSIsInRocm90dGxlIiwidXBkYXRlUGFyYW1zIiwic2NoZW1hIiwidHlwZSIsImdldEZldGNoS2V5Iiwib3B0aW9ucyIsImtleSIsInJlc29sdmUiLCJyZWplY3QiLCJwcm9taXNlIiwiUHJvbWlzZSIsImEiLCJiIiwibWV0YSIsImFyZ3MiLCJjcmVhdGVkQXQiLCJEYXRlIiwibm93IiwidXBkYXRlIiwibmV3cmVzdWx0IiwidXBkYXRlTWFwIiwiZm9yRWFjaCIsInRvU2hhcGUiLCJ0b1BhcmFtcyIsInVwZGF0ZUZuIiwiZXhpc3RpbmciLCJvcHRpbWlzdGljVXBkYXRlIiwib3B0aW1pc3RpY1Jlc3BvbnNlIiwicGF5bG9hZCIsImZldGNoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL2xlZ2FjeS1hY3Rpb25zL2NyZWF0ZUZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIFRPRE8oYnJlYWtpbmcpOiByZW1vdmUgZmlsZSAtIG5vdCB1c2VkXG5pbXBvcnQgeyBTY2hlbWEgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBGRVRDSF9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHtcbiAgRmV0Y2hTaGFwZSxcbiAgU2NoZW1hRnJvbVNoYXBlLFxuICBQYXJhbXNGcm9tU2hhcGUsXG4gIEJvZHlGcm9tU2hhcGUsXG4gIE9wdGltaXN0aWNVcGRhdGVQYXJhbXMsXG59IGZyb20gJy4uLy4uL2VuZHBvaW50L2luZGV4LmpzJztcbmltcG9ydCB7IEZldGNoQWN0aW9uIH0gZnJvbSAnLi4vLi4vbGVnYWN5QWN0aW9ucy5qcyc7XG5cbmludGVyZmFjZSBPcHRpb25zPFxuICBTaGFwZSBleHRlbmRzIEZldGNoU2hhcGU8XG4gICAgU2NoZW1hIHwgdW5kZWZpbmVkLFxuICAgIFJlYWRvbmx5PG9iamVjdD4sXG4gICAgUmVhZG9ubHk8b2JqZWN0IHwgc3RyaW5nPiB8IHZvaWRcbiAgPixcbj4ge1xuICBwYXJhbXM6IFBhcmFtc0Zyb21TaGFwZTxTaGFwZT47XG4gIGJvZHk/OiBCb2R5RnJvbVNoYXBlPFNoYXBlPjtcbiAgdGhyb3R0bGU6IGJvb2xlYW47XG4gIHVwZGF0ZVBhcmFtcz86XG4gICAgfCBPcHRpbWlzdGljVXBkYXRlUGFyYW1zPFxuICAgICAgICBTY2hlbWFGcm9tU2hhcGU8U2hhcGU+LFxuICAgICAgICBGZXRjaFNoYXBlPFNjaGVtYSB8IHVuZGVmaW5lZCwgYW55LCBhbnk+XG4gICAgICA+W11cbiAgICB8IHVuZGVmaW5lZDtcbn1cblxuLyoqIFJlcXVlc3RpbmcgYSBmZXRjaCB0byBiZWdpblxuICpcbiAqIEBwYXJhbSBmZXRjaFNoYXBlXG4gKiBAcGFyYW0gcGFyYW0xIHsgcGFyYW1zLCBib2R5LCB0aHJvdHRsZSwgdXBkYXRlUGFyYW1zIH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlRmV0Y2g8XG4gIFNoYXBlIGV4dGVuZHMgRmV0Y2hTaGFwZTxcbiAgICBTY2hlbWEgfCB1bmRlZmluZWQsXG4gICAgUmVhZG9ubHk8b2JqZWN0PixcbiAgICBSZWFkb25seTxvYmplY3QgfCBzdHJpbmc+IHwgdm9pZFxuICA+LFxuPihcbiAgZmV0Y2hTaGFwZTogU2hhcGUgJiB7XG4gICAgdXBkYXRlPzogKC4uLmFyZ3M6IGFueSkgPT4gUmVjb3JkPHN0cmluZywgKC4uLmFyZ3M6IGFueSkgPT4gYW55PjtcbiAgfSxcbiAgeyBwYXJhbXMsIGJvZHksIHRocm90dGxlLCB1cGRhdGVQYXJhbXMgfTogT3B0aW9uczxTaGFwZT4sXG4pOiBGZXRjaEFjdGlvbiB7XG4gIGNvbnN0IHsgc2NoZW1hLCB0eXBlLCBnZXRGZXRjaEtleSwgb3B0aW9ucyB9ID0gZmV0Y2hTaGFwZTtcblxuICBjb25zdCBrZXkgPSBnZXRGZXRjaEtleShwYXJhbXMpO1xuICBsZXQgcmVzb2x2ZTogKHZhbHVlPzogYW55IHwgUHJvbWlzZUxpa2U8YW55PikgPT4gdm9pZCA9IDAgYXMgYW55O1xuICBsZXQgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZTxhbnk+KChhLCBiKSA9PiB7XG4gICAgW3Jlc29sdmUsIHJlamVjdF0gPSBbYSwgYl07XG4gIH0pO1xuICBjb25zdCBtZXRhOiBGZXRjaEFjdGlvblsnbWV0YSddID0ge1xuICAgIHNjaGVtYSxcbiAgICB0eXBlLFxuICAgIGFyZ3M6IFtwYXJhbXMsIGJvZHldLFxuICAgIGtleSxcbiAgICB0aHJvdHRsZSxcbiAgICBvcHRpb25zLFxuICAgIHJlc29sdmUsXG4gICAgcmVqZWN0LFxuICAgIHByb21pc2UsXG4gICAgY3JlYXRlZEF0OiBEYXRlLm5vdygpLFxuICB9O1xuXG4gIGlmIChmZXRjaFNoYXBlLnVwZGF0ZSkge1xuICAgIG1ldGEudXBkYXRlID0gZmV0Y2hTaGFwZS51cGRhdGU7XG4gIH1cblxuICAvLyBmb3Igc2ltcGxpY2l0eSB3ZSBzaW1wbHkgb3ZlcnJpZGUgaWYgdXBkYXRlUGFyYW1zIGFyZSBkZWZpbmVkIC0gdXNhZ2UgdG9nZXRoZXIgaXMgc2lsbHkgdG8gc3VwcG9ydCBhcyB3ZSBhcmUgbWlncmF0aW5nXG4gIGlmICh1cGRhdGVQYXJhbXMpIHtcbiAgICBtZXRhLnVwZGF0ZSA9IChuZXdyZXN1bHQ6IGFueSk6IFJlY29yZDxzdHJpbmcsICguLi5hcmdzOiBhbnkpID0+IGFueT4gPT4ge1xuICAgICAgY29uc3QgdXBkYXRlTWFwOiBhbnkgPSB7fTtcbiAgICAgIHVwZGF0ZVBhcmFtcy5mb3JFYWNoKChbdG9TaGFwZSwgdG9QYXJhbXMsIHVwZGF0ZUZuXSkgPT4ge1xuICAgICAgICB1cGRhdGVNYXBbdG9TaGFwZS5nZXRGZXRjaEtleSh0b1BhcmFtcyldID0gKGV4aXN0aW5nOiBhbnkpID0+XG4gICAgICAgICAgdXBkYXRlRm4obmV3cmVzdWx0LCBleGlzdGluZyk7XG4gICAgICB9KTtcbiAgICAgIHJldHVybiB1cGRhdGVNYXA7XG4gICAgfTtcbiAgfVxuXG4gIGlmIChvcHRpb25zPy5vcHRpbWlzdGljVXBkYXRlKSB7XG4gICAgbWV0YS5vcHRpbWlzdGljUmVzcG9uc2UgPSBvcHRpb25zLm9wdGltaXN0aWNVcGRhdGUocGFyYW1zLCBib2R5KTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHlwZTogRkVUQ0hfVFlQRSxcbiAgICBwYXlsb2FkOiAoKSA9PiBmZXRjaFNoYXBlLmZldGNoKHBhcmFtcywgYm9keSksXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBR0EsU0FBU0EsVUFBVSxRQUFRLHNCQUFzQjtBQTRCakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsV0FBV0EsQ0FPakNDLFVBRUMsRUFDRDtFQUFFQyxNQUFNO0VBQUVDLElBQUk7RUFBRUMsUUFBUTtFQUFFQztBQUE2QixDQUFDLEVBQzNDO0VBQ2IsTUFBTTtJQUFFQyxNQUFNO0lBQUVDLElBQUk7SUFBRUMsV0FBVztJQUFFQztFQUFRLENBQUMsR0FBR1IsVUFBVTtFQUV6RCxNQUFNUyxHQUFHLEdBQUdGLFdBQVcsQ0FBQ04sTUFBTSxDQUFDO0VBQy9CLElBQUlTLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQXlCLEdBQUc7SUFDaENYLE1BQU07SUFDTkMsSUFBSTtJQUNKVyxJQUFJLEVBQUUsQ0FBQ2hCLE1BQU0sRUFBRUMsSUFBSSxDQUFDO0lBQ3BCTyxHQUFHO0lBQ0hOLFFBQVE7SUFDUkssT0FBTztJQUNQRSxPQUFPO0lBQ1BDLE1BQU07SUFDTkMsT0FBTztJQUNQTSxTQUFTLEVBQUVDLElBQUksQ0FBQ0MsR0FBRztFQUNyQixDQUFDO0VBRUQsSUFBSXBCLFVBQVUsQ0FBQ3FCLE1BQU0sRUFBRTtJQUNyQkwsSUFBSSxDQUFDSyxNQUFNLEdBQUdyQixVQUFVLENBQUNxQixNQUFNO0VBQ2pDOztFQUVBO0VBQ0EsSUFBSWpCLFlBQVksRUFBRTtJQUNoQlksSUFBSSxDQUFDSyxNQUFNLEdBQUlDLFNBQWMsSUFBNEM7TUFDdkUsTUFBTUMsU0FBYyxHQUFHLENBQUMsQ0FBQztNQUN6Qm5CLFlBQVksQ0FBQ29CLE9BQU8sQ0FBQyxDQUFDLENBQUNDLE9BQU8sRUFBRUMsUUFBUSxFQUFFQyxRQUFRLENBQUMsS0FBSztRQUN0REosU0FBUyxDQUFDRSxPQUFPLENBQUNsQixXQUFXLENBQUNtQixRQUFRLENBQUMsQ0FBQyxHQUFJRSxRQUFhLElBQ3ZERCxRQUFRLENBQUNMLFNBQVMsRUFBRU0sUUFBUSxDQUFDO01BQ2pDLENBQUMsQ0FBQztNQUNGLE9BQU9MLFNBQVM7SUFDbEIsQ0FBQztFQUNIO0VBRUEsSUFBSWYsT0FBTyxZQUFQQSxPQUFPLENBQUVxQixnQkFBZ0IsRUFBRTtJQUM3QmIsSUFBSSxDQUFDYyxrQkFBa0IsR0FBR3RCLE9BQU8sQ0FBQ3FCLGdCQUFnQixDQUFDNUIsTUFBTSxFQUFFQyxJQUFJLENBQUM7RUFDbEU7RUFFQSxPQUFPO0lBQ0xJLElBQUksRUFBRVIsVUFBVTtJQUNoQmlDLE9BQU8sRUFBRUEsQ0FBQSxLQUFNL0IsVUFBVSxDQUFDZ0MsS0FBSyxDQUFDL0IsTUFBTSxFQUFFQyxJQUFJLENBQUM7SUFDN0NjO0VBQ0YsQ0FBQztBQUNIIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJmZXRjaFNoYXBlIiwicGFyYW1zIiwiYm9keSIsInRocm90dGxlIiwidXBkYXRlUGFyYW1zIiwic2NoZW1hIiwidHlwZSIsImdldEZldGNoS2V5Iiwib3B0aW9ucyIsImtleSIsInJlc29sdmUiLCJyZWplY3QiLCJwcm9taXNlIiwiUHJvbWlzZSIsImEiLCJiIiwibWV0YSIsImFyZ3MiLCJjcmVhdGVkQXQiLCJEYXRlIiwibm93IiwidXBkYXRlIiwibmV3cmVzdWx0IiwidXBkYXRlTWFwIiwiZm9yRWFjaCIsInRvU2hhcGUiLCJ0b1BhcmFtcyIsInVwZGF0ZUZuIiwiZXhpc3RpbmciLCJvcHRpbWlzdGljVXBkYXRlIiwib3B0aW1pc3RpY1Jlc3BvbnNlIiwicGF5bG9hZCIsImZldGNoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL2xlZ2FjeS1hY3Rpb25zL2NyZWF0ZUZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIFRPRE8oYnJlYWtpbmcpOiByZW1vdmUgZmlsZSAtIG5vdCB1c2VkXG5pbXBvcnQgeyBTY2hlbWEgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBGRVRDSF9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHtcbiAgRmV0Y2hTaGFwZSxcbiAgU2NoZW1hRnJvbVNoYXBlLFxuICBQYXJhbXNGcm9tU2hhcGUsXG4gIEJvZHlGcm9tU2hhcGUsXG4gIE9wdGltaXN0aWNVcGRhdGVQYXJhbXMsXG59IGZyb20gJy4uLy4uL2VuZHBvaW50L2luZGV4LmpzJztcbmltcG9ydCB7IEZldGNoQWN0aW9uIH0gZnJvbSAnLi4vLi4vbGVnYWN5QWN0aW9ucy5qcyc7XG5cbmludGVyZmFjZSBPcHRpb25zPFxuICBTaGFwZSBleHRlbmRzIEZldGNoU2hhcGU8XG4gICAgU2NoZW1hIHwgdW5kZWZpbmVkLFxuICAgIFJlYWRvbmx5PG9iamVjdD4sXG4gICAgUmVhZG9ubHk8b2JqZWN0IHwgc3RyaW5nPiB8IHZvaWRcbiAgPixcbj4ge1xuICBwYXJhbXM6IFBhcmFtc0Zyb21TaGFwZTxTaGFwZT47XG4gIGJvZHk/OiBCb2R5RnJvbVNoYXBlPFNoYXBlPjtcbiAgdGhyb3R0bGU6IGJvb2xlYW47XG4gIHVwZGF0ZVBhcmFtcz86XG4gICAgfCBPcHRpbWlzdGljVXBkYXRlUGFyYW1zPFxuICAgICAgICBTY2hlbWFGcm9tU2hhcGU8U2hhcGU+LFxuICAgICAgICBGZXRjaFNoYXBlPFNjaGVtYSB8IHVuZGVmaW5lZCwgYW55LCBhbnk+XG4gICAgICA+W11cbiAgICB8IHVuZGVmaW5lZDtcbn1cblxuLyoqIFJlcXVlc3RpbmcgYSBmZXRjaCB0byBiZWdpblxuICpcbiAqIEBwYXJhbSBmZXRjaFNoYXBlXG4gKiBAcGFyYW0gcGFyYW0xIHsgcGFyYW1zLCBib2R5LCB0aHJvdHRsZSwgdXBkYXRlUGFyYW1zIH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlRmV0Y2g8XG4gIFNoYXBlIGV4dGVuZHMgRmV0Y2hTaGFwZTxcbiAgICBTY2hlbWEgfCB1bmRlZmluZWQsXG4gICAgUmVhZG9ubHk8b2JqZWN0PixcbiAgICBSZWFkb25seTxvYmplY3QgfCBzdHJpbmc+IHwgdm9pZFxuICA+LFxuPihcbiAgZmV0Y2hTaGFwZTogU2hhcGUgJiB7XG4gICAgdXBkYXRlPzogKC4uLmFyZ3M6IGFueSkgPT4gUmVjb3JkPHN0cmluZywgKC4uLmFyZ3M6IGFueSkgPT4gYW55PjtcbiAgfSxcbiAgeyBwYXJhbXMsIGJvZHksIHRocm90dGxlLCB1cGRhdGVQYXJhbXMgfTogT3B0aW9uczxTaGFwZT4sXG4pOiBGZXRjaEFjdGlvbiB7XG4gIGNvbnN0IHsgc2NoZW1hLCB0eXBlLCBnZXRGZXRjaEtleSwgb3B0aW9ucyB9ID0gZmV0Y2hTaGFwZTtcblxuICBjb25zdCBrZXkgPSBnZXRGZXRjaEtleShwYXJhbXMpO1xuICBsZXQgcmVzb2x2ZTogKHZhbHVlPzogYW55IHwgUHJvbWlzZUxpa2U8YW55PikgPT4gdm9pZCA9IDAgYXMgYW55O1xuICBsZXQgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZTxhbnk+KChhLCBiKSA9PiB7XG4gICAgW3Jlc29sdmUsIHJlamVjdF0gPSBbYSwgYl07XG4gIH0pO1xuICBjb25zdCBtZXRhOiBGZXRjaEFjdGlvblsnbWV0YSddID0ge1xuICAgIHNjaGVtYSxcbiAgICB0eXBlLFxuICAgIGFyZ3M6IFtwYXJhbXMsIGJvZHldLFxuICAgIGtleSxcbiAgICB0aHJvdHRsZSxcbiAgICBvcHRpb25zLFxuICAgIHJlc29sdmUsXG4gICAgcmVqZWN0LFxuICAgIHByb21pc2UsXG4gICAgY3JlYXRlZEF0OiBEYXRlLm5vdygpLFxuICB9O1xuXG4gIGlmIChmZXRjaFNoYXBlLnVwZGF0ZSkge1xuICAgIG1ldGEudXBkYXRlID0gZmV0Y2hTaGFwZS51cGRhdGU7XG4gIH1cblxuICAvLyBmb3Igc2ltcGxpY2l0eSB3ZSBzaW1wbHkgb3ZlcnJpZGUgaWYgdXBkYXRlUGFyYW1zIGFyZSBkZWZpbmVkIC0gdXNhZ2UgdG9nZXRoZXIgaXMgc2lsbHkgdG8gc3VwcG9ydCBhcyB3ZSBhcmUgbWlncmF0aW5nXG4gIGlmICh1cGRhdGVQYXJhbXMpIHtcbiAgICBtZXRhLnVwZGF0ZSA9IChuZXdyZXN1bHQ6IGFueSk6IFJlY29yZDxzdHJpbmcsICguLi5hcmdzOiBhbnkpID0+IGFueT4gPT4ge1xuICAgICAgY29uc3QgdXBkYXRlTWFwOiBhbnkgPSB7fTtcbiAgICAgIHVwZGF0ZVBhcmFtcy5mb3JFYWNoKChbdG9TaGFwZSwgdG9QYXJhbXMsIHVwZGF0ZUZuXSkgPT4ge1xuICAgICAgICB1cGRhdGVNYXBbdG9TaGFwZS5nZXRGZXRjaEtleSh0b1BhcmFtcyldID0gKGV4aXN0aW5nOiBhbnkpID0+XG4gICAgICAgICAgdXBkYXRlRm4obmV3cmVzdWx0LCBleGlzdGluZyk7XG4gICAgICB9KTtcbiAgICAgIHJldHVybiB1cGRhdGVNYXA7XG4gICAgfTtcbiAgfVxuXG4gIGlmIChvcHRpb25zPy5vcHRpbWlzdGljVXBkYXRlKSB7XG4gICAgbWV0YS5vcHRpbWlzdGljUmVzcG9uc2UgPSBvcHRpb25zLm9wdGltaXN0aWNVcGRhdGUocGFyYW1zLCBib2R5KTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHlwZTogRkVUQ0hfVFlQRSxcbiAgICBwYXlsb2FkOiAoKSA9PiBmZXRjaFNoYXBlLmZldGNoKHBhcmFtcywgYm9keSksXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBR0EsU0FBU0EsVUFBVSxRQUFRLHNCQUFzQjtBQTRCakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsV0FBV0EsQ0FPakNDLFVBRUMsRUFDRDtFQUFFQyxNQUFNO0VBQUVDLElBQUk7RUFBRUMsUUFBUTtFQUFFQztBQUE2QixDQUFDLEVBQzNDO0VBQ2IsTUFBTTtJQUFFQyxNQUFNO0lBQUVDLElBQUk7SUFBRUMsV0FBVztJQUFFQztFQUFRLENBQUMsR0FBR1IsVUFBVTtFQUV6RCxNQUFNUyxHQUFHLEdBQUdGLFdBQVcsQ0FBQ04sTUFBTSxDQUFDO0VBQy9CLElBQUlTLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQXlCLEdBQUc7SUFDaENYLE1BQU07SUFDTkMsSUFBSTtJQUNKVyxJQUFJLEVBQUUsQ0FBQ2hCLE1BQU0sRUFBRUMsSUFBSSxDQUFDO0lBQ3BCTyxHQUFHO0lBQ0hOLFFBQVE7SUFDUkssT0FBTztJQUNQRSxPQUFPO0lBQ1BDLE1BQU07SUFDTkMsT0FBTztJQUNQTSxTQUFTLEVBQUVDLElBQUksQ0FBQ0MsR0FBRyxDQUFDO0VBQ3RCLENBQUM7RUFFRCxJQUFJcEIsVUFBVSxDQUFDcUIsTUFBTSxFQUFFO0lBQ3JCTCxJQUFJLENBQUNLLE1BQU0sR0FBR3JCLFVBQVUsQ0FBQ3FCLE1BQU07RUFDakM7O0VBRUE7RUFDQSxJQUFJakIsWUFBWSxFQUFFO0lBQ2hCWSxJQUFJLENBQUNLLE1BQU0sR0FBSUMsU0FBYyxJQUE0QztNQUN2RSxNQUFNQyxTQUFjLEdBQUcsQ0FBQyxDQUFDO01BQ3pCbkIsWUFBWSxDQUFDb0IsT0FBTyxDQUFDLENBQUMsQ0FBQ0MsT0FBTyxFQUFFQyxRQUFRLEVBQUVDLFFBQVEsQ0FBQyxLQUFLO1FBQ3RESixTQUFTLENBQUNFLE9BQU8sQ0FBQ2xCLFdBQVcsQ0FBQ21CLFFBQVEsQ0FBQyxDQUFDLEdBQUlFLFFBQWEsSUFDdkRELFFBQVEsQ0FBQ0wsU0FBUyxFQUFFTSxRQUFRLENBQUM7TUFDakMsQ0FBQyxDQUFDO01BQ0YsT0FBT0wsU0FBUztJQUNsQixDQUFDO0VBQ0g7RUFFQSxJQUFJZixPQUFPLFlBQVBBLE9BQU8sQ0FBRXFCLGdCQUFnQixFQUFFO0lBQzdCYixJQUFJLENBQUNjLGtCQUFrQixHQUFHdEIsT0FBTyxDQUFDcUIsZ0JBQWdCLENBQUM1QixNQUFNLEVBQUVDLElBQUksQ0FBQztFQUNsRTtFQUVBLE9BQU87SUFDTEksSUFBSSxFQUFFUixVQUFVO0lBQ2hCaUMsT0FBTyxFQUFFQSxDQUFBLEtBQU0vQixVQUFVLENBQUNnQyxLQUFLLENBQUMvQixNQUFNLEVBQUVDLElBQUksQ0FBQztJQUM3Q2M7RUFDRixDQUFDO0FBQ0gifQ== |
@@ -37,2 +37,2 @@ import { RECEIVE_TYPE } from '../../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUNFSVZFX1RZUEUiLCJjcmVhdGVSZWNlaXZlIiwiZGF0YSIsInNjaGVtYSIsImtleSIsImFyZ3MiLCJ1cGRhdGVycyIsImZldGNoZWRBdCIsInVwZGF0ZSIsImRhdGFFeHBpcnlMZW5ndGgiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJFcnJvciIsIm5vdyIsIkRhdGUiLCJtZXRhIiwiZGF0ZSIsImV4cGlyZXNBdCIsInR5cGUiLCJwYXlsb2FkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL2xlZ2FjeS1hY3Rpb25zL2NyZWF0ZVJlY2VpdmUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIEVuZHBvaW50RXh0cmFPcHRpb25zIGFzIEZldGNoT3B0aW9ucyxcbn0gZnJvbSAnQHJlc3QtaG9va3Mvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgUkVDRUlWRV9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHsgRmV0Y2hBY3Rpb24sIFJlY2VpdmVBY3Rpb24gfSBmcm9tICcuLi8uLi9sZWdhY3lBY3Rpb25zLmpzJztcblxuaW50ZXJmYWNlIE9wdGlvbnM8XG4gIFBheWxvYWQgZXh0ZW5kcyBvYmplY3QgfCBzdHJpbmcgfCBudW1iZXIgfCBudWxsID1cbiAgICB8IG9iamVjdFxuICAgIHwgc3RyaW5nXG4gICAgfCBudW1iZXJcbiAgICB8IG51bGwsXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBhbnksXG4+IGV4dGVuZHMgUGljazxcbiAgICBGZXRjaEFjdGlvbjxQYXlsb2FkLCBTPlsnbWV0YSddLFxuICAgICdzY2hlbWEnIHwgJ2tleScgfCAndHlwZScgfCAndXBkYXRlcnMnIHwgJ3VwZGF0ZScgfCAnYXJncydcbiAgPiB7XG4gIGRhdGFFeHBpcnlMZW5ndGg6IE5vbk51bGxhYmxlPEZldGNoT3B0aW9uc1snZGF0YUV4cGlyeUxlbmd0aCddPjtcbiAgZmV0Y2hlZEF0PzogbnVtYmVyO1xufVxuXG4vKiogVXBkYXRlIHN0YXRlIHdpdGggZGF0YVxuICpcbiAqIEBwYXJhbSBkYXRhXG4gKiBAcGFyYW0gcGFyYW0xIHsgc2NoZW1hLCBrZXksIHR5cGUsIHVwZGF0ZXJzLCBkYXRhRXhwaXJ5TGVuZ3RoIH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlUmVjZWl2ZTxcbiAgUGF5bG9hZCBleHRlbmRzIG9iamVjdCB8IHN0cmluZyB8IG51bWJlciB8IG51bGwgPVxuICAgIHwgb2JqZWN0XG4gICAgfCBzdHJpbmdcbiAgICB8IG51bWJlclxuICAgIHwgbnVsbCxcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IGFueSxcbj4oXG4gIGRhdGE6IFBheWxvYWQsXG4gIHtcbiAgICBzY2hlbWEsXG4gICAga2V5LFxuICAgIGFyZ3MsXG4gICAgdXBkYXRlcnMsXG4gICAgZmV0Y2hlZEF0ID0gMCxcbiAgICB1cGRhdGUsXG4gICAgZGF0YUV4cGlyeUxlbmd0aCxcbiAgfTogT3B0aW9uczxQYXlsb2FkLCBTPixcbik6IFJlY2VpdmVBY3Rpb248UGF5bG9hZCwgUz4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZGF0YUV4cGlyeUxlbmd0aCA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05lZ2F0aXZlIGRhdGFFeHBpcnlMZW5ndGggYXJlIG5vdCBhbGxvd2VkLicpO1xuICB9XG4gIGNvbnN0IG5vdyA9IERhdGUubm93KCk7XG4gIGNvbnN0IG1ldGE6IFJlY2VpdmVBY3Rpb25bJ21ldGEnXSA9IHtcbiAgICBzY2hlbWEsXG4gICAga2V5LFxuICAgIGFyZ3MsXG4gICAgZGF0ZTogbm93LFxuICAgIGZldGNoZWRBdCxcbiAgICBleHBpcmVzQXQ6IG5vdyArIGRhdGFFeHBpcnlMZW5ndGgsXG4gIH07XG4gIG1ldGEudXBkYXRlcnMgPSB1cGRhdGVycztcbiAgbWV0YS51cGRhdGUgPSB1cGRhdGU7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVDRUlWRV9UWVBFLFxuICAgIHBheWxvYWQ6IGRhdGEsXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBS0EsU0FBU0EsWUFBWSxRQUFRLHNCQUFzQjtBQWtCbkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsYUFBYUEsQ0FRbkNDLElBQWEsRUFDYjtFQUNFQyxNQUFNO0VBQ05DLEdBQUc7RUFDSEMsSUFBSTtFQUNKQyxRQUFRO0VBQ1JDLFNBQVMsR0FBRyxDQUFDO0VBQ2JDLE1BQU07RUFDTkM7QUFDbUIsQ0FBQyxFQUNLO0VBQzNCO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlILGdCQUFnQixHQUFHLENBQUMsRUFBRTtJQUNsRSxNQUFNLElBQUlJLEtBQUssQ0FBQyw0Q0FBNEMsQ0FBQztFQUMvRDtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLEVBQUU7RUFDdEIsTUFBTUUsSUFBMkIsR0FBRztJQUNsQ2IsTUFBTTtJQUNOQyxHQUFHO0lBQ0hDLElBQUk7SUFDSlksSUFBSSxFQUFFSCxHQUFHO0lBQ1RQLFNBQVM7SUFDVFcsU0FBUyxFQUFFSixHQUFHLEdBQUdMO0VBQ25CLENBQUM7RUFDRE8sSUFBSSxDQUFDVixRQUFRLEdBQUdBLFFBQVE7RUFDeEJVLElBQUksQ0FBQ1IsTUFBTSxHQUFHQSxNQUFNO0VBQ3BCLE9BQU87SUFDTFcsSUFBSSxFQUFFbkIsWUFBWTtJQUNsQm9CLE9BQU8sRUFBRWxCLElBQUk7SUFDYmM7RUFDRixDQUFDO0FBQ0gifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUNFSVZFX1RZUEUiLCJjcmVhdGVSZWNlaXZlIiwiZGF0YSIsInNjaGVtYSIsImtleSIsImFyZ3MiLCJ1cGRhdGVycyIsImZldGNoZWRBdCIsInVwZGF0ZSIsImRhdGFFeHBpcnlMZW5ndGgiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJFcnJvciIsIm5vdyIsIkRhdGUiLCJtZXRhIiwiZGF0ZSIsImV4cGlyZXNBdCIsInR5cGUiLCJwYXlsb2FkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL2xlZ2FjeS1hY3Rpb25zL2NyZWF0ZVJlY2VpdmUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIEVuZHBvaW50RXh0cmFPcHRpb25zIGFzIEZldGNoT3B0aW9ucyxcbn0gZnJvbSAnQHJlc3QtaG9va3Mvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgUkVDRUlWRV9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHsgRmV0Y2hBY3Rpb24sIFJlY2VpdmVBY3Rpb24gfSBmcm9tICcuLi8uLi9sZWdhY3lBY3Rpb25zLmpzJztcblxuaW50ZXJmYWNlIE9wdGlvbnM8XG4gIFBheWxvYWQgZXh0ZW5kcyBvYmplY3QgfCBzdHJpbmcgfCBudW1iZXIgfCBudWxsID1cbiAgICB8IG9iamVjdFxuICAgIHwgc3RyaW5nXG4gICAgfCBudW1iZXJcbiAgICB8IG51bGwsXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBhbnksXG4+IGV4dGVuZHMgUGljazxcbiAgICBGZXRjaEFjdGlvbjxQYXlsb2FkLCBTPlsnbWV0YSddLFxuICAgICdzY2hlbWEnIHwgJ2tleScgfCAndHlwZScgfCAndXBkYXRlcnMnIHwgJ3VwZGF0ZScgfCAnYXJncydcbiAgPiB7XG4gIGRhdGFFeHBpcnlMZW5ndGg6IE5vbk51bGxhYmxlPEZldGNoT3B0aW9uc1snZGF0YUV4cGlyeUxlbmd0aCddPjtcbiAgZmV0Y2hlZEF0PzogbnVtYmVyO1xufVxuXG4vKiogVXBkYXRlIHN0YXRlIHdpdGggZGF0YVxuICpcbiAqIEBwYXJhbSBkYXRhXG4gKiBAcGFyYW0gcGFyYW0xIHsgc2NoZW1hLCBrZXksIHR5cGUsIHVwZGF0ZXJzLCBkYXRhRXhwaXJ5TGVuZ3RoIH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlUmVjZWl2ZTxcbiAgUGF5bG9hZCBleHRlbmRzIG9iamVjdCB8IHN0cmluZyB8IG51bWJlciB8IG51bGwgPVxuICAgIHwgb2JqZWN0XG4gICAgfCBzdHJpbmdcbiAgICB8IG51bWJlclxuICAgIHwgbnVsbCxcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IGFueSxcbj4oXG4gIGRhdGE6IFBheWxvYWQsXG4gIHtcbiAgICBzY2hlbWEsXG4gICAga2V5LFxuICAgIGFyZ3MsXG4gICAgdXBkYXRlcnMsXG4gICAgZmV0Y2hlZEF0ID0gMCxcbiAgICB1cGRhdGUsXG4gICAgZGF0YUV4cGlyeUxlbmd0aCxcbiAgfTogT3B0aW9uczxQYXlsb2FkLCBTPixcbik6IFJlY2VpdmVBY3Rpb248UGF5bG9hZCwgUz4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZGF0YUV4cGlyeUxlbmd0aCA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05lZ2F0aXZlIGRhdGFFeHBpcnlMZW5ndGggYXJlIG5vdCBhbGxvd2VkLicpO1xuICB9XG4gIGNvbnN0IG5vdyA9IERhdGUubm93KCk7XG4gIGNvbnN0IG1ldGE6IFJlY2VpdmVBY3Rpb25bJ21ldGEnXSA9IHtcbiAgICBzY2hlbWEsXG4gICAga2V5LFxuICAgIGFyZ3MsXG4gICAgZGF0ZTogbm93LFxuICAgIGZldGNoZWRBdCxcbiAgICBleHBpcmVzQXQ6IG5vdyArIGRhdGFFeHBpcnlMZW5ndGgsXG4gIH07XG4gIG1ldGEudXBkYXRlcnMgPSB1cGRhdGVycztcbiAgbWV0YS51cGRhdGUgPSB1cGRhdGU7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVDRUlWRV9UWVBFLFxuICAgIHBheWxvYWQ6IGRhdGEsXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBS0EsU0FBU0EsWUFBWSxRQUFRLHNCQUFzQjtBQWtCbkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsYUFBYUEsQ0FRbkNDLElBQWEsRUFDYjtFQUNFQyxNQUFNO0VBQ05DLEdBQUc7RUFDSEMsSUFBSTtFQUNKQyxRQUFRO0VBQ1JDLFNBQVMsR0FBRyxDQUFDO0VBQ2JDLE1BQU07RUFDTkM7QUFDbUIsQ0FBQyxFQUNLO0VBQzNCO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlILGdCQUFnQixHQUFHLENBQUMsRUFBRTtJQUNsRSxNQUFNLElBQUlJLEtBQUssQ0FBQyw0Q0FBNEMsQ0FBQztFQUMvRDtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLENBQUMsQ0FBQztFQUN0QixNQUFNRSxJQUEyQixHQUFHO0lBQ2xDYixNQUFNO0lBQ05DLEdBQUc7SUFDSEMsSUFBSTtJQUNKWSxJQUFJLEVBQUVILEdBQUc7SUFDVFAsU0FBUztJQUNUVyxTQUFTLEVBQUVKLEdBQUcsR0FBR0w7RUFDbkIsQ0FBQztFQUNETyxJQUFJLENBQUNWLFFBQVEsR0FBR0EsUUFBUTtFQUN4QlUsSUFBSSxDQUFDUixNQUFNLEdBQUdBLE1BQU07RUFDcEIsT0FBTztJQUNMVyxJQUFJLEVBQUVuQixZQUFZO0lBQ2xCb0IsT0FBTyxFQUFFbEIsSUFBSTtJQUNiYztFQUNGLENBQUM7QUFDSCJ9 |
@@ -28,2 +28,2 @@ import { RECEIVE_TYPE } from '../../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUNFSVZFX1RZUEUiLCJjcmVhdGVSZWNlaXZlRXJyb3IiLCJlcnJvciIsInNjaGVtYSIsImtleSIsIm9wdGlvbnMiLCJlcnJvckV4cGlyeUxlbmd0aCIsImZldGNoZWRBdCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwibm93IiwiRGF0ZSIsInR5cGUiLCJwYXlsb2FkIiwibWV0YSIsImRhdGUiLCJleHBpcmVzQXQiLCJlcnJvclBvbGljeSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zdGF0ZS9sZWdhY3ktYWN0aW9ucy9jcmVhdGVSZWNlaXZlRXJyb3IudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgU2NoZW1hLFxuICBFbmRwb2ludEV4dHJhT3B0aW9ucyBhcyBGZXRjaE9wdGlvbnMsXG59IGZyb20gJ0ByZXN0LWhvb2tzL25vcm1hbGl6cic7XG5cbmltcG9ydCB7IFJFQ0VJVkVfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB7IEZldGNoQWN0aW9uLCBSZWNlaXZlQWN0aW9uIH0gZnJvbSAnLi4vLi4vbGVnYWN5QWN0aW9ucy5qcyc7XG5cbmludGVyZmFjZSBPcHRpb25zPFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBhbnk+XG4gIGV4dGVuZHMgUGljazxGZXRjaEFjdGlvbjxhbnksIFM+WydtZXRhJ10sICdzY2hlbWEnIHwgJ2tleScgfCAnb3B0aW9ucyc+IHtcbiAgZXJyb3JFeHBpcnlMZW5ndGg/OiBOb25OdWxsYWJsZTxGZXRjaE9wdGlvbnNbJ2Vycm9yRXhwaXJ5TGVuZ3RoJ10+O1xuICBmZXRjaGVkQXQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlY2VpdmVFcnJvcjxTIGV4dGVuZHMgU2NoZW1hIHwgdW5kZWZpbmVkID0gYW55PihcbiAgZXJyb3I6IEVycm9yLFxuICB7XG4gICAgc2NoZW1hLFxuICAgIGtleSxcbiAgICBvcHRpb25zLFxuICAgIGVycm9yRXhwaXJ5TGVuZ3RoID0gNjAwMDAsXG4gICAgZmV0Y2hlZEF0ID0gMCxcbiAgfTogT3B0aW9uczxTPixcbik6IFJlY2VpdmVBY3Rpb24ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZXJyb3JFeHBpcnlMZW5ndGggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBlcnJvckV4cGlyeUxlbmd0aCBhcmUgbm90IGFsbG93ZWQuJyk7XG4gIH1cbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBSRUNFSVZFX1RZUEUsXG4gICAgcGF5bG9hZDogZXJyb3IsXG4gICAgbWV0YToge1xuICAgICAgc2NoZW1hLFxuICAgICAga2V5LFxuICAgICAgZGF0ZTogbm93LFxuICAgICAgZmV0Y2hlZEF0LFxuICAgICAgZXhwaXJlc0F0OiBub3cgKyBlcnJvckV4cGlyeUxlbmd0aCxcbiAgICAgIGVycm9yUG9saWN5OiBvcHRpb25zPy5lcnJvclBvbGljeSxcbiAgICB9LFxuICAgIGVycm9yOiB0cnVlLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFLQSxTQUFTQSxZQUFZLFFBQVEsc0JBQXNCO0FBU25ELGVBQWUsU0FBU0Msa0JBQWtCQSxDQUN4Q0MsS0FBWSxFQUNaO0VBQ0VDLE1BQU07RUFDTkMsR0FBRztFQUNIQyxPQUFPO0VBQ1BDLGlCQUFpQixHQUFHLEtBQUs7RUFDekJDLFNBQVMsR0FBRztBQUNGLENBQUMsRUFDRTtFQUNmO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlKLGlCQUFpQixHQUFHLENBQUMsRUFBRTtJQUNuRSxNQUFNLElBQUlLLEtBQUssQ0FBQyw2Q0FBNkMsQ0FBQztFQUNoRTtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLEVBQUU7RUFDdEIsT0FBTztJQUNMRSxJQUFJLEVBQUVkLFlBQVk7SUFDbEJlLE9BQU8sRUFBRWIsS0FBSztJQUNkYyxJQUFJLEVBQUU7TUFDSmIsTUFBTTtNQUNOQyxHQUFHO01BQ0hhLElBQUksRUFBRUwsR0FBRztNQUNUTCxTQUFTO01BQ1RXLFNBQVMsRUFBRU4sR0FBRyxHQUFHTixpQkFBaUI7TUFDbENhLFdBQVcsRUFBRWQsT0FBTyxvQkFBUEEsT0FBTyxDQUFFYztJQUN4QixDQUFDO0lBQ0RqQixLQUFLLEVBQUU7RUFDVCxDQUFDO0FBQ0gifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUNFSVZFX1RZUEUiLCJjcmVhdGVSZWNlaXZlRXJyb3IiLCJlcnJvciIsInNjaGVtYSIsImtleSIsIm9wdGlvbnMiLCJlcnJvckV4cGlyeUxlbmd0aCIsImZldGNoZWRBdCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwibm93IiwiRGF0ZSIsInR5cGUiLCJwYXlsb2FkIiwibWV0YSIsImRhdGUiLCJleHBpcmVzQXQiLCJlcnJvclBvbGljeSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zdGF0ZS9sZWdhY3ktYWN0aW9ucy9jcmVhdGVSZWNlaXZlRXJyb3IudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgU2NoZW1hLFxuICBFbmRwb2ludEV4dHJhT3B0aW9ucyBhcyBGZXRjaE9wdGlvbnMsXG59IGZyb20gJ0ByZXN0LWhvb2tzL25vcm1hbGl6cic7XG5cbmltcG9ydCB7IFJFQ0VJVkVfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB7IEZldGNoQWN0aW9uLCBSZWNlaXZlQWN0aW9uIH0gZnJvbSAnLi4vLi4vbGVnYWN5QWN0aW9ucy5qcyc7XG5cbmludGVyZmFjZSBPcHRpb25zPFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBhbnk+XG4gIGV4dGVuZHMgUGljazxGZXRjaEFjdGlvbjxhbnksIFM+WydtZXRhJ10sICdzY2hlbWEnIHwgJ2tleScgfCAnb3B0aW9ucyc+IHtcbiAgZXJyb3JFeHBpcnlMZW5ndGg/OiBOb25OdWxsYWJsZTxGZXRjaE9wdGlvbnNbJ2Vycm9yRXhwaXJ5TGVuZ3RoJ10+O1xuICBmZXRjaGVkQXQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlY2VpdmVFcnJvcjxTIGV4dGVuZHMgU2NoZW1hIHwgdW5kZWZpbmVkID0gYW55PihcbiAgZXJyb3I6IEVycm9yLFxuICB7XG4gICAgc2NoZW1hLFxuICAgIGtleSxcbiAgICBvcHRpb25zLFxuICAgIGVycm9yRXhwaXJ5TGVuZ3RoID0gNjAwMDAsXG4gICAgZmV0Y2hlZEF0ID0gMCxcbiAgfTogT3B0aW9uczxTPixcbik6IFJlY2VpdmVBY3Rpb24ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZXJyb3JFeHBpcnlMZW5ndGggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBlcnJvckV4cGlyeUxlbmd0aCBhcmUgbm90IGFsbG93ZWQuJyk7XG4gIH1cbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBSRUNFSVZFX1RZUEUsXG4gICAgcGF5bG9hZDogZXJyb3IsXG4gICAgbWV0YToge1xuICAgICAgc2NoZW1hLFxuICAgICAga2V5LFxuICAgICAgZGF0ZTogbm93LFxuICAgICAgZmV0Y2hlZEF0LFxuICAgICAgZXhwaXJlc0F0OiBub3cgKyBlcnJvckV4cGlyeUxlbmd0aCxcbiAgICAgIGVycm9yUG9saWN5OiBvcHRpb25zPy5lcnJvclBvbGljeSxcbiAgICB9LFxuICAgIGVycm9yOiB0cnVlLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFLQSxTQUFTQSxZQUFZLFFBQVEsc0JBQXNCO0FBU25ELGVBQWUsU0FBU0Msa0JBQWtCQSxDQUN4Q0MsS0FBWSxFQUNaO0VBQ0VDLE1BQU07RUFDTkMsR0FBRztFQUNIQyxPQUFPO0VBQ1BDLGlCQUFpQixHQUFHLEtBQUs7RUFDekJDLFNBQVMsR0FBRztBQUNGLENBQUMsRUFDRTtFQUNmO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlKLGlCQUFpQixHQUFHLENBQUMsRUFBRTtJQUNuRSxNQUFNLElBQUlLLEtBQUssQ0FBQyw2Q0FBNkMsQ0FBQztFQUNoRTtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLENBQUMsQ0FBQztFQUN0QixPQUFPO0lBQ0xFLElBQUksRUFBRWQsWUFBWTtJQUNsQmUsT0FBTyxFQUFFYixLQUFLO0lBQ2RjLElBQUksRUFBRTtNQUNKYixNQUFNO01BQ05DLEdBQUc7TUFDSGEsSUFBSSxFQUFFTCxHQUFHO01BQ1RMLFNBQVM7TUFDVFcsU0FBUyxFQUFFTixHQUFHLEdBQUdOLGlCQUFpQjtNQUNsQ2EsV0FBVyxFQUFFZCxPQUFPLG9CQUFQQSxPQUFPLENBQUVjO0lBQ3hCLENBQUM7SUFDRGpCLEtBQUssRUFBRTtFQUNULENBQUM7QUFDSCJ9 |
@@ -54,2 +54,2 @@ import { fetchReducer } from './fetchReducer.js'; | ||
}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmZXRjaFJlZHVjZXIiLCJpbnZhbGlkYXRlUmVkdWNlciIsInNldFJlZHVjZXIiLCJTRVRfVFlQRSIsIklOVkFMSURBVEVfVFlQRSIsIlJFU0VUX1RZUEUiLCJGRVRDSF9UWVBFIiwiR0NfVFlQRSIsIk9QVElNSVNUSUNfVFlQRSIsIklOVkFMSURBVEVBTExfVFlQRSIsImNyZWF0ZVJlZHVjZXIiLCJjb250cm9sbGVyIiwicmVkdWNlciIsInN0YXRlIiwiYWN0aW9uIiwiX2FjdGlvbiRkYXRlIiwiaW5pdGlhbFN0YXRlIiwidHlwZSIsImVudGl0aWVzIiwiZm9yRWFjaCIsImtleSIsInBrIiwiX2VudGl0aWVzJGtleSIsIl9lbnRpdHlNZXRhJGtleSIsImVudGl0eU1ldGEiLCJyZXN1bHRzIiwiZmV0Y2hLZXkiLCJtZXRhIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZGF0ZSIsInVuZGVmaW5lZCIsImNvbnNvbGUiLCJ3YXJuIiwiT2JqZWN0IiwiYXNzaWduIiwibGFzdFJlc2V0IiwiRGF0ZSIsIm5vdyIsImluZGV4ZXMiLCJvcHRpbWlzdGljIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL3JlZHVjZXIvY3JlYXRlUmVkdWNlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmZXRjaFJlZHVjZXIgfSBmcm9tICcuL2ZldGNoUmVkdWNlci5qcyc7XG5pbXBvcnQgeyBpbnZhbGlkYXRlUmVkdWNlciB9IGZyb20gJy4vaW52YWxpZGF0ZVJlZHVjZXIuanMnO1xuaW1wb3J0IHsgc2V0UmVkdWNlciB9IGZyb20gJy4vc2V0UmVkdWNlci5qcyc7XG5pbXBvcnQge1xuICBTRVRfVFlQRSxcbiAgSU5WQUxJREFURV9UWVBFLFxuICBSRVNFVF9UWVBFLFxuICBGRVRDSF9UWVBFLFxuICBHQ19UWVBFLFxuICBPUFRJTUlTVElDX1RZUEUsXG4gIElOVkFMSURBVEVBTExfVFlQRSxcbn0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi8uLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBPbGRBY3Rpb25UeXBlcywgQWN0aW9uVHlwZXMsIFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWR1Y2VyKGNvbnRyb2xsZXI6IENvbnRyb2xsZXIpOiBSZWR1Y2VyVHlwZSB7XG4gIHJldHVybiBmdW5jdGlvbiByZWR1Y2VyKFxuICAgIHN0YXRlOiBTdGF0ZTx1bmtub3duPiB8IHVuZGVmaW5lZCxcbiAgICBhY3Rpb246IE9sZEFjdGlvblR5cGVzLFxuICApOiBTdGF0ZTx1bmtub3duPiB7XG4gICAgaWYgKCFzdGF0ZSkgc3RhdGUgPSBpbml0aWFsU3RhdGU7XG4gICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgY2FzZSBHQ19UWVBFOlxuICAgICAgICAvLyBpbmxpbmUgZGVsZXRlcyBhcmUgZmluZSBhcyB0aGVzZSBzaG91bGQgaGF2ZSAwIHJlZmNvdW50c1xuICAgICAgICBhY3Rpb24uZW50aXRpZXMuZm9yRWFjaCgoW2tleSwgcGtdKSA9PiB7XG4gICAgICAgICAgZGVsZXRlIChzdGF0ZSBhcyBhbnkpLmVudGl0aWVzW2tleV0/Lltwa107XG4gICAgICAgICAgZGVsZXRlIChzdGF0ZSBhcyBhbnkpLmVudGl0eU1ldGFba2V5XT8uW3BrXTtcbiAgICAgICAgfSk7XG4gICAgICAgIGFjdGlvbi5yZXN1bHRzLmZvckVhY2goZmV0Y2hLZXkgPT4ge1xuICAgICAgICAgIGRlbGV0ZSAoc3RhdGUgYXMgYW55KS5yZXN1bHRzW2ZldGNoS2V5XTtcbiAgICAgICAgICBkZWxldGUgKHN0YXRlIGFzIGFueSkubWV0YVtmZXRjaEtleV07XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgICBjYXNlIEZFVENIX1RZUEU6XG4gICAgICAgIHJldHVybiBmZXRjaFJlZHVjZXIoc3RhdGUsIGFjdGlvbik7XG5cbiAgICAgIGNhc2UgT1BUSU1JU1RJQ19UWVBFOlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWZhbGx0aHJvdWdoXG4gICAgICBjYXNlIFNFVF9UWVBFOlxuICAgICAgICByZXR1cm4gc2V0UmVkdWNlcihzdGF0ZSwgYWN0aW9uLCBjb250cm9sbGVyKTtcblxuICAgICAgY2FzZSBJTlZBTElEQVRFQUxMX1RZUEU6XG4gICAgICBjYXNlIElOVkFMSURBVEVfVFlQRTpcbiAgICAgICAgcmV0dXJuIGludmFsaWRhdGVSZWR1Y2VyKHN0YXRlLCBhY3Rpb24pO1xuXG4gICAgICBjYXNlIFJFU0VUX1RZUEU6XG4gICAgICAgIGlmIChcbiAgICAgICAgICBwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nICYmXG4gICAgICAgICAgYWN0aW9uLmRhdGUgPT09IHVuZGVmaW5lZFxuICAgICAgICApIHtcbiAgICAgICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICAgICBgJHtSRVNFVF9UWVBFfSBzZW50IHdpdGhvdXQgJ2RhdGUnIG1lbWJlci4gVGhpcyBpcyBkZXByZWNhdGVkLiBQbGVhc2UgdXNlIGNyZWF0ZVJlc2V0KCkgYWN0aW9uIGNyZWF0b3IgdG8gZW5zdXJlIGNvcnJlY3QgYWN0aW9uIHNoYXBlLmAsXG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4geyAuLi5pbml0aWFsU3RhdGUsIGxhc3RSZXNldDogYWN0aW9uLmRhdGUgPz8gRGF0ZS5ub3coKSB9O1xuXG4gICAgICBkZWZhdWx0OlxuICAgICAgICAvLyBBIHJlZHVjZXIgbXVzdCBhbHdheXMgcmV0dXJuIGEgdmFsaWQgc3RhdGUuXG4gICAgICAgIC8vIEFsdGVybmF0aXZlbHkgeW91IGNhbiB0aHJvdyBhbiBlcnJvciBpZiBhbiBpbnZhbGlkIGFjdGlvbiBpcyBkaXNwYXRjaGVkLlxuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgfVxuICB9IGFzIGFueTtcbn1cblxuZXhwb3J0IGNvbnN0IGluaXRpYWxTdGF0ZTogU3RhdGU8dW5rbm93bj4gPSB7XG4gIGVudGl0aWVzOiB7fSxcbiAgaW5kZXhlczoge30sXG4gIHJlc3VsdHM6IHt9LFxuICBtZXRhOiB7fSxcbiAgZW50aXR5TWV0YToge30sXG4gIG9wdGltaXN0aWM6IFtdLFxuICBsYXN0UmVzZXQ6IDAsXG59O1xuXG50eXBlIFJlZHVjZXJUeXBlID0gKFxuICBzdGF0ZTogU3RhdGU8dW5rbm93bj4gfCB1bmRlZmluZWQsXG4gIGFjdGlvbjogQWN0aW9uVHlwZXMsXG4pID0+IFN0YXRlPHVua25vd24+O1xuXG50eXBlIFdyaXRhYmxlPFQ+ID0geyBbUCBpbiBrZXlvZiBUXTogTm9uTnVsbGFibGU8V3JpdGFibGU8VFtQXT4+IH07XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFlBQVksUUFBUSxtQkFBbUI7QUFDaEQsU0FBU0MsaUJBQWlCLFFBQVEsd0JBQXdCO0FBQzFELFNBQVNDLFVBQVUsUUFBUSxpQkFBaUI7QUFDNUMsU0FDRUMsUUFBUSxFQUNSQyxlQUFlLEVBQ2ZDLFVBQVUsRUFDVkMsVUFBVSxFQUNWQyxPQUFPLEVBQ1BDLGVBQWUsRUFDZkMsa0JBQWtCLFFBQ2Isc0JBQXNCO0FBSTdCLGVBQWUsU0FBU0MsYUFBYUEsQ0FBQ0MsVUFBc0IsRUFBZTtFQUN6RSxPQUFPLFNBQVNDLE9BQU9BLENBQ3JCQyxLQUFpQyxFQUNqQ0MsTUFBc0IsRUFDTjtJQUFBLElBQUFDLFlBQUE7SUFDaEIsSUFBSSxDQUFDRixLQUFLLEVBQUVBLEtBQUssR0FBR0csWUFBWTtJQUNoQyxRQUFRRixNQUFNLENBQUNHLElBQUk7TUFDakIsS0FBS1YsT0FBTztRQUNWO1FBQ0FPLE1BQU0sQ0FBQ0ksUUFBUSxDQUFDQyxPQUFPLENBQUMsQ0FBQyxDQUFDQyxHQUFHLEVBQUVDLEVBQUUsQ0FBQyxLQUFLO1VBQUEsSUFBQUMsYUFBQSxFQUFBQyxlQUFBO1VBQ3JDLENBQUFELGFBQUEsR0FBUVQsS0FBSyxDQUFTSyxRQUFRLENBQUNFLEdBQUcsQ0FBQyxtQkFBbkMsT0FBT0UsYUFBQSxDQUErQkQsRUFBRSxDQUFDO1VBQ3pDLENBQUFFLGVBQUEsR0FBUVYsS0FBSyxDQUFTVyxVQUFVLENBQUNKLEdBQUcsQ0FBQyxtQkFBckMsT0FBT0csZUFBQSxDQUFpQ0YsRUFBRSxDQUFDO1FBQzdDLENBQUMsQ0FBQztRQUNGUCxNQUFNLENBQUNXLE9BQU8sQ0FBQ04sT0FBTyxDQUFDTyxRQUFRLElBQUk7VUFDakMsT0FBUWIsS0FBSyxDQUFTWSxPQUFPLENBQUNDLFFBQVEsQ0FBQztVQUN2QyxPQUFRYixLQUFLLENBQVNjLElBQUksQ0FBQ0QsUUFBUSxDQUFDO1FBQ3RDLENBQUMsQ0FBQztRQUNGLE9BQU9iLEtBQUs7TUFDZCxLQUFLUCxVQUFVO1FBQ2IsT0FBT04sWUFBWSxDQUFDYSxLQUFLLEVBQUVDLE1BQU0sQ0FBQztNQUVwQyxLQUFLTixlQUFlO01BQ3BCO01BQ0EsS0FBS0wsUUFBUTtRQUNYLE9BQU9ELFVBQVUsQ0FBQ1csS0FBSyxFQUFFQyxNQUFNLEVBQUVILFVBQVUsQ0FBQztNQUU5QyxLQUFLRixrQkFBa0I7TUFDdkIsS0FBS0wsZUFBZTtRQUNsQixPQUFPSCxpQkFBaUIsQ0FBQ1ksS0FBSyxFQUFFQyxNQUFNLENBQUM7TUFFekMsS0FBS1QsVUFBVTtRQUNiLElBQ0V1QixPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFlBQVksSUFDckNoQixNQUFNLENBQUNpQixJQUFJLEtBQUtDLFNBQVMsRUFDekI7VUFDQUMsT0FBTyxDQUFDQyxJQUFJLENBQ1QsR0FBRTdCLFVBQVcsMEhBQXlILENBQ3hJO1FBQ0g7UUFDQSxPQUFBOEIsTUFBQSxDQUFBQyxNQUFBLEtBQVlwQixZQUFZO1VBQUVxQixTQUFTLEdBQUF0QixZQUFBLEdBQUVELE1BQU0sQ0FBQ2lCLElBQUksWUFBQWhCLFlBQUEsR0FBSXVCLElBQUksQ0FBQ0MsR0FBRztRQUFFO01BRWhFO1FBQ0U7UUFDQTtRQUNBLE9BQU8xQixLQUFLO0lBQUM7RUFFbkIsQ0FBQztBQUNIO0FBRUEsT0FBTyxNQUFNRyxZQUE0QixHQUFHO0VBQzFDRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO0VBQ1pzQixPQUFPLEVBQUUsQ0FBQyxDQUFDO0VBQ1hmLE9BQU8sRUFBRSxDQUFDLENBQUM7RUFDWEUsSUFBSSxFQUFFLENBQUMsQ0FBQztFQUNSSCxVQUFVLEVBQUUsQ0FBQyxDQUFDO0VBQ2RpQixVQUFVLEVBQUUsRUFBRTtFQUNkSixTQUFTLEVBQUU7QUFDYixDQUFDIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmZXRjaFJlZHVjZXIiLCJpbnZhbGlkYXRlUmVkdWNlciIsInNldFJlZHVjZXIiLCJTRVRfVFlQRSIsIklOVkFMSURBVEVfVFlQRSIsIlJFU0VUX1RZUEUiLCJGRVRDSF9UWVBFIiwiR0NfVFlQRSIsIk9QVElNSVNUSUNfVFlQRSIsIklOVkFMSURBVEVBTExfVFlQRSIsImNyZWF0ZVJlZHVjZXIiLCJjb250cm9sbGVyIiwicmVkdWNlciIsInN0YXRlIiwiYWN0aW9uIiwiX2FjdGlvbiRkYXRlIiwiaW5pdGlhbFN0YXRlIiwidHlwZSIsImVudGl0aWVzIiwiZm9yRWFjaCIsImtleSIsInBrIiwiX2VudGl0aWVzJGtleSIsIl9lbnRpdHlNZXRhJGtleSIsImVudGl0eU1ldGEiLCJyZXN1bHRzIiwiZmV0Y2hLZXkiLCJtZXRhIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZGF0ZSIsInVuZGVmaW5lZCIsImNvbnNvbGUiLCJ3YXJuIiwiT2JqZWN0IiwiYXNzaWduIiwibGFzdFJlc2V0IiwiRGF0ZSIsIm5vdyIsImluZGV4ZXMiLCJvcHRpbWlzdGljIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL3JlZHVjZXIvY3JlYXRlUmVkdWNlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmZXRjaFJlZHVjZXIgfSBmcm9tICcuL2ZldGNoUmVkdWNlci5qcyc7XG5pbXBvcnQgeyBpbnZhbGlkYXRlUmVkdWNlciB9IGZyb20gJy4vaW52YWxpZGF0ZVJlZHVjZXIuanMnO1xuaW1wb3J0IHsgc2V0UmVkdWNlciB9IGZyb20gJy4vc2V0UmVkdWNlci5qcyc7XG5pbXBvcnQge1xuICBTRVRfVFlQRSxcbiAgSU5WQUxJREFURV9UWVBFLFxuICBSRVNFVF9UWVBFLFxuICBGRVRDSF9UWVBFLFxuICBHQ19UWVBFLFxuICBPUFRJTUlTVElDX1RZUEUsXG4gIElOVkFMSURBVEVBTExfVFlQRSxcbn0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi8uLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBPbGRBY3Rpb25UeXBlcywgQWN0aW9uVHlwZXMsIFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWR1Y2VyKGNvbnRyb2xsZXI6IENvbnRyb2xsZXIpOiBSZWR1Y2VyVHlwZSB7XG4gIHJldHVybiBmdW5jdGlvbiByZWR1Y2VyKFxuICAgIHN0YXRlOiBTdGF0ZTx1bmtub3duPiB8IHVuZGVmaW5lZCxcbiAgICBhY3Rpb246IE9sZEFjdGlvblR5cGVzLFxuICApOiBTdGF0ZTx1bmtub3duPiB7XG4gICAgaWYgKCFzdGF0ZSkgc3RhdGUgPSBpbml0aWFsU3RhdGU7XG4gICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgY2FzZSBHQ19UWVBFOlxuICAgICAgICAvLyBpbmxpbmUgZGVsZXRlcyBhcmUgZmluZSBhcyB0aGVzZSBzaG91bGQgaGF2ZSAwIHJlZmNvdW50c1xuICAgICAgICBhY3Rpb24uZW50aXRpZXMuZm9yRWFjaCgoW2tleSwgcGtdKSA9PiB7XG4gICAgICAgICAgZGVsZXRlIChzdGF0ZSBhcyBhbnkpLmVudGl0aWVzW2tleV0/Lltwa107XG4gICAgICAgICAgZGVsZXRlIChzdGF0ZSBhcyBhbnkpLmVudGl0eU1ldGFba2V5XT8uW3BrXTtcbiAgICAgICAgfSk7XG4gICAgICAgIGFjdGlvbi5yZXN1bHRzLmZvckVhY2goZmV0Y2hLZXkgPT4ge1xuICAgICAgICAgIGRlbGV0ZSAoc3RhdGUgYXMgYW55KS5yZXN1bHRzW2ZldGNoS2V5XTtcbiAgICAgICAgICBkZWxldGUgKHN0YXRlIGFzIGFueSkubWV0YVtmZXRjaEtleV07XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgICBjYXNlIEZFVENIX1RZUEU6XG4gICAgICAgIHJldHVybiBmZXRjaFJlZHVjZXIoc3RhdGUsIGFjdGlvbik7XG5cbiAgICAgIGNhc2UgT1BUSU1JU1RJQ19UWVBFOlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWZhbGx0aHJvdWdoXG4gICAgICBjYXNlIFNFVF9UWVBFOlxuICAgICAgICByZXR1cm4gc2V0UmVkdWNlcihzdGF0ZSwgYWN0aW9uLCBjb250cm9sbGVyKTtcblxuICAgICAgY2FzZSBJTlZBTElEQVRFQUxMX1RZUEU6XG4gICAgICBjYXNlIElOVkFMSURBVEVfVFlQRTpcbiAgICAgICAgcmV0dXJuIGludmFsaWRhdGVSZWR1Y2VyKHN0YXRlLCBhY3Rpb24pO1xuXG4gICAgICBjYXNlIFJFU0VUX1RZUEU6XG4gICAgICAgIGlmIChcbiAgICAgICAgICBwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nICYmXG4gICAgICAgICAgYWN0aW9uLmRhdGUgPT09IHVuZGVmaW5lZFxuICAgICAgICApIHtcbiAgICAgICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICAgICBgJHtSRVNFVF9UWVBFfSBzZW50IHdpdGhvdXQgJ2RhdGUnIG1lbWJlci4gVGhpcyBpcyBkZXByZWNhdGVkLiBQbGVhc2UgdXNlIGNyZWF0ZVJlc2V0KCkgYWN0aW9uIGNyZWF0b3IgdG8gZW5zdXJlIGNvcnJlY3QgYWN0aW9uIHNoYXBlLmAsXG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4geyAuLi5pbml0aWFsU3RhdGUsIGxhc3RSZXNldDogYWN0aW9uLmRhdGUgPz8gRGF0ZS5ub3coKSB9O1xuXG4gICAgICBkZWZhdWx0OlxuICAgICAgICAvLyBBIHJlZHVjZXIgbXVzdCBhbHdheXMgcmV0dXJuIGEgdmFsaWQgc3RhdGUuXG4gICAgICAgIC8vIEFsdGVybmF0aXZlbHkgeW91IGNhbiB0aHJvdyBhbiBlcnJvciBpZiBhbiBpbnZhbGlkIGFjdGlvbiBpcyBkaXNwYXRjaGVkLlxuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgfVxuICB9IGFzIGFueTtcbn1cblxuZXhwb3J0IGNvbnN0IGluaXRpYWxTdGF0ZTogU3RhdGU8dW5rbm93bj4gPSB7XG4gIGVudGl0aWVzOiB7fSxcbiAgaW5kZXhlczoge30sXG4gIHJlc3VsdHM6IHt9LFxuICBtZXRhOiB7fSxcbiAgZW50aXR5TWV0YToge30sXG4gIG9wdGltaXN0aWM6IFtdLFxuICBsYXN0UmVzZXQ6IDAsXG59O1xuXG50eXBlIFJlZHVjZXJUeXBlID0gKFxuICBzdGF0ZTogU3RhdGU8dW5rbm93bj4gfCB1bmRlZmluZWQsXG4gIGFjdGlvbjogQWN0aW9uVHlwZXMsXG4pID0+IFN0YXRlPHVua25vd24+O1xuXG50eXBlIFdyaXRhYmxlPFQ+ID0geyBbUCBpbiBrZXlvZiBUXTogTm9uTnVsbGFibGU8V3JpdGFibGU8VFtQXT4+IH07XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFlBQVksUUFBUSxtQkFBbUI7QUFDaEQsU0FBU0MsaUJBQWlCLFFBQVEsd0JBQXdCO0FBQzFELFNBQVNDLFVBQVUsUUFBUSxpQkFBaUI7QUFDNUMsU0FDRUMsUUFBUSxFQUNSQyxlQUFlLEVBQ2ZDLFVBQVUsRUFDVkMsVUFBVSxFQUNWQyxPQUFPLEVBQ1BDLGVBQWUsRUFDZkMsa0JBQWtCLFFBQ2Isc0JBQXNCO0FBSTdCLGVBQWUsU0FBU0MsYUFBYUEsQ0FBQ0MsVUFBc0IsRUFBZTtFQUN6RSxPQUFPLFNBQVNDLE9BQU9BLENBQ3JCQyxLQUFpQyxFQUNqQ0MsTUFBc0IsRUFDTjtJQUFBLElBQUFDLFlBQUE7SUFDaEIsSUFBSSxDQUFDRixLQUFLLEVBQUVBLEtBQUssR0FBR0csWUFBWTtJQUNoQyxRQUFRRixNQUFNLENBQUNHLElBQUk7TUFDakIsS0FBS1YsT0FBTztRQUNWO1FBQ0FPLE1BQU0sQ0FBQ0ksUUFBUSxDQUFDQyxPQUFPLENBQUMsQ0FBQyxDQUFDQyxHQUFHLEVBQUVDLEVBQUUsQ0FBQyxLQUFLO1VBQUEsSUFBQUMsYUFBQSxFQUFBQyxlQUFBO1VBQ3JDLENBQUFELGFBQUEsR0FBUVQsS0FBSyxDQUFTSyxRQUFRLENBQUNFLEdBQUcsQ0FBQyxtQkFBbkMsT0FBT0UsYUFBQSxDQUErQkQsRUFBRSxDQUFDO1VBQ3pDLENBQUFFLGVBQUEsR0FBUVYsS0FBSyxDQUFTVyxVQUFVLENBQUNKLEdBQUcsQ0FBQyxtQkFBckMsT0FBT0csZUFBQSxDQUFpQ0YsRUFBRSxDQUFDO1FBQzdDLENBQUMsQ0FBQztRQUNGUCxNQUFNLENBQUNXLE9BQU8sQ0FBQ04sT0FBTyxDQUFDTyxRQUFRLElBQUk7VUFDakMsT0FBUWIsS0FBSyxDQUFTWSxPQUFPLENBQUNDLFFBQVEsQ0FBQztVQUN2QyxPQUFRYixLQUFLLENBQVNjLElBQUksQ0FBQ0QsUUFBUSxDQUFDO1FBQ3RDLENBQUMsQ0FBQztRQUNGLE9BQU9iLEtBQUs7TUFDZCxLQUFLUCxVQUFVO1FBQ2IsT0FBT04sWUFBWSxDQUFDYSxLQUFLLEVBQUVDLE1BQU0sQ0FBQztNQUVwQyxLQUFLTixlQUFlO01BQ3BCO01BQ0EsS0FBS0wsUUFBUTtRQUNYLE9BQU9ELFVBQVUsQ0FBQ1csS0FBSyxFQUFFQyxNQUFNLEVBQUVILFVBQVUsQ0FBQztNQUU5QyxLQUFLRixrQkFBa0I7TUFDdkIsS0FBS0wsZUFBZTtRQUNsQixPQUFPSCxpQkFBaUIsQ0FBQ1ksS0FBSyxFQUFFQyxNQUFNLENBQUM7TUFFekMsS0FBS1QsVUFBVTtRQUNiLElBQ0V1QixPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFlBQVksSUFDckNoQixNQUFNLENBQUNpQixJQUFJLEtBQUtDLFNBQVMsRUFDekI7VUFDQUMsT0FBTyxDQUFDQyxJQUFJLENBQ1QsR0FBRTdCLFVBQVcsMEhBQ2hCLENBQUM7UUFDSDtRQUNBLE9BQUE4QixNQUFBLENBQUFDLE1BQUEsS0FBWXBCLFlBQVk7VUFBRXFCLFNBQVMsR0FBQXRCLFlBQUEsR0FBRUQsTUFBTSxDQUFDaUIsSUFBSSxZQUFBaEIsWUFBQSxHQUFJdUIsSUFBSSxDQUFDQyxHQUFHLENBQUM7UUFBQztNQUVoRTtRQUNFO1FBQ0E7UUFDQSxPQUFPMUIsS0FBSztJQUNoQjtFQUNGLENBQUM7QUFDSDtBQUVBLE9BQU8sTUFBTUcsWUFBNEIsR0FBRztFQUMxQ0UsUUFBUSxFQUFFLENBQUMsQ0FBQztFQUNac0IsT0FBTyxFQUFFLENBQUMsQ0FBQztFQUNYZixPQUFPLEVBQUUsQ0FBQyxDQUFDO0VBQ1hFLElBQUksRUFBRSxDQUFDLENBQUM7RUFDUkgsVUFBVSxFQUFFLENBQUMsQ0FBQztFQUNkaUIsVUFBVSxFQUFFLEVBQUU7RUFDZEosU0FBUyxFQUFFO0FBQ2IsQ0FBQyJ9 |
@@ -32,2 +32,2 @@ import createOptimistic from '../../controller/createOptimistic.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVPcHRpbWlzdGljIiwiY3JlYXRlUmVjZWl2ZSIsImxlZ2FjeUNyZWF0ZVJlY2VpdmUiLCJmZXRjaFJlZHVjZXIiLCJzdGF0ZSIsImFjdGlvbiIsIl9hY3Rpb24kZW5kcG9pbnQiLCJvcHRpbWlzdGljUmVzcG9uc2UiLCJtZXRhIiwiZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlIiwiZW5kcG9pbnQiLCJyZWNlaXZlQWN0aW9uIiwiYXJncyIsImZldGNoZWRBdCIsImNyZWF0ZWRBdCIsImdldFRpbWUiLCJPYmplY3QiLCJhc3NpZ24iLCJkYXRhRXhwaXJ5TGVuZ3RoIiwiSW5maW5pdHkiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJjb25zb2xlIiwid2FybiIsIm9wdGltaXN0aWMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RhdGUvcmVkdWNlci9mZXRjaFJlZHVjZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNyZWF0ZU9wdGltaXN0aWMgZnJvbSAnLi4vLi4vY29udHJvbGxlci9jcmVhdGVPcHRpbWlzdGljLmpzJztcbmltcG9ydCB0eXBlIHtcbiAgUmVjZWl2ZUFjdGlvbixcbiAgT3B0aW1pc3RpY0FjdGlvbixcbiAgRmV0Y2hBY3Rpb24sXG59IGZyb20gJy4uLy4uL3ByZXZpb3VzQWN0aW9ucy5qcyc7XG5pbXBvcnQgdHlwZSB7IFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuaW1wb3J0IHsgY3JlYXRlUmVjZWl2ZSBhcyBsZWdhY3lDcmVhdGVSZWNlaXZlIH0gZnJvbSAnLi4vbGVnYWN5LWFjdGlvbnMvaW5kZXguanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZmV0Y2hSZWR1Y2VyKHN0YXRlOiBTdGF0ZTx1bmtub3duPiwgYWN0aW9uOiBGZXRjaEFjdGlvbikge1xuICBjb25zdCBvcHRpbWlzdGljUmVzcG9uc2UgPSBhY3Rpb24ubWV0YS5vcHRpbWlzdGljUmVzcG9uc2U7XG4gIGNvbnN0IGdldE9wdGltaXN0aWNSZXNwb25zZSA9IGFjdGlvbi5lbmRwb2ludD8uZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlO1xuICBsZXQgcmVjZWl2ZUFjdGlvbjogUmVjZWl2ZUFjdGlvbiB8IE9wdGltaXN0aWNBY3Rpb247XG5cbiAgaWYgKGdldE9wdGltaXN0aWNSZXNwb25zZSAmJiBhY3Rpb24uZW5kcG9pbnQpIHtcbiAgICByZWNlaXZlQWN0aW9uID0gY3JlYXRlT3B0aW1pc3RpYyhhY3Rpb24uZW5kcG9pbnQsIHtcbiAgICAgIGFyZ3M6IGFjdGlvbi5tZXRhLmFyZ3MgYXMgcmVhZG9ubHkgYW55W10sXG4gICAgICBmZXRjaGVkQXQ6XG4gICAgICAgIHR5cGVvZiBhY3Rpb24ubWV0YS5jcmVhdGVkQXQgIT09ICdudW1iZXInXG4gICAgICAgICAgPyBhY3Rpb24ubWV0YS5jcmVhdGVkQXQuZ2V0VGltZSgpXG4gICAgICAgICAgOiBhY3Rpb24ubWV0YS5jcmVhdGVkQXQsXG4gICAgfSkgYXMgYW55O1xuICB9IC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqLyBlbHNlIGlmIChvcHRpbWlzdGljUmVzcG9uc2UpIHtcbiAgICAvLyBUT0RPKGJyZWFraW5nKTogdGhpcyBpcyBubyBsb25nZXIgdXNlZCwgcmVtb3ZlIHRoaXMgYnJhbmNoXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZWNlaXZlQWN0aW9uID0gbGVnYWN5Q3JlYXRlUmVjZWl2ZShvcHRpbWlzdGljUmVzcG9uc2UsIHtcbiAgICAgIC4uLmFjdGlvbi5tZXRhLFxuICAgICAgZGF0YUV4cGlyeUxlbmd0aDogSW5maW5pdHksXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgLy8gSWYgJ2ZldGNoJyBhY3Rpb24gcmVhY2hlcyB0aGUgcmVkdWNlciB0aGVyZSBhcmUgbm8gbWlkZGxld2FyZXMgaW5zdGFsbGVkIHRvIGhhbmRsZSBpdFxuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAncHJvZHVjdGlvbicpIHtcbiAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgJ0ZldGNoIGFwcGVhcnMgdW5oYW5kbGVkIC0geW91IGFyZSBsaWtlbHkgbWlzc2luZyB0aGUgTmV0d29ya01hbmFnZXIgbWlkZGxld2FyZScsXG4gICAgICApO1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnU2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL2RvY3MvZ3VpZGVzL3JlZHV4I2luZGV4dHN4IGZvciBob29raW5nIHVwIHJlZHV4JyxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlO1xuICB9XG4gIHJldHVybiB7XG4gICAgLi4uc3RhdGUsXG4gICAgb3B0aW1pc3RpYzogWy4uLnN0YXRlLm9wdGltaXN0aWMsIHJlY2VpdmVBY3Rpb25dLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxnQkFBZ0IsTUFBTSxzQ0FBc0M7QUFPbkUsU0FBU0MsYUFBYSxJQUFJQyxtQkFBbUIsUUFBUSw0QkFBNEI7QUFFakYsT0FBTyxTQUFTQyxZQUFZQSxDQUFDQyxLQUFxQixFQUFFQyxNQUFtQixFQUFFO0VBQUEsSUFBQUMsZ0JBQUE7RUFDdkUsTUFBTUMsa0JBQWtCLEdBQUdGLE1BQU0sQ0FBQ0csSUFBSSxDQUFDRCxrQkFBa0I7RUFDekQsTUFBTUUscUJBQXFCLElBQUFILGdCQUFBLEdBQUdELE1BQU0sQ0FBQ0ssUUFBUSxxQkFBZkosZ0JBQUEsQ0FBaUJHLHFCQUFxQjtFQUNwRSxJQUFJRSxhQUErQztFQUVuRCxJQUFJRixxQkFBcUIsSUFBSUosTUFBTSxDQUFDSyxRQUFRLEVBQUU7SUFDNUNDLGFBQWEsR0FBR1gsZ0JBQWdCLENBQUNLLE1BQU0sQ0FBQ0ssUUFBUSxFQUFFO01BQ2hERSxJQUFJLEVBQUVQLE1BQU0sQ0FBQ0csSUFBSSxDQUFDSSxJQUFzQjtNQUN4Q0MsU0FBUyxFQUNQLE9BQU9SLE1BQU0sQ0FBQ0csSUFBSSxDQUFDTSxTQUFTLEtBQUssUUFBUSxHQUNyQ1QsTUFBTSxDQUFDRyxJQUFJLENBQUNNLFNBQVMsQ0FBQ0MsT0FBTyxFQUFFLEdBQy9CVixNQUFNLENBQUNHLElBQUksQ0FBQ007SUFDcEIsQ0FBQyxDQUFRO0VBQ1gsQ0FBQyxDQUFDLDZCQUE4QixJQUFJUCxrQkFBa0IsRUFBRTtJQUN0RDtJQUNBO0lBQ0FJLGFBQWEsR0FBR1QsbUJBQW1CLENBQUNLLGtCQUFrQixFQUFBUyxNQUFBLENBQUFDLE1BQUEsS0FDakRaLE1BQU0sQ0FBQ0csSUFBSTtNQUNkVSxnQkFBZ0IsRUFBRUM7SUFBUSxHQUMxQjtFQUNKLENBQUMsTUFBTTtJQUNMO0lBQ0E7SUFDQSxJQUFJQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFlBQVksRUFBRTtNQUN6Q0MsT0FBTyxDQUFDQyxJQUFJLENBQ1YsZ0ZBQWdGLENBQ2pGO01BQ0RELE9BQU8sQ0FBQ0MsSUFBSSxDQUNWLDBFQUEwRSxDQUMzRTtJQUNIO0lBRUEsT0FBT3BCLEtBQUs7RUFDZDtFQUNBLE9BQUFZLE1BQUEsQ0FBQUMsTUFBQSxLQUNLYixLQUFLO0lBQ1JxQixVQUFVLEVBQUUsQ0FBQyxHQUFHckIsS0FBSyxDQUFDcUIsVUFBVSxFQUFFZCxhQUFhO0VBQUM7QUFFcEQifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVPcHRpbWlzdGljIiwiY3JlYXRlUmVjZWl2ZSIsImxlZ2FjeUNyZWF0ZVJlY2VpdmUiLCJmZXRjaFJlZHVjZXIiLCJzdGF0ZSIsImFjdGlvbiIsIl9hY3Rpb24kZW5kcG9pbnQiLCJvcHRpbWlzdGljUmVzcG9uc2UiLCJtZXRhIiwiZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlIiwiZW5kcG9pbnQiLCJyZWNlaXZlQWN0aW9uIiwiYXJncyIsImZldGNoZWRBdCIsImNyZWF0ZWRBdCIsImdldFRpbWUiLCJPYmplY3QiLCJhc3NpZ24iLCJkYXRhRXhwaXJ5TGVuZ3RoIiwiSW5maW5pdHkiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJjb25zb2xlIiwid2FybiIsIm9wdGltaXN0aWMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RhdGUvcmVkdWNlci9mZXRjaFJlZHVjZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNyZWF0ZU9wdGltaXN0aWMgZnJvbSAnLi4vLi4vY29udHJvbGxlci9jcmVhdGVPcHRpbWlzdGljLmpzJztcbmltcG9ydCB0eXBlIHtcbiAgUmVjZWl2ZUFjdGlvbixcbiAgT3B0aW1pc3RpY0FjdGlvbixcbiAgRmV0Y2hBY3Rpb24sXG59IGZyb20gJy4uLy4uL3ByZXZpb3VzQWN0aW9ucy5qcyc7XG5pbXBvcnQgdHlwZSB7IFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuaW1wb3J0IHsgY3JlYXRlUmVjZWl2ZSBhcyBsZWdhY3lDcmVhdGVSZWNlaXZlIH0gZnJvbSAnLi4vbGVnYWN5LWFjdGlvbnMvaW5kZXguanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZmV0Y2hSZWR1Y2VyKHN0YXRlOiBTdGF0ZTx1bmtub3duPiwgYWN0aW9uOiBGZXRjaEFjdGlvbikge1xuICBjb25zdCBvcHRpbWlzdGljUmVzcG9uc2UgPSBhY3Rpb24ubWV0YS5vcHRpbWlzdGljUmVzcG9uc2U7XG4gIGNvbnN0IGdldE9wdGltaXN0aWNSZXNwb25zZSA9IGFjdGlvbi5lbmRwb2ludD8uZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlO1xuICBsZXQgcmVjZWl2ZUFjdGlvbjogUmVjZWl2ZUFjdGlvbiB8IE9wdGltaXN0aWNBY3Rpb247XG5cbiAgaWYgKGdldE9wdGltaXN0aWNSZXNwb25zZSAmJiBhY3Rpb24uZW5kcG9pbnQpIHtcbiAgICByZWNlaXZlQWN0aW9uID0gY3JlYXRlT3B0aW1pc3RpYyhhY3Rpb24uZW5kcG9pbnQsIHtcbiAgICAgIGFyZ3M6IGFjdGlvbi5tZXRhLmFyZ3MgYXMgcmVhZG9ubHkgYW55W10sXG4gICAgICBmZXRjaGVkQXQ6XG4gICAgICAgIHR5cGVvZiBhY3Rpb24ubWV0YS5jcmVhdGVkQXQgIT09ICdudW1iZXInXG4gICAgICAgICAgPyBhY3Rpb24ubWV0YS5jcmVhdGVkQXQuZ2V0VGltZSgpXG4gICAgICAgICAgOiBhY3Rpb24ubWV0YS5jcmVhdGVkQXQsXG4gICAgfSkgYXMgYW55O1xuICB9IC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqLyBlbHNlIGlmIChvcHRpbWlzdGljUmVzcG9uc2UpIHtcbiAgICAvLyBUT0RPKGJyZWFraW5nKTogdGhpcyBpcyBubyBsb25nZXIgdXNlZCwgcmVtb3ZlIHRoaXMgYnJhbmNoXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZWNlaXZlQWN0aW9uID0gbGVnYWN5Q3JlYXRlUmVjZWl2ZShvcHRpbWlzdGljUmVzcG9uc2UsIHtcbiAgICAgIC4uLmFjdGlvbi5tZXRhLFxuICAgICAgZGF0YUV4cGlyeUxlbmd0aDogSW5maW5pdHksXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgLy8gSWYgJ2ZldGNoJyBhY3Rpb24gcmVhY2hlcyB0aGUgcmVkdWNlciB0aGVyZSBhcmUgbm8gbWlkZGxld2FyZXMgaW5zdGFsbGVkIHRvIGhhbmRsZSBpdFxuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAncHJvZHVjdGlvbicpIHtcbiAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgJ0ZldGNoIGFwcGVhcnMgdW5oYW5kbGVkIC0geW91IGFyZSBsaWtlbHkgbWlzc2luZyB0aGUgTmV0d29ya01hbmFnZXIgbWlkZGxld2FyZScsXG4gICAgICApO1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnU2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL2RvY3MvZ3VpZGVzL3JlZHV4I2luZGV4dHN4IGZvciBob29raW5nIHVwIHJlZHV4JyxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlO1xuICB9XG4gIHJldHVybiB7XG4gICAgLi4uc3RhdGUsXG4gICAgb3B0aW1pc3RpYzogWy4uLnN0YXRlLm9wdGltaXN0aWMsIHJlY2VpdmVBY3Rpb25dLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxnQkFBZ0IsTUFBTSxzQ0FBc0M7QUFPbkUsU0FBU0MsYUFBYSxJQUFJQyxtQkFBbUIsUUFBUSw0QkFBNEI7QUFFakYsT0FBTyxTQUFTQyxZQUFZQSxDQUFDQyxLQUFxQixFQUFFQyxNQUFtQixFQUFFO0VBQUEsSUFBQUMsZ0JBQUE7RUFDdkUsTUFBTUMsa0JBQWtCLEdBQUdGLE1BQU0sQ0FBQ0csSUFBSSxDQUFDRCxrQkFBa0I7RUFDekQsTUFBTUUscUJBQXFCLElBQUFILGdCQUFBLEdBQUdELE1BQU0sQ0FBQ0ssUUFBUSxxQkFBZkosZ0JBQUEsQ0FBaUJHLHFCQUFxQjtFQUNwRSxJQUFJRSxhQUErQztFQUVuRCxJQUFJRixxQkFBcUIsSUFBSUosTUFBTSxDQUFDSyxRQUFRLEVBQUU7SUFDNUNDLGFBQWEsR0FBR1gsZ0JBQWdCLENBQUNLLE1BQU0sQ0FBQ0ssUUFBUSxFQUFFO01BQ2hERSxJQUFJLEVBQUVQLE1BQU0sQ0FBQ0csSUFBSSxDQUFDSSxJQUFzQjtNQUN4Q0MsU0FBUyxFQUNQLE9BQU9SLE1BQU0sQ0FBQ0csSUFBSSxDQUFDTSxTQUFTLEtBQUssUUFBUSxHQUNyQ1QsTUFBTSxDQUFDRyxJQUFJLENBQUNNLFNBQVMsQ0FBQ0MsT0FBTyxDQUFDLENBQUMsR0FDL0JWLE1BQU0sQ0FBQ0csSUFBSSxDQUFDTTtJQUNwQixDQUFDLENBQVE7RUFDWCxDQUFDLENBQUMsNkJBQThCLElBQUlQLGtCQUFrQixFQUFFO0lBQ3REO0lBQ0E7SUFDQUksYUFBYSxHQUFHVCxtQkFBbUIsQ0FBQ0ssa0JBQWtCLEVBQUFTLE1BQUEsQ0FBQUMsTUFBQSxLQUNqRFosTUFBTSxDQUFDRyxJQUFJO01BQ2RVLGdCQUFnQixFQUFFQztJQUFRLEVBQzNCLENBQUM7RUFDSixDQUFDLE1BQU07SUFDTDtJQUNBO0lBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxZQUFZLEVBQUU7TUFDekNDLE9BQU8sQ0FBQ0MsSUFBSSxDQUNWLGdGQUNGLENBQUM7TUFDREQsT0FBTyxDQUFDQyxJQUFJLENBQ1YsMEVBQ0YsQ0FBQztJQUNIO0lBRUEsT0FBT3BCLEtBQUs7RUFDZDtFQUNBLE9BQUFZLE1BQUEsQ0FBQUMsTUFBQSxLQUNLYixLQUFLO0lBQ1JxQixVQUFVLEVBQUUsQ0FBQyxHQUFHckIsS0FBSyxDQUFDcUIsVUFBVSxFQUFFZCxhQUFhO0VBQUM7QUFFcEQifQ== |
@@ -113,2 +113,2 @@ import { normalize } from '@rest-hooks/normalizr'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC_TYPE","applyUpdatersToResults","setReducer","state","action","controller","error","reduceError","payload","_state$meta$action$me","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","_e$constructor","constructor","name","result","entities","indexes","entityMeta","schema","Object","assign","date","results","key","updaters","update","keys","forEach","console","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setReducer.ts"],"sourcesContent":["import { normalize } from '@rest-hooks/normalizr';\n\nimport { OPTIMISTIC_TYPE } from '../../actionTypes.js';\nimport type Controller from '../../controller/Controller.js';\nimport type { ReceiveAction, OptimisticAction } from '../../previousActions.js';\nimport type { State } from '../../types.js';\nimport applyUpdatersToResults from '../applyUpdatersToResults.js';\n\nexport function setReducer(\n  state: State<unknown>,\n  action: OptimisticAction | ReceiveAction,\n  controller: Controller,\n) {\n  if (action.error) {\n    return reduceError(state, action, action.payload);\n  }\n  try {\n    let payload: any;\n    // for true receives payload is contained in action\n    if (action.type === OPTIMISTIC_TYPE) {\n      if (!action.endpoint.getOptimisticResponse) return state;\n      try {\n        // compute optimistic response based on current state\n        payload = action.endpoint.getOptimisticResponse.call(\n          action.endpoint,\n          controller.snapshot(state, action.meta.fetchedAt),\n          // if endpoint exists, so must args; TODO: fix typing\n          ...(action.meta.args as any[]),\n        );\n      } catch (e: any) {\n        // AbortOptimistic means 'do nothing', otherwise we count the exception as endpoint failure\n        if (e.constructor?.name === 'AbortOptimistic') {\n          return state;\n        }\n        throw e;\n      }\n    } else {\n      payload = action.payload;\n    }\n    const { result, entities, indexes, entityMeta } = normalize(\n      payload,\n      action.meta.schema,\n      action.meta.args as any,\n      state.entities,\n      state.indexes,\n      state.entityMeta,\n      { fetchedAt: action.meta.date, ...action.meta },\n    );\n    let results = {\n      ...state.results,\n      [action.meta.key]: result,\n    };\n    try {\n      if ('updaters' in action.meta && action.meta.updaters) {\n        results = applyUpdatersToResults(\n          results,\n          result,\n          action.meta.updaters as any,\n        );\n      }\n      if (action.meta.update) {\n        const updaters = action.meta.update(\n          result,\n          ...(action.meta.args || []),\n        );\n        Object.keys(updaters).forEach(key => {\n          results[key] = updaters[key](results[key]);\n        });\n      }\n      // no reason to completely fail because of user-code error\n      // integrity of this state update is still guaranteed\n    } catch (error) {\n      console.error(\n        `The following error occured during Endpoint.update() for ${action.meta.key}`,\n      );\n      console.error(error);\n    }\n    return {\n      entities,\n      indexes,\n      results,\n      entityMeta,\n      meta: {\n        ...state.meta,\n        [action.meta.key]: {\n          date: action.meta.date,\n          expiresAt: action.meta.expiresAt,\n          prevExpiresAt: state.meta[action.meta.key]?.expiresAt,\n        },\n      },\n      optimistic: filterOptimistic(state, action),\n      lastReset: state.lastReset,\n    };\n    // reducer must update the state, so in case of processing errors we simply compute the results inline\n  } catch (error: any) {\n    if (typeof error === 'object') {\n      error.message = `Error processing ${\n        action.meta.key\n      }\\n\\nFull Schema: ${JSON.stringify(\n        action.meta.schema,\n        undefined,\n        2,\n      )}\\n\\nError:\\n${error.message}`;\n      if ('payload' in action) error.payload = action.payload;\n      error.status = 400;\n    }\n\n    // this is not always bubbled up, so let's double sure this doesn't fail silently\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      console.error(error);\n    }\n    return reduceError(state, action, error);\n  }\n}\n\nfunction reduceError(\n  state: State<unknown>,\n  action: ReceiveAction | OptimisticAction,\n  error: any,\n): State<unknown> {\n  if (error.name === 'AbortError') {\n    // In case we abort simply undo the optimistic update and act like no fetch even occured\n    // We still want those watching promises from fetch directly to observed the abort, but we don't want to\n    // Trigger errors in this case. This means theoretically improperly built abortes useResource() could suspend forever.\n    return {\n      ...state,\n      optimistic: filterOptimistic(state, action),\n    };\n  }\n  return {\n    ...state,\n    meta: {\n      ...state.meta,\n      [action.meta.key]: {\n        date: action.meta.date,\n        error,\n        expiresAt: action.meta.expiresAt,\n        errorPolicy: action.meta.errorPolicy?.(error),\n      },\n    },\n    optimistic: filterOptimistic(state, action),\n  };\n}\n/** Filter all requests with same serialization that did not start after the resolving request */\nfunction filterOptimistic(\n  state: State<unknown>,\n  resolvingAction: ReceiveAction | OptimisticAction,\n) {\n  return state.optimistic.filter(\n    optimisticAction =>\n      optimisticAction.meta.key !== resolvingAction.meta.key ||\n      (optimisticAction.type === OPTIMISTIC_TYPE\n        ? optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt\n        : optimisticAction.meta.date > resolvingAction.meta.date),\n  );\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC_TYPE","applyUpdatersToResults","setReducer","state","action","controller","error","reduceError","payload","_state$meta$action$me","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","_e$constructor","constructor","name","result","entities","indexes","entityMeta","schema","Object","assign","date","results","key","updaters","update","keys","forEach","console","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setReducer.ts"],"sourcesContent":["import { normalize } from '@rest-hooks/normalizr';\n\nimport { OPTIMISTIC_TYPE } from '../../actionTypes.js';\nimport type Controller from '../../controller/Controller.js';\nimport type { ReceiveAction, OptimisticAction } from '../../previousActions.js';\nimport type { State } from '../../types.js';\nimport applyUpdatersToResults from '../applyUpdatersToResults.js';\n\nexport function setReducer(\n  state: State<unknown>,\n  action: OptimisticAction | ReceiveAction,\n  controller: Controller,\n) {\n  if (action.error) {\n    return reduceError(state, action, action.payload);\n  }\n  try {\n    let payload: any;\n    // for true receives payload is contained in action\n    if (action.type === OPTIMISTIC_TYPE) {\n      if (!action.endpoint.getOptimisticResponse) return state;\n      try {\n        // compute optimistic response based on current state\n        payload = action.endpoint.getOptimisticResponse.call(\n          action.endpoint,\n          controller.snapshot(state, action.meta.fetchedAt),\n          // if endpoint exists, so must args; TODO: fix typing\n          ...(action.meta.args as any[]),\n        );\n      } catch (e: any) {\n        // AbortOptimistic means 'do nothing', otherwise we count the exception as endpoint failure\n        if (e.constructor?.name === 'AbortOptimistic') {\n          return state;\n        }\n        throw e;\n      }\n    } else {\n      payload = action.payload;\n    }\n    const { result, entities, indexes, entityMeta } = normalize(\n      payload,\n      action.meta.schema,\n      action.meta.args as any,\n      state.entities,\n      state.indexes,\n      state.entityMeta,\n      { fetchedAt: action.meta.date, ...action.meta },\n    );\n    let results = {\n      ...state.results,\n      [action.meta.key]: result,\n    };\n    try {\n      if ('updaters' in action.meta && action.meta.updaters) {\n        results = applyUpdatersToResults(\n          results,\n          result,\n          action.meta.updaters as any,\n        );\n      }\n      if (action.meta.update) {\n        const updaters = action.meta.update(\n          result,\n          ...(action.meta.args || []),\n        );\n        Object.keys(updaters).forEach(key => {\n          results[key] = updaters[key](results[key]);\n        });\n      }\n      // no reason to completely fail because of user-code error\n      // integrity of this state update is still guaranteed\n    } catch (error) {\n      console.error(\n        `The following error occured during Endpoint.update() for ${action.meta.key}`,\n      );\n      console.error(error);\n    }\n    return {\n      entities,\n      indexes,\n      results,\n      entityMeta,\n      meta: {\n        ...state.meta,\n        [action.meta.key]: {\n          date: action.meta.date,\n          expiresAt: action.meta.expiresAt,\n          prevExpiresAt: state.meta[action.meta.key]?.expiresAt,\n        },\n      },\n      optimistic: filterOptimistic(state, action),\n      lastReset: state.lastReset,\n    };\n    // reducer must update the state, so in case of processing errors we simply compute the results inline\n  } catch (error: any) {\n    if (typeof error === 'object') {\n      error.message = `Error processing ${\n        action.meta.key\n      }\\n\\nFull Schema: ${JSON.stringify(\n        action.meta.schema,\n        undefined,\n        2,\n      )}\\n\\nError:\\n${error.message}`;\n      if ('payload' in action) error.payload = action.payload;\n      error.status = 400;\n    }\n\n    // this is not always bubbled up, so let's double sure this doesn't fail silently\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      console.error(error);\n    }\n    return reduceError(state, action, error);\n  }\n}\n\nfunction reduceError(\n  state: State<unknown>,\n  action: ReceiveAction | OptimisticAction,\n  error: any,\n): State<unknown> {\n  if (error.name === 'AbortError') {\n    // In case we abort simply undo the optimistic update and act like no fetch even occured\n    // We still want those watching promises from fetch directly to observed the abort, but we don't want to\n    // Trigger errors in this case. This means theoretically improperly built abortes useResource() could suspend forever.\n    return {\n      ...state,\n      optimistic: filterOptimistic(state, action),\n    };\n  }\n  return {\n    ...state,\n    meta: {\n      ...state.meta,\n      [action.meta.key]: {\n        date: action.meta.date,\n        error,\n        expiresAt: action.meta.expiresAt,\n        errorPolicy: action.meta.errorPolicy?.(error),\n      },\n    },\n    optimistic: filterOptimistic(state, action),\n  };\n}\n/** Filter all requests with same serialization that did not start after the resolving request */\nfunction filterOptimistic(\n  state: State<unknown>,\n  resolvingAction: ReceiveAction | OptimisticAction,\n) {\n  return state.optimistic.filter(\n    optimisticAction =>\n      optimisticAction.meta.key !== resolvingAction.meta.key ||\n      (optimisticAction.type === OPTIMISTIC_TYPE\n        ? optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt\n        : optimisticAction.meta.date > resolvingAction.meta.date),\n  );\n}\n"],"mappings":"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"} |
@@ -9,2 +9,2 @@ /* istanbul ignore file */ | ||
export default reducer; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZWR1Y2VyIiwiQ29udHJvbGxlciIsInJlZHVjZXIiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhdGUvcmVkdWNlckluc3RhbmNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG5pbXBvcnQgY3JlYXRlUmVkdWNlciBmcm9tICcuL3JlZHVjZXIvY3JlYXRlUmVkdWNlci5qcyc7XG5pbXBvcnQgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHsgQWN0aW9uVHlwZXMsIFN0YXRlIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIHVzZSBjcmVhdGVSZWR1Y2VyIGluc3RlYWRcbiAqL1xuY29uc3QgcmVkdWNlcjogKFxuICBzdGF0ZTogU3RhdGU8dW5rbm93bj4gfCB1bmRlZmluZWQsXG4gIGFjdGlvbjogQWN0aW9uVHlwZXMsXG4pID0+IFN0YXRlPHVua25vd24+ID0gY3JlYXRlUmVkdWNlcihuZXcgQ29udHJvbGxlcigpKTtcblxuZXhwb3J0IGRlZmF1bHQgcmVkdWNlcjtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQSxPQUFPQSxhQUFhLE1BQU0sNEJBQTRCO0FBQ3RELE9BQU9DLFVBQVUsTUFBTSw2QkFBNkI7QUFHcEQ7QUFDQTtBQUNBO0FBQ0EsTUFBTUMsT0FHYSxHQUFHRixhQUFhLENBQUMsSUFBSUMsVUFBVSxFQUFFLENBQUM7QUFFckQsZUFBZUMsT0FBTyJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZWR1Y2VyIiwiQ29udHJvbGxlciIsInJlZHVjZXIiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhdGUvcmVkdWNlckluc3RhbmNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG5pbXBvcnQgY3JlYXRlUmVkdWNlciBmcm9tICcuL3JlZHVjZXIvY3JlYXRlUmVkdWNlci5qcyc7XG5pbXBvcnQgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHsgQWN0aW9uVHlwZXMsIFN0YXRlIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIHVzZSBjcmVhdGVSZWR1Y2VyIGluc3RlYWRcbiAqL1xuY29uc3QgcmVkdWNlcjogKFxuICBzdGF0ZTogU3RhdGU8dW5rbm93bj4gfCB1bmRlZmluZWQsXG4gIGFjdGlvbjogQWN0aW9uVHlwZXMsXG4pID0+IFN0YXRlPHVua25vd24+ID0gY3JlYXRlUmVkdWNlcihuZXcgQ29udHJvbGxlcigpKTtcblxuZXhwb3J0IGRlZmF1bHQgcmVkdWNlcjtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQSxPQUFPQSxhQUFhLE1BQU0sNEJBQTRCO0FBQ3RELE9BQU9DLFVBQVUsTUFBTSw2QkFBNkI7QUFHcEQ7QUFDQTtBQUNBO0FBQ0EsTUFBTUMsT0FHYSxHQUFHRixhQUFhLENBQUMsSUFBSUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUVyRCxlQUFlQyxPQUFPIn0= |
@@ -289,2 +289,2 @@ import { WeakEntityMap, ExpiryStatus, denormalizeCached, isEntity } from '@rest-hooks/normalizr'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["WeakEntityMap","ExpiryStatus","denormalizeCached","isEntity","inferResults","validateInference","createInvalidate","createInvalidateAll","createReceive","createReset","createUnsubscription","createSubscription","initialState","selectMeta","unsetDispatch","action","Error","unsetState","Controller","constructor","dispatch","getState","globalCache","entities","results","invalidate","endpoint","args","Promise","resolve","invalidateAll","options","key","testKey","resetEntireStore","setResponse","rest","response","length","slice","receive","setError","error","receiveError","meta","subscribe","unsubscribe","snapshot","state","fetchedAt","Snapshot","getError","undefined","errorPolicy","getResponse","isActive","cacheResults","schema","expiresAt","invalidResults","indexes","data","expiryStatus","Valid","Infinity","schemaHasEntity","invalidated","Invalid","invalidIfStale","InvalidIfStale","process","env","NODE_ENV","Array","isArray","paths","invalidDenormalize","entityExpiresAt","entityMeta","pk","_entityMeta$key","_entityMeta$key$pk","entityExpiry","nestedSchema","Object","values","some","x","controller"],"sources":["../../src/controller/BaseController.ts"],"sourcesContent":["import type {\n  ErrorTypes,\n  SnapshotInterface,\n  DenormalizeCache,\n  Schema,\n} from '@rest-hooks/normalizr';\nimport {\n  WeakEntityMap,\n  ExpiryStatus,\n  EndpointInterface,\n  FetchFunction,\n  ResolveType,\n  DenormalizeNullable,\n  Path,\n  denormalizeCached,\n  isEntity,\n} from '@rest-hooks/normalizr';\nimport { inferResults, validateInference } from '@rest-hooks/normalizr';\n\nimport createInvalidate from './createInvalidate.js';\nimport createInvalidateAll from './createInvalidateAll.js';\nimport createReceive from './createReceive.js';\nimport createReset from './createReset.js';\nimport {\n  createUnsubscription,\n  createSubscription,\n} from './createSubscription.js';\nimport type { EndpointUpdateFunction } from './types.js';\nimport { initialState } from '../state/reducer/createReducer.js';\nimport selectMeta from '../state/selectMeta.js';\nimport type {\n  ActionTypes as BroadActionTypes,\n  CombinedActionTypes,\n  State,\n} from '../types.js';\n\nexport type GenericDispatch = (value: any) => Promise<void>;\nexport type CompatibleDispatch = (value: CombinedActionTypes) => Promise<void>;\ntype PreviousDispatch = (value: BroadActionTypes) => Promise<void>;\n\ninterface ConstructorProps<D extends GenericDispatch = CompatibleDispatch> {\n  dispatch?: D;\n  getState?: () => State<unknown>;\n  globalCache?: DenormalizeCache;\n}\n\nconst unsetDispatch = (action: unknown): Promise<void> => {\n  throw new Error(\n    `Dispatching while constructing your middleware is not allowed. ` +\n      `Other middleware would not be applied to this dispatch.`,\n  );\n};\nconst unsetState = (): State<unknown> => {\n  // This is only the value until it is set by the CacheProvider\n  /* istanbul ignore next */\n  return initialState;\n};\n\n/**\n * Imperative control of Rest Hooks store\n * @see https://resthooks.io/docs/api/Controller\n */\nexport default class Controller<\n  D extends GenericDispatch = CompatibleDispatch,\n> {\n  /**\n   * Dispatches an action to Rest Hooks reducer.\n   *\n   * @see https://resthooks.io/docs/api/Controller#dispatch\n   */\n  declare readonly dispatch: D;\n  /**\n   * Gets the latest state snapshot that is fully committed.\n   *\n   * This can be useful for imperative use-cases like event handlers.\n   * This should *not* be used to render; instead useSuspense() or useCache()\n   * @see https://resthooks.io/docs/api/Controller#getState\n   */\n  declare readonly getState: () => State<unknown>;\n  declare readonly globalCache: DenormalizeCache;\n\n  constructor({\n    dispatch = unsetDispatch as any,\n    getState = unsetState,\n    globalCache = {\n      entities: {},\n      results: {},\n    },\n  }: ConstructorProps<D> = {}) {\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.globalCache = globalCache;\n  }\n\n  /*************** Action Dispatchers ***************/\n\n  /**\n   * Forces refetching and suspense on useSuspense with the same Endpoint and parameters.\n   * @see https://resthooks.io/docs/api/Controller#invalidate\n   */\n  invalidate = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createInvalidate(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /**\n   * Forces refetching and suspense on useSuspense on all matching endpoint result keys.\n   * @see https://resthooks.io/docs/api/Controller#invalidateAll\n   */\n  invalidateAll = (options: { testKey: (key: string) => boolean }) =>\n    this.dispatch(createInvalidateAll((key: string) => options.testKey(key)));\n\n  /**\n   * Resets the entire Rest Hooks cache. All inflight requests will not resolve.\n   * @see https://resthooks.io/docs/api/Controller#resetEntireStore\n   */\n  resetEntireStore = (): Promise<void> => this.dispatch(createReset());\n\n  /**\n   * Stores response in cache for given Endpoint and args.\n   * @see https://resthooks.io/docs/api/Controller#set\n   */\n  setResponse = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    const response: ResolveType<E> = rest[rest.length - 1];\n    const action = createReceive(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n    });\n    return this.dispatch(action);\n  };\n\n  // TODO: deprecate\n  /**\n   * Another name for setResponse\n   * @see https://resthooks.io/docs/api/Controller#setResponse\n   */\n  /* istanbul ignore next */ receive = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    /* istanbul ignore next */\n    return this.setResponse(endpoint, ...rest);\n  };\n\n  /**\n   * Stores the result of Endpoint and args as the error provided.\n   * @see https://resthooks.io/docs/api/Controller#setError\n   */\n  setError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    const response: Error = rest[rest.length - 1];\n    const action = createReceive(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n      error: true,\n    });\n    return this.dispatch(action);\n  };\n\n  // TODO: deprecate\n  /**\n   * Another name for setError\n   * @see https://resthooks.io/docs/api/Controller#setError\n   */\n  /* istanbul ignore next */ receiveError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    /* istanbul ignore next */\n    return this.setError(endpoint, ...rest);\n  };\n\n  /**\n   * Resolves an inflight fetch. `fetchedAt` should `fetch`'s `createdAt`\n   * @see https://resthooks.io/docs/api/Controller#resolve\n   */\n  resolve = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    meta:\n      | {\n          args: readonly [...Parameters<E>];\n          response: Error;\n          fetchedAt: number;\n          error: true;\n        }\n      | {\n          args: readonly [...Parameters<E>];\n          response: any;\n          fetchedAt: number;\n          error?: false;\n        },\n  ): Promise<void> => {\n    return this.dispatch(createReceive(endpoint, meta as any));\n  };\n\n  /**\n   * Marks a new subscription to a given Endpoint.\n   * @see https://resthooks.io/docs/api/Controller#subscribe\n   */\n  subscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createSubscription(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /**\n   * Marks completion of subscription to a given Endpoint.\n   * @see https://resthooks.io/docs/api/Controller#unsubscribe\n   */\n  unsubscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createUnsubscription(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /*************** More ***************/\n\n  /* TODO:\n  abort = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): Promise<void>\n  */\n\n  /**\n   * Gets a snapshot (https://resthooks.io/docs/api/Snapshot)\n   * @see https://resthooks.io/docs/api/Controller#snapshot\n   */\n  snapshot = (state: State<unknown>, fetchedAt?: number): SnapshotInterface => {\n    return new Snapshot(this, state, fetchedAt);\n  };\n\n  /**\n   * Gets the error, if any, for a given endpoint. Returns undefined for no errors.\n   * @see https://resthooks.io/docs/api/Controller#getError\n   */\n  getError = <\n    E extends Pick<EndpointInterface, 'key'>,\n    Args extends readonly [...Parameters<E['key']>] | readonly [null],\n  >(\n    endpoint: E,\n    ...rest: [...Args, State<unknown>]\n  ): ErrorTypes | undefined => {\n    if (rest[0] === null) return;\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;\n    const key = endpoint.key(...args);\n\n    const meta = selectMeta(state, key);\n    const results = state.results[key];\n\n    if (results !== undefined && meta?.errorPolicy === 'soft') return;\n\n    return meta?.error as any;\n  };\n\n  /**\n   * Gets the (globally referentially stable) response for a given endpoint/args pair from state given.\n   * @see https://resthooks.io/docs/api/Controller#getResponse\n   */\n  getResponse = <\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n    Args extends readonly [...Parameters<E['key']>] | readonly [null],\n  >(\n    endpoint: E,\n    ...rest: [...Args, State<unknown>]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } => {\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;\n    const isActive = args.length !== 1 || args[0] !== null;\n    const key = isActive ? endpoint.key(...args) : '';\n    const cacheResults = isActive ? state.results[key] : undefined;\n    const schema = endpoint.schema;\n    const meta = selectMeta(state, key);\n    let expiresAt = meta?.expiresAt;\n\n    let invalidResults = false;\n    let results;\n    if (cacheResults === undefined && endpoint.schema !== undefined) {\n      results = inferResults(\n        endpoint.schema,\n        args,\n        state.indexes,\n        state.entities,\n      );\n      invalidResults = !validateInference(results);\n      if (!expiresAt && invalidResults) expiresAt = 1;\n    } else {\n      results = cacheResults;\n    }\n\n    if (!isActive) {\n      return {\n        data: results as any,\n        expiryStatus: ExpiryStatus.Valid,\n        expiresAt: Infinity,\n      };\n    }\n\n    if (!endpoint.schema || !schemaHasEntity(endpoint.schema)) {\n      return {\n        data: results,\n        expiryStatus: meta?.invalidated\n          ? ExpiryStatus.Invalid\n          : cacheResults && !endpoint.invalidIfStale\n          ? ExpiryStatus.Valid\n          : ExpiryStatus.InvalidIfStale,\n        expiresAt: expiresAt || 0,\n      } as {\n        data: DenormalizeNullable<E['schema']>;\n        expiryStatus: ExpiryStatus;\n        expiresAt: number;\n      };\n    }\n\n    // Warn users with bad configurations\n    /* istanbul ignore next */\n    if (process.env.NODE_ENV !== 'production' && schema && isEntity(schema)) {\n      if (Array.isArray(results)) {\n        throw new Error(\n          `fetch key ${key} has list results when single result is expected`,\n        );\n      }\n      if (typeof results === 'object') {\n        throw new Error(\n          `fetch key ${key} has object results when entity's primary key (string) result is expected`,\n        );\n      }\n    }\n\n    if (!this.globalCache.results[key])\n      this.globalCache.results[key] = new WeakEntityMap();\n\n    // second argument is false if any entities are missing\n    // eslint-disable-next-line prefer-const\n    const { data, paths } = denormalizeCached(\n      results,\n      schema,\n      state.entities,\n      this.globalCache.entities,\n      this.globalCache.results[key],\n      args,\n    ) as { data: DenormalizeNullable<E['schema']>; paths: Path[] };\n    const invalidDenormalize = typeof data === 'symbol';\n\n    // fallback to entity expiry time\n    if (!expiresAt) {\n      expiresAt = entityExpiresAt(paths, state.entityMeta);\n    }\n\n    // https://resthooks.io/docs/concepts/expiry-policy#expiry-status\n    // we don't track the difference between stale or fresh because that is tied to triggering\n    // conditions\n    const expiryStatus =\n      meta?.invalidated || (invalidDenormalize && !meta?.error)\n        ? ExpiryStatus.Invalid\n        : invalidDenormalize || endpoint.invalidIfStale || invalidResults\n        ? ExpiryStatus.InvalidIfStale\n        : ExpiryStatus.Valid;\n\n    return { data, expiryStatus, expiresAt };\n  };\n}\n\n// benchmark: https://www.measurethat.net/Benchmarks/Show/24691/0/min-reducer-vs-imperative-with-paths\n// earliest expiry dictates age\nfunction entityExpiresAt(\n  paths: Path[],\n  entityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number; // This is only the value until it is set by the CacheProvider\n      };\n    };\n  },\n) {\n  let expiresAt = Infinity;\n  for (const { pk, key } of paths) {\n    const entityExpiry = entityMeta[key]?.[pk]?.expiresAt;\n    // expiresAt will always resolve to false with any comparison\n    if (entityExpiry < expiresAt) expiresAt = entityExpiry;\n  }\n  return expiresAt;\n}\n\n/** Determine whether the schema has any entities.\n *\n * Without entities, denormalization is not needed, and results should not be inferred.\n */\nfunction schemaHasEntity(schema: Schema): boolean {\n  if (isEntity(schema)) return true;\n  if (Array.isArray(schema))\n    return schema.length !== 0 && schemaHasEntity(schema[0]);\n  if (schema && (typeof schema === 'object' || typeof schema === 'function')) {\n    const nestedSchema =\n      'schema' in schema ? (schema.schema as Record<string, Schema>) : schema;\n    if (typeof nestedSchema === 'function') {\n      return schemaHasEntity(nestedSchema);\n    }\n    return Object.values(nestedSchema).some(x => schemaHasEntity(x));\n  }\n  return false;\n}\n\nexport type { ErrorTypes };\n\nclass Snapshot<T = unknown> implements SnapshotInterface {\n  private state: State<T>;\n  private controller: Controller;\n  readonly fetchedAt: number;\n\n  constructor(controller: Controller, state: State<T>, fetchedAt = 0) {\n    this.state = state;\n    this.controller = controller;\n    this.fetchedAt = fetchedAt;\n  }\n\n  /*************** Data Access ***************/\n  /** @see https://resthooks.io/docs/api/Snapshot#getResponse */\n  getResponse = <\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n    Args extends readonly [...Parameters<E['key']>],\n  >(\n    endpoint: E,\n    ...args: Args\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } => {\n    return this.controller.getResponse(endpoint, ...args, this.state);\n  };\n\n  /** @see https://resthooks.io/docs/api/Snapshot#getError */\n  getError = <\n    E extends Pick<EndpointInterface, 'key'>,\n    Args extends readonly [...Parameters<E['key']>],\n  >(\n    endpoint: E,\n    ...args: Args\n  ): ErrorTypes | undefined => {\n    return this.controller.getError(endpoint, ...args, this.state);\n  };\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["WeakEntityMap","ExpiryStatus","denormalizeCached","isEntity","inferResults","validateInference","createInvalidate","createInvalidateAll","createReceive","createReset","createUnsubscription","createSubscription","initialState","selectMeta","unsetDispatch","action","Error","unsetState","Controller","constructor","dispatch","getState","globalCache","entities","results","invalidate","endpoint","args","Promise","resolve","invalidateAll","options","key","testKey","resetEntireStore","setResponse","rest","response","length","slice","receive","setError","error","receiveError","meta","subscribe","unsubscribe","snapshot","state","fetchedAt","Snapshot","getError","undefined","errorPolicy","getResponse","isActive","cacheResults","schema","expiresAt","invalidResults","indexes","data","expiryStatus","Valid","Infinity","schemaHasEntity","invalidated","Invalid","invalidIfStale","InvalidIfStale","process","env","NODE_ENV","Array","isArray","paths","invalidDenormalize","entityExpiresAt","entityMeta","pk","_entityMeta$key","_entityMeta$key$pk","entityExpiry","nestedSchema","Object","values","some","x","controller"],"sources":["../../src/controller/BaseController.ts"],"sourcesContent":["import type {\n  ErrorTypes,\n  SnapshotInterface,\n  DenormalizeCache,\n  Schema,\n} from '@rest-hooks/normalizr';\nimport {\n  WeakEntityMap,\n  ExpiryStatus,\n  EndpointInterface,\n  FetchFunction,\n  ResolveType,\n  DenormalizeNullable,\n  Path,\n  denormalizeCached,\n  isEntity,\n} from '@rest-hooks/normalizr';\nimport { inferResults, validateInference } from '@rest-hooks/normalizr';\n\nimport createInvalidate from './createInvalidate.js';\nimport createInvalidateAll from './createInvalidateAll.js';\nimport createReceive from './createReceive.js';\nimport createReset from './createReset.js';\nimport {\n  createUnsubscription,\n  createSubscription,\n} from './createSubscription.js';\nimport type { EndpointUpdateFunction } from './types.js';\nimport { initialState } from '../state/reducer/createReducer.js';\nimport selectMeta from '../state/selectMeta.js';\nimport type {\n  ActionTypes as BroadActionTypes,\n  CombinedActionTypes,\n  State,\n} from '../types.js';\n\nexport type GenericDispatch = (value: any) => Promise<void>;\nexport type CompatibleDispatch = (value: CombinedActionTypes) => Promise<void>;\ntype PreviousDispatch = (value: BroadActionTypes) => Promise<void>;\n\ninterface ConstructorProps<D extends GenericDispatch = CompatibleDispatch> {\n  dispatch?: D;\n  getState?: () => State<unknown>;\n  globalCache?: DenormalizeCache;\n}\n\nconst unsetDispatch = (action: unknown): Promise<void> => {\n  throw new Error(\n    `Dispatching while constructing your middleware is not allowed. ` +\n      `Other middleware would not be applied to this dispatch.`,\n  );\n};\nconst unsetState = (): State<unknown> => {\n  // This is only the value until it is set by the CacheProvider\n  /* istanbul ignore next */\n  return initialState;\n};\n\n/**\n * Imperative control of Rest Hooks store\n * @see https://resthooks.io/docs/api/Controller\n */\nexport default class Controller<\n  D extends GenericDispatch = CompatibleDispatch,\n> {\n  /**\n   * Dispatches an action to Rest Hooks reducer.\n   *\n   * @see https://resthooks.io/docs/api/Controller#dispatch\n   */\n  declare readonly dispatch: D;\n  /**\n   * Gets the latest state snapshot that is fully committed.\n   *\n   * This can be useful for imperative use-cases like event handlers.\n   * This should *not* be used to render; instead useSuspense() or useCache()\n   * @see https://resthooks.io/docs/api/Controller#getState\n   */\n  declare readonly getState: () => State<unknown>;\n  declare readonly globalCache: DenormalizeCache;\n\n  constructor({\n    dispatch = unsetDispatch as any,\n    getState = unsetState,\n    globalCache = {\n      entities: {},\n      results: {},\n    },\n  }: ConstructorProps<D> = {}) {\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.globalCache = globalCache;\n  }\n\n  /*************** Action Dispatchers ***************/\n\n  /**\n   * Forces refetching and suspense on useSuspense with the same Endpoint and parameters.\n   * @see https://resthooks.io/docs/api/Controller#invalidate\n   */\n  invalidate = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createInvalidate(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /**\n   * Forces refetching and suspense on useSuspense on all matching endpoint result keys.\n   * @see https://resthooks.io/docs/api/Controller#invalidateAll\n   */\n  invalidateAll = (options: { testKey: (key: string) => boolean }) =>\n    this.dispatch(createInvalidateAll((key: string) => options.testKey(key)));\n\n  /**\n   * Resets the entire Rest Hooks cache. All inflight requests will not resolve.\n   * @see https://resthooks.io/docs/api/Controller#resetEntireStore\n   */\n  resetEntireStore = (): Promise<void> => this.dispatch(createReset());\n\n  /**\n   * Stores response in cache for given Endpoint and args.\n   * @see https://resthooks.io/docs/api/Controller#set\n   */\n  setResponse = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    const response: ResolveType<E> = rest[rest.length - 1];\n    const action = createReceive(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n    });\n    return this.dispatch(action);\n  };\n\n  // TODO: deprecate\n  /**\n   * Another name for setResponse\n   * @see https://resthooks.io/docs/api/Controller#setResponse\n   */\n  /* istanbul ignore next */ receive = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, any]\n  ): Promise<void> => {\n    /* istanbul ignore next */\n    return this.setResponse(endpoint, ...rest);\n  };\n\n  /**\n   * Stores the result of Endpoint and args as the error provided.\n   * @see https://resthooks.io/docs/api/Controller#setError\n   */\n  setError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    const response: Error = rest[rest.length - 1];\n    const action = createReceive(endpoint, {\n      args: rest.slice(0, rest.length - 1) as Parameters<E>,\n      response,\n      error: true,\n    });\n    return this.dispatch(action);\n  };\n\n  // TODO: deprecate\n  /**\n   * Another name for setError\n   * @see https://resthooks.io/docs/api/Controller#setError\n   */\n  /* istanbul ignore next */ receiveError = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    ...rest: readonly [...Parameters<E>, Error]\n  ): Promise<void> => {\n    /* istanbul ignore next */\n    return this.setError(endpoint, ...rest);\n  };\n\n  /**\n   * Resolves an inflight fetch. `fetchedAt` should `fetch`'s `createdAt`\n   * @see https://resthooks.io/docs/api/Controller#resolve\n   */\n  resolve = <\n    E extends EndpointInterface & {\n      update?: EndpointUpdateFunction<E>;\n    },\n  >(\n    endpoint: E,\n    meta:\n      | {\n          args: readonly [...Parameters<E>];\n          response: Error;\n          fetchedAt: number;\n          error: true;\n        }\n      | {\n          args: readonly [...Parameters<E>];\n          response: any;\n          fetchedAt: number;\n          error?: false;\n        },\n  ): Promise<void> => {\n    return this.dispatch(createReceive(endpoint, meta as any));\n  };\n\n  /**\n   * Marks a new subscription to a given Endpoint.\n   * @see https://resthooks.io/docs/api/Controller#subscribe\n   */\n  subscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createSubscription(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /**\n   * Marks completion of subscription to a given Endpoint.\n   * @see https://resthooks.io/docs/api/Controller#unsubscribe\n   */\n  unsubscribe = <\n    E extends EndpointInterface<\n      FetchFunction,\n      Schema | undefined,\n      undefined | false\n    >,\n  >(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>] | readonly [null]\n  ): Promise<void> =>\n    args[0] !== null\n      ? this.dispatch(\n          createUnsubscription(endpoint, {\n            args: args as readonly [...Parameters<E>],\n          }),\n        )\n      : Promise.resolve();\n\n  /*************** More ***************/\n\n  /* TODO:\n  abort = <E extends EndpointInterface>(\n    endpoint: E,\n    ...args: readonly [...Parameters<E>]\n  ): Promise<void>\n  */\n\n  /**\n   * Gets a snapshot (https://resthooks.io/docs/api/Snapshot)\n   * @see https://resthooks.io/docs/api/Controller#snapshot\n   */\n  snapshot = (state: State<unknown>, fetchedAt?: number): SnapshotInterface => {\n    return new Snapshot(this, state, fetchedAt);\n  };\n\n  /**\n   * Gets the error, if any, for a given endpoint. Returns undefined for no errors.\n   * @see https://resthooks.io/docs/api/Controller#getError\n   */\n  getError = <\n    E extends Pick<EndpointInterface, 'key'>,\n    Args extends readonly [...Parameters<E['key']>] | readonly [null],\n  >(\n    endpoint: E,\n    ...rest: [...Args, State<unknown>]\n  ): ErrorTypes | undefined => {\n    if (rest[0] === null) return;\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;\n    const key = endpoint.key(...args);\n\n    const meta = selectMeta(state, key);\n    const results = state.results[key];\n\n    if (results !== undefined && meta?.errorPolicy === 'soft') return;\n\n    return meta?.error as any;\n  };\n\n  /**\n   * Gets the (globally referentially stable) response for a given endpoint/args pair from state given.\n   * @see https://resthooks.io/docs/api/Controller#getResponse\n   */\n  getResponse = <\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n    Args extends readonly [...Parameters<E['key']>] | readonly [null],\n  >(\n    endpoint: E,\n    ...rest: [...Args, State<unknown>]\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } => {\n    const state = rest[rest.length - 1] as State<unknown>;\n    // this is typescript generics breaking\n    const args: any = rest.slice(0, rest.length - 1) as Parameters<E['key']>;\n    const isActive = args.length !== 1 || args[0] !== null;\n    const key = isActive ? endpoint.key(...args) : '';\n    const cacheResults = isActive ? state.results[key] : undefined;\n    const schema = endpoint.schema;\n    const meta = selectMeta(state, key);\n    let expiresAt = meta?.expiresAt;\n\n    let invalidResults = false;\n    let results;\n    if (cacheResults === undefined && endpoint.schema !== undefined) {\n      results = inferResults(\n        endpoint.schema,\n        args,\n        state.indexes,\n        state.entities,\n      );\n      invalidResults = !validateInference(results);\n      if (!expiresAt && invalidResults) expiresAt = 1;\n    } else {\n      results = cacheResults;\n    }\n\n    if (!isActive) {\n      return {\n        data: results as any,\n        expiryStatus: ExpiryStatus.Valid,\n        expiresAt: Infinity,\n      };\n    }\n\n    if (!endpoint.schema || !schemaHasEntity(endpoint.schema)) {\n      return {\n        data: results,\n        expiryStatus: meta?.invalidated\n          ? ExpiryStatus.Invalid\n          : cacheResults && !endpoint.invalidIfStale\n          ? ExpiryStatus.Valid\n          : ExpiryStatus.InvalidIfStale,\n        expiresAt: expiresAt || 0,\n      } as {\n        data: DenormalizeNullable<E['schema']>;\n        expiryStatus: ExpiryStatus;\n        expiresAt: number;\n      };\n    }\n\n    // Warn users with bad configurations\n    /* istanbul ignore next */\n    if (process.env.NODE_ENV !== 'production' && schema && isEntity(schema)) {\n      if (Array.isArray(results)) {\n        throw new Error(\n          `fetch key ${key} has list results when single result is expected`,\n        );\n      }\n      if (typeof results === 'object') {\n        throw new Error(\n          `fetch key ${key} has object results when entity's primary key (string) result is expected`,\n        );\n      }\n    }\n\n    if (!this.globalCache.results[key])\n      this.globalCache.results[key] = new WeakEntityMap();\n\n    // second argument is false if any entities are missing\n    // eslint-disable-next-line prefer-const\n    const { data, paths } = denormalizeCached(\n      results,\n      schema,\n      state.entities,\n      this.globalCache.entities,\n      this.globalCache.results[key],\n      args,\n    ) as { data: DenormalizeNullable<E['schema']>; paths: Path[] };\n    const invalidDenormalize = typeof data === 'symbol';\n\n    // fallback to entity expiry time\n    if (!expiresAt) {\n      expiresAt = entityExpiresAt(paths, state.entityMeta);\n    }\n\n    // https://resthooks.io/docs/concepts/expiry-policy#expiry-status\n    // we don't track the difference between stale or fresh because that is tied to triggering\n    // conditions\n    const expiryStatus =\n      meta?.invalidated || (invalidDenormalize && !meta?.error)\n        ? ExpiryStatus.Invalid\n        : invalidDenormalize || endpoint.invalidIfStale || invalidResults\n        ? ExpiryStatus.InvalidIfStale\n        : ExpiryStatus.Valid;\n\n    return { data, expiryStatus, expiresAt };\n  };\n}\n\n// benchmark: https://www.measurethat.net/Benchmarks/Show/24691/0/min-reducer-vs-imperative-with-paths\n// earliest expiry dictates age\nfunction entityExpiresAt(\n  paths: Path[],\n  entityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number; // This is only the value until it is set by the CacheProvider\n      };\n    };\n  },\n) {\n  let expiresAt = Infinity;\n  for (const { pk, key } of paths) {\n    const entityExpiry = entityMeta[key]?.[pk]?.expiresAt;\n    // expiresAt will always resolve to false with any comparison\n    if (entityExpiry < expiresAt) expiresAt = entityExpiry;\n  }\n  return expiresAt;\n}\n\n/** Determine whether the schema has any entities.\n *\n * Without entities, denormalization is not needed, and results should not be inferred.\n */\nfunction schemaHasEntity(schema: Schema): boolean {\n  if (isEntity(schema)) return true;\n  if (Array.isArray(schema))\n    return schema.length !== 0 && schemaHasEntity(schema[0]);\n  if (schema && (typeof schema === 'object' || typeof schema === 'function')) {\n    const nestedSchema =\n      'schema' in schema ? (schema.schema as Record<string, Schema>) : schema;\n    if (typeof nestedSchema === 'function') {\n      return schemaHasEntity(nestedSchema);\n    }\n    return Object.values(nestedSchema).some(x => schemaHasEntity(x));\n  }\n  return false;\n}\n\nexport type { ErrorTypes };\n\nclass Snapshot<T = unknown> implements SnapshotInterface {\n  private state: State<T>;\n  private controller: Controller;\n  readonly fetchedAt: number;\n\n  constructor(controller: Controller, state: State<T>, fetchedAt = 0) {\n    this.state = state;\n    this.controller = controller;\n    this.fetchedAt = fetchedAt;\n  }\n\n  /*************** Data Access ***************/\n  /** @see https://resthooks.io/docs/api/Snapshot#getResponse */\n  getResponse = <\n    E extends Pick<EndpointInterface, 'key' | 'schema' | 'invalidIfStale'>,\n    Args extends readonly [...Parameters<E['key']>],\n  >(\n    endpoint: E,\n    ...args: Args\n  ): {\n    data: DenormalizeNullable<E['schema']>;\n    expiryStatus: ExpiryStatus;\n    expiresAt: number;\n  } => {\n    return this.controller.getResponse(endpoint, ...args, this.state);\n  };\n\n  /** @see https://resthooks.io/docs/api/Snapshot#getError */\n  getError = <\n    E extends Pick<EndpointInterface, 'key'>,\n    Args extends readonly [...Parameters<E['key']>],\n  >(\n    endpoint: E,\n    ...args: Args\n  ): ErrorTypes | undefined => {\n    return this.controller.getError(endpoint, ...args, this.state);\n  };\n}\n"],"mappings":"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"} |
@@ -42,2 +42,2 @@ import { FETCH_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJlbmRwb2ludCIsImFyZ3MiLCJrZXkiLCJyZXNvbHZlIiwicmVqZWN0IiwicHJvbWlzZSIsIlByb21pc2UiLCJhIiwiYiIsIm1ldGEiLCJzY2hlbWEiLCJ0eXBlIiwic2lkZUVmZmVjdCIsInRocm90dGxlIiwib3B0aW9ucyIsImNyZWF0ZWRBdCIsIkRhdGUiLCJub3ciLCJ1cGRhdGUiLCJvcHRpbWlzdGljVXBkYXRlIiwib3B0aW1pc3RpY1Jlc3BvbnNlIiwicGF5bG9hZCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cm9sbGVyL2NyZWF0ZUZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW5kcG9pbnRJbnRlcmZhY2UgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi90eXBlcy5qcyc7XG5pbXBvcnQgeyBGRVRDSF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUge1xuICBDb21wYXRpYmxlRmV0Y2hBY3Rpb24sXG4gIENvbXBhdGlibGVGZXRjaE1ldGEsXG59IGZyb20gJy4uL2NvbXBhdGlibGVBY3Rpb25zLmpzJztcblxuLyoqXG4gKiBSZXF1ZXN0aW5nIGEgZmV0Y2ggdG8gYmVnaW5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlRmV0Y2g8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZSAmIHsgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPiB9LFxuPihcbiAgZW5kcG9pbnQ6IEUsXG4gIHsgYXJncyB9OiB7IGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB9LFxuKTogQ29tcGF0aWJsZUZldGNoQWN0aW9uPEU+IHtcbiAgY29uc3Qga2V5ID0gZW5kcG9pbnQua2V5KC4uLmFyZ3MpO1xuICBsZXQgcmVzb2x2ZTogKHZhbHVlPzogYW55IHwgUHJvbWlzZUxpa2U8YW55PikgPT4gdm9pZCA9IDAgYXMgYW55O1xuICBsZXQgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZTxhbnk+KChhLCBiKSA9PiB7XG4gICAgW3Jlc29sdmUsIHJlamVjdF0gPSBbYSwgYl07XG4gIH0pO1xuICBjb25zdCBtZXRhOiBDb21wYXRpYmxlRmV0Y2hNZXRhID0ge1xuICAgIHNjaGVtYTogZW5kcG9pbnQuc2NoZW1hLFxuICAgIHR5cGU6IGVuZHBvaW50LnNpZGVFZmZlY3QgPyAoJ211dGF0ZScgYXMgY29uc3QpIDogKCdyZWFkJyBhcyBjb25zdCksXG4gICAgYXJncyxcbiAgICBrZXksXG4gICAgdGhyb3R0bGU6ICFlbmRwb2ludC5zaWRlRWZmZWN0LFxuICAgIG9wdGlvbnM6IGVuZHBvaW50LFxuICAgIHJlc29sdmUsXG4gICAgcmVqZWN0LFxuICAgIHByb21pc2UsXG4gICAgY3JlYXRlZEF0OiBEYXRlLm5vdygpLFxuICB9O1xuXG4gIGlmIChlbmRwb2ludC51cGRhdGUpIHtcbiAgICBtZXRhLnVwZGF0ZSA9IGVuZHBvaW50LnVwZGF0ZTtcbiAgfVxuXG4gIC8vIFRPRE86IFJlbW92ZSBvbmNlIEVPTCBvbiB0aGlzIGRlcHJlY2F0ZWQgcGllY2VcbiAgLyogaXN0YW5idWwgaWdub3JlIGlmICovXG4gIGlmIChlbmRwb2ludC5vcHRpbWlzdGljVXBkYXRlKSB7XG4gICAgbWV0YS5vcHRpbWlzdGljUmVzcG9uc2UgPSBlbmRwb2ludC5vcHRpbWlzdGljVXBkYXRlKC4uLmFyZ3MpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBGRVRDSF9UWVBFLFxuICAgIHBheWxvYWQ6ICgpID0+IGVuZHBvaW50KC4uLmFyZ3MpIGFzIGFueSxcbiAgICBtZXRhLFxuICAgIGVuZHBvaW50LFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFHQSxTQUFTQSxVQUFVLFFBQVEsbUJBQW1CO0FBTTlDO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsV0FBV0EsQ0FHakNDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQ3JCO0VBQzFCLE1BQU1DLEdBQUcsR0FBR0YsUUFBUSxDQUFDRSxHQUFHLENBQUMsR0FBR0QsSUFBSSxDQUFDO0VBQ2pDLElBQUlFLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQXlCLEdBQUc7SUFDaENDLE1BQU0sRUFBRVYsUUFBUSxDQUFDVSxNQUFNO0lBQ3ZCQyxJQUFJLEVBQUVYLFFBQVEsQ0FBQ1ksVUFBVSxHQUFJLFFBQVEsR0FBYyxNQUFnQjtJQUNuRVgsSUFBSTtJQUNKQyxHQUFHO0lBQ0hXLFFBQVEsRUFBRSxDQUFDYixRQUFRLENBQUNZLFVBQVU7SUFDOUJFLE9BQU8sRUFBRWQsUUFBUTtJQUNqQkcsT0FBTztJQUNQQyxNQUFNO0lBQ05DLE9BQU87SUFDUFUsU0FBUyxFQUFFQyxJQUFJLENBQUNDLEdBQUc7RUFDckIsQ0FBQztFQUVELElBQUlqQixRQUFRLENBQUNrQixNQUFNLEVBQUU7SUFDbkJULElBQUksQ0FBQ1MsTUFBTSxHQUFHbEIsUUFBUSxDQUFDa0IsTUFBTTtFQUMvQjs7RUFFQTtFQUNBO0VBQ0EsSUFBSWxCLFFBQVEsQ0FBQ21CLGdCQUFnQixFQUFFO0lBQzdCVixJQUFJLENBQUNXLGtCQUFrQixHQUFHcEIsUUFBUSxDQUFDbUIsZ0JBQWdCLENBQUMsR0FBR2xCLElBQUksQ0FBQztFQUM5RDtFQUVBLE9BQU87SUFDTFUsSUFBSSxFQUFFYixVQUFVO0lBQ2hCdUIsT0FBTyxFQUFFQSxDQUFBLEtBQU1yQixRQUFRLENBQUMsR0FBR0MsSUFBSSxDQUFRO0lBQ3ZDUSxJQUFJO0lBQ0pUO0VBQ0YsQ0FBQztBQUNIIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJlbmRwb2ludCIsImFyZ3MiLCJrZXkiLCJyZXNvbHZlIiwicmVqZWN0IiwicHJvbWlzZSIsIlByb21pc2UiLCJhIiwiYiIsIm1ldGEiLCJzY2hlbWEiLCJ0eXBlIiwic2lkZUVmZmVjdCIsInRocm90dGxlIiwib3B0aW9ucyIsImNyZWF0ZWRBdCIsIkRhdGUiLCJub3ciLCJ1cGRhdGUiLCJvcHRpbWlzdGljVXBkYXRlIiwib3B0aW1pc3RpY1Jlc3BvbnNlIiwicGF5bG9hZCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250cm9sbGVyL2NyZWF0ZUZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRW5kcG9pbnRJbnRlcmZhY2UgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi90eXBlcy5qcyc7XG5pbXBvcnQgeyBGRVRDSF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUge1xuICBDb21wYXRpYmxlRmV0Y2hBY3Rpb24sXG4gIENvbXBhdGlibGVGZXRjaE1ldGEsXG59IGZyb20gJy4uL2NvbXBhdGlibGVBY3Rpb25zLmpzJztcblxuLyoqXG4gKiBSZXF1ZXN0aW5nIGEgZmV0Y2ggdG8gYmVnaW5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlRmV0Y2g8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZSAmIHsgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPiB9LFxuPihcbiAgZW5kcG9pbnQ6IEUsXG4gIHsgYXJncyB9OiB7IGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XSB9LFxuKTogQ29tcGF0aWJsZUZldGNoQWN0aW9uPEU+IHtcbiAgY29uc3Qga2V5ID0gZW5kcG9pbnQua2V5KC4uLmFyZ3MpO1xuICBsZXQgcmVzb2x2ZTogKHZhbHVlPzogYW55IHwgUHJvbWlzZUxpa2U8YW55PikgPT4gdm9pZCA9IDAgYXMgYW55O1xuICBsZXQgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZTxhbnk+KChhLCBiKSA9PiB7XG4gICAgW3Jlc29sdmUsIHJlamVjdF0gPSBbYSwgYl07XG4gIH0pO1xuICBjb25zdCBtZXRhOiBDb21wYXRpYmxlRmV0Y2hNZXRhID0ge1xuICAgIHNjaGVtYTogZW5kcG9pbnQuc2NoZW1hLFxuICAgIHR5cGU6IGVuZHBvaW50LnNpZGVFZmZlY3QgPyAoJ211dGF0ZScgYXMgY29uc3QpIDogKCdyZWFkJyBhcyBjb25zdCksXG4gICAgYXJncyxcbiAgICBrZXksXG4gICAgdGhyb3R0bGU6ICFlbmRwb2ludC5zaWRlRWZmZWN0LFxuICAgIG9wdGlvbnM6IGVuZHBvaW50LFxuICAgIHJlc29sdmUsXG4gICAgcmVqZWN0LFxuICAgIHByb21pc2UsXG4gICAgY3JlYXRlZEF0OiBEYXRlLm5vdygpLFxuICB9O1xuXG4gIGlmIChlbmRwb2ludC51cGRhdGUpIHtcbiAgICBtZXRhLnVwZGF0ZSA9IGVuZHBvaW50LnVwZGF0ZTtcbiAgfVxuXG4gIC8vIFRPRE86IFJlbW92ZSBvbmNlIEVPTCBvbiB0aGlzIGRlcHJlY2F0ZWQgcGllY2VcbiAgLyogaXN0YW5idWwgaWdub3JlIGlmICovXG4gIGlmIChlbmRwb2ludC5vcHRpbWlzdGljVXBkYXRlKSB7XG4gICAgbWV0YS5vcHRpbWlzdGljUmVzcG9uc2UgPSBlbmRwb2ludC5vcHRpbWlzdGljVXBkYXRlKC4uLmFyZ3MpO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBGRVRDSF9UWVBFLFxuICAgIHBheWxvYWQ6ICgpID0+IGVuZHBvaW50KC4uLmFyZ3MpIGFzIGFueSxcbiAgICBtZXRhLFxuICAgIGVuZHBvaW50LFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFHQSxTQUFTQSxVQUFVLFFBQVEsbUJBQW1CO0FBTTlDO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsV0FBV0EsQ0FHakNDLFFBQVcsRUFDWDtFQUFFQztBQUE0QyxDQUFDLEVBQ3JCO0VBQzFCLE1BQU1DLEdBQUcsR0FBR0YsUUFBUSxDQUFDRSxHQUFHLENBQUMsR0FBR0QsSUFBSSxDQUFDO0VBQ2pDLElBQUlFLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQXlCLEdBQUc7SUFDaENDLE1BQU0sRUFBRVYsUUFBUSxDQUFDVSxNQUFNO0lBQ3ZCQyxJQUFJLEVBQUVYLFFBQVEsQ0FBQ1ksVUFBVSxHQUFJLFFBQVEsR0FBYyxNQUFnQjtJQUNuRVgsSUFBSTtJQUNKQyxHQUFHO0lBQ0hXLFFBQVEsRUFBRSxDQUFDYixRQUFRLENBQUNZLFVBQVU7SUFDOUJFLE9BQU8sRUFBRWQsUUFBUTtJQUNqQkcsT0FBTztJQUNQQyxNQUFNO0lBQ05DLE9BQU87SUFDUFUsU0FBUyxFQUFFQyxJQUFJLENBQUNDLEdBQUcsQ0FBQztFQUN0QixDQUFDO0VBRUQsSUFBSWpCLFFBQVEsQ0FBQ2tCLE1BQU0sRUFBRTtJQUNuQlQsSUFBSSxDQUFDUyxNQUFNLEdBQUdsQixRQUFRLENBQUNrQixNQUFNO0VBQy9COztFQUVBO0VBQ0E7RUFDQSxJQUFJbEIsUUFBUSxDQUFDbUIsZ0JBQWdCLEVBQUU7SUFDN0JWLElBQUksQ0FBQ1csa0JBQWtCLEdBQUdwQixRQUFRLENBQUNtQixnQkFBZ0IsQ0FBQyxHQUFHbEIsSUFBSSxDQUFDO0VBQzlEO0VBRUEsT0FBTztJQUNMVSxJQUFJLEVBQUViLFVBQVU7SUFDaEJ1QixPQUFPLEVBQUVBLENBQUEsS0FBTXJCLFFBQVEsQ0FBQyxHQUFHQyxJQUFJLENBQVE7SUFDdkNRLElBQUk7SUFDSlQ7RUFDRixDQUFDO0FBQ0gifQ== |
@@ -33,2 +33,2 @@ import { OPTIMISTIC_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPUFRJTUlTVElDX1RZUEUiLCJjcmVhdGVPcHRpbWlzdGljIiwiZW5kcG9pbnQiLCJhcmdzIiwiZmV0Y2hlZEF0IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZGF0YUV4cGlyeUxlbmd0aCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwibm93IiwiRGF0ZSIsIm1ldGEiLCJkYXRlIiwiZXhwaXJlc0F0Iiwic2NoZW1hIiwia2V5IiwidXBkYXRlIiwiZXJyb3JQb2xpY3kiLCJhY3Rpb24iLCJ0eXBlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2xsZXIvY3JlYXRlT3B0aW1pc3RpYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQHJlc3QtaG9va3Mvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgRW5kcG9pbnRVcGRhdGVGdW5jdGlvbiB9IGZyb20gJy4vdHlwZXMuanMnO1xuaW1wb3J0IHsgT1BUSU1JU1RJQ19UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHsgT3B0aW1pc3RpY0FjdGlvbiB9IGZyb20gJy4uL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVPcHRpbWlzdGljPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gIH06IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl07XG4gICAgZmV0Y2hlZEF0OiBudW1iZXI7XG4gIH0sXG4pOiBPcHRpbWlzdGljQWN0aW9uPEU+IHtcbiAgY29uc3QgZXhwaXJ5TGVuZ3RoOiBudW1iZXIgPSBlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwO1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZXhwaXJ5TGVuZ3RoIDwgMCkge1xuICAgIHRocm93IG5ldyBFcnJvcignTmVnYXRpdmUgZXhwaXJ5IGxlbmd0aCBhcmUgbm90IGFsbG93ZWQuJyk7XG4gIH1cbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgLy8gVE9ETzogVXNlIGNvcnJlY3QgdHlwZSBvbmNlIHdlIG5vIGxvbmdlciBuZWVkIGJhY2tjb21wYXRcbiAgY29uc3QgbWV0YTogYW55ID0ge1xuICAgIGFyZ3MsXG4gICAgZmV0Y2hlZEF0LFxuICAgIGRhdGU6IG5vdyxcbiAgICBleHBpcmVzQXQ6IG5vdyArIGV4cGlyeUxlbmd0aCxcbiAgICAvLyBGb3IgbGVnYWN5IHN1cHBvcnQ7IFRPRE86IHJlbW92ZVxuICAgIHNjaGVtYTogZW5kcG9pbnQuc2NoZW1hLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICB9O1xuICAvLyBGb3IgbGVnYWN5IHN1cHBvcnQ7IFRPRE86IHJlbW92ZVxuICBpZiAoZW5kcG9pbnQudXBkYXRlKSBtZXRhLnVwZGF0ZSA9IGVuZHBvaW50LnVwZGF0ZTtcbiAgaWYgKGVuZHBvaW50LmVycm9yUG9saWN5KSBtZXRhLmVycm9yUG9saWN5ID0gZW5kcG9pbnQuZXJyb3JQb2xpY3k7XG5cbiAgY29uc3QgYWN0aW9uOiBPcHRpbWlzdGljQWN0aW9uPEU+ID0ge1xuICAgIHR5cGU6IE9QVElNSVNUSUNfVFlQRSxcbiAgICBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xuICByZXR1cm4gYWN0aW9uO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFHQSxTQUFTQSxlQUFlLFFBQVEsbUJBQW1CO0FBR25ELGVBQWUsU0FBU0MsZ0JBQWdCQSxDQUt0Q0MsUUFBVyxFQUNYO0VBQ0VDLElBQUk7RUFDSkM7QUFJRixDQUFDLEVBQ29CO0VBQUEsSUFBQUMscUJBQUE7RUFDckIsTUFBTUMsWUFBb0IsSUFBQUQscUJBQUEsR0FBR0gsUUFBUSxDQUFDSyxnQkFBZ0IsWUFBQUYscUJBQUEsR0FBSSxLQUFLO0VBQy9EO0VBQ0EsSUFBSUcsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlKLFlBQVksR0FBRyxDQUFDLEVBQUU7SUFDOUQsTUFBTSxJQUFJSyxLQUFLLENBQUMseUNBQXlDLENBQUM7RUFDNUQ7RUFDQSxNQUFNQyxHQUFHLEdBQUdDLElBQUksQ0FBQ0QsR0FBRyxFQUFFO0VBQ3RCO0VBQ0EsTUFBTUUsSUFBUyxHQUFHO0lBQ2hCWCxJQUFJO0lBQ0pDLFNBQVM7SUFDVFcsSUFBSSxFQUFFSCxHQUFHO0lBQ1RJLFNBQVMsRUFBRUosR0FBRyxHQUFHTixZQUFZO0lBQzdCO0lBQ0FXLE1BQU0sRUFBRWYsUUFBUSxDQUFDZSxNQUFNO0lBQ3ZCQyxHQUFHLEVBQUVoQixRQUFRLENBQUNnQixHQUFHLENBQUMsR0FBR2YsSUFBSTtFQUMzQixDQUFDO0VBQ0Q7RUFDQSxJQUFJRCxRQUFRLENBQUNpQixNQUFNLEVBQUVMLElBQUksQ0FBQ0ssTUFBTSxHQUFHakIsUUFBUSxDQUFDaUIsTUFBTTtFQUNsRCxJQUFJakIsUUFBUSxDQUFDa0IsV0FBVyxFQUFFTixJQUFJLENBQUNNLFdBQVcsR0FBR2xCLFFBQVEsQ0FBQ2tCLFdBQVc7RUFFakUsTUFBTUMsTUFBMkIsR0FBRztJQUNsQ0MsSUFBSSxFQUFFdEIsZUFBZTtJQUNyQkUsUUFBUTtJQUNSWTtFQUNGLENBQUM7RUFDRCxPQUFPTyxNQUFNO0FBQ2YifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPUFRJTUlTVElDX1RZUEUiLCJjcmVhdGVPcHRpbWlzdGljIiwiZW5kcG9pbnQiLCJhcmdzIiwiZmV0Y2hlZEF0IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZGF0YUV4cGlyeUxlbmd0aCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwibm93IiwiRGF0ZSIsIm1ldGEiLCJkYXRlIiwiZXhwaXJlc0F0Iiwic2NoZW1hIiwia2V5IiwidXBkYXRlIiwiZXJyb3JQb2xpY3kiLCJhY3Rpb24iLCJ0eXBlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2xsZXIvY3JlYXRlT3B0aW1pc3RpYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlIH0gZnJvbSAnQHJlc3QtaG9va3Mvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgRW5kcG9pbnRVcGRhdGVGdW5jdGlvbiB9IGZyb20gJy4vdHlwZXMuanMnO1xuaW1wb3J0IHsgT1BUSU1JU1RJQ19UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHsgT3B0aW1pc3RpY0FjdGlvbiB9IGZyb20gJy4uL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVPcHRpbWlzdGljPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gIH06IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl07XG4gICAgZmV0Y2hlZEF0OiBudW1iZXI7XG4gIH0sXG4pOiBPcHRpbWlzdGljQWN0aW9uPEU+IHtcbiAgY29uc3QgZXhwaXJ5TGVuZ3RoOiBudW1iZXIgPSBlbmRwb2ludC5kYXRhRXhwaXJ5TGVuZ3RoID8/IDYwMDAwO1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZXhwaXJ5TGVuZ3RoIDwgMCkge1xuICAgIHRocm93IG5ldyBFcnJvcignTmVnYXRpdmUgZXhwaXJ5IGxlbmd0aCBhcmUgbm90IGFsbG93ZWQuJyk7XG4gIH1cbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgLy8gVE9ETzogVXNlIGNvcnJlY3QgdHlwZSBvbmNlIHdlIG5vIGxvbmdlciBuZWVkIGJhY2tjb21wYXRcbiAgY29uc3QgbWV0YTogYW55ID0ge1xuICAgIGFyZ3MsXG4gICAgZmV0Y2hlZEF0LFxuICAgIGRhdGU6IG5vdyxcbiAgICBleHBpcmVzQXQ6IG5vdyArIGV4cGlyeUxlbmd0aCxcbiAgICAvLyBGb3IgbGVnYWN5IHN1cHBvcnQ7IFRPRE86IHJlbW92ZVxuICAgIHNjaGVtYTogZW5kcG9pbnQuc2NoZW1hLFxuICAgIGtleTogZW5kcG9pbnQua2V5KC4uLmFyZ3MpLFxuICB9O1xuICAvLyBGb3IgbGVnYWN5IHN1cHBvcnQ7IFRPRE86IHJlbW92ZVxuICBpZiAoZW5kcG9pbnQudXBkYXRlKSBtZXRhLnVwZGF0ZSA9IGVuZHBvaW50LnVwZGF0ZTtcbiAgaWYgKGVuZHBvaW50LmVycm9yUG9saWN5KSBtZXRhLmVycm9yUG9saWN5ID0gZW5kcG9pbnQuZXJyb3JQb2xpY3k7XG5cbiAgY29uc3QgYWN0aW9uOiBPcHRpbWlzdGljQWN0aW9uPEU+ID0ge1xuICAgIHR5cGU6IE9QVElNSVNUSUNfVFlQRSxcbiAgICBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xuICByZXR1cm4gYWN0aW9uO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFHQSxTQUFTQSxlQUFlLFFBQVEsbUJBQW1CO0FBR25ELGVBQWUsU0FBU0MsZ0JBQWdCQSxDQUt0Q0MsUUFBVyxFQUNYO0VBQ0VDLElBQUk7RUFDSkM7QUFJRixDQUFDLEVBQ29CO0VBQUEsSUFBQUMscUJBQUE7RUFDckIsTUFBTUMsWUFBb0IsSUFBQUQscUJBQUEsR0FBR0gsUUFBUSxDQUFDSyxnQkFBZ0IsWUFBQUYscUJBQUEsR0FBSSxLQUFLO0VBQy9EO0VBQ0EsSUFBSUcsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlKLFlBQVksR0FBRyxDQUFDLEVBQUU7SUFDOUQsTUFBTSxJQUFJSyxLQUFLLENBQUMseUNBQXlDLENBQUM7RUFDNUQ7RUFDQSxNQUFNQyxHQUFHLEdBQUdDLElBQUksQ0FBQ0QsR0FBRyxDQUFDLENBQUM7RUFDdEI7RUFDQSxNQUFNRSxJQUFTLEdBQUc7SUFDaEJYLElBQUk7SUFDSkMsU0FBUztJQUNUVyxJQUFJLEVBQUVILEdBQUc7SUFDVEksU0FBUyxFQUFFSixHQUFHLEdBQUdOLFlBQVk7SUFDN0I7SUFDQVcsTUFBTSxFQUFFZixRQUFRLENBQUNlLE1BQU07SUFDdkJDLEdBQUcsRUFBRWhCLFFBQVEsQ0FBQ2dCLEdBQUcsQ0FBQyxHQUFHZixJQUFJO0VBQzNCLENBQUM7RUFDRDtFQUNBLElBQUlELFFBQVEsQ0FBQ2lCLE1BQU0sRUFBRUwsSUFBSSxDQUFDSyxNQUFNLEdBQUdqQixRQUFRLENBQUNpQixNQUFNO0VBQ2xELElBQUlqQixRQUFRLENBQUNrQixXQUFXLEVBQUVOLElBQUksQ0FBQ00sV0FBVyxHQUFHbEIsUUFBUSxDQUFDa0IsV0FBVztFQUVqRSxNQUFNQyxNQUEyQixHQUFHO0lBQ2xDQyxJQUFJLEVBQUV0QixlQUFlO0lBQ3JCRSxRQUFRO0lBQ1JZO0VBQ0YsQ0FBQztFQUNELE9BQU9PLE1BQU07QUFDZiJ9 |
@@ -36,2 +36,2 @@ import { SET_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfVFlQRSIsImNyZWF0ZVJlY2VpdmUiLCJlbmRwb2ludCIsImFyZ3MiLCJmZXRjaGVkQXQiLCJyZXNwb25zZSIsImVycm9yIiwiX2VuZHBvaW50JGVycm9yRXhwaXJ5IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZXJyb3JFeHBpcnlMZW5ndGgiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiRXJyb3IiLCJub3ciLCJEYXRlIiwibWV0YSIsImRhdGUiLCJleHBpcmVzQXQiLCJzY2hlbWEiLCJrZXkiLCJ1cGRhdGUiLCJlcnJvclBvbGljeSIsImFjdGlvbiIsInR5cGUiLCJwYXlsb2FkIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2xsZXIvY3JlYXRlUmVjZWl2ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlLCBSZXNvbHZlVHlwZSB9IGZyb20gJ0ByZXN0LWhvb2tzL25vcm1hbGl6cic7XG5cbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuL3R5cGVzLmpzJztcbmltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUge1xuICBDb21wYXRpYmxlUmVjZWl2ZUFjdGlvbixcbiAgQ29tcGF0aWJsZVJlY2VpdmVNZXRhLFxufSBmcm9tICcuLi9jb21wYXRpYmxlQWN0aW9ucy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlY2VpdmU8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZSAmIHtcbiAgICB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+O1xuICB9LFxuPihcbiAgZW5kcG9pbnQ6IEUsXG4gIG9wdGlvbnM6IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl07XG4gICAgcmVzcG9uc2U6IEVycm9yO1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcjogdHJ1ZTtcbiAgfSxcbik6IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWNlaXZlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICBvcHRpb25zOiB7XG4gICAgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dO1xuICAgIHJlc3BvbnNlOiBSZXNvbHZlVHlwZTxFPjtcbiAgICBmZXRjaGVkQXQ/OiBudW1iZXI7XG4gICAgZXJyb3I/OiBmYWxzZTtcbiAgfSxcbik6IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWNlaXZlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgcmVzcG9uc2UsXG4gICAgZXJyb3IgPSBmYWxzZSxcbiAgfToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogYW55O1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcj86IGJvb2xlYW47XG4gIH0sXG4pOiBDb21wYXRpYmxlUmVjZWl2ZUFjdGlvbjxFPiB7XG4gIGNvbnN0IGV4cGlyeUxlbmd0aDogbnVtYmVyID0gZXJyb3JcbiAgICA/IGVuZHBvaW50LmVycm9yRXhwaXJ5TGVuZ3RoID8/IDEwMDBcbiAgICA6IGVuZHBvaW50LmRhdGFFeHBpcnlMZW5ndGggPz8gNjAwMDA7XG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGlmIChwcm9jZXNzLmVudi5OT0RFX0VOViA9PT0gJ2RldmVsb3BtZW50JyAmJiBleHBpcnlMZW5ndGggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBleHBpcnkgbGVuZ3RoIGFyZSBub3QgYWxsb3dlZC4nKTtcbiAgfVxuICBjb25zdCBub3cgPSBEYXRlLm5vdygpO1xuICBjb25zdCBtZXRhOiBDb21wYXRpYmxlUmVjZWl2ZU1ldGEgPSB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQ6IGZldGNoZWRBdCA/PyBub3csXG4gICAgZGF0ZTogbm93LFxuICAgIGV4cGlyZXNBdDogbm93ICsgZXhwaXJ5TGVuZ3RoLFxuICAgIC8vIEZvciBsZWdhY3kgc3VwcG9ydDsgVE9ETzogcmVtb3ZlXG4gICAgc2NoZW1hOiBlbmRwb2ludC5zY2hlbWEsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gIH07XG4gIC8vIEZvciBsZWdhY3kgc3VwcG9ydDsgVE9ETzogcmVtb3ZlXG4gIGlmIChlbmRwb2ludC51cGRhdGUpIG1ldGEudXBkYXRlID0gZW5kcG9pbnQudXBkYXRlO1xuICBpZiAoZW5kcG9pbnQuZXJyb3JQb2xpY3kpIG1ldGEuZXJyb3JQb2xpY3kgPSBlbmRwb2ludC5lcnJvclBvbGljeTtcblxuICBjb25zdCBhY3Rpb246IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+ID0ge1xuICAgIHR5cGU6IFNFVF9UWVBFLFxuICAgIHBheWxvYWQ6IHJlc3BvbnNlLFxuICAgIGVuZHBvaW50OiBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xuICBpZiAoZXJyb3IpIChhY3Rpb24gYXMgYW55KS5lcnJvciA9IHRydWU7XG4gIHJldHVybiBhY3Rpb247XG59XG4iXSwibWFwcGluZ3MiOiJBQUdBLFNBQVNBLFFBQVEsUUFBUSxtQkFBbUI7QUFrQzVDLGVBQWUsU0FBU0MsYUFBYUEsQ0FLbkNDLFFBQVcsRUFDWDtFQUNFQyxJQUFJO0VBQ0pDLFNBQVM7RUFDVEMsUUFBUTtFQUNSQyxLQUFLLEdBQUc7QUFNVixDQUFDLEVBQzJCO0VBQUEsSUFBQUMscUJBQUEsRUFBQUMscUJBQUE7RUFDNUIsTUFBTUMsWUFBb0IsR0FBR0gsS0FBSyxJQUFBQyxxQkFBQSxHQUM5QkwsUUFBUSxDQUFDUSxpQkFBaUIsWUFBQUgscUJBQUEsR0FBSSxJQUFJLElBQUFDLHFCQUFBLEdBQ2xDTixRQUFRLENBQUNTLGdCQUFnQixZQUFBSCxxQkFBQSxHQUFJLEtBQUs7RUFDdEM7RUFDQSxJQUFJSSxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsSUFBSUwsWUFBWSxHQUFHLENBQUMsRUFBRTtJQUM5RCxNQUFNLElBQUlNLEtBQUssQ0FBQyx5Q0FBeUMsQ0FBQztFQUM1RDtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLEVBQUU7RUFDdEIsTUFBTUUsSUFBMkIsR0FBRztJQUNsQ2YsSUFBSTtJQUNKQyxTQUFTLEVBQUVBLFNBQVMsV0FBVEEsU0FBUyxHQUFJWSxHQUFHO0lBQzNCRyxJQUFJLEVBQUVILEdBQUc7SUFDVEksU0FBUyxFQUFFSixHQUFHLEdBQUdQLFlBQVk7SUFDN0I7SUFDQVksTUFBTSxFQUFFbkIsUUFBUSxDQUFDbUIsTUFBTTtJQUN2QkMsR0FBRyxFQUFFcEIsUUFBUSxDQUFDb0IsR0FBRyxDQUFDLEdBQUduQixJQUFJO0VBQzNCLENBQUM7RUFDRDtFQUNBLElBQUlELFFBQVEsQ0FBQ3FCLE1BQU0sRUFBRUwsSUFBSSxDQUFDSyxNQUFNLEdBQUdyQixRQUFRLENBQUNxQixNQUFNO0VBQ2xELElBQUlyQixRQUFRLENBQUNzQixXQUFXLEVBQUVOLElBQUksQ0FBQ00sV0FBVyxHQUFHdEIsUUFBUSxDQUFDc0IsV0FBVztFQUVqRSxNQUFNQyxNQUFrQyxHQUFHO0lBQ3pDQyxJQUFJLEVBQUUxQixRQUFRO0lBQ2QyQixPQUFPLEVBQUV0QixRQUFRO0lBQ2pCSCxRQUFRLEVBQUVBLFFBQVE7SUFDbEJnQjtFQUNGLENBQUM7RUFDRCxJQUFJWixLQUFLLEVBQUdtQixNQUFNLENBQVNuQixLQUFLLEdBQUcsSUFBSTtFQUN2QyxPQUFPbUIsTUFBTTtBQUNmIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfVFlQRSIsImNyZWF0ZVJlY2VpdmUiLCJlbmRwb2ludCIsImFyZ3MiLCJmZXRjaGVkQXQiLCJyZXNwb25zZSIsImVycm9yIiwiX2VuZHBvaW50JGVycm9yRXhwaXJ5IiwiX2VuZHBvaW50JGRhdGFFeHBpcnlMIiwiZXhwaXJ5TGVuZ3RoIiwiZXJyb3JFeHBpcnlMZW5ndGgiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiRXJyb3IiLCJub3ciLCJEYXRlIiwibWV0YSIsImRhdGUiLCJleHBpcmVzQXQiLCJzY2hlbWEiLCJrZXkiLCJ1cGRhdGUiLCJlcnJvclBvbGljeSIsImFjdGlvbiIsInR5cGUiLCJwYXlsb2FkIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyb2xsZXIvY3JlYXRlUmVjZWl2ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEVuZHBvaW50SW50ZXJmYWNlLCBSZXNvbHZlVHlwZSB9IGZyb20gJ0ByZXN0LWhvb2tzL25vcm1hbGl6cic7XG5cbmltcG9ydCB7IEVuZHBvaW50VXBkYXRlRnVuY3Rpb24gfSBmcm9tICcuL3R5cGVzLmpzJztcbmltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUge1xuICBDb21wYXRpYmxlUmVjZWl2ZUFjdGlvbixcbiAgQ29tcGF0aWJsZVJlY2VpdmVNZXRhLFxufSBmcm9tICcuLi9jb21wYXRpYmxlQWN0aW9ucy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlY2VpdmU8XG4gIEUgZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZSAmIHtcbiAgICB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+O1xuICB9LFxuPihcbiAgZW5kcG9pbnQ6IEUsXG4gIG9wdGlvbnM6IHtcbiAgICBhcmdzOiByZWFkb25seSBbLi4uUGFyYW1ldGVyczxFPl07XG4gICAgcmVzcG9uc2U6IEVycm9yO1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcjogdHJ1ZTtcbiAgfSxcbik6IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWNlaXZlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICBvcHRpb25zOiB7XG4gICAgYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dO1xuICAgIHJlc3BvbnNlOiBSZXNvbHZlVHlwZTxFPjtcbiAgICBmZXRjaGVkQXQ/OiBudW1iZXI7XG4gICAgZXJyb3I/OiBmYWxzZTtcbiAgfSxcbik6IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWNlaXZlPFxuICBFIGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2UgJiB7XG4gICAgdXBkYXRlPzogRW5kcG9pbnRVcGRhdGVGdW5jdGlvbjxFPjtcbiAgfSxcbj4oXG4gIGVuZHBvaW50OiBFLFxuICB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQsXG4gICAgcmVzcG9uc2UsXG4gICAgZXJyb3IgPSBmYWxzZSxcbiAgfToge1xuICAgIGFyZ3M6IHJlYWRvbmx5IFsuLi5QYXJhbWV0ZXJzPEU+XTtcbiAgICByZXNwb25zZTogYW55O1xuICAgIGZldGNoZWRBdD86IG51bWJlcjtcbiAgICBlcnJvcj86IGJvb2xlYW47XG4gIH0sXG4pOiBDb21wYXRpYmxlUmVjZWl2ZUFjdGlvbjxFPiB7XG4gIGNvbnN0IGV4cGlyeUxlbmd0aDogbnVtYmVyID0gZXJyb3JcbiAgICA/IGVuZHBvaW50LmVycm9yRXhwaXJ5TGVuZ3RoID8/IDEwMDBcbiAgICA6IGVuZHBvaW50LmRhdGFFeHBpcnlMZW5ndGggPz8gNjAwMDA7XG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIGlmIChwcm9jZXNzLmVudi5OT0RFX0VOViA9PT0gJ2RldmVsb3BtZW50JyAmJiBleHBpcnlMZW5ndGggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBleHBpcnkgbGVuZ3RoIGFyZSBub3QgYWxsb3dlZC4nKTtcbiAgfVxuICBjb25zdCBub3cgPSBEYXRlLm5vdygpO1xuICBjb25zdCBtZXRhOiBDb21wYXRpYmxlUmVjZWl2ZU1ldGEgPSB7XG4gICAgYXJncyxcbiAgICBmZXRjaGVkQXQ6IGZldGNoZWRBdCA/PyBub3csXG4gICAgZGF0ZTogbm93LFxuICAgIGV4cGlyZXNBdDogbm93ICsgZXhwaXJ5TGVuZ3RoLFxuICAgIC8vIEZvciBsZWdhY3kgc3VwcG9ydDsgVE9ETzogcmVtb3ZlXG4gICAgc2NoZW1hOiBlbmRwb2ludC5zY2hlbWEsXG4gICAga2V5OiBlbmRwb2ludC5rZXkoLi4uYXJncyksXG4gIH07XG4gIC8vIEZvciBsZWdhY3kgc3VwcG9ydDsgVE9ETzogcmVtb3ZlXG4gIGlmIChlbmRwb2ludC51cGRhdGUpIG1ldGEudXBkYXRlID0gZW5kcG9pbnQudXBkYXRlO1xuICBpZiAoZW5kcG9pbnQuZXJyb3JQb2xpY3kpIG1ldGEuZXJyb3JQb2xpY3kgPSBlbmRwb2ludC5lcnJvclBvbGljeTtcblxuICBjb25zdCBhY3Rpb246IENvbXBhdGlibGVSZWNlaXZlQWN0aW9uPEU+ID0ge1xuICAgIHR5cGU6IFNFVF9UWVBFLFxuICAgIHBheWxvYWQ6IHJlc3BvbnNlLFxuICAgIGVuZHBvaW50OiBlbmRwb2ludCxcbiAgICBtZXRhLFxuICB9O1xuICBpZiAoZXJyb3IpIChhY3Rpb24gYXMgYW55KS5lcnJvciA9IHRydWU7XG4gIHJldHVybiBhY3Rpb247XG59XG4iXSwibWFwcGluZ3MiOiJBQUdBLFNBQVNBLFFBQVEsUUFBUSxtQkFBbUI7QUFrQzVDLGVBQWUsU0FBU0MsYUFBYUEsQ0FLbkNDLFFBQVcsRUFDWDtFQUNFQyxJQUFJO0VBQ0pDLFNBQVM7RUFDVEMsUUFBUTtFQUNSQyxLQUFLLEdBQUc7QUFNVixDQUFDLEVBQzJCO0VBQUEsSUFBQUMscUJBQUEsRUFBQUMscUJBQUE7RUFDNUIsTUFBTUMsWUFBb0IsR0FBR0gsS0FBSyxJQUFBQyxxQkFBQSxHQUM5QkwsUUFBUSxDQUFDUSxpQkFBaUIsWUFBQUgscUJBQUEsR0FBSSxJQUFJLElBQUFDLHFCQUFBLEdBQ2xDTixRQUFRLENBQUNTLGdCQUFnQixZQUFBSCxxQkFBQSxHQUFJLEtBQUs7RUFDdEM7RUFDQSxJQUFJSSxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGFBQWEsSUFBSUwsWUFBWSxHQUFHLENBQUMsRUFBRTtJQUM5RCxNQUFNLElBQUlNLEtBQUssQ0FBQyx5Q0FBeUMsQ0FBQztFQUM1RDtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLENBQUMsQ0FBQztFQUN0QixNQUFNRSxJQUEyQixHQUFHO0lBQ2xDZixJQUFJO0lBQ0pDLFNBQVMsRUFBRUEsU0FBUyxXQUFUQSxTQUFTLEdBQUlZLEdBQUc7SUFDM0JHLElBQUksRUFBRUgsR0FBRztJQUNUSSxTQUFTLEVBQUVKLEdBQUcsR0FBR1AsWUFBWTtJQUM3QjtJQUNBWSxNQUFNLEVBQUVuQixRQUFRLENBQUNtQixNQUFNO0lBQ3ZCQyxHQUFHLEVBQUVwQixRQUFRLENBQUNvQixHQUFHLENBQUMsR0FBR25CLElBQUk7RUFDM0IsQ0FBQztFQUNEO0VBQ0EsSUFBSUQsUUFBUSxDQUFDcUIsTUFBTSxFQUFFTCxJQUFJLENBQUNLLE1BQU0sR0FBR3JCLFFBQVEsQ0FBQ3FCLE1BQU07RUFDbEQsSUFBSXJCLFFBQVEsQ0FBQ3NCLFdBQVcsRUFBRU4sSUFBSSxDQUFDTSxXQUFXLEdBQUd0QixRQUFRLENBQUNzQixXQUFXO0VBRWpFLE1BQU1DLE1BQWtDLEdBQUc7SUFDekNDLElBQUksRUFBRTFCLFFBQVE7SUFDZDJCLE9BQU8sRUFBRXRCLFFBQVE7SUFDakJILFFBQVEsRUFBRUEsUUFBUTtJQUNsQmdCO0VBQ0YsQ0FBQztFQUNELElBQUlaLEtBQUssRUFBR21CLE1BQU0sQ0FBU25CLEtBQUssR0FBRyxJQUFJO0VBQ3ZDLE9BQU9tQixNQUFNO0FBQ2YifQ== |
@@ -8,2 +8,2 @@ import { RESET_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRVNFVF9UWVBFIiwiY3JlYXRlUmVzZXQiLCJ0eXBlIiwiZGF0ZSIsIkRhdGUiLCJub3ciXSwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udHJvbGxlci9jcmVhdGVSZXNldC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSRVNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBSZXNldEFjdGlvbiB9IGZyb20gJy4uL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZXNldCgpOiBSZXNldEFjdGlvbiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVTRVRfVFlQRSxcbiAgICBkYXRlOiBEYXRlLm5vdygpLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFVLFFBQVEsbUJBQW1CO0FBRzlDLGVBQWUsU0FBU0MsV0FBV0EsQ0FBQSxFQUFnQjtFQUNqRCxPQUFPO0lBQ0xDLElBQUksRUFBRUYsVUFBVTtJQUNoQkcsSUFBSSxFQUFFQyxJQUFJLENBQUNDLEdBQUc7RUFDaEIsQ0FBQztBQUNIIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRVNFVF9UWVBFIiwiY3JlYXRlUmVzZXQiLCJ0eXBlIiwiZGF0ZSIsIkRhdGUiLCJub3ciXSwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udHJvbGxlci9jcmVhdGVSZXNldC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSRVNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgeyBSZXNldEFjdGlvbiB9IGZyb20gJy4uL25ld0FjdGlvbnMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZXNldCgpOiBSZXNldEFjdGlvbiB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVTRVRfVFlQRSxcbiAgICBkYXRlOiBEYXRlLm5vdygpLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFVLFFBQVEsbUJBQW1CO0FBRzlDLGVBQWUsU0FBU0MsV0FBV0EsQ0FBQSxFQUFnQjtFQUNqRCxPQUFPO0lBQ0xDLElBQUksRUFBRUYsVUFBVTtJQUNoQkcsSUFBSSxFQUFFQyxJQUFJLENBQUNDLEdBQUcsQ0FBQztFQUNqQixDQUFDO0FBQ0gifQ== |
@@ -23,2 +23,2 @@ export default function applyManager(managers, controller) { | ||
/* These should be compatible with redux */ | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseU1hbmFnZXIiLCJtYW5hZ2VycyIsImNvbnRyb2xsZXIiLCJtYXAiLCJtYW5hZ2VyIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIiwiQVBJIiwiT2JqZWN0IiwiY3JlYXRlIiwidmFsdWUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9hcHBseU1hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBSZWR1Y2VyLCBEaXNwYXRjaCwgUmVkdWNlclN0YXRlIH0gZnJvbSAnLi4vbWlkZGxld2FyZVR5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5TWFuYWdlcihcbiAgbWFuYWdlcnM6IE1hbmFnZXJbXSxcbiAgY29udHJvbGxlcjogQ29udHJvbGxlcixcbik6IE1pZGRsZXdhcmVbXSB7XG4gIHJldHVybiBtYW5hZ2Vycy5tYXAobWFuYWdlciA9PiB7XG4gICAgY29uc3QgbWlkZGxld2FyZSA9IG1hbmFnZXIuZ2V0TWlkZGxld2FyZSgpO1xuICAgIHJldHVybiAoeyBkaXNwYXRjaCwgZ2V0U3RhdGUgfSkgPT4ge1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5kaXNwYXRjaCA9IGRpc3BhdGNoO1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5nZXRTdGF0ZSA9IGdldFN0YXRlO1xuICAgICAgLy8gdGhpcyBpcyBuZWVkZWQgZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5IGFzIHdlIGFkZGVkICdjb250cm9sbGVyJyBwcm9wIHByZXZpb3VzbHlcbiAgICAgIGNvbnN0IEFQSSA9IE9iamVjdC5jcmVhdGUoY29udHJvbGxlciwge1xuICAgICAgICBjb250cm9sbGVyOiB7IHZhbHVlOiBjb250cm9sbGVyIH0sXG4gICAgICB9KTtcbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKEFQSSk7XG4gICAgfTtcbiAgfSk7XG59XG5cbi8qIFRoZXNlIHNob3VsZCBiZSBjb21wYXRpYmxlIHdpdGggcmVkdXggKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWlkZGxld2FyZUFQSTxcbiAgUiBleHRlbmRzIFJlZHVjZXI8YW55LCBhbnk+ID0gUmVkdWNlcjxhbnksIGFueT4sXG4+IHtcbiAgZ2V0U3RhdGU6ICgpID0+IFJlZHVjZXJTdGF0ZTxSPjtcbiAgZGlzcGF0Y2g6IERpc3BhdGNoPFI+O1xufVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4+KHtcbiAgZGlzcGF0Y2gsXG59OiBNaWRkbGV3YXJlQVBJPFI+KSA9PiAobmV4dDogRGlzcGF0Y2g8Uj4pID0+IERpc3BhdGNoPFI+O1xuIl0sIm1hcHBpbmdzIjoiQUFJQSxlQUFlLFNBQVNBLFlBQVlBLENBQ2xDQyxRQUFtQixFQUNuQkMsVUFBc0IsRUFDUjtFQUNkLE9BQU9ELFFBQVEsQ0FBQ0UsR0FBRyxDQUFDQyxPQUFPLElBQUk7SUFDN0IsTUFBTUMsVUFBVSxHQUFHRCxPQUFPLENBQUNFLGFBQWEsRUFBRTtJQUMxQyxPQUFPLENBQUM7TUFBRUMsUUFBUTtNQUFFQztJQUFTLENBQUMsS0FBSztNQUNoQ04sVUFBVSxDQUFTSyxRQUFRLEdBQUdBLFFBQVE7TUFDdENMLFVBQVUsQ0FBU00sUUFBUSxHQUFHQSxRQUFRO01BQ3ZDO01BQ0EsTUFBTUMsR0FBRyxHQUFHQyxNQUFNLENBQUNDLE1BQU0sQ0FBQ1QsVUFBVSxFQUFFO1FBQ3BDQSxVQUFVLEVBQUU7VUFBRVUsS0FBSyxFQUFFVjtRQUFXO01BQ2xDLENBQUMsQ0FBQztNQUNGO01BQ0EsT0FBT0csVUFBVSxDQUFDSSxHQUFHLENBQUM7SUFDeEIsQ0FBQztFQUNILENBQUMsQ0FBQztBQUNKOztBQUVBIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseU1hbmFnZXIiLCJtYW5hZ2VycyIsImNvbnRyb2xsZXIiLCJtYXAiLCJtYW5hZ2VyIiwibWlkZGxld2FyZSIsImdldE1pZGRsZXdhcmUiLCJkaXNwYXRjaCIsImdldFN0YXRlIiwiQVBJIiwiT2JqZWN0IiwiY3JlYXRlIiwidmFsdWUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9hcHBseU1hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBSZWR1Y2VyLCBEaXNwYXRjaCwgUmVkdWNlclN0YXRlIH0gZnJvbSAnLi4vbWlkZGxld2FyZVR5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5TWFuYWdlcihcbiAgbWFuYWdlcnM6IE1hbmFnZXJbXSxcbiAgY29udHJvbGxlcjogQ29udHJvbGxlcixcbik6IE1pZGRsZXdhcmVbXSB7XG4gIHJldHVybiBtYW5hZ2Vycy5tYXAobWFuYWdlciA9PiB7XG4gICAgY29uc3QgbWlkZGxld2FyZSA9IG1hbmFnZXIuZ2V0TWlkZGxld2FyZSgpO1xuICAgIHJldHVybiAoeyBkaXNwYXRjaCwgZ2V0U3RhdGUgfSkgPT4ge1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5kaXNwYXRjaCA9IGRpc3BhdGNoO1xuICAgICAgKGNvbnRyb2xsZXIgYXMgYW55KS5nZXRTdGF0ZSA9IGdldFN0YXRlO1xuICAgICAgLy8gdGhpcyBpcyBuZWVkZWQgZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5IGFzIHdlIGFkZGVkICdjb250cm9sbGVyJyBwcm9wIHByZXZpb3VzbHlcbiAgICAgIGNvbnN0IEFQSSA9IE9iamVjdC5jcmVhdGUoY29udHJvbGxlciwge1xuICAgICAgICBjb250cm9sbGVyOiB7IHZhbHVlOiBjb250cm9sbGVyIH0sXG4gICAgICB9KTtcbiAgICAgIC8vIGNvbnRyb2xsZXIgaXMgYSBzdXBlcnNldCBvZiB0aGUgbWlkZGxld2FyZSBBUElcbiAgICAgIHJldHVybiBtaWRkbGV3YXJlKEFQSSk7XG4gICAgfTtcbiAgfSk7XG59XG5cbi8qIFRoZXNlIHNob3VsZCBiZSBjb21wYXRpYmxlIHdpdGggcmVkdXggKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWlkZGxld2FyZUFQSTxcbiAgUiBleHRlbmRzIFJlZHVjZXI8YW55LCBhbnk+ID0gUmVkdWNlcjxhbnksIGFueT4sXG4+IHtcbiAgZ2V0U3RhdGU6ICgpID0+IFJlZHVjZXJTdGF0ZTxSPjtcbiAgZGlzcGF0Y2g6IERpc3BhdGNoPFI+O1xufVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxSIGV4dGVuZHMgUmVkdWNlcjxhbnksIGFueT4+KHtcbiAgZGlzcGF0Y2gsXG59OiBNaWRkbGV3YXJlQVBJPFI+KSA9PiAobmV4dDogRGlzcGF0Y2g8Uj4pID0+IERpc3BhdGNoPFI+O1xuIl0sIm1hcHBpbmdzIjoiQUFJQSxlQUFlLFNBQVNBLFlBQVlBLENBQ2xDQyxRQUFtQixFQUNuQkMsVUFBc0IsRUFDUjtFQUNkLE9BQU9ELFFBQVEsQ0FBQ0UsR0FBRyxDQUFDQyxPQUFPLElBQUk7SUFDN0IsTUFBTUMsVUFBVSxHQUFHRCxPQUFPLENBQUNFLGFBQWEsQ0FBQyxDQUFDO0lBQzFDLE9BQU8sQ0FBQztNQUFFQyxRQUFRO01BQUVDO0lBQVMsQ0FBQyxLQUFLO01BQ2hDTixVQUFVLENBQVNLLFFBQVEsR0FBR0EsUUFBUTtNQUN0Q0wsVUFBVSxDQUFTTSxRQUFRLEdBQUdBLFFBQVE7TUFDdkM7TUFDQSxNQUFNQyxHQUFHLEdBQUdDLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDVCxVQUFVLEVBQUU7UUFDcENBLFVBQVUsRUFBRTtVQUFFVSxLQUFLLEVBQUVWO1FBQVc7TUFDbEMsQ0FBQyxDQUFDO01BQ0Y7TUFDQSxPQUFPRyxVQUFVLENBQUNJLEdBQUcsQ0FBQztJQUN4QixDQUFDO0VBQ0gsQ0FBQyxDQUFDO0FBQ0o7O0FBRUEifQ== |
@@ -74,2 +74,2 @@ var _globalThis$document; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZWR1Y2VyIiwiSEFTSU5UTCIsIkludGwiLCJERUZBVUxUX0NPTkZJRyIsIm5hbWUiLCJfZ2xvYmFsVGhpcyRkb2N1bWVudCIsImdsb2JhbFRoaXMiLCJkb2N1bWVudCIsInRpdGxlIiwiYXV0b1BhdXNlIiwic2VyaWFsaXplIiwib3B0aW9ucyIsInVuZGVmaW5lZCIsInJlcGxhY2VyIiwia2V5IiwidmFsdWUiLCJpc0Zpbml0ZSIsImVuZHNXaXRoIiwiRGF0ZVRpbWVGb3JtYXQiLCJob3VyIiwibWludXRlIiwic2Vjb25kIiwiZnJhY3Rpb25hbFNlY29uZERpZ2l0cyIsImZvcm1hdCIsIkRldlRvb2xzTWFuYWdlciIsImNvbnN0cnVjdG9yIiwiY29uZmlnIiwic2tpcExvZ2dpbmciLCJkZXZUb29scyIsIndpbmRvdyIsIl9fUkVEVVhfREVWVE9PTFNfRVhURU5TSU9OX18iLCJjb25uZWN0IiwibWlkZGxld2FyZSIsImNvbnRyb2xsZXIiLCJyZWR1Y2VyIiwibmV4dCIsImFjdGlvbiIsInJldCIsInRoZW4iLCJzdGF0ZSIsImdldFN0YXRlIiwic2VuZCIsIm9wdGltaXN0aWMiLCJyZWR1Y2UiLCJpbml0IiwiY2xlYW51cCIsImdldE1pZGRsZXdhcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9EZXZ0b29sc01hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBEZXZUb29sc0NvbmZpZyB9IGZyb20gJy4vZGV2dG9vbHNUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IE1pZGRsZXdhcmUgfSBmcm9tICcuL0xvZ291dE1hbmFnZXIuanMnO1xuaW1wb3J0IGNyZWF0ZVJlZHVjZXIgZnJvbSAnLi4vc3RhdGUvcmVkdWNlci9jcmVhdGVSZWR1Y2VyLmpzJztcbmltcG9ydCB0eXBlIHsgTWFuYWdlciwgU3RhdGUsIEFjdGlvblR5cGVzIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgdHlwZSB7IERldlRvb2xzQ29uZmlnIH07XG5cbmNvbnN0IEhBU0lOVEwgPSB0eXBlb2YgSW50bCAhPT0gJ3VuZGVmaW5lZCc7XG5jb25zdCBERUZBVUxUX0NPTkZJRyA9IHtcbiAgbmFtZTogYFJlc3QgSG9va3M6ICR7Z2xvYmFsVGhpcy5kb2N1bWVudD8udGl0bGV9YCxcbiAgYXV0b1BhdXNlOiB0cnVlLFxuICBzZXJpYWxpemU6IHtcbiAgICBvcHRpb25zOiB1bmRlZmluZWQsXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZXBsYWNlcjogSEFTSU5UTFxuICAgICAgPyAoa2V5OiBzdHJpbmcgfCBudW1iZXIgfCBzeW1ib2wsIHZhbHVlOiB1bmtub3duKSA9PiB7XG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJyAmJlxuICAgICAgICAgICAgdHlwZW9mIGtleSA9PT0gJ3N0cmluZycgJiZcbiAgICAgICAgICAgIGlzRmluaXRlKHZhbHVlKSAmJlxuICAgICAgICAgICAgKGtleSA9PT0gJ2RhdGUnIHx8IGtleS5lbmRzV2l0aCgnQXQnKSlcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIHJldHVybiBJbnRsLkRhdGVUaW1lRm9ybWF0KCdlbi1VUycsIHtcbiAgICAgICAgICAgICAgaG91cjogJ251bWVyaWMnLFxuICAgICAgICAgICAgICBtaW51dGU6ICdudW1lcmljJyxcbiAgICAgICAgICAgICAgc2Vjb25kOiAnbnVtZXJpYycsXG4gICAgICAgICAgICAgIGZyYWN0aW9uYWxTZWNvbmREaWdpdHM6IDMsXG4gICAgICAgICAgICB9KS5mb3JtYXQodmFsdWUpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH1cbiAgICAgIDogdW5kZWZpbmVkLFxuICB9LFxufTtcblxuLyoqIEludGVncmF0ZXMgd2l0aCBodHRwczovL2dpdGh1Yi5jb20vcmVkdXhqcy9yZWR1eC1kZXZ0b29sc1xuICpcbiAqIE9wdGlvbnM6IGh0dHBzOi8vZ2l0aHViLmNvbS9yZWR1eGpzL3JlZHV4LWRldnRvb2xzL2Jsb2IvbWFpbi9leHRlbnNpb24vZG9jcy9BUEkvQXJndW1lbnRzLm1kXG4gKlxuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9kb2NzL2FwaS9EZXZUb29sc01hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRGV2VG9vbHNNYW5hZ2VyIGltcGxlbWVudHMgTWFuYWdlciB7XG4gIHByb3RlY3RlZCBkZWNsYXJlIG1pZGRsZXdhcmU6IE1pZGRsZXdhcmU7XG4gIHByb3RlY3RlZCBkZWNsYXJlIGRldlRvb2xzOiB1bmRlZmluZWQgfCBhbnk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgY29uZmlnPzogRGV2VG9vbHNDb25maWcsXG4gICAgc2tpcExvZ2dpbmc/OiAoYWN0aW9uOiBBY3Rpb25UeXBlcykgPT4gYm9vbGVhbixcbiAgKSB7XG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICB0aGlzLmRldlRvb2xzID1cbiAgICAgIHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmXG4gICAgICAod2luZG93IGFzIGFueSkuX19SRURVWF9ERVZUT09MU19FWFRFTlNJT05fXyAmJlxuICAgICAgKHdpbmRvdyBhcyBhbnkpLl9fUkVEVVhfREVWVE9PTFNfRVhURU5TSU9OX18uY29ubmVjdCh7XG4gICAgICAgIC4uLkRFRkFVTFRfQ09ORklHLFxuICAgICAgICBjb25maWcsXG4gICAgICB9KTtcblxuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqL1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgaWYgKHRoaXMuZGV2VG9vbHMpIHtcbiAgICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4ge1xuICAgICAgICBjb25zdCByZWR1Y2VyID0gY3JlYXRlUmVkdWNlcihjb250cm9sbGVyIGFzIGFueSk7XG4gICAgICAgIHJldHVybiBuZXh0ID0+IGFjdGlvbiA9PiB7XG4gICAgICAgICAgY29uc3QgcmV0ID0gbmV4dChhY3Rpb24pO1xuICAgICAgICAgIHJldC50aGVuKCgpID0+IHtcbiAgICAgICAgICAgIGlmIChza2lwTG9nZ2luZz8uKGFjdGlvbikpIHJldHVybjtcbiAgICAgICAgICAgIGNvbnN0IHN0YXRlID0gY29udHJvbGxlci5nZXRTdGF0ZSgpO1xuICAgICAgICAgICAgdGhpcy5kZXZUb29scy5zZW5kKFxuICAgICAgICAgICAgICBhY3Rpb24sXG4gICAgICAgICAgICAgIHN0YXRlLm9wdGltaXN0aWMucmVkdWNlKHJlZHVjZXIsIHN0YXRlKSxcbiAgICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAgICAnUkVTVF9IT09LUycsXG4gICAgICAgICAgICApO1xuICAgICAgICAgIH0pO1xuICAgICAgICAgIHJldHVybiByZXQ7XG4gICAgICAgIH07XG4gICAgICB9O1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1pZGRsZXdhcmUgPSAoKSA9PiBuZXh0ID0+IGFjdGlvbiA9PiBuZXh0KGFjdGlvbik7XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIGluaXRpYWwgc3RhdGUgaXMgcmVhZHkgKi9cbiAgaW5pdChzdGF0ZTogU3RhdGU8YW55Pikge1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqL1xuICAgIGlmICh0aGlzLmRldlRvb2xzKSB0aGlzLmRldlRvb2xzLmluaXQoc3RhdGUpO1xuICB9XG5cbiAgLyoqIEVuc3VyZXMgYWxsIHN1YnNjcmlwdGlvbnMgYXJlIGNsZWFuZWQgdXAuICovXG4gIGNsZWFudXAoKSB7fVxuXG4gIC8qKiBBdHRhY2hlcyBNYW5hZ2VyIHRvIHN0b3JlXG4gICAqXG4gICAqL1xuICBnZXRNaWRkbGV3YXJlKCkge1xuICAgIHJldHVybiB0aGlzLm1pZGRsZXdhcmU7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IjtBQUVBLE9BQU9BLGFBQWEsTUFBTSxtQ0FBbUM7QUFLN0QsTUFBTUMsT0FBTyxHQUFH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 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZWR1Y2VyIiwiSEFTSU5UTCIsIkludGwiLCJERUZBVUxUX0NPTkZJRyIsIm5hbWUiLCJfZ2xvYmFsVGhpcyRkb2N1bWVudCIsImdsb2JhbFRoaXMiLCJkb2N1bWVudCIsInRpdGxlIiwiYXV0b1BhdXNlIiwic2VyaWFsaXplIiwib3B0aW9ucyIsInVuZGVmaW5lZCIsInJlcGxhY2VyIiwia2V5IiwidmFsdWUiLCJpc0Zpbml0ZSIsImVuZHNXaXRoIiwiRGF0ZVRpbWVGb3JtYXQiLCJob3VyIiwibWludXRlIiwic2Vjb25kIiwiZnJhY3Rpb25hbFNlY29uZERpZ2l0cyIsImZvcm1hdCIsIkRldlRvb2xzTWFuYWdlciIsImNvbnN0cnVjdG9yIiwiY29uZmlnIiwic2tpcExvZ2dpbmciLCJkZXZUb29scyIsIndpbmRvdyIsIl9fUkVEVVhfREVWVE9PTFNfRVhURU5TSU9OX18iLCJjb25uZWN0IiwibWlkZGxld2FyZSIsImNvbnRyb2xsZXIiLCJyZWR1Y2VyIiwibmV4dCIsImFjdGlvbiIsInJldCIsInRoZW4iLCJzdGF0ZSIsImdldFN0YXRlIiwic2VuZCIsIm9wdGltaXN0aWMiLCJyZWR1Y2UiLCJpbml0IiwiY2xlYW51cCIsImdldE1pZGRsZXdhcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9EZXZ0b29sc01hbmFnZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBEZXZUb29sc0NvbmZpZyB9IGZyb20gJy4vZGV2dG9vbHNUeXBlcy5qcyc7XG5pbXBvcnQgdHlwZSB7IE1pZGRsZXdhcmUgfSBmcm9tICcuL0xvZ291dE1hbmFnZXIuanMnO1xuaW1wb3J0IGNyZWF0ZVJlZHVjZXIgZnJvbSAnLi4vc3RhdGUvcmVkdWNlci9jcmVhdGVSZWR1Y2VyLmpzJztcbmltcG9ydCB0eXBlIHsgTWFuYWdlciwgU3RhdGUsIEFjdGlvblR5cGVzIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgdHlwZSB7IERldlRvb2xzQ29uZmlnIH07XG5cbmNvbnN0IEhBU0lOVEwgPSB0eXBlb2YgSW50bCAhPT0gJ3VuZGVmaW5lZCc7XG5jb25zdCBERUZBVUxUX0NPTkZJRyA9IHtcbiAgbmFtZTogYFJlc3QgSG9va3M6ICR7Z2xvYmFsVGhpcy5kb2N1bWVudD8udGl0bGV9YCxcbiAgYXV0b1BhdXNlOiB0cnVlLFxuICBzZXJpYWxpemU6IHtcbiAgICBvcHRpb25zOiB1bmRlZmluZWQsXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZXBsYWNlcjogSEFTSU5UTFxuICAgICAgPyAoa2V5OiBzdHJpbmcgfCBudW1iZXIgfCBzeW1ib2wsIHZhbHVlOiB1bmtub3duKSA9PiB7XG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJyAmJlxuICAgICAgICAgICAgdHlwZW9mIGtleSA9PT0gJ3N0cmluZycgJiZcbiAgICAgICAgICAgIGlzRmluaXRlKHZhbHVlKSAmJlxuICAgICAgICAgICAgKGtleSA9PT0gJ2RhdGUnIHx8IGtleS5lbmRzV2l0aCgnQXQnKSlcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIHJldHVybiBJbnRsLkRhdGVUaW1lRm9ybWF0KCdlbi1VUycsIHtcbiAgICAgICAgICAgICAgaG91cjogJ251bWVyaWMnLFxuICAgICAgICAgICAgICBtaW51dGU6ICdudW1lcmljJyxcbiAgICAgICAgICAgICAgc2Vjb25kOiAnbnVtZXJpYycsXG4gICAgICAgICAgICAgIGZyYWN0aW9uYWxTZWNvbmREaWdpdHM6IDMsXG4gICAgICAgICAgICB9KS5mb3JtYXQodmFsdWUpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH1cbiAgICAgIDogdW5kZWZpbmVkLFxuICB9LFxufTtcblxuLyoqIEludGVncmF0ZXMgd2l0aCBodHRwczovL2dpdGh1Yi5jb20vcmVkdXhqcy9yZWR1eC1kZXZ0b29sc1xuICpcbiAqIE9wdGlvbnM6IGh0dHBzOi8vZ2l0aHViLmNvbS9yZWR1eGpzL3JlZHV4LWRldnRvb2xzL2Jsb2IvbWFpbi9leHRlbnNpb24vZG9jcy9BUEkvQXJndW1lbnRzLm1kXG4gKlxuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9kb2NzL2FwaS9EZXZUb29sc01hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRGV2VG9vbHNNYW5hZ2VyIGltcGxlbWVudHMgTWFuYWdlciB7XG4gIHByb3RlY3RlZCBkZWNsYXJlIG1pZGRsZXdhcmU6IE1pZGRsZXdhcmU7XG4gIHByb3RlY3RlZCBkZWNsYXJlIGRldlRvb2xzOiB1bmRlZmluZWQgfCBhbnk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgY29uZmlnPzogRGV2VG9vbHNDb25maWcsXG4gICAgc2tpcExvZ2dpbmc/OiAoYWN0aW9uOiBBY3Rpb25UeXBlcykgPT4gYm9vbGVhbixcbiAgKSB7XG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICB0aGlzLmRldlRvb2xzID1cbiAgICAgIHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmXG4gICAgICAod2luZG93IGFzIGFueSkuX19SRURVWF9ERVZUT09MU19FWFRFTlNJT05fXyAmJlxuICAgICAgKHdpbmRvdyBhcyBhbnkpLl9fUkVEVVhfREVWVE9PTFNfRVhURU5TSU9OX18uY29ubmVjdCh7XG4gICAgICAgIC4uLkRFRkFVTFRfQ09ORklHLFxuICAgICAgICBjb25maWcsXG4gICAgICB9KTtcblxuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqL1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgaWYgKHRoaXMuZGV2VG9vbHMpIHtcbiAgICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4ge1xuICAgICAgICBjb25zdCByZWR1Y2VyID0gY3JlYXRlUmVkdWNlcihjb250cm9sbGVyIGFzIGFueSk7XG4gICAgICAgIHJldHVybiBuZXh0ID0+IGFjdGlvbiA9PiB7XG4gICAgICAgICAgY29uc3QgcmV0ID0gbmV4dChhY3Rpb24pO1xuICAgICAgICAgIHJldC50aGVuKCgpID0+IHtcbiAgICAgICAgICAgIGlmIChza2lwTG9nZ2luZz8uKGFjdGlvbikpIHJldHVybjtcbiAgICAgICAgICAgIGNvbnN0IHN0YXRlID0gY29udHJvbGxlci5nZXRTdGF0ZSgpO1xuICAgICAgICAgICAgdGhpcy5kZXZUb29scy5zZW5kKFxuICAgICAgICAgICAgICBhY3Rpb24sXG4gICAgICAgICAgICAgIHN0YXRlLm9wdGltaXN0aWMucmVkdWNlKHJlZHVjZXIsIHN0YXRlKSxcbiAgICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAgICAnUkVTVF9IT09LUycsXG4gICAgICAgICAgICApO1xuICAgICAgICAgIH0pO1xuICAgICAgICAgIHJldHVybiByZXQ7XG4gICAgICAgIH07XG4gICAgICB9O1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm1pZGRsZXdhcmUgPSAoKSA9PiBuZXh0ID0+IGFjdGlvbiA9PiBuZXh0KGFjdGlvbik7XG4gICAgfVxuICB9XG5cbiAgLyoqIENhbGxlZCB3aGVuIGluaXRpYWwgc3RhdGUgaXMgcmVhZHkgKi9cbiAgaW5pdChzdGF0ZTogU3RhdGU8YW55Pikge1xuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqL1xuICAgIGlmICh0aGlzLmRldlRvb2xzKSB0aGlzLmRldlRvb2xzLmluaXQoc3RhdGUpO1xuICB9XG5cbiAgLyoqIEVuc3VyZXMgYWxsIHN1YnNjcmlwdGlvbnMgYXJlIGNsZWFuZWQgdXAuICovXG4gIGNsZWFudXAoKSB7fVxuXG4gIC8qKiBBdHRhY2hlcyBNYW5hZ2VyIHRvIHN0b3JlXG4gICAqXG4gICAqL1xuICBnZXRNaWRkbGV3YXJlKCkge1xuICAgIHJldHVybiB0aGlzLm1pZGRsZXdhcmU7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IjtBQUVBLE9BQU9BLGFBQWEsTUFBTSxtQ0FBbUM7QUFLN0QsTUFBTUMsT0FBTyxHQUFH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 |
@@ -34,2 +34,2 @@ import { SET_TYPE } from '../actionTypes.js'; | ||
// this further restricts the types to be future compatible | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfVFlQRSIsIkxvZ291dE1hbmFnZXIiLCJjb25zdHJ1Y3RvciIsImhhbmRsZUxvZ291dCIsInNob3VsZExvZ291dCIsIm1pZGRsZXdhcmUiLCJjb250cm9sbGVyIiwibmV4dCIsImFjdGlvbiIsInR5cGUiLCJlcnJvciIsInBheWxvYWQiLCJjbGVhbnVwIiwiZ2V0TWlkZGxld2FyZSIsInN0YXR1cyIsInJlc2V0RW50aXJlU3RvcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9Mb2dvdXRNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB7IFVua25vd25FcnJvciB9IGZyb20gJy4uL2luZGV4LmpzJztcbmltcG9ydCB0eXBlIHsgQ29tYmluZWRBY3Rpb25UeXBlcyB9IGZyb20gJy4uL3R5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbi8qKiBIYW5kbGluZyBuZXR3b3JrIHVuYXV0aG9yaXplZCBpbmRpY2F0b3JzIGxpa2UgSFRUUCA0MDFcbiAqXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL2RvY3MvYXBpL0xvZ291dE1hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTG9nb3V0TWFuYWdlciBpbXBsZW1lbnRzIE1hbmFnZXI8Q29tYmluZWRBY3Rpb25UeXBlcz4ge1xuICBwcm90ZWN0ZWQgZGVjbGFyZSBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlO1xuXG4gIGNvbnN0cnVjdG9yKHsgaGFuZGxlTG9nb3V0LCBzaG91bGRMb2dvdXQgfTogUHJvcHMgPSB7fSkge1xuICAgIGlmIChoYW5kbGVMb2dvdXQpIHRoaXMuaGFuZGxlTG9nb3V0ID0gaGFuZGxlTG9nb3V0O1xuICAgIGlmIChzaG91bGRMb2dvdXQpIHRoaXMuc2hvdWxkTG9nb3V0ID0gc2hvdWxkTG9nb3V0O1xuICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4gbmV4dCA9PiBhc3luYyBhY3Rpb24gPT4ge1xuICAgICAgYXdhaXQgbmV4dChhY3Rpb24pO1xuICAgICAgaWYgKFxuICAgICAgICBhY3Rpb24udHlwZSA9PT0gU0VUX1RZUEUgJiZcbiAgICAgICAgYWN0aW9uLmVycm9yICYmXG4gICAgICAgIHRoaXMuc2hvdWxkTG9nb3V0KGFjdGlvbi5wYXlsb2FkKVxuICAgICAgKSB7XG4gICAgICAgIHRoaXMuaGFuZGxlTG9nb3V0KGNvbnRyb2xsZXIpO1xuICAgICAgfVxuICAgIH07XG4gIH1cblxuICBjbGVhbnVwKCkge31cblxuICBnZXRNaWRkbGV3YXJlKCkge1xuICAgIHJldHVybiB0aGlzLm1pZGRsZXdhcmU7XG4gIH1cblxuICBwcm90ZWN0ZWQgc2hvdWxkTG9nb3V0KGVycm9yOiBVbmtub3duRXJyb3IpIHtcbiAgICAvLyA0MDEgaW5kaWNhdGVzIHJlYXV0aG9yaXphdGlvbiBpcyBuZWVkZWRcbiAgICByZXR1cm4gZXJyb3Iuc3RhdHVzID09PSA0MDE7XG4gIH1cblxuICBoYW5kbGVMb2dvdXQoY29udHJvbGxlcjogQ29udHJvbGxlcjxEaXNwYXRjaD4pIHtcbiAgICBjb250cm9sbGVyLnJlc2V0RW50aXJlU3RvcmUoKTtcbiAgfVxufVxuXG50eXBlIERpc3BhdGNoID0gKHZhbHVlOiBDb21iaW5lZEFjdGlvblR5cGVzKSA9PiBQcm9taXNlPHZvaWQ+O1xuXG4vLyB0aGlzIGZ1cnRoZXIgcmVzdHJpY3RzIHRoZSB0eXBlcyB0byBiZSBmdXR1cmUgY29tcGF0aWJsZVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxDIGV4dGVuZHMgQ29udHJvbGxlcjxEaXNwYXRjaD4+KFxuICBjb250cm9sbGVyOiBDLFxuKSA9PiAobmV4dDogQ1snZGlzcGF0Y2gnXSkgPT4gQ1snZGlzcGF0Y2gnXTtcblxudHlwZSBIYW5kbGVMb2dvdXQgPSAoY29udHJvbGxlcjogQ29udHJvbGxlcjxEaXNwYXRjaD4pID0+IHZvaWQ7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGhhbmRsZUxvZ291dD86IEhhbmRsZUxvZ291dDtcbiAgc2hvdWxkTG9nb3V0PzogKGVycm9yOiBVbmtub3duRXJyb3IpID0+IGJvb2xlYW47XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFFBQVEsUUFBUSxtQkFBbUI7QUFNNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLE1BQU1DLGFBQWEsQ0FBeUM7RUFHekVDLFdBQVdBLENBQUM7SUFBRUMsWUFBWTtJQUFFQztFQUFvQixDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUU7SUFDdEQsSUFBSUQsWUFBWSxFQUFFLElBQUksQ0FBQ0EsWUFBWSxHQUFHQSxZQUFZO0lBQ2xELElBQUlDLFlBQVksRUFBRSxJQUFJLENBQUNBLFlBQVksR0FBR0EsWUFBWTtJQUNsRCxJQUFJLENBQUNDLFVBQVUsR0FBR0MsVUFBVSxJQUFJQyxJQUFJLElBQUksTUFBTUMsTUFBTSxJQUFJO01BQ3RELE1BQU1ELElBQUksQ0FBQ0MsTUFBTSxDQUFDO01BQ2xCLElBQ0VBLE1BQU0sQ0FBQ0MsSUFBSSxLQUFLVCxRQUFRLElBQ3hCUSxNQUFNLENBQUNFLEtBQUssSUFDWixJQUFJLENBQUNOLFlBQVksQ0FBQ0ksTUFBTSxDQUFDRyxPQUFPLENBQUMsRUFDakM7UUFDQSxJQUFJLENBQUNSLFlBQVksQ0FBQ0csVUFBVSxDQUFDO01BQy9CO0lBQ0YsQ0FBQztFQUNIO0VBRUFNLE9BQU9BLENBQUEsRUFBRyxDQUFDO0VBRVhDLGFBQWFBLENBQUEsRUFBRztJQUNkLE9BQU8sSUFBSSxDQUFDUixVQUFVO0VBQ3hCO0VBRVVELFlBQVlBLENBQUNNLEtBQW1CLEVBQUU7SUFDMUM7SUFDQSxPQUFPQSxLQUFLLENBQUNJLE1BQU0sS0FBSyxHQUFHO0VBQzdCO0VBRUFYLFlBQVlBLENBQUNHLFVBQWdDLEVBQUU7SUFDN0NBLFVBQVUsQ0FBQ1MsZ0JBQWdCLEVBQUU7RUFDL0I7QUFDRjs7QUFJQSJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTRVRfVFlQRSIsIkxvZ291dE1hbmFnZXIiLCJjb25zdHJ1Y3RvciIsImhhbmRsZUxvZ291dCIsInNob3VsZExvZ291dCIsIm1pZGRsZXdhcmUiLCJjb250cm9sbGVyIiwibmV4dCIsImFjdGlvbiIsInR5cGUiLCJlcnJvciIsInBheWxvYWQiLCJjbGVhbnVwIiwiZ2V0TWlkZGxld2FyZSIsInN0YXR1cyIsInJlc2V0RW50aXJlU3RvcmUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFuYWdlci9Mb2dvdXRNYW5hZ2VyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNFVF9UWVBFIH0gZnJvbSAnLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IENvbnRyb2xsZXIgZnJvbSAnLi4vY29udHJvbGxlci9Db250cm9sbGVyLmpzJztcbmltcG9ydCB7IFVua25vd25FcnJvciB9IGZyb20gJy4uL2luZGV4LmpzJztcbmltcG9ydCB0eXBlIHsgQ29tYmluZWRBY3Rpb25UeXBlcyB9IGZyb20gJy4uL3R5cGVzLmpzJztcbmltcG9ydCB7IE1hbmFnZXIgfSBmcm9tICcuLi90eXBlcy5qcyc7XG5cbi8qKiBIYW5kbGluZyBuZXR3b3JrIHVuYXV0aG9yaXplZCBpbmRpY2F0b3JzIGxpa2UgSFRUUCA0MDFcbiAqXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL2RvY3MvYXBpL0xvZ291dE1hbmFnZXJcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTG9nb3V0TWFuYWdlciBpbXBsZW1lbnRzIE1hbmFnZXI8Q29tYmluZWRBY3Rpb25UeXBlcz4ge1xuICBwcm90ZWN0ZWQgZGVjbGFyZSBtaWRkbGV3YXJlOiBNaWRkbGV3YXJlO1xuXG4gIGNvbnN0cnVjdG9yKHsgaGFuZGxlTG9nb3V0LCBzaG91bGRMb2dvdXQgfTogUHJvcHMgPSB7fSkge1xuICAgIGlmIChoYW5kbGVMb2dvdXQpIHRoaXMuaGFuZGxlTG9nb3V0ID0gaGFuZGxlTG9nb3V0O1xuICAgIGlmIChzaG91bGRMb2dvdXQpIHRoaXMuc2hvdWxkTG9nb3V0ID0gc2hvdWxkTG9nb3V0O1xuICAgIHRoaXMubWlkZGxld2FyZSA9IGNvbnRyb2xsZXIgPT4gbmV4dCA9PiBhc3luYyBhY3Rpb24gPT4ge1xuICAgICAgYXdhaXQgbmV4dChhY3Rpb24pO1xuICAgICAgaWYgKFxuICAgICAgICBhY3Rpb24udHlwZSA9PT0gU0VUX1RZUEUgJiZcbiAgICAgICAgYWN0aW9uLmVycm9yICYmXG4gICAgICAgIHRoaXMuc2hvdWxkTG9nb3V0KGFjdGlvbi5wYXlsb2FkKVxuICAgICAgKSB7XG4gICAgICAgIHRoaXMuaGFuZGxlTG9nb3V0KGNvbnRyb2xsZXIpO1xuICAgICAgfVxuICAgIH07XG4gIH1cblxuICBjbGVhbnVwKCkge31cblxuICBnZXRNaWRkbGV3YXJlKCkge1xuICAgIHJldHVybiB0aGlzLm1pZGRsZXdhcmU7XG4gIH1cblxuICBwcm90ZWN0ZWQgc2hvdWxkTG9nb3V0KGVycm9yOiBVbmtub3duRXJyb3IpIHtcbiAgICAvLyA0MDEgaW5kaWNhdGVzIHJlYXV0aG9yaXphdGlvbiBpcyBuZWVkZWRcbiAgICByZXR1cm4gZXJyb3Iuc3RhdHVzID09PSA0MDE7XG4gIH1cblxuICBoYW5kbGVMb2dvdXQoY29udHJvbGxlcjogQ29udHJvbGxlcjxEaXNwYXRjaD4pIHtcbiAgICBjb250cm9sbGVyLnJlc2V0RW50aXJlU3RvcmUoKTtcbiAgfVxufVxuXG50eXBlIERpc3BhdGNoID0gKHZhbHVlOiBDb21iaW5lZEFjdGlvblR5cGVzKSA9PiBQcm9taXNlPHZvaWQ+O1xuXG4vLyB0aGlzIGZ1cnRoZXIgcmVzdHJpY3RzIHRoZSB0eXBlcyB0byBiZSBmdXR1cmUgY29tcGF0aWJsZVxuZXhwb3J0IHR5cGUgTWlkZGxld2FyZSA9IDxDIGV4dGVuZHMgQ29udHJvbGxlcjxEaXNwYXRjaD4+KFxuICBjb250cm9sbGVyOiBDLFxuKSA9PiAobmV4dDogQ1snZGlzcGF0Y2gnXSkgPT4gQ1snZGlzcGF0Y2gnXTtcblxudHlwZSBIYW5kbGVMb2dvdXQgPSAoY29udHJvbGxlcjogQ29udHJvbGxlcjxEaXNwYXRjaD4pID0+IHZvaWQ7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGhhbmRsZUxvZ291dD86IEhhbmRsZUxvZ291dDtcbiAgc2hvdWxkTG9nb3V0PzogKGVycm9yOiBVbmtub3duRXJyb3IpID0+IGJvb2xlYW47XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFFBQVEsUUFBUSxtQkFBbUI7QUFNNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLE1BQU1DLGFBQWEsQ0FBeUM7RUFHekVDLFdBQVdBLENBQUM7SUFBRUMsWUFBWTtJQUFFQztFQUFvQixDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUU7SUFDdEQsSUFBSUQsWUFBWSxFQUFFLElBQUksQ0FBQ0EsWUFBWSxHQUFHQSxZQUFZO0lBQ2xELElBQUlDLFlBQVksRUFBRSxJQUFJLENBQUNBLFlBQVksR0FBR0EsWUFBWTtJQUNsRCxJQUFJLENBQUNDLFVBQVUsR0FBR0MsVUFBVSxJQUFJQyxJQUFJLElBQUksTUFBTUMsTUFBTSxJQUFJO01BQ3RELE1BQU1ELElBQUksQ0FBQ0MsTUFBTSxDQUFDO01BQ2xCLElBQ0VBLE1BQU0sQ0FBQ0MsSUFBSSxLQUFLVCxRQUFRLElBQ3hCUSxNQUFNLENBQUNFLEtBQUssSUFDWixJQUFJLENBQUNOLFlBQVksQ0FBQ0ksTUFBTSxDQUFDRyxPQUFPLENBQUMsRUFDakM7UUFDQSxJQUFJLENBQUNSLFlBQVksQ0FBQ0csVUFBVSxDQUFDO01BQy9CO0lBQ0YsQ0FBQztFQUNIO0VBRUFNLE9BQU9BLENBQUEsRUFBRyxDQUFDO0VBRVhDLGFBQWFBLENBQUEsRUFBRztJQUNkLE9BQU8sSUFBSSxDQUFDUixVQUFVO0VBQ3hCO0VBRVVELFlBQVlBLENBQUNNLEtBQW1CLEVBQUU7SUFDMUM7SUFDQSxPQUFPQSxLQUFLLENBQUNJLE1BQU0sS0FBSyxHQUFHO0VBQzdCO0VBRUFYLFlBQVlBLENBQUNHLFVBQWdDLEVBQUU7SUFDN0NBLFVBQVUsQ0FBQ1MsZ0JBQWdCLENBQUMsQ0FBQztFQUMvQjtBQUNGOztBQUlBIn0= |
@@ -295,2 +295,2 @@ import { SET_TYPE, FETCH_TYPE, RESET_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SET_TYPE","FETCH_TYPE","RESET_TYPE","Controller","initialState","createReceive","createReceiveError","RIC","ResetError","Error","constructor","name","NetworkManager","dataExpiryLength","errorExpiryLength","fetched","Object","create","resolvers","rejectors","fetchedAt","getState","controller","middleware","dispatch","next","action","_action$endpoint","type","handleFetch","meta","optimisticResponse","undefined","endpoint","getOptimisticResponse","Promise","resolve","then","key","_controller$getState$","error","handleReceive","clearAll","k","skipLogging","init","cleanupDate","cleanup","Date","now","allSettled","fetches","values","length","clear","catch","getLastReset","lastReset","valueOf","Infinity","fetch","payload","throttle","reject","createdAt","getTime","deferedFetch","promise","resolvePromise","data","process","env","NODE_ENV","isNaN","console","args","response","_action$meta$options$","_action$meta$options","options","_action$meta$options$2","_action$meta$options2","promiseHandler","getMiddleware","timeout"],"sources":["../../src/manager/NetworkManager.ts"],"sourcesContent":["import { SET_TYPE, FETCH_TYPE, RESET_TYPE } from '../actionTypes.js';\nimport Controller from '../controller/Controller.js';\nimport { initialState } from '../internal.js';\nimport {\n  createReceive,\n  createReceiveError,\n} from '../state/legacy-actions/index.js';\nimport RIC from '../state/RIC.js';\nimport type {\n  FetchAction,\n  ReceiveAction,\n  Manager,\n  ActionTypes,\n  MiddlewareAPI,\n  Middleware,\n  State,\n} from '../types.js';\n\nexport class ResetError extends Error {\n  name = 'ResetError';\n\n  constructor() {\n    super('Aborted due to RESET');\n  }\n}\n\n/** Handles all async network dispatches\n *\n * Dedupes concurrent requests by keeping track of all fetches in flight\n * and returning existing promises for requests already in flight.\n *\n * Interfaces with store via a redux-compatible middleware.\n *\n * @see https://resthooks.io/docs/api/NetworkManager\n */\nexport default class NetworkManager implements Manager {\n  protected fetched: { [k: string]: Promise<any> } = Object.create(null);\n  protected resolvers: { [k: string]: (value?: any) => void } = {};\n  protected rejectors: { [k: string]: (value?: any) => void } = {};\n  protected fetchedAt: { [k: string]: number } = {};\n  declare readonly dataExpiryLength: number;\n  declare readonly errorExpiryLength: number;\n  protected declare middleware: Middleware;\n  protected getState: () => State<unknown> = () => initialState;\n  protected controller: Controller = new Controller();\n  declare cleanupDate?: number;\n\n  constructor(dataExpiryLength = 60000, errorExpiryLength = 1000) {\n    this.dataExpiryLength = dataExpiryLength;\n    this.errorExpiryLength = errorExpiryLength;\n\n    this.middleware = <C extends MiddlewareAPI>({\n      dispatch,\n      getState,\n      controller,\n    }: C) => {\n      this.getState = getState;\n      this.controller = controller;\n      return (next: C['dispatch']): C['dispatch'] =>\n        (action): Promise<void> => {\n          switch (action.type) {\n            case FETCH_TYPE:\n              this.handleFetch(action, dispatch, controller);\n              // This is the only case that causes any state change\n              // It's important to intercept other fetches as we don't want to trigger reducers during\n              // render - so we need to stop 'readonly' fetches which can be triggered in render\n              if (\n                action.meta.optimisticResponse !== undefined ||\n                action.endpoint?.getOptimisticResponse !== undefined\n              ) {\n                return next(action);\n              }\n              return Promise.resolve();\n            case SET_TYPE:\n              // only receive after new state is computed\n              return next(action).then(() => {\n                if (action.meta.key in this.fetched) {\n                  // Note: meta *must* be set by reducer so this should be safe\n                  const error =\n                    controller.getState().meta[action.meta.key]?.error;\n                  // processing errors result in state meta having error, so we should reject the promise\n                  if (error) {\n                    // TODO: use only new action types\n                    this.handleReceive(createReceiveError(error, action.meta));\n                  } else {\n                    this.handleReceive(action);\n                  }\n                }\n              });\n            case RESET_TYPE: {\n              const rejectors = { ...this.rejectors };\n\n              this.clearAll();\n              return next(action).then(() => {\n                // there could be external listeners to the promise\n                // this must happen after commit so our own rejector knows not to dispatch an error based on this\n                for (const k in rejectors) {\n                  rejectors[k](new ResetError());\n                }\n              });\n            }\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Used by DevtoolsManager to determine whether to log an action */\n  skipLogging(action: ActionTypes) {\n    /* istanbul ignore next */\n    return action.type === FETCH_TYPE && action.meta.key in this.fetched;\n  }\n\n  /** On mount */\n  init() {\n    delete this.cleanupDate;\n  }\n\n  /** Ensures all promises are completed by rejecting remaining. */\n  cleanup() {\n    // ensure no dispatches after unmount\n    // this must be reversible (done in init) so useEffect() remains symmetric\n    this.cleanupDate = Date.now();\n  }\n\n  allSettled() {\n    const fetches = Object.values(this.fetched);\n    if (fetches.length) return Promise.allSettled(fetches);\n  }\n\n  /** Clear all promise state */\n  protected clearAll() {\n    for (const k in this.rejectors) {\n      this.clear(k);\n    }\n  }\n\n  /** Clear promise state for a given key */\n  protected clear(key: string) {\n    this.fetched[key].catch(() => {});\n    delete this.resolvers[key];\n    delete this.rejectors[key];\n    delete this.fetched[key];\n    delete this.fetchedAt[key];\n  }\n\n  protected getLastReset() {\n    if (this.cleanupDate) return this.cleanupDate;\n    const lastReset = this.controller.getState().lastReset;\n    if (lastReset instanceof Date) return lastReset.valueOf();\n    if (typeof lastReset !== 'number') return -Infinity;\n    return lastReset;\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/fetch' action.\n   *\n   * Will then start a promise for a key and potentially start the network\n   * fetch.\n   *\n   * Uses throttle only when instructed by action meta. This is valuable\n   * for ensures mutation requests always go through.\n   */\n  protected handleFetch(\n    action: FetchAction,\n    dispatch: (action: any) => Promise<void>,\n    controller: Controller,\n  ) {\n    const fetch = action.payload;\n    const { key, throttle, resolve, reject } = action.meta;\n    // TODO(breaking): remove support for Date type in 'Receive' action\n    const createdAt =\n      typeof action.meta.createdAt !== 'number'\n        ? action.meta.createdAt.getTime()\n        : action.meta.createdAt;\n\n    const deferedFetch = () => {\n      let promise = fetch();\n      const resolvePromise = (\n        promise: Promise<string | number | object | null>,\n      ) =>\n        promise\n          .then(data => {\n            resolve(data);\n            return data;\n          })\n          .catch(error => {\n            reject(error);\n            throw error;\n          });\n      // schedule non-throttled resolutions in a microtask before receive\n      // this enables users awaiting their fetch to trigger any react updates needed to deal\n      // with upcoming changes because of the fetch (for instance avoiding suspense if something is deleted)\n      if (!throttle && action.endpoint) {\n        promise = resolvePromise(promise);\n      }\n      promise = promise\n        .then(data => {\n          let lastReset = this.getLastReset();\n\n          /* istanbul ignore else */\n          if (process.env.NODE_ENV !== 'production' && isNaN(lastReset)) {\n            console.error(\n              'state.lastReset is NaN. Only positive timestamps are valid.',\n            );\n            lastReset = 0;\n          }\n\n          // don't update state with promises started before last clear\n          if (createdAt >= lastReset) {\n            // we still check for controller in case someone didn't have type protection since this didn't always exist\n            if (action.endpoint && this.controller) {\n              this.controller.resolve(action.endpoint, {\n                args: action.meta.args as any,\n                response: data,\n                fetchedAt: createdAt,\n              });\n            } else {\n              // TODO(breaking): is this branch still possible? remove in next major update\n              // does this throw if the reducer fails? - no because reducer is wrapped in try/catch\n              this.controller.dispatch(\n                createReceive(data, {\n                  ...action.meta,\n                  fetchedAt: createdAt,\n                  dataExpiryLength:\n                    action.meta.options?.dataExpiryLength ??\n                    this.dataExpiryLength,\n                }),\n              );\n            }\n          }\n          return data;\n        })\n        .catch(error => {\n          const lastReset = this.getLastReset();\n          // don't update state with promises started before last clear\n          if (createdAt >= lastReset) {\n            if (action.endpoint && this.controller) {\n              this.controller.resolve(action.endpoint, {\n                args: action.meta.args as any,\n                response: error,\n                fetchedAt: createdAt,\n                error: true,\n              });\n            } else {\n              this.controller.dispatch(\n                createReceiveError(error, {\n                  ...action.meta,\n                  errorExpiryLength:\n                    action.meta.options?.errorExpiryLength ??\n                    this.errorExpiryLength,\n                  fetchedAt: createdAt,\n                }),\n              );\n            }\n          }\n          throw error;\n        });\n      // legacy behavior schedules resolution after dispatch\n      if (!throttle && !action.endpoint) {\n        promise = resolvePromise(promise);\n      }\n      return promise;\n    };\n\n    if (throttle) {\n      return this.throttle(key, deferedFetch, createdAt)\n        .then(data => resolve(data))\n        .catch(error => reject(error));\n    } else {\n      return deferedFetch().catch(() => {});\n    }\n  }\n\n  /** Called when middleware intercepts a receive action.\n   *\n   * Will resolve the promise associated with receive key.\n   */\n  protected handleReceive(action: ReceiveAction) {\n    // this can still turn out to be untrue since this is async\n    if (action.meta.key in this.fetched) {\n      let promiseHandler: (value?: any) => void;\n      if (action.error) {\n        promiseHandler = this.rejectors[action.meta.key];\n      } else {\n        promiseHandler = this.resolvers[action.meta.key];\n      }\n      promiseHandler(action.payload);\n      // since we're resolved we no longer need to keep track of this promise\n      this.clear(action.meta.key);\n    }\n  }\n\n  /** Attaches NetworkManager to store\n   *\n   * Intercepts 'rest-hooks/fetch' actions to start requests.\n   *\n   * Resolve/rejects a request when matching 'rest-hooks/receive' event\n   * is seen.\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n\n  /** Ensures only one request for a given key is in flight at any time\n   *\n   * Uses key to either retrieve in-flight promise, or if not\n   * create a new promise and call fetch.\n   *\n   * Note: The new promise is not actually tied to fetch at all,\n   * but is resolved when the expected 'recieve' action is processed.\n   * This ensures promises are resolved only once their data is processed\n   * by the reducer.\n   */\n  protected throttle(\n    key: string,\n    fetch: () => Promise<any>,\n    createdAt: number,\n  ) {\n    const lastReset = this.getLastReset();\n    // we're already fetching so reuse the promise\n    // fetches after reset do not count\n    if (key in this.fetched && this.fetchedAt[key] > lastReset) {\n      return this.fetched[key];\n    }\n\n    this.fetched[key] = new Promise((resolve, reject) => {\n      this.resolvers[key] = resolve;\n      this.rejectors[key] = reject;\n    });\n    this.fetchedAt[key] = createdAt;\n\n    // since our real promise is resolved via the wrapReducer(),\n    // we should just stop all errors here.\n    // TODO: decouple this from useFetcher() (that's what's dispatching the error the resolves in here)\n    RIC(\n      () => {\n        fetch().catch(() => null);\n      },\n      { timeout: 500 },\n    );\n\n    return this.fetched[key];\n  }\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SET_TYPE","FETCH_TYPE","RESET_TYPE","Controller","initialState","createReceive","createReceiveError","RIC","ResetError","Error","constructor","name","NetworkManager","dataExpiryLength","errorExpiryLength","fetched","Object","create","resolvers","rejectors","fetchedAt","getState","controller","middleware","dispatch","next","action","_action$endpoint","type","handleFetch","meta","optimisticResponse","undefined","endpoint","getOptimisticResponse","Promise","resolve","then","key","_controller$getState$","error","handleReceive","clearAll","k","skipLogging","init","cleanupDate","cleanup","Date","now","allSettled","fetches","values","length","clear","catch","getLastReset","lastReset","valueOf","Infinity","fetch","payload","throttle","reject","createdAt","getTime","deferedFetch","promise","resolvePromise","data","process","env","NODE_ENV","isNaN","console","args","response","_action$meta$options$","_action$meta$options","options","_action$meta$options$2","_action$meta$options2","promiseHandler","getMiddleware","timeout"],"sources":["../../src/manager/NetworkManager.ts"],"sourcesContent":["import { SET_TYPE, FETCH_TYPE, RESET_TYPE } from '../actionTypes.js';\nimport Controller from '../controller/Controller.js';\nimport { initialState } from '../internal.js';\nimport {\n  createReceive,\n  createReceiveError,\n} from '../state/legacy-actions/index.js';\nimport RIC from '../state/RIC.js';\nimport type {\n  FetchAction,\n  ReceiveAction,\n  Manager,\n  ActionTypes,\n  MiddlewareAPI,\n  Middleware,\n  State,\n} from '../types.js';\n\nexport class ResetError extends Error {\n  name = 'ResetError';\n\n  constructor() {\n    super('Aborted due to RESET');\n  }\n}\n\n/** Handles all async network dispatches\n *\n * Dedupes concurrent requests by keeping track of all fetches in flight\n * and returning existing promises for requests already in flight.\n *\n * Interfaces with store via a redux-compatible middleware.\n *\n * @see https://resthooks.io/docs/api/NetworkManager\n */\nexport default class NetworkManager implements Manager {\n  protected fetched: { [k: string]: Promise<any> } = Object.create(null);\n  protected resolvers: { [k: string]: (value?: any) => void } = {};\n  protected rejectors: { [k: string]: (value?: any) => void } = {};\n  protected fetchedAt: { [k: string]: number } = {};\n  declare readonly dataExpiryLength: number;\n  declare readonly errorExpiryLength: number;\n  protected declare middleware: Middleware;\n  protected getState: () => State<unknown> = () => initialState;\n  protected controller: Controller = new Controller();\n  declare cleanupDate?: number;\n\n  constructor(dataExpiryLength = 60000, errorExpiryLength = 1000) {\n    this.dataExpiryLength = dataExpiryLength;\n    this.errorExpiryLength = errorExpiryLength;\n\n    this.middleware = <C extends MiddlewareAPI>({\n      dispatch,\n      getState,\n      controller,\n    }: C) => {\n      this.getState = getState;\n      this.controller = controller;\n      return (next: C['dispatch']): C['dispatch'] =>\n        (action): Promise<void> => {\n          switch (action.type) {\n            case FETCH_TYPE:\n              this.handleFetch(action, dispatch, controller);\n              // This is the only case that causes any state change\n              // It's important to intercept other fetches as we don't want to trigger reducers during\n              // render - so we need to stop 'readonly' fetches which can be triggered in render\n              if (\n                action.meta.optimisticResponse !== undefined ||\n                action.endpoint?.getOptimisticResponse !== undefined\n              ) {\n                return next(action);\n              }\n              return Promise.resolve();\n            case SET_TYPE:\n              // only receive after new state is computed\n              return next(action).then(() => {\n                if (action.meta.key in this.fetched) {\n                  // Note: meta *must* be set by reducer so this should be safe\n                  const error =\n                    controller.getState().meta[action.meta.key]?.error;\n                  // processing errors result in state meta having error, so we should reject the promise\n                  if (error) {\n                    // TODO: use only new action types\n                    this.handleReceive(createReceiveError(error, action.meta));\n                  } else {\n                    this.handleReceive(action);\n                  }\n                }\n              });\n            case RESET_TYPE: {\n              const rejectors = { ...this.rejectors };\n\n              this.clearAll();\n              return next(action).then(() => {\n                // there could be external listeners to the promise\n                // this must happen after commit so our own rejector knows not to dispatch an error based on this\n                for (const k in rejectors) {\n                  rejectors[k](new ResetError());\n                }\n              });\n            }\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Used by DevtoolsManager to determine whether to log an action */\n  skipLogging(action: ActionTypes) {\n    /* istanbul ignore next */\n    return action.type === FETCH_TYPE && action.meta.key in this.fetched;\n  }\n\n  /** On mount */\n  init() {\n    delete this.cleanupDate;\n  }\n\n  /** Ensures all promises are completed by rejecting remaining. */\n  cleanup() {\n    // ensure no dispatches after unmount\n    // this must be reversible (done in init) so useEffect() remains symmetric\n    this.cleanupDate = Date.now();\n  }\n\n  allSettled() {\n    const fetches = Object.values(this.fetched);\n    if (fetches.length) return Promise.allSettled(fetches);\n  }\n\n  /** Clear all promise state */\n  protected clearAll() {\n    for (const k in this.rejectors) {\n      this.clear(k);\n    }\n  }\n\n  /** Clear promise state for a given key */\n  protected clear(key: string) {\n    this.fetched[key].catch(() => {});\n    delete this.resolvers[key];\n    delete this.rejectors[key];\n    delete this.fetched[key];\n    delete this.fetchedAt[key];\n  }\n\n  protected getLastReset() {\n    if (this.cleanupDate) return this.cleanupDate;\n    const lastReset = this.controller.getState().lastReset;\n    if (lastReset instanceof Date) return lastReset.valueOf();\n    if (typeof lastReset !== 'number') return -Infinity;\n    return lastReset;\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/fetch' action.\n   *\n   * Will then start a promise for a key and potentially start the network\n   * fetch.\n   *\n   * Uses throttle only when instructed by action meta. This is valuable\n   * for ensures mutation requests always go through.\n   */\n  protected handleFetch(\n    action: FetchAction,\n    dispatch: (action: any) => Promise<void>,\n    controller: Controller,\n  ) {\n    const fetch = action.payload;\n    const { key, throttle, resolve, reject } = action.meta;\n    // TODO(breaking): remove support for Date type in 'Receive' action\n    const createdAt =\n      typeof action.meta.createdAt !== 'number'\n        ? action.meta.createdAt.getTime()\n        : action.meta.createdAt;\n\n    const deferedFetch = () => {\n      let promise = fetch();\n      const resolvePromise = (\n        promise: Promise<string | number | object | null>,\n      ) =>\n        promise\n          .then(data => {\n            resolve(data);\n            return data;\n          })\n          .catch(error => {\n            reject(error);\n            throw error;\n          });\n      // schedule non-throttled resolutions in a microtask before receive\n      // this enables users awaiting their fetch to trigger any react updates needed to deal\n      // with upcoming changes because of the fetch (for instance avoiding suspense if something is deleted)\n      if (!throttle && action.endpoint) {\n        promise = resolvePromise(promise);\n      }\n      promise = promise\n        .then(data => {\n          let lastReset = this.getLastReset();\n\n          /* istanbul ignore else */\n          if (process.env.NODE_ENV !== 'production' && isNaN(lastReset)) {\n            console.error(\n              'state.lastReset is NaN. Only positive timestamps are valid.',\n            );\n            lastReset = 0;\n          }\n\n          // don't update state with promises started before last clear\n          if (createdAt >= lastReset) {\n            // we still check for controller in case someone didn't have type protection since this didn't always exist\n            if (action.endpoint && this.controller) {\n              this.controller.resolve(action.endpoint, {\n                args: action.meta.args as any,\n                response: data,\n                fetchedAt: createdAt,\n              });\n            } else {\n              // TODO(breaking): is this branch still possible? remove in next major update\n              // does this throw if the reducer fails? - no because reducer is wrapped in try/catch\n              this.controller.dispatch(\n                createReceive(data, {\n                  ...action.meta,\n                  fetchedAt: createdAt,\n                  dataExpiryLength:\n                    action.meta.options?.dataExpiryLength ??\n                    this.dataExpiryLength,\n                }),\n              );\n            }\n          }\n          return data;\n        })\n        .catch(error => {\n          const lastReset = this.getLastReset();\n          // don't update state with promises started before last clear\n          if (createdAt >= lastReset) {\n            if (action.endpoint && this.controller) {\n              this.controller.resolve(action.endpoint, {\n                args: action.meta.args as any,\n                response: error,\n                fetchedAt: createdAt,\n                error: true,\n              });\n            } else {\n              this.controller.dispatch(\n                createReceiveError(error, {\n                  ...action.meta,\n                  errorExpiryLength:\n                    action.meta.options?.errorExpiryLength ??\n                    this.errorExpiryLength,\n                  fetchedAt: createdAt,\n                }),\n              );\n            }\n          }\n          throw error;\n        });\n      // legacy behavior schedules resolution after dispatch\n      if (!throttle && !action.endpoint) {\n        promise = resolvePromise(promise);\n      }\n      return promise;\n    };\n\n    if (throttle) {\n      return this.throttle(key, deferedFetch, createdAt)\n        .then(data => resolve(data))\n        .catch(error => reject(error));\n    } else {\n      return deferedFetch().catch(() => {});\n    }\n  }\n\n  /** Called when middleware intercepts a receive action.\n   *\n   * Will resolve the promise associated with receive key.\n   */\n  protected handleReceive(action: ReceiveAction) {\n    // this can still turn out to be untrue since this is async\n    if (action.meta.key in this.fetched) {\n      let promiseHandler: (value?: any) => void;\n      if (action.error) {\n        promiseHandler = this.rejectors[action.meta.key];\n      } else {\n        promiseHandler = this.resolvers[action.meta.key];\n      }\n      promiseHandler(action.payload);\n      // since we're resolved we no longer need to keep track of this promise\n      this.clear(action.meta.key);\n    }\n  }\n\n  /** Attaches NetworkManager to store\n   *\n   * Intercepts 'rest-hooks/fetch' actions to start requests.\n   *\n   * Resolve/rejects a request when matching 'rest-hooks/receive' event\n   * is seen.\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n\n  /** Ensures only one request for a given key is in flight at any time\n   *\n   * Uses key to either retrieve in-flight promise, or if not\n   * create a new promise and call fetch.\n   *\n   * Note: The new promise is not actually tied to fetch at all,\n   * but is resolved when the expected 'recieve' action is processed.\n   * This ensures promises are resolved only once their data is processed\n   * by the reducer.\n   */\n  protected throttle(\n    key: string,\n    fetch: () => Promise<any>,\n    createdAt: number,\n  ) {\n    const lastReset = this.getLastReset();\n    // we're already fetching so reuse the promise\n    // fetches after reset do not count\n    if (key in this.fetched && this.fetchedAt[key] > lastReset) {\n      return this.fetched[key];\n    }\n\n    this.fetched[key] = new Promise((resolve, reject) => {\n      this.resolvers[key] = resolve;\n      this.rejectors[key] = reject;\n    });\n    this.fetchedAt[key] = createdAt;\n\n    // since our real promise is resolved via the wrapReducer(),\n    // we should just stop all errors here.\n    // TODO: decouple this from useFetcher() (that's what's dispatching the error the resolves in here)\n    RIC(\n      () => {\n        fetch().catch(() => null);\n      },\n      { timeout: 500 },\n    );\n\n    return this.fetched[key];\n  }\n}\n"],"mappings":"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"} |
@@ -159,2 +159,2 @@ import DefaultConnectionListener from './DefaultConnectionListener.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","createFetch","PollingSubscription","constructor","key","schema","fetch","frequency","getState","dispatch","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","Math","max","lastFetchTime","addOfflineListener","undefined","Error","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","endpoint","dataExpiryLength","errorExpiryLength","errorPolicy","action","args","meta","promise","catch","e","setInterval","_this$getState$meta$t","_this$getState$meta$t2","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface, Schema } from '@rest-hooks/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport { Subscription, SubscriptionInit } from './SubscriptionManager.js';\nimport createFetch from '../controller/createFetch.js';\nimport type { State, Dispatch } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://resthooks.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  protected declare readonly schema: Schema | undefined;\n  protected declare readonly fetch: () => Promise<any>;\n  protected declare readonly key: string;\n  protected declare frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  protected declare dispatch: Dispatch<any>;\n  protected declare getState: () => State<unknown>;\n  protected declare intervalId?: ReturnType<typeof setInterval>;\n  protected declare lastIntervalId?: ReturnType<typeof setInterval>;\n  protected declare startId?: ReturnType<typeof setTimeout>;\n  private declare connectionListener: ConnectionListener;\n\n  constructor(\n    { key, schema, fetch, frequency, getState }: SubscriptionInit,\n    dispatch: Dispatch<any>,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (frequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.schema = schema;\n    this.fetch = fetch;\n    this.frequency = frequency;\n    this.key = key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const endpoint: EndpointInterface = () => this.fetch();\n    (endpoint as any).schema = this.schema;\n    endpoint.key = () => this.key;\n    (endpoint as any).dataExpiryLength = this.frequency / 2;\n    (endpoint as any).errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    const action = createFetch(endpoint, { args: [] });\n    // stop any errors here from bubbling\n    (action.meta.promise as Promise<any>).catch(e => null);\n    this.dispatch(action);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(() => {\n      if (this.startId) {\n        delete this.startId;\n        this.update();\n        this.run();\n      } else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n        );\n      }\n    }, Math.max(0, this.lastFetchTime() - now + this.frequency));\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"AAGA,OAAOA,yBAAyB,MAAM,gCAAgC;AAEtE,OAAOC,WAAW,MAAM,8BAA8B;AAGtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,MAAMC,mBAAmB,CAAyB;EAa/DC,WAAWA,CACT;IAAEC,GAAG;IAAEC,MAAM;IAAEC,KAAK;IAAEC,SAAS;IAAEC;EAA2B,CAAC,EAC7DC,QAAuB,EACvBC,kBAAuC,EACvC;IAAA,KAZQC,kBAAkB,GAAwB,IAAIC,GAAG,EAAE;IAqH7D;IAAA,KACUC,eAAe,GAAG,MAAM;MAChC;MACA,IAAI,CAACC,OAAO,EAAE;MACd,IAAI,CAACJ,kBAAkB,CAACK,iBAAiB,CAAC,IAAI,CAACC,cAAc,CAAC;IAChE,CAAC;IAED;IAAA,KACUA,cAAc,GAAG,MAAM;MAC/B,IAAI,CAACN,kBAAkB,CAACO,oBAAoB,CAAC,IAAI,CAACD,cAAc,CAAC;MACjE,MAAME,GAAG,GAAGC,IAAI,CAACD,GAAG,EAAE;MACtB,IAAI,CAACE,OAAO,GAAGC,UAAU,CAAC,MAAM;QAC9B,IAAI,IAAI,CAACD,OAAO,EAAE;UAChB,OAAO,IAAI,CAACA,OAAO;UACnB,IAAI,CAACE,MAAM,EAAE;UACb,IAAI,CAACC,GAAG,EAAE;QACZ,CAAC,MAAM,IAAIC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;UAChDC,OAAO,CAACC,IAAI,CACT,uBAAsB,IAAI,CAACxB,GAAI,uCAAsC,CACvE;QACH;MACF,CAAC,EAAEyB,IAAI,CAACC,GAAG,CAAC,CAAC,EAAE,IAAI,CAACC,aAAa,EAAE,GAAGb,GAAG,GAAG,IAAI,CAACX,SAAS,CAAC,CAAC;MAC5D,IAAI,CAACG,kBAAkB,CAACsB,kBAAkB,CAAC,IAAI,CAACnB,eAAe,CAAC;IAClE,CAAC;IA/HC,IAAIN,SAAS,KAAK0B,SAAS,EACzB,MAAM,IAAIC,KAAK,CAAC,2CAA2C,CAAC;IAC9D,IAAI,CAAC7B,MAAM,GAAGA,MAAM;IACpB,IAAI,CAACC,KAAK,GAAGA,KAAK;IAClB,IAAI,CAACC,SAAS,GAAGA,SAAS;IAC1B,IAAI,CAACH,GAAG,GAAGA,GAAG;IACd,IAAI,CAACO,kBAAkB,CAACwB,GAAG,CAAC,IAAI,CAAC5B,SAAS,EAAE,CAAC,CAAC;IAC9C,IAAI,CAACE,QAAQ,GAAGA,QAAQ;IACxB,IAAI,CAACD,QAAQ,GAAGA,QAAQ;IACxB,IAAI,CAACE,kBAAkB,GACrBA,kBAAkB,IAAI,IAAIV,yBAAyB,EAAE;;IAEvD;IACA,IAAI,IAAI,CAACU,kBAAkB,CAAC0B,QAAQ,EAAE,EAAE;MACtC,IAAI,CAACpB,cAAc,EAAE;IACvB,CAAC,MAAM;MACL,IAAI,CAACH,eAAe,EAAE;IACxB;EACF;;EAEA;EACAwB,GAAGA,CAAC9B,SAAkB,EAAE;IACtB,IAAIA,SAAS,KAAK0B,SAAS,EAAE;IAC7B,IAAI,IAAI,CAACtB,kBAAkB,CAAC2B,GAAG,CAAC/B,SAAS,CAAC,EAAE;MAC1C,IAAI,CAACI,kBAAkB,CAACwB,GAAG,CACzB5B,SAAS,EACR,IAAI,CAACI,kBAAkB,CAAC4B,GAAG,CAAChC,SAAS,CAAC,GAAc,CAAC,CACvD;IACH,CAAC,MAAM;MACL,IAAI,CAACI,kBAAkB,CAACwB,GAAG,CAAC5B,SAAS,EAAE,CAAC,CAAC;;MAEzC;MACA,IAAIA,SAAS,GAAG,IAAI,CAACA,SAAS,EAAE;QAC9B,IAAI,CAACA,SAAS,GAAGA,SAAS;QAC1B,IAAI,CAACgB,GAAG,EAAE;MACZ;IACF;EACF;;EAEA;EACAiB,MAAMA,CAACjC,SAAkB,EAAE;IACzB,IAAIA,SAAS,KAAK0B,SAAS,EAAE,OAAO,KAAK;IACzC,IAAI,IAAI,CAACtB,kBAAkB,CAAC2B,GAAG,CAAC/B,SAAS,CAAC,EAAE;MAC1C,IAAI,CAACI,kBAAkB,CAACwB,GAAG,CACzB5B,SAAS,EACR,IAAI,CAACI,kBAAkB,CAAC4B,GAAG,CAAChC,SAAS,CAAC,GAAc,CAAC,CACvD;MACD,IAAK,IAAI,CAACI,kBAAkB,CAAC4B,GAAG,CAAChC,SAAS,CAAC,GAAc,CAAC,EAAE;QAC1D,IAAI,CAACI,kBAAkB,CAAC8B,MAAM,CAAClC,SAAS,CAAC;;QAEzC;QACA,IAAI,IAAI,CAACI,kBAAkB,CAAC+B,IAAI,KAAK,CAAC,EAAE;UACtC,IAAI,CAAC5B,OAAO,EAAE;UACd,OAAO,IAAI;QACb;;QAEA;QACA,IAAIP,SAAS,IAAI,IAAI,CAACA,SAAS,EAAE;UAC/B,IAAI,CAACA,SAAS,GAAGsB,IAAI,CAACc,GAAG,CAAC,GAAG,IAAI,CAAChC,kBAAkB,CAACiC,IAAI,EAAE,CAAC;UAC5D,IAAI,CAACrB,GAAG,EAAE;QACZ;MACF;IACF,CAAC,CAAC,+BAAgC,IAChCC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EACrC;MACAC,OAAO,CAACkB,KAAK,CACV,sBAAqBtC,SAAU,0BAAyB,IAAI,CAACH,GAAI,EAAC,CACpE;IACH;IACA,OAAO,KAAK;EACd;;EAEA;EACAU,OAAOA,CAAA,EAAG;IACR,IAAI,IAAI,CAACgC,UAAU,EAAE;MACnBC,aAAa,CAAC,IAAI,CAACD,UAAU,CAAC;MAC9B,OAAO,IAAI,CAACA,UAAU;IACxB;IACA,IAAI,IAAI,CAACE,cAAc,EAAE;MACvBD,aAAa,CAAC,IAAI,CAACC,cAAc,CAAC;MAClC,OAAO,IAAI,CAACA,cAAc;IAC5B;IACA,IAAI,IAAI,CAAC5B,OAAO,EAAE;MAChB6B,YAAY,CAAC,IAAI,CAAC7B,OAAO,CAAC;MAC1B,OAAO,IAAI,CAACA,OAAO;IACrB;IACA,IAAI,CAACV,kBAAkB,CAACO,oBAAoB,CAAC,IAAI,CAACD,cAAc,CAAC;IACjE,IAAI,CAACN,kBAAkB,CAACwC,qBAAqB,CAAC,IAAI,CAACrC,eAAe,CAAC;EACrE;;EAEA;EACUS,MAAMA,CAAA,EAAG;IACjB,MAAM6B,QAA2B,GAAGA,CAAA,KAAM,IAAI,CAAC7C,KAAK,EAAE;IACrD6C,QAAQ,CAAS9C,MAAM,GAAG,IAAI,CAACA,MAAM;IACtC8C,QAAQ,CAAC/C,GAAG,GAAG,MAAM,IAAI,CAACA,GAAG;IAC5B+C,QAAQ,CAASC,gBAAgB,GAAG,IAAI,CAAC7C,SAAS,GAAG,CAAC;IACtD4C,QAAQ,CAASE,iBAAiB,GAAG,IAAI,CAAC9C,SAAS,GAAG,EAAE;IACzD4C,QAAQ,CAACG,WAAW,GAAG,MAAM,MAAe;IAC5C,MAAMC,MAAM,GAAGtD,WAAW,CAACkD,QAAQ,EAAE;MAAEK,IAAI,EAAE;IAAG,CAAC,CAAC;IAClD;IACCD,MAAM,CAACE,IAAI,CAACC,OAAO,CAAkBC,KAAK,CAACC,CAAC,IAAI,IAAI,CAAC;IACtD,IAAI,CAACnD,QAAQ,CAAC8C,MAAM,CAAC;EACvB;EA2BA;AACF;AACA;AACA;EACYhC,GAAGA,CAAA,EAAG;IACd,IAAI,IAAI,CAACH,OAAO,EAAE;IAClB,IAAI,IAAI,CAAC0B,UAAU,EAAE,IAAI,CAACE,cAAc,GAAG,IAAI,CAACF,UAAU;IAC1D,IAAI,CAACA,UAAU,GAAGe,WAAW,CAAC,MAAM;MAClC;MACA;MACA,IAAI,IAAI,CAACb,cAAc,EAAE;QACvBD,aAAa,CAAC,IAAI,CAACC,cAAc,CAAC;QAClC,OAAO,IAAI,CAACA,cAAc;MAC5B;MACA,IAAI,IAAI,CAACF,UAAU,EAAE,IAAI,CAACxB,MAAM,EAAE,CAAC,KAC9B,IAAIE,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;QAC9CC,OAAO,CAACC,IAAI,CACT,uBAAsB,IAAI,CAACxB,GAAI,wCAAuC,CACxE;MACH;IACF,CAAC,EAAE,IAAI,CAACG,SAAS,CAAC;EACpB;;EAEA;EACUwB,aAAaA,CAAA,EAAG;IAAA,IAAA+B,qBAAA,EAAAC,sBAAA;IACxB,QAAAD,qBAAA,IAAAC,sBAAA,GAAO,IAAI,CAACvD,QAAQ,EAAE,CAACiD,IAAI,CAAC,IAAI,CAACrD,GAAG,CAAC,qBAA9B2D,sBAAA,CAAgCC,IAAI,YAAAF,qBAAA,GAAI,CAAC;EAClD;AACF"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultConnectionListener","createFetch","PollingSubscription","constructor","key","schema","fetch","frequency","getState","dispatch","connectionListener","frequencyHistogram","Map","offlineListener","cleanup","addOnlineListener","onlineListener","removeOnlineListener","now","Date","startId","setTimeout","update","run","process","env","NODE_ENV","console","warn","Math","max","lastFetchTime","addOfflineListener","undefined","Error","set","isOnline","add","has","get","remove","delete","size","min","keys","error","intervalId","clearInterval","lastIntervalId","clearTimeout","removeOfflineListener","endpoint","dataExpiryLength","errorExpiryLength","errorPolicy","action","args","meta","promise","catch","e","setInterval","_this$getState$meta$t","_this$getState$meta$t2","date"],"sources":["../../src/manager/PollingSubscription.ts"],"sourcesContent":["import type { EndpointInterface, Schema } from '@rest-hooks/normalizr';\n\nimport ConnectionListener from './ConnectionListener.js';\nimport DefaultConnectionListener from './DefaultConnectionListener.js';\nimport { Subscription, SubscriptionInit } from './SubscriptionManager.js';\nimport createFetch from '../controller/createFetch.js';\nimport type { State, Dispatch } from '../types.js';\n\n/**\n * PollingSubscription keeps a given resource updated by\n * dispatching a fetch at a rate equal to the minimum update\n * interval requested.\n *\n * @see https://resthooks.io/docs/api/PollingSubscription\n */\nexport default class PollingSubscription implements Subscription {\n  protected declare readonly schema: Schema | undefined;\n  protected declare readonly fetch: () => Promise<any>;\n  protected declare readonly key: string;\n  protected declare frequency: number;\n  protected frequencyHistogram: Map<number, number> = new Map();\n  protected declare dispatch: Dispatch<any>;\n  protected declare getState: () => State<unknown>;\n  protected declare intervalId?: ReturnType<typeof setInterval>;\n  protected declare lastIntervalId?: ReturnType<typeof setInterval>;\n  protected declare startId?: ReturnType<typeof setTimeout>;\n  private declare connectionListener: ConnectionListener;\n\n  constructor(\n    { key, schema, fetch, frequency, getState }: SubscriptionInit,\n    dispatch: Dispatch<any>,\n    connectionListener?: ConnectionListener,\n  ) {\n    if (frequency === undefined)\n      throw new Error('frequency needed for polling subscription');\n    this.schema = schema;\n    this.fetch = fetch;\n    this.frequency = frequency;\n    this.key = key;\n    this.frequencyHistogram.set(this.frequency, 1);\n    this.dispatch = dispatch;\n    this.getState = getState;\n    this.connectionListener =\n      connectionListener || new DefaultConnectionListener();\n\n    // Kickstart running since this is initialized after the online notif is sent\n    if (this.connectionListener.isOnline()) {\n      this.onlineListener();\n    } else {\n      this.offlineListener();\n    }\n  }\n\n  /** Subscribe to a frequency */\n  add(frequency?: number) {\n    if (frequency === undefined) return;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) + 1,\n      );\n    } else {\n      this.frequencyHistogram.set(frequency, 1);\n\n      // new min so restart service\n      if (frequency < this.frequency) {\n        this.frequency = frequency;\n        this.run();\n      }\n    }\n  }\n\n  /** Unsubscribe from a frequency */\n  remove(frequency?: number) {\n    if (frequency === undefined) return false;\n    if (this.frequencyHistogram.has(frequency)) {\n      this.frequencyHistogram.set(\n        frequency,\n        (this.frequencyHistogram.get(frequency) as number) - 1,\n      );\n      if ((this.frequencyHistogram.get(frequency) as number) < 1) {\n        this.frequencyHistogram.delete(frequency);\n\n        // nothing subscribed to this anymore...it is invalid\n        if (this.frequencyHistogram.size === 0) {\n          this.cleanup();\n          return true;\n        }\n\n        // this was the min, so find the next size\n        if (frequency <= this.frequency) {\n          this.frequency = Math.min(...this.frequencyHistogram.keys());\n          this.run();\n        }\n      }\n    } /* istanbul ignore next */ else if (\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.error(\n        `Mismatched remove: ${frequency} is not subscribed for ${this.key}`,\n      );\n    }\n    return false;\n  }\n\n  /** Cleanup means clearing out background interval. */\n  cleanup() {\n    if (this.intervalId) {\n      clearInterval(this.intervalId);\n      delete this.intervalId;\n    }\n    if (this.lastIntervalId) {\n      clearInterval(this.lastIntervalId);\n      delete this.lastIntervalId;\n    }\n    if (this.startId) {\n      clearTimeout(this.startId);\n      delete this.startId;\n    }\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    this.connectionListener.removeOfflineListener(this.offlineListener);\n  }\n\n  /** Trigger request for latest resource */\n  protected update() {\n    const endpoint: EndpointInterface = () => this.fetch();\n    (endpoint as any).schema = this.schema;\n    endpoint.key = () => this.key;\n    (endpoint as any).dataExpiryLength = this.frequency / 2;\n    (endpoint as any).errorExpiryLength = this.frequency / 10;\n    endpoint.errorPolicy = () => 'soft' as const;\n    const action = createFetch(endpoint, { args: [] });\n    // stop any errors here from bubbling\n    (action.meta.promise as Promise<any>).catch(e => null);\n    this.dispatch(action);\n  }\n\n  /** What happens when browser goes offline */\n  protected offlineListener = () => {\n    // this clears existing listeners, so no need to clear offline listener\n    this.cleanup();\n    this.connectionListener.addOnlineListener(this.onlineListener);\n  };\n\n  /** What happens when browser comes online */\n  protected onlineListener = () => {\n    this.connectionListener.removeOnlineListener(this.onlineListener);\n    const now = Date.now();\n    this.startId = setTimeout(() => {\n      if (this.startId) {\n        delete this.startId;\n        this.update();\n        this.run();\n      } else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll setTimeout for ${this.key} still running, but timeoutId deleted`,\n        );\n      }\n    }, Math.max(0, this.lastFetchTime() - now + this.frequency));\n    this.connectionListener.addOfflineListener(this.offlineListener);\n  };\n\n  /** Run polling process with current frequency\n   *\n   * Will clean up old poll interval on next run\n   */\n  protected run() {\n    if (this.startId) return;\n    if (this.intervalId) this.lastIntervalId = this.intervalId;\n    this.intervalId = setInterval(() => {\n      // since we don't know how long into the last poll it was before resetting\n      // we wait til the next fetch to clear old intervals\n      if (this.lastIntervalId) {\n        clearInterval(this.lastIntervalId);\n        delete this.lastIntervalId;\n      }\n      if (this.intervalId) this.update();\n      else if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `Poll intervalId for ${this.key} still running, but intervalId deleted`,\n        );\n      }\n    }, this.frequency);\n  }\n\n  /** Last fetch time */\n  protected lastFetchTime() {\n    return this.getState().meta[this.key]?.date ?? 0;\n  }\n}\n"],"mappings":"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"} |
@@ -117,2 +117,2 @@ import { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SUBSCRIBE_TYPE","UNSUBSCRIBE_TYPE","SubscriptionManager","constructor","Subscription","subscriptions","middleware","dispatch","getState","next","action","type","handleSubscribe","e","console","error","Promise","resolve","handleUnsubscribe","cleanup","key","options","endpoint","args","meta","schema","fetch","frequency","pollFrequency","_action$meta$options","add","_action$meta$options2","empty","remove","process","env","NODE_ENV","getMiddleware"],"sources":["../../src/manager/SubscriptionManager.ts"],"sourcesContent":["import type { Schema } from '@rest-hooks/normalizr';\n\nimport { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../actionTypes.js';\nimport type {\n  Manager,\n  State,\n  MiddlewareAPI,\n  Middleware,\n  Dispatch,\n  UnsubscribeAction,\n  SubscribeAction,\n} from '../types.js';\n\ntype Actions = UnsubscribeAction | SubscribeAction;\n\n/** Properties sent to Subscription constructor */\nexport interface SubscriptionInit {\n  schema?: Schema | undefined;\n  fetch: () => Promise<any>;\n  key: string;\n  getState: () => State<unknown>;\n  frequency?: number | undefined;\n}\n\n/** Interface handling a single resource subscription */\nexport interface Subscription {\n  add(frequency?: number): void;\n  remove(frequency?: number): boolean;\n  cleanup(): void;\n}\n\n/** The static class that constructs Subscription */\nexport interface SubscriptionConstructable {\n  new (init: SubscriptionInit, dispatch: Dispatch<any>): Subscription;\n}\n\n/** Handles subscription actions -> fetch or receive actions\n *\n * Constructor takes a SubscriptionConstructable class to control how\n * subscriptions are handled. (e.g., polling, websockets)\n *\n * @see https://resthooks.io/docs/api/SubscriptionManager\n */\nexport default class SubscriptionManager<S extends SubscriptionConstructable>\n  implements Manager\n{\n  protected subscriptions: {\n    [key: string]: InstanceType<S>;\n  } = {};\n\n  protected declare readonly Subscription: S;\n  protected declare middleware: Middleware;\n\n  constructor(Subscription: S) {\n    this.Subscription = Subscription;\n\n    this.middleware = <C extends MiddlewareAPI>({ dispatch, getState }: C) => {\n      return (next: C['dispatch']): C['dispatch'] =>\n        action => {\n          switch (action.type) {\n            case SUBSCRIBE_TYPE:\n              try {\n                this.handleSubscribe(action, dispatch, getState);\n              } catch (e) {\n                console.error(e);\n              }\n              return Promise.resolve();\n            case UNSUBSCRIBE_TYPE:\n              this.handleUnsubscribe(action, dispatch);\n              return Promise.resolve();\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {\n    for (const key in this.subscriptions) {\n      this.subscriptions[key].cleanup();\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/subscribe' action.\n   *\n   */\n  protected handleSubscribe(\n    action: SubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n    getState: () => State<unknown>,\n  ) {\n    let options: SubscriptionInit;\n    if (action.endpoint) {\n      const { endpoint } = action;\n      const { args } = action.meta;\n      options = {\n        schema: endpoint.schema,\n        fetch: () => endpoint(...args),\n        frequency: endpoint.pollFrequency,\n        key: endpoint.key(...args),\n        getState,\n      };\n    } else {\n      options = {\n        key: action.meta.key,\n        frequency: action.meta.options?.pollFrequency,\n        schema: action.meta.schema,\n        fetch: action.meta.fetch,\n        getState,\n      };\n    }\n\n    if (options.key in this.subscriptions) {\n      this.subscriptions[options.key].add(options.frequency);\n    } else {\n      this.subscriptions[options.key] = new this.Subscription(\n        options,\n        dispatch,\n      ) as InstanceType<S>;\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/unsubscribe' action.\n   *\n   */\n  protected handleUnsubscribe(\n    action: UnsubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n  ) {\n    const key = action.meta.key;\n    const frequency = action.meta.options?.pollFrequency;\n\n    /* istanbul ignore else */\n    if (key in this.subscriptions) {\n      const empty = this.subscriptions[key].remove(frequency);\n      if (empty) {\n        delete this.subscriptions[key];\n      }\n    } else if (process.env.NODE_ENV !== 'production') {\n      console.error(`Mismatched unsubscribe: ${key} is not subscribed`);\n    }\n  }\n\n  /** Attaches Manager to store\n   *\n   * Intercepts 'rest-hooks/subscribe'/'rest-hooks/unsubscribe' to register resources that\n   * need to be kept up to date.\n   *\n   * Will possibly dispatch 'rest-hooks/fetch' or 'rest-hooks/receive' to keep resources fresh\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["SUBSCRIBE_TYPE","UNSUBSCRIBE_TYPE","SubscriptionManager","constructor","Subscription","subscriptions","middleware","dispatch","getState","next","action","type","handleSubscribe","e","console","error","Promise","resolve","handleUnsubscribe","cleanup","key","options","endpoint","args","meta","schema","fetch","frequency","pollFrequency","_action$meta$options","add","_action$meta$options2","empty","remove","process","env","NODE_ENV","getMiddleware"],"sources":["../../src/manager/SubscriptionManager.ts"],"sourcesContent":["import type { Schema } from '@rest-hooks/normalizr';\n\nimport { SUBSCRIBE_TYPE, UNSUBSCRIBE_TYPE } from '../actionTypes.js';\nimport type {\n  Manager,\n  State,\n  MiddlewareAPI,\n  Middleware,\n  Dispatch,\n  UnsubscribeAction,\n  SubscribeAction,\n} from '../types.js';\n\ntype Actions = UnsubscribeAction | SubscribeAction;\n\n/** Properties sent to Subscription constructor */\nexport interface SubscriptionInit {\n  schema?: Schema | undefined;\n  fetch: () => Promise<any>;\n  key: string;\n  getState: () => State<unknown>;\n  frequency?: number | undefined;\n}\n\n/** Interface handling a single resource subscription */\nexport interface Subscription {\n  add(frequency?: number): void;\n  remove(frequency?: number): boolean;\n  cleanup(): void;\n}\n\n/** The static class that constructs Subscription */\nexport interface SubscriptionConstructable {\n  new (init: SubscriptionInit, dispatch: Dispatch<any>): Subscription;\n}\n\n/** Handles subscription actions -> fetch or receive actions\n *\n * Constructor takes a SubscriptionConstructable class to control how\n * subscriptions are handled. (e.g., polling, websockets)\n *\n * @see https://resthooks.io/docs/api/SubscriptionManager\n */\nexport default class SubscriptionManager<S extends SubscriptionConstructable>\n  implements Manager\n{\n  protected subscriptions: {\n    [key: string]: InstanceType<S>;\n  } = {};\n\n  protected declare readonly Subscription: S;\n  protected declare middleware: Middleware;\n\n  constructor(Subscription: S) {\n    this.Subscription = Subscription;\n\n    this.middleware = <C extends MiddlewareAPI>({ dispatch, getState }: C) => {\n      return (next: C['dispatch']): C['dispatch'] =>\n        action => {\n          switch (action.type) {\n            case SUBSCRIBE_TYPE:\n              try {\n                this.handleSubscribe(action, dispatch, getState);\n              } catch (e) {\n                console.error(e);\n              }\n              return Promise.resolve();\n            case UNSUBSCRIBE_TYPE:\n              this.handleUnsubscribe(action, dispatch);\n              return Promise.resolve();\n            default:\n              return next(action);\n          }\n        };\n    };\n  }\n\n  /** Ensures all subscriptions are cleaned up. */\n  cleanup() {\n    for (const key in this.subscriptions) {\n      this.subscriptions[key].cleanup();\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/subscribe' action.\n   *\n   */\n  protected handleSubscribe(\n    action: SubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n    getState: () => State<unknown>,\n  ) {\n    let options: SubscriptionInit;\n    if (action.endpoint) {\n      const { endpoint } = action;\n      const { args } = action.meta;\n      options = {\n        schema: endpoint.schema,\n        fetch: () => endpoint(...args),\n        frequency: endpoint.pollFrequency,\n        key: endpoint.key(...args),\n        getState,\n      };\n    } else {\n      options = {\n        key: action.meta.key,\n        frequency: action.meta.options?.pollFrequency,\n        schema: action.meta.schema,\n        fetch: action.meta.fetch,\n        getState,\n      };\n    }\n\n    if (options.key in this.subscriptions) {\n      this.subscriptions[options.key].add(options.frequency);\n    } else {\n      this.subscriptions[options.key] = new this.Subscription(\n        options,\n        dispatch,\n      ) as InstanceType<S>;\n    }\n  }\n\n  /** Called when middleware intercepts 'rest-hooks/unsubscribe' action.\n   *\n   */\n  protected handleUnsubscribe(\n    action: UnsubscribeAction,\n    dispatch: (action: any) => Promise<void>,\n  ) {\n    const key = action.meta.key;\n    const frequency = action.meta.options?.pollFrequency;\n\n    /* istanbul ignore else */\n    if (key in this.subscriptions) {\n      const empty = this.subscriptions[key].remove(frequency);\n      if (empty) {\n        delete this.subscriptions[key];\n      }\n    } else if (process.env.NODE_ENV !== 'production') {\n      console.error(`Mismatched unsubscribe: ${key} is not subscribed`);\n    }\n  }\n\n  /** Attaches Manager to store\n   *\n   * Intercepts 'rest-hooks/subscribe'/'rest-hooks/unsubscribe' to register resources that\n   * need to be kept up to date.\n   *\n   * Will possibly dispatch 'rest-hooks/fetch' or 'rest-hooks/receive' to keep resources fresh\n   *\n   */\n  getMiddleware() {\n    return this.middleware;\n  }\n}\n"],"mappings":"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"} |
@@ -24,2 +24,2 @@ import { denormalize } from '@rest-hooks/normalizr'; | ||
export * from '../controller/BaseController.js'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZW5vcm1hbGl6ZSIsIkJhc2VDb250cm9sbGVyIiwiY3JlYXRlRmV0Y2giLCJDb250cm9sbGVyIiwiY29uc3RydWN0b3IiLCJfYXJncyIsImZldGNoIiwiZW5kcG9pbnQiLCJhcmdzIiwiYWN0aW9uIiwiZGlzcGF0Y2giLCJzY2hlbWEiLCJtZXRhIiwicHJvbWlzZSIsInRoZW4iLCJpbnB1dCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZXh0L0NvbnRyb2xsZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgRGVub3JtYWxpemUgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuaW1wb3J0IHsgZGVub3JtYWxpemUgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgQmFzZUNvbnRyb2xsZXIsIHtcbiAgQ29tcGF0aWJsZURpc3BhdGNoLFxuICBHZW5lcmljRGlzcGF0Y2gsXG59IGZyb20gJy4uL2NvbnRyb2xsZXIvQmFzZUNvbnRyb2xsZXIuanMnO1xuaW1wb3J0IGNyZWF0ZUZldGNoIGZyb20gJy4uL2NvbnRyb2xsZXIvY3JlYXRlRmV0Y2guanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi4vY29udHJvbGxlci90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbnRyb2xsZXI8XG4gIEQgZXh0ZW5kcyBHZW5lcmljRGlzcGF0Y2ggPSBDb21wYXRpYmxlRGlzcGF0Y2gsXG4+IGV4dGVuZHMgQmFzZUNvbnRyb2xsZXI8RD4ge1xuICAvKipcbiAgICogRmV0Y2hlcyB0aGUgZW5kcG9pbnQgd2l0aCBnaXZlbiBhcmdzLCB1cGRhdGluZyB0aGUgUmVzdCBIb29rcyBjYWNoZSB3aXRoIHRoZSByZXNwb25zZSBvciBlcnJvciB1cG9uIGNvbXBsZXRpb24uXG4gICAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvQ29udHJvbGxlciNmZXRjaFxuICAgKi9cbiAgZmV0Y2ggPSA8XG4gICAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYgeyB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+IH0sXG4gID4oXG4gICAgZW5kcG9pbnQ6IEUsXG4gICAgLi4uYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dXG4gICk6IEVbJ3NjaGVtYSddIGV4dGVuZHMgdW5kZWZpbmVkIHwgbnVsbFxuICAgID8gUmV0dXJuVHlwZTxFPlxuICAgIDogUHJvbWlzZTxEZW5vcm1hbGl6ZTxFWydzY2hlbWEnXT4+ID0+IHtcbiAgICBjb25zdCBhY3Rpb24gPSBjcmVhdGVGZXRjaChlbmRwb2ludCwge1xuICAgICAgYXJncyxcbiAgICB9KTtcbiAgICB0aGlzLmRpc3BhdGNoKGFjdGlvbik7XG5cbiAgICBpZiAoZW5kcG9pbnQuc2NoZW1hKSB7XG4gICAgICByZXR1cm4gYWN0aW9uLm1ldGEucHJvbWlzZS50aGVuKGlucHV0ID0+XG4gICAgICAgIGRlbm9ybWFsaXplKGlucHV0LCBlbmRwb2ludC5zY2hlbWEsIHt9LCBhcmdzKSxcbiAgICAgICkgYXMgYW55O1xuICAgIH1cbiAgICByZXR1cm4gYWN0aW9uLm1ldGEucHJvbWlzZSBhcyBhbnk7XG4gIH07XG59XG5leHBvcnQgKiBmcm9tICcuLi9jb250cm9sbGVyL0Jhc2VDb250cm9sbGVyLmpzJztcbiJdLCJtYXBwaW5ncyI6IkFBQ0EsU0FBU0EsV0FBVyxRQUFRLHVCQUF1QjtBQUVuRCxPQUFPQyxjQUFjLE1BR2QsaUNBQWlDO0FBQ3hDLE9BQU9DLFdBQVcsTUFBTSw4QkFBOEI7QUFHdEQsZUFBZSxNQUFNQyxVQUFVLFNBRXJCRixjQUFjLENBQUk7RUFBQUcsWUFBQSxHQUFBQyxLQUFBO0lBQUEsU0FBQUEsS0FBQTtJQUMxQjtBQUNGO0FBQ0E7QUFDQTtJQUhFLEtBSUFDLEtBQUssR0FBRyxDQUdOQyxRQUFXLEVBQ1gsR0FBR0MsSUFBaUMsS0FHRztNQUN2QyxNQUFNQyxNQUFNLEdBQUdQLFdBQVcsQ0FBQ0ssUUFBUSxFQUFFO1FBQ25DQztNQUNGLENBQUMsQ0FBQztNQUNGLElBQUksQ0FBQ0UsUUFBUSxDQUFDRCxNQUFNLENBQUM7TUFFckIsSUFBSUYsUUFBUSxDQUFDSSxNQUFNLEVBQUU7UUFDbkIsT0FBT0YsTUFBTSxDQUFDRyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsSUFBSSxDQUFDQyxLQUFLLElBQ25DZixXQUFXLENBQUNlLEtBQUssRUFBRVIsUUFBUSxDQUFDSSxNQUFNLEVBQUUsQ0FBQyxDQUFDLEVBQUVILElBQUksQ0FBQyxDQUM5QztNQUNIO01BQ0EsT0FBT0MsTUFBTSxDQUFDRyxJQUFJLENBQUNDLE9BQU87SUFDNUIsQ0FBQztFQUFBO0FBQ0g7QUFDQSxjQUFjLGlDQUFpQyJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZW5vcm1hbGl6ZSIsIkJhc2VDb250cm9sbGVyIiwiY3JlYXRlRmV0Y2giLCJDb250cm9sbGVyIiwiY29uc3RydWN0b3IiLCJfYXJncyIsImZldGNoIiwiZW5kcG9pbnQiLCJhcmdzIiwiYWN0aW9uIiwiZGlzcGF0Y2giLCJzY2hlbWEiLCJtZXRhIiwicHJvbWlzZSIsInRoZW4iLCJpbnB1dCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZXh0L0NvbnRyb2xsZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBFbmRwb2ludEludGVyZmFjZSwgRGVub3JtYWxpemUgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuaW1wb3J0IHsgZGVub3JtYWxpemUgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgQmFzZUNvbnRyb2xsZXIsIHtcbiAgQ29tcGF0aWJsZURpc3BhdGNoLFxuICBHZW5lcmljRGlzcGF0Y2gsXG59IGZyb20gJy4uL2NvbnRyb2xsZXIvQmFzZUNvbnRyb2xsZXIuanMnO1xuaW1wb3J0IGNyZWF0ZUZldGNoIGZyb20gJy4uL2NvbnRyb2xsZXIvY3JlYXRlRmV0Y2guanMnO1xuaW1wb3J0IHR5cGUgeyBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi4vY29udHJvbGxlci90eXBlcy5qcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENvbnRyb2xsZXI8XG4gIEQgZXh0ZW5kcyBHZW5lcmljRGlzcGF0Y2ggPSBDb21wYXRpYmxlRGlzcGF0Y2gsXG4+IGV4dGVuZHMgQmFzZUNvbnRyb2xsZXI8RD4ge1xuICAvKipcbiAgICogRmV0Y2hlcyB0aGUgZW5kcG9pbnQgd2l0aCBnaXZlbiBhcmdzLCB1cGRhdGluZyB0aGUgUmVzdCBIb29rcyBjYWNoZSB3aXRoIHRoZSByZXNwb25zZSBvciBlcnJvciB1cG9uIGNvbXBsZXRpb24uXG4gICAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvQ29udHJvbGxlciNmZXRjaFxuICAgKi9cbiAgZmV0Y2ggPSA8XG4gICAgRSBleHRlbmRzIEVuZHBvaW50SW50ZXJmYWNlICYgeyB1cGRhdGU/OiBFbmRwb2ludFVwZGF0ZUZ1bmN0aW9uPEU+IH0sXG4gID4oXG4gICAgZW5kcG9pbnQ6IEUsXG4gICAgLi4uYXJnczogcmVhZG9ubHkgWy4uLlBhcmFtZXRlcnM8RT5dXG4gICk6IEVbJ3NjaGVtYSddIGV4dGVuZHMgdW5kZWZpbmVkIHwgbnVsbFxuICAgID8gUmV0dXJuVHlwZTxFPlxuICAgIDogUHJvbWlzZTxEZW5vcm1hbGl6ZTxFWydzY2hlbWEnXT4+ID0+IHtcbiAgICBjb25zdCBhY3Rpb24gPSBjcmVhdGVGZXRjaChlbmRwb2ludCwge1xuICAgICAgYXJncyxcbiAgICB9KTtcbiAgICB0aGlzLmRpc3BhdGNoKGFjdGlvbik7XG5cbiAgICBpZiAoZW5kcG9pbnQuc2NoZW1hKSB7XG4gICAgICByZXR1cm4gYWN0aW9uLm1ldGEucHJvbWlzZS50aGVuKGlucHV0ID0+XG4gICAgICAgIGRlbm9ybWFsaXplKGlucHV0LCBlbmRwb2ludC5zY2hlbWEsIHt9LCBhcmdzKSxcbiAgICAgICkgYXMgYW55O1xuICAgIH1cbiAgICByZXR1cm4gYWN0aW9uLm1ldGEucHJvbWlzZSBhcyBhbnk7XG4gIH07XG59XG5leHBvcnQgKiBmcm9tICcuLi9jb250cm9sbGVyL0Jhc2VDb250cm9sbGVyLmpzJztcbiJdLCJtYXBwaW5ncyI6IkFBQ0EsU0FBU0EsV0FBVyxRQUFRLHVCQUF1QjtBQUVuRCxPQUFPQyxjQUFjLE1BR2QsaUNBQWlDO0FBQ3hDLE9BQU9DLFdBQVcsTUFBTSw4QkFBOEI7QUFHdEQsZUFBZSxNQUFNQyxVQUFVLFNBRXJCRixjQUFjLENBQUk7RUFBQUcsWUFBQSxHQUFBQyxLQUFBO0lBQUEsU0FBQUEsS0FBQTtJQUMxQjtBQUNGO0FBQ0E7QUFDQTtJQUhFLEtBSUFDLEtBQUssR0FBRyxDQUdOQyxRQUFXLEVBQ1gsR0FBR0MsSUFBaUMsS0FHRztNQUN2QyxNQUFNQyxNQUFNLEdBQUdQLFdBQVcsQ0FBQ0ssUUFBUSxFQUFFO1FBQ25DQztNQUNGLENBQUMsQ0FBQztNQUNGLElBQUksQ0FBQ0UsUUFBUSxDQUFDRCxNQUFNLENBQUM7TUFFckIsSUFBSUYsUUFBUSxDQUFDSSxNQUFNLEVBQUU7UUFDbkIsT0FBT0YsTUFBTSxDQUFDRyxJQUFJLENBQUNDLE9BQU8sQ0FBQ0MsSUFBSSxDQUFDQyxLQUFLLElBQ25DZixXQUFXLENBQUNlLEtBQUssRUFBRVIsUUFBUSxDQUFDSSxNQUFNLEVBQUUsQ0FBQyxDQUFDLEVBQUVILElBQUksQ0FDOUMsQ0FBQztNQUNIO01BQ0EsT0FBT0MsTUFBTSxDQUFDRyxJQUFJLENBQUNDLE9BQU87SUFDNUIsQ0FBQztFQUFBO0FBQ0g7QUFDQSxjQUFjLGlDQUFpQyJ9 |
@@ -7,2 +7,2 @@ export default function applyUpdatersToResults(results, result, updaters) { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseVVwZGF0ZXJzVG9SZXN1bHRzIiwicmVzdWx0cyIsInJlc3VsdCIsInVwZGF0ZXJzIiwiT2JqZWN0IiwiZnJvbUVudHJpZXMiLCJlbnRyaWVzIiwibWFwIiwiZmV0Y2hLZXkiLCJ1cGRhdGVyIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3N0YXRlL2FwcGx5VXBkYXRlcnNUb1Jlc3VsdHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBTY2hlbWEsIE5vcm1hbGl6ZSwgVXBkYXRlRnVuY3Rpb24gfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG50eXBlIFJlc3VsdFN0YXRlRnJvbVVwZGF0ZUZ1bmN0aW9uczxcbiAgU291cmNlU2NoZW1hIGV4dGVuZHMgU2NoZW1hLFxuICBVcGRhdGVGdW5jdGlvbnMgZXh0ZW5kcyB7XG4gICAgW2tleTogc3RyaW5nXTogVXBkYXRlRnVuY3Rpb248U291cmNlU2NoZW1hLCBhbnk+O1xuICB9LFxuPiA9IHsgW0sgaW4ga2V5b2YgVXBkYXRlRnVuY3Rpb25zXTogYW55IH07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5VXBkYXRlcnNUb1Jlc3VsdHM8XG4gIFNvdXJjZVNjaGVtYSBleHRlbmRzIFNjaGVtYSxcbiAgVXBkYXRlRnVuY3Rpb25zIGV4dGVuZHMge1xuICAgIFtrZXk6IHN0cmluZ106IFVwZGF0ZUZ1bmN0aW9uPFNvdXJjZVNjaGVtYSwgYW55PjtcbiAgfSxcbj4oXG4gIHJlc3VsdHM6IFJlc3VsdFN0YXRlRnJvbVVwZGF0ZUZ1bmN0aW9uczxTb3VyY2VTY2hlbWEsIFVwZGF0ZUZ1bmN0aW9ucz4sXG4gIHJlc3VsdDogTm9ybWFsaXplPFNvdXJjZVNjaGVtYT4sXG4gIHVwZGF0ZXJzOiBVcGRhdGVGdW5jdGlvbnMsXG4pIHtcbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHRzLFxuICAgIC4uLk9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgIE9iamVjdC5lbnRyaWVzKHVwZGF0ZXJzKS5tYXAoKFtmZXRjaEtleSwgdXBkYXRlcl0pID0+IFtcbiAgICAgICAgZmV0Y2hLZXksXG4gICAgICAgIHVwZGF0ZXIocmVzdWx0LCByZXN1bHRzW2ZldGNoS2V5XSksXG4gICAgICBdKSxcbiAgICApLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFTQSxlQUFlLFNBQVNBLHNCQUFzQkEsQ0FNNUNDLE9BQXNFLEVBQ3RFQyxNQUErQixFQUMvQkMsUUFBeUIsRUFDekI7RUFDQSxPQUFPO0lBQ0wsR0FBR0YsT0FBTztJQUNWLEdBQUdHLE1BQU0sQ0FBQ0MsV0FBVyxDQUNuQkQsTUFBTSxDQUFDRSxPQUFPLENBQUNILFFBQVEsQ0FBQyxDQUFDSSxHQUFHLENBQUMsQ0FBQyxDQUFDQyxRQUFRLEVBQUVDLE9BQU8sQ0FBQyxLQUFLLENBQ3BERCxRQUFRLEVBQ1JDLE9BQU8sQ0FBQ1AsTUFBTSxFQUFFRCxPQUFPLENBQUNPLFFBQVEsQ0FBQyxDQUFDLENBQ25DLENBQUM7RUFFTixDQUFDO0FBQ0gifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhcHBseVVwZGF0ZXJzVG9SZXN1bHRzIiwicmVzdWx0cyIsInJlc3VsdCIsInVwZGF0ZXJzIiwiT2JqZWN0IiwiZnJvbUVudHJpZXMiLCJlbnRyaWVzIiwibWFwIiwiZmV0Y2hLZXkiLCJ1cGRhdGVyIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3N0YXRlL2FwcGx5VXBkYXRlcnNUb1Jlc3VsdHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBTY2hlbWEsIE5vcm1hbGl6ZSwgVXBkYXRlRnVuY3Rpb24gfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG50eXBlIFJlc3VsdFN0YXRlRnJvbVVwZGF0ZUZ1bmN0aW9uczxcbiAgU291cmNlU2NoZW1hIGV4dGVuZHMgU2NoZW1hLFxuICBVcGRhdGVGdW5jdGlvbnMgZXh0ZW5kcyB7XG4gICAgW2tleTogc3RyaW5nXTogVXBkYXRlRnVuY3Rpb248U291cmNlU2NoZW1hLCBhbnk+O1xuICB9LFxuPiA9IHsgW0sgaW4ga2V5b2YgVXBkYXRlRnVuY3Rpb25zXTogYW55IH07XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGFwcGx5VXBkYXRlcnNUb1Jlc3VsdHM8XG4gIFNvdXJjZVNjaGVtYSBleHRlbmRzIFNjaGVtYSxcbiAgVXBkYXRlRnVuY3Rpb25zIGV4dGVuZHMge1xuICAgIFtrZXk6IHN0cmluZ106IFVwZGF0ZUZ1bmN0aW9uPFNvdXJjZVNjaGVtYSwgYW55PjtcbiAgfSxcbj4oXG4gIHJlc3VsdHM6IFJlc3VsdFN0YXRlRnJvbVVwZGF0ZUZ1bmN0aW9uczxTb3VyY2VTY2hlbWEsIFVwZGF0ZUZ1bmN0aW9ucz4sXG4gIHJlc3VsdDogTm9ybWFsaXplPFNvdXJjZVNjaGVtYT4sXG4gIHVwZGF0ZXJzOiBVcGRhdGVGdW5jdGlvbnMsXG4pIHtcbiAgcmV0dXJuIHtcbiAgICAuLi5yZXN1bHRzLFxuICAgIC4uLk9iamVjdC5mcm9tRW50cmllcyhcbiAgICAgIE9iamVjdC5lbnRyaWVzKHVwZGF0ZXJzKS5tYXAoKFtmZXRjaEtleSwgdXBkYXRlcl0pID0+IFtcbiAgICAgICAgZmV0Y2hLZXksXG4gICAgICAgIHVwZGF0ZXIocmVzdWx0LCByZXN1bHRzW2ZldGNoS2V5XSksXG4gICAgICBdKSxcbiAgICApLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFTQSxlQUFlLFNBQVNBLHNCQUFzQkEsQ0FNNUNDLE9BQXNFLEVBQ3RFQyxNQUErQixFQUMvQkMsUUFBeUIsRUFDekI7RUFDQSxPQUFPO0lBQ0wsR0FBR0YsT0FBTztJQUNWLEdBQUdHLE1BQU0sQ0FBQ0MsV0FBVyxDQUNuQkQsTUFBTSxDQUFDRSxPQUFPLENBQUNILFFBQVEsQ0FBQyxDQUFDSSxHQUFHLENBQUMsQ0FBQyxDQUFDQyxRQUFRLEVBQUVDLE9BQU8sQ0FBQyxLQUFLLENBQ3BERCxRQUFRLEVBQ1JDLE9BQU8sQ0FBQ1AsTUFBTSxFQUFFRCxPQUFPLENBQUNPLFFBQVEsQ0FBQyxDQUFDLENBQ25DLENBQ0g7RUFDRixDQUFDO0FBQ0gifQ== |
@@ -62,2 +62,2 @@ // TODO(breaking): remove file - not used | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJmZXRjaFNoYXBlIiwicGFyYW1zIiwiYm9keSIsInRocm90dGxlIiwidXBkYXRlUGFyYW1zIiwic2NoZW1hIiwidHlwZSIsImdldEZldGNoS2V5Iiwib3B0aW9ucyIsImtleSIsInJlc29sdmUiLCJyZWplY3QiLCJwcm9taXNlIiwiUHJvbWlzZSIsImEiLCJiIiwibWV0YSIsImFyZ3MiLCJjcmVhdGVkQXQiLCJEYXRlIiwibm93IiwidXBkYXRlIiwibmV3cmVzdWx0IiwidXBkYXRlTWFwIiwiZm9yRWFjaCIsInRvU2hhcGUiLCJ0b1BhcmFtcyIsInVwZGF0ZUZuIiwiZXhpc3RpbmciLCJvcHRpbWlzdGljVXBkYXRlIiwib3B0aW1pc3RpY1Jlc3BvbnNlIiwicGF5bG9hZCIsImZldGNoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL2xlZ2FjeS1hY3Rpb25zL2NyZWF0ZUZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIFRPRE8oYnJlYWtpbmcpOiByZW1vdmUgZmlsZSAtIG5vdCB1c2VkXG5pbXBvcnQgeyBTY2hlbWEgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBGRVRDSF9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHtcbiAgRmV0Y2hTaGFwZSxcbiAgU2NoZW1hRnJvbVNoYXBlLFxuICBQYXJhbXNGcm9tU2hhcGUsXG4gIEJvZHlGcm9tU2hhcGUsXG4gIE9wdGltaXN0aWNVcGRhdGVQYXJhbXMsXG59IGZyb20gJy4uLy4uL2VuZHBvaW50L2luZGV4LmpzJztcbmltcG9ydCB7IEZldGNoQWN0aW9uIH0gZnJvbSAnLi4vLi4vbGVnYWN5QWN0aW9ucy5qcyc7XG5cbmludGVyZmFjZSBPcHRpb25zPFxuICBTaGFwZSBleHRlbmRzIEZldGNoU2hhcGU8XG4gICAgU2NoZW1hIHwgdW5kZWZpbmVkLFxuICAgIFJlYWRvbmx5PG9iamVjdD4sXG4gICAgUmVhZG9ubHk8b2JqZWN0IHwgc3RyaW5nPiB8IHZvaWRcbiAgPixcbj4ge1xuICBwYXJhbXM6IFBhcmFtc0Zyb21TaGFwZTxTaGFwZT47XG4gIGJvZHk/OiBCb2R5RnJvbVNoYXBlPFNoYXBlPjtcbiAgdGhyb3R0bGU6IGJvb2xlYW47XG4gIHVwZGF0ZVBhcmFtcz86XG4gICAgfCBPcHRpbWlzdGljVXBkYXRlUGFyYW1zPFxuICAgICAgICBTY2hlbWFGcm9tU2hhcGU8U2hhcGU+LFxuICAgICAgICBGZXRjaFNoYXBlPFNjaGVtYSB8IHVuZGVmaW5lZCwgYW55LCBhbnk+XG4gICAgICA+W11cbiAgICB8IHVuZGVmaW5lZDtcbn1cblxuLyoqIFJlcXVlc3RpbmcgYSBmZXRjaCB0byBiZWdpblxuICpcbiAqIEBwYXJhbSBmZXRjaFNoYXBlXG4gKiBAcGFyYW0gcGFyYW0xIHsgcGFyYW1zLCBib2R5LCB0aHJvdHRsZSwgdXBkYXRlUGFyYW1zIH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlRmV0Y2g8XG4gIFNoYXBlIGV4dGVuZHMgRmV0Y2hTaGFwZTxcbiAgICBTY2hlbWEgfCB1bmRlZmluZWQsXG4gICAgUmVhZG9ubHk8b2JqZWN0PixcbiAgICBSZWFkb25seTxvYmplY3QgfCBzdHJpbmc+IHwgdm9pZFxuICA+LFxuPihcbiAgZmV0Y2hTaGFwZTogU2hhcGUgJiB7XG4gICAgdXBkYXRlPzogKC4uLmFyZ3M6IGFueSkgPT4gUmVjb3JkPHN0cmluZywgKC4uLmFyZ3M6IGFueSkgPT4gYW55PjtcbiAgfSxcbiAgeyBwYXJhbXMsIGJvZHksIHRocm90dGxlLCB1cGRhdGVQYXJhbXMgfTogT3B0aW9uczxTaGFwZT4sXG4pOiBGZXRjaEFjdGlvbiB7XG4gIGNvbnN0IHsgc2NoZW1hLCB0eXBlLCBnZXRGZXRjaEtleSwgb3B0aW9ucyB9ID0gZmV0Y2hTaGFwZTtcblxuICBjb25zdCBrZXkgPSBnZXRGZXRjaEtleShwYXJhbXMpO1xuICBsZXQgcmVzb2x2ZTogKHZhbHVlPzogYW55IHwgUHJvbWlzZUxpa2U8YW55PikgPT4gdm9pZCA9IDAgYXMgYW55O1xuICBsZXQgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZTxhbnk+KChhLCBiKSA9PiB7XG4gICAgW3Jlc29sdmUsIHJlamVjdF0gPSBbYSwgYl07XG4gIH0pO1xuICBjb25zdCBtZXRhOiBGZXRjaEFjdGlvblsnbWV0YSddID0ge1xuICAgIHNjaGVtYSxcbiAgICB0eXBlLFxuICAgIGFyZ3M6IFtwYXJhbXMsIGJvZHldLFxuICAgIGtleSxcbiAgICB0aHJvdHRsZSxcbiAgICBvcHRpb25zLFxuICAgIHJlc29sdmUsXG4gICAgcmVqZWN0LFxuICAgIHByb21pc2UsXG4gICAgY3JlYXRlZEF0OiBEYXRlLm5vdygpLFxuICB9O1xuXG4gIGlmIChmZXRjaFNoYXBlLnVwZGF0ZSkge1xuICAgIG1ldGEudXBkYXRlID0gZmV0Y2hTaGFwZS51cGRhdGU7XG4gIH1cblxuICAvLyBmb3Igc2ltcGxpY2l0eSB3ZSBzaW1wbHkgb3ZlcnJpZGUgaWYgdXBkYXRlUGFyYW1zIGFyZSBkZWZpbmVkIC0gdXNhZ2UgdG9nZXRoZXIgaXMgc2lsbHkgdG8gc3VwcG9ydCBhcyB3ZSBhcmUgbWlncmF0aW5nXG4gIGlmICh1cGRhdGVQYXJhbXMpIHtcbiAgICBtZXRhLnVwZGF0ZSA9IChuZXdyZXN1bHQ6IGFueSk6IFJlY29yZDxzdHJpbmcsICguLi5hcmdzOiBhbnkpID0+IGFueT4gPT4ge1xuICAgICAgY29uc3QgdXBkYXRlTWFwOiBhbnkgPSB7fTtcbiAgICAgIHVwZGF0ZVBhcmFtcy5mb3JFYWNoKChbdG9TaGFwZSwgdG9QYXJhbXMsIHVwZGF0ZUZuXSkgPT4ge1xuICAgICAgICB1cGRhdGVNYXBbdG9TaGFwZS5nZXRGZXRjaEtleSh0b1BhcmFtcyldID0gKGV4aXN0aW5nOiBhbnkpID0+XG4gICAgICAgICAgdXBkYXRlRm4obmV3cmVzdWx0LCBleGlzdGluZyk7XG4gICAgICB9KTtcbiAgICAgIHJldHVybiB1cGRhdGVNYXA7XG4gICAgfTtcbiAgfVxuXG4gIGlmIChvcHRpb25zPy5vcHRpbWlzdGljVXBkYXRlKSB7XG4gICAgbWV0YS5vcHRpbWlzdGljUmVzcG9uc2UgPSBvcHRpb25zLm9wdGltaXN0aWNVcGRhdGUocGFyYW1zLCBib2R5KTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHlwZTogRkVUQ0hfVFlQRSxcbiAgICBwYXlsb2FkOiAoKSA9PiBmZXRjaFNoYXBlLmZldGNoKHBhcmFtcywgYm9keSksXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBR0EsU0FBU0EsVUFBVSxRQUFRLHNCQUFzQjtBQTRCakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsV0FBV0EsQ0FPakNDLFVBRUMsRUFDRDtFQUFFQyxNQUFNO0VBQUVDLElBQUk7RUFBRUMsUUFBUTtFQUFFQztBQUE2QixDQUFDLEVBQzNDO0VBQ2IsTUFBTTtJQUFFQyxNQUFNO0lBQUVDLElBQUk7SUFBRUMsV0FBVztJQUFFQztFQUFRLENBQUMsR0FBR1IsVUFBVTtFQUV6RCxNQUFNUyxHQUFHLEdBQUdGLFdBQVcsQ0FBQ04sTUFBTSxDQUFDO0VBQy9CLElBQUlTLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQXlCLEdBQUc7SUFDaENYLE1BQU07SUFDTkMsSUFBSTtJQUNKVyxJQUFJLEVBQUUsQ0FBQ2hCLE1BQU0sRUFBRUMsSUFBSSxDQUFDO0lBQ3BCTyxHQUFHO0lBQ0hOLFFBQVE7SUFDUkssT0FBTztJQUNQRSxPQUFPO0lBQ1BDLE1BQU07SUFDTkMsT0FBTztJQUNQTSxTQUFTLEVBQUVDLElBQUksQ0FBQ0MsR0FBRztFQUNyQixDQUFDO0VBRUQsSUFBSXBCLFVBQVUsQ0FBQ3FCLE1BQU0sRUFBRTtJQUNyQkwsSUFBSSxDQUFDSyxNQUFNLEdBQUdyQixVQUFVLENBQUNxQixNQUFNO0VBQ2pDOztFQUVBO0VBQ0EsSUFBSWpCLFlBQVksRUFBRTtJQUNoQlksSUFBSSxDQUFDSyxNQUFNLEdBQUlDLFNBQWMsSUFBNEM7TUFDdkUsTUFBTUMsU0FBYyxHQUFHLENBQUMsQ0FBQztNQUN6Qm5CLFlBQVksQ0FBQ29CLE9BQU8sQ0FBQyxDQUFDLENBQUNDLE9BQU8sRUFBRUMsUUFBUSxFQUFFQyxRQUFRLENBQUMsS0FBSztRQUN0REosU0FBUyxDQUFDRSxPQUFPLENBQUNsQixXQUFXLENBQUNtQixRQUFRLENBQUMsQ0FBQyxHQUFJRSxRQUFhLElBQ3ZERCxRQUFRLENBQUNMLFNBQVMsRUFBRU0sUUFBUSxDQUFDO01BQ2pDLENBQUMsQ0FBQztNQUNGLE9BQU9MLFNBQVM7SUFDbEIsQ0FBQztFQUNIO0VBRUEsSUFBSWYsT0FBTyxZQUFQQSxPQUFPLENBQUVxQixnQkFBZ0IsRUFBRTtJQUM3QmIsSUFBSSxDQUFDYyxrQkFBa0IsR0FBR3RCLE9BQU8sQ0FBQ3FCLGdCQUFnQixDQUFDNUIsTUFBTSxFQUFFQyxJQUFJLENBQUM7RUFDbEU7RUFFQSxPQUFPO0lBQ0xJLElBQUksRUFBRVIsVUFBVTtJQUNoQmlDLE9BQU8sRUFBRUEsQ0FBQSxLQUFNL0IsVUFBVSxDQUFDZ0MsS0FBSyxDQUFDL0IsTUFBTSxFQUFFQyxJQUFJLENBQUM7SUFDN0NjO0VBQ0YsQ0FBQztBQUNIIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJGRVRDSF9UWVBFIiwiY3JlYXRlRmV0Y2giLCJmZXRjaFNoYXBlIiwicGFyYW1zIiwiYm9keSIsInRocm90dGxlIiwidXBkYXRlUGFyYW1zIiwic2NoZW1hIiwidHlwZSIsImdldEZldGNoS2V5Iiwib3B0aW9ucyIsImtleSIsInJlc29sdmUiLCJyZWplY3QiLCJwcm9taXNlIiwiUHJvbWlzZSIsImEiLCJiIiwibWV0YSIsImFyZ3MiLCJjcmVhdGVkQXQiLCJEYXRlIiwibm93IiwidXBkYXRlIiwibmV3cmVzdWx0IiwidXBkYXRlTWFwIiwiZm9yRWFjaCIsInRvU2hhcGUiLCJ0b1BhcmFtcyIsInVwZGF0ZUZuIiwiZXhpc3RpbmciLCJvcHRpbWlzdGljVXBkYXRlIiwib3B0aW1pc3RpY1Jlc3BvbnNlIiwicGF5bG9hZCIsImZldGNoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL2xlZ2FjeS1hY3Rpb25zL2NyZWF0ZUZldGNoLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIFRPRE8oYnJlYWtpbmcpOiByZW1vdmUgZmlsZSAtIG5vdCB1c2VkXG5pbXBvcnQgeyBTY2hlbWEgfSBmcm9tICdAcmVzdC1ob29rcy9ub3JtYWxpenInO1xuXG5pbXBvcnQgeyBGRVRDSF9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHtcbiAgRmV0Y2hTaGFwZSxcbiAgU2NoZW1hRnJvbVNoYXBlLFxuICBQYXJhbXNGcm9tU2hhcGUsXG4gIEJvZHlGcm9tU2hhcGUsXG4gIE9wdGltaXN0aWNVcGRhdGVQYXJhbXMsXG59IGZyb20gJy4uLy4uL2VuZHBvaW50L2luZGV4LmpzJztcbmltcG9ydCB7IEZldGNoQWN0aW9uIH0gZnJvbSAnLi4vLi4vbGVnYWN5QWN0aW9ucy5qcyc7XG5cbmludGVyZmFjZSBPcHRpb25zPFxuICBTaGFwZSBleHRlbmRzIEZldGNoU2hhcGU8XG4gICAgU2NoZW1hIHwgdW5kZWZpbmVkLFxuICAgIFJlYWRvbmx5PG9iamVjdD4sXG4gICAgUmVhZG9ubHk8b2JqZWN0IHwgc3RyaW5nPiB8IHZvaWRcbiAgPixcbj4ge1xuICBwYXJhbXM6IFBhcmFtc0Zyb21TaGFwZTxTaGFwZT47XG4gIGJvZHk/OiBCb2R5RnJvbVNoYXBlPFNoYXBlPjtcbiAgdGhyb3R0bGU6IGJvb2xlYW47XG4gIHVwZGF0ZVBhcmFtcz86XG4gICAgfCBPcHRpbWlzdGljVXBkYXRlUGFyYW1zPFxuICAgICAgICBTY2hlbWFGcm9tU2hhcGU8U2hhcGU+LFxuICAgICAgICBGZXRjaFNoYXBlPFNjaGVtYSB8IHVuZGVmaW5lZCwgYW55LCBhbnk+XG4gICAgICA+W11cbiAgICB8IHVuZGVmaW5lZDtcbn1cblxuLyoqIFJlcXVlc3RpbmcgYSBmZXRjaCB0byBiZWdpblxuICpcbiAqIEBwYXJhbSBmZXRjaFNoYXBlXG4gKiBAcGFyYW0gcGFyYW0xIHsgcGFyYW1zLCBib2R5LCB0aHJvdHRsZSwgdXBkYXRlUGFyYW1zIH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlRmV0Y2g8XG4gIFNoYXBlIGV4dGVuZHMgRmV0Y2hTaGFwZTxcbiAgICBTY2hlbWEgfCB1bmRlZmluZWQsXG4gICAgUmVhZG9ubHk8b2JqZWN0PixcbiAgICBSZWFkb25seTxvYmplY3QgfCBzdHJpbmc+IHwgdm9pZFxuICA+LFxuPihcbiAgZmV0Y2hTaGFwZTogU2hhcGUgJiB7XG4gICAgdXBkYXRlPzogKC4uLmFyZ3M6IGFueSkgPT4gUmVjb3JkPHN0cmluZywgKC4uLmFyZ3M6IGFueSkgPT4gYW55PjtcbiAgfSxcbiAgeyBwYXJhbXMsIGJvZHksIHRocm90dGxlLCB1cGRhdGVQYXJhbXMgfTogT3B0aW9uczxTaGFwZT4sXG4pOiBGZXRjaEFjdGlvbiB7XG4gIGNvbnN0IHsgc2NoZW1hLCB0eXBlLCBnZXRGZXRjaEtleSwgb3B0aW9ucyB9ID0gZmV0Y2hTaGFwZTtcblxuICBjb25zdCBrZXkgPSBnZXRGZXRjaEtleShwYXJhbXMpO1xuICBsZXQgcmVzb2x2ZTogKHZhbHVlPzogYW55IHwgUHJvbWlzZUxpa2U8YW55PikgPT4gdm9pZCA9IDAgYXMgYW55O1xuICBsZXQgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkID0gMCBhcyBhbnk7XG4gIGNvbnN0IHByb21pc2UgPSBuZXcgUHJvbWlzZTxhbnk+KChhLCBiKSA9PiB7XG4gICAgW3Jlc29sdmUsIHJlamVjdF0gPSBbYSwgYl07XG4gIH0pO1xuICBjb25zdCBtZXRhOiBGZXRjaEFjdGlvblsnbWV0YSddID0ge1xuICAgIHNjaGVtYSxcbiAgICB0eXBlLFxuICAgIGFyZ3M6IFtwYXJhbXMsIGJvZHldLFxuICAgIGtleSxcbiAgICB0aHJvdHRsZSxcbiAgICBvcHRpb25zLFxuICAgIHJlc29sdmUsXG4gICAgcmVqZWN0LFxuICAgIHByb21pc2UsXG4gICAgY3JlYXRlZEF0OiBEYXRlLm5vdygpLFxuICB9O1xuXG4gIGlmIChmZXRjaFNoYXBlLnVwZGF0ZSkge1xuICAgIG1ldGEudXBkYXRlID0gZmV0Y2hTaGFwZS51cGRhdGU7XG4gIH1cblxuICAvLyBmb3Igc2ltcGxpY2l0eSB3ZSBzaW1wbHkgb3ZlcnJpZGUgaWYgdXBkYXRlUGFyYW1zIGFyZSBkZWZpbmVkIC0gdXNhZ2UgdG9nZXRoZXIgaXMgc2lsbHkgdG8gc3VwcG9ydCBhcyB3ZSBhcmUgbWlncmF0aW5nXG4gIGlmICh1cGRhdGVQYXJhbXMpIHtcbiAgICBtZXRhLnVwZGF0ZSA9IChuZXdyZXN1bHQ6IGFueSk6IFJlY29yZDxzdHJpbmcsICguLi5hcmdzOiBhbnkpID0+IGFueT4gPT4ge1xuICAgICAgY29uc3QgdXBkYXRlTWFwOiBhbnkgPSB7fTtcbiAgICAgIHVwZGF0ZVBhcmFtcy5mb3JFYWNoKChbdG9TaGFwZSwgdG9QYXJhbXMsIHVwZGF0ZUZuXSkgPT4ge1xuICAgICAgICB1cGRhdGVNYXBbdG9TaGFwZS5nZXRGZXRjaEtleSh0b1BhcmFtcyldID0gKGV4aXN0aW5nOiBhbnkpID0+XG4gICAgICAgICAgdXBkYXRlRm4obmV3cmVzdWx0LCBleGlzdGluZyk7XG4gICAgICB9KTtcbiAgICAgIHJldHVybiB1cGRhdGVNYXA7XG4gICAgfTtcbiAgfVxuXG4gIGlmIChvcHRpb25zPy5vcHRpbWlzdGljVXBkYXRlKSB7XG4gICAgbWV0YS5vcHRpbWlzdGljUmVzcG9uc2UgPSBvcHRpb25zLm9wdGltaXN0aWNVcGRhdGUocGFyYW1zLCBib2R5KTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHlwZTogRkVUQ0hfVFlQRSxcbiAgICBwYXlsb2FkOiAoKSA9PiBmZXRjaFNoYXBlLmZldGNoKHBhcmFtcywgYm9keSksXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBR0EsU0FBU0EsVUFBVSxRQUFRLHNCQUFzQjtBQTRCakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsV0FBV0EsQ0FPakNDLFVBRUMsRUFDRDtFQUFFQyxNQUFNO0VBQUVDLElBQUk7RUFBRUMsUUFBUTtFQUFFQztBQUE2QixDQUFDLEVBQzNDO0VBQ2IsTUFBTTtJQUFFQyxNQUFNO0lBQUVDLElBQUk7SUFBRUMsV0FBVztJQUFFQztFQUFRLENBQUMsR0FBR1IsVUFBVTtFQUV6RCxNQUFNUyxHQUFHLEdBQUdGLFdBQVcsQ0FBQ04sTUFBTSxDQUFDO0VBQy9CLElBQUlTLE9BQWlELEdBQUcsQ0FBUTtFQUNoRSxJQUFJQyxNQUE4QixHQUFHLENBQVE7RUFDN0MsTUFBTUMsT0FBTyxHQUFHLElBQUlDLE9BQU8sQ0FBTSxDQUFDQyxDQUFDLEVBQUVDLENBQUMsS0FBSztJQUN6QyxDQUFDTCxPQUFPLEVBQUVDLE1BQU0sQ0FBQyxHQUFHLENBQUNHLENBQUMsRUFBRUMsQ0FBQyxDQUFDO0VBQzVCLENBQUMsQ0FBQztFQUNGLE1BQU1DLElBQXlCLEdBQUc7SUFDaENYLE1BQU07SUFDTkMsSUFBSTtJQUNKVyxJQUFJLEVBQUUsQ0FBQ2hCLE1BQU0sRUFBRUMsSUFBSSxDQUFDO0lBQ3BCTyxHQUFHO0lBQ0hOLFFBQVE7SUFDUkssT0FBTztJQUNQRSxPQUFPO0lBQ1BDLE1BQU07SUFDTkMsT0FBTztJQUNQTSxTQUFTLEVBQUVDLElBQUksQ0FBQ0MsR0FBRyxDQUFDO0VBQ3RCLENBQUM7RUFFRCxJQUFJcEIsVUFBVSxDQUFDcUIsTUFBTSxFQUFFO0lBQ3JCTCxJQUFJLENBQUNLLE1BQU0sR0FBR3JCLFVBQVUsQ0FBQ3FCLE1BQU07RUFDakM7O0VBRUE7RUFDQSxJQUFJakIsWUFBWSxFQUFFO0lBQ2hCWSxJQUFJLENBQUNLLE1BQU0sR0FBSUMsU0FBYyxJQUE0QztNQUN2RSxNQUFNQyxTQUFjLEdBQUcsQ0FBQyxDQUFDO01BQ3pCbkIsWUFBWSxDQUFDb0IsT0FBTyxDQUFDLENBQUMsQ0FBQ0MsT0FBTyxFQUFFQyxRQUFRLEVBQUVDLFFBQVEsQ0FBQyxLQUFLO1FBQ3RESixTQUFTLENBQUNFLE9BQU8sQ0FBQ2xCLFdBQVcsQ0FBQ21CLFFBQVEsQ0FBQyxDQUFDLEdBQUlFLFFBQWEsSUFDdkRELFFBQVEsQ0FBQ0wsU0FBUyxFQUFFTSxRQUFRLENBQUM7TUFDakMsQ0FBQyxDQUFDO01BQ0YsT0FBT0wsU0FBUztJQUNsQixDQUFDO0VBQ0g7RUFFQSxJQUFJZixPQUFPLFlBQVBBLE9BQU8sQ0FBRXFCLGdCQUFnQixFQUFFO0lBQzdCYixJQUFJLENBQUNjLGtCQUFrQixHQUFHdEIsT0FBTyxDQUFDcUIsZ0JBQWdCLENBQUM1QixNQUFNLEVBQUVDLElBQUksQ0FBQztFQUNsRTtFQUVBLE9BQU87SUFDTEksSUFBSSxFQUFFUixVQUFVO0lBQ2hCaUMsT0FBTyxFQUFFQSxDQUFBLEtBQU0vQixVQUFVLENBQUNnQyxLQUFLLENBQUMvQixNQUFNLEVBQUVDLElBQUksQ0FBQztJQUM3Q2M7RUFDRixDQUFDO0FBQ0gifQ== |
@@ -37,2 +37,2 @@ import { RECEIVE_TYPE } from '../../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUNFSVZFX1RZUEUiLCJjcmVhdGVSZWNlaXZlIiwiZGF0YSIsInNjaGVtYSIsImtleSIsImFyZ3MiLCJ1cGRhdGVycyIsImZldGNoZWRBdCIsInVwZGF0ZSIsImRhdGFFeHBpcnlMZW5ndGgiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJFcnJvciIsIm5vdyIsIkRhdGUiLCJtZXRhIiwiZGF0ZSIsImV4cGlyZXNBdCIsInR5cGUiLCJwYXlsb2FkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL2xlZ2FjeS1hY3Rpb25zL2NyZWF0ZVJlY2VpdmUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIEVuZHBvaW50RXh0cmFPcHRpb25zIGFzIEZldGNoT3B0aW9ucyxcbn0gZnJvbSAnQHJlc3QtaG9va3Mvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgUkVDRUlWRV9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHsgRmV0Y2hBY3Rpb24sIFJlY2VpdmVBY3Rpb24gfSBmcm9tICcuLi8uLi9sZWdhY3lBY3Rpb25zLmpzJztcblxuaW50ZXJmYWNlIE9wdGlvbnM8XG4gIFBheWxvYWQgZXh0ZW5kcyBvYmplY3QgfCBzdHJpbmcgfCBudW1iZXIgfCBudWxsID1cbiAgICB8IG9iamVjdFxuICAgIHwgc3RyaW5nXG4gICAgfCBudW1iZXJcbiAgICB8IG51bGwsXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBhbnksXG4+IGV4dGVuZHMgUGljazxcbiAgICBGZXRjaEFjdGlvbjxQYXlsb2FkLCBTPlsnbWV0YSddLFxuICAgICdzY2hlbWEnIHwgJ2tleScgfCAndHlwZScgfCAndXBkYXRlcnMnIHwgJ3VwZGF0ZScgfCAnYXJncydcbiAgPiB7XG4gIGRhdGFFeHBpcnlMZW5ndGg6IE5vbk51bGxhYmxlPEZldGNoT3B0aW9uc1snZGF0YUV4cGlyeUxlbmd0aCddPjtcbiAgZmV0Y2hlZEF0PzogbnVtYmVyO1xufVxuXG4vKiogVXBkYXRlIHN0YXRlIHdpdGggZGF0YVxuICpcbiAqIEBwYXJhbSBkYXRhXG4gKiBAcGFyYW0gcGFyYW0xIHsgc2NoZW1hLCBrZXksIHR5cGUsIHVwZGF0ZXJzLCBkYXRhRXhwaXJ5TGVuZ3RoIH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlUmVjZWl2ZTxcbiAgUGF5bG9hZCBleHRlbmRzIG9iamVjdCB8IHN0cmluZyB8IG51bWJlciB8IG51bGwgPVxuICAgIHwgb2JqZWN0XG4gICAgfCBzdHJpbmdcbiAgICB8IG51bWJlclxuICAgIHwgbnVsbCxcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IGFueSxcbj4oXG4gIGRhdGE6IFBheWxvYWQsXG4gIHtcbiAgICBzY2hlbWEsXG4gICAga2V5LFxuICAgIGFyZ3MsXG4gICAgdXBkYXRlcnMsXG4gICAgZmV0Y2hlZEF0ID0gMCxcbiAgICB1cGRhdGUsXG4gICAgZGF0YUV4cGlyeUxlbmd0aCxcbiAgfTogT3B0aW9uczxQYXlsb2FkLCBTPixcbik6IFJlY2VpdmVBY3Rpb248UGF5bG9hZCwgUz4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZGF0YUV4cGlyeUxlbmd0aCA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05lZ2F0aXZlIGRhdGFFeHBpcnlMZW5ndGggYXJlIG5vdCBhbGxvd2VkLicpO1xuICB9XG4gIGNvbnN0IG5vdyA9IERhdGUubm93KCk7XG4gIGNvbnN0IG1ldGE6IFJlY2VpdmVBY3Rpb25bJ21ldGEnXSA9IHtcbiAgICBzY2hlbWEsXG4gICAga2V5LFxuICAgIGFyZ3MsXG4gICAgZGF0ZTogbm93LFxuICAgIGZldGNoZWRBdCxcbiAgICBleHBpcmVzQXQ6IG5vdyArIGRhdGFFeHBpcnlMZW5ndGgsXG4gIH07XG4gIG1ldGEudXBkYXRlcnMgPSB1cGRhdGVycztcbiAgbWV0YS51cGRhdGUgPSB1cGRhdGU7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVDRUlWRV9UWVBFLFxuICAgIHBheWxvYWQ6IGRhdGEsXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBS0EsU0FBU0EsWUFBWSxRQUFRLHNCQUFzQjtBQWtCbkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsYUFBYUEsQ0FRbkNDLElBQWEsRUFDYjtFQUNFQyxNQUFNO0VBQ05DLEdBQUc7RUFDSEMsSUFBSTtFQUNKQyxRQUFRO0VBQ1JDLFNBQVMsR0FBRyxDQUFDO0VBQ2JDLE1BQU07RUFDTkM7QUFDbUIsQ0FBQyxFQUNLO0VBQzNCO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlILGdCQUFnQixHQUFHLENBQUMsRUFBRTtJQUNsRSxNQUFNLElBQUlJLEtBQUssQ0FBQyw0Q0FBNEMsQ0FBQztFQUMvRDtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLEVBQUU7RUFDdEIsTUFBTUUsSUFBMkIsR0FBRztJQUNsQ2IsTUFBTTtJQUNOQyxHQUFHO0lBQ0hDLElBQUk7SUFDSlksSUFBSSxFQUFFSCxHQUFHO0lBQ1RQLFNBQVM7SUFDVFcsU0FBUyxFQUFFSixHQUFHLEdBQUdMO0VBQ25CLENBQUM7RUFDRE8sSUFBSSxDQUFDVixRQUFRLEdBQUdBLFFBQVE7RUFDeEJVLElBQUksQ0FBQ1IsTUFBTSxHQUFHQSxNQUFNO0VBQ3BCLE9BQU87SUFDTFcsSUFBSSxFQUFFbkIsWUFBWTtJQUNsQm9CLE9BQU8sRUFBRWxCLElBQUk7SUFDYmM7RUFDRixDQUFDO0FBQ0gifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUNFSVZFX1RZUEUiLCJjcmVhdGVSZWNlaXZlIiwiZGF0YSIsInNjaGVtYSIsImtleSIsImFyZ3MiLCJ1cGRhdGVycyIsImZldGNoZWRBdCIsInVwZGF0ZSIsImRhdGFFeHBpcnlMZW5ndGgiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJFcnJvciIsIm5vdyIsIkRhdGUiLCJtZXRhIiwiZGF0ZSIsImV4cGlyZXNBdCIsInR5cGUiLCJwYXlsb2FkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL2xlZ2FjeS1hY3Rpb25zL2NyZWF0ZVJlY2VpdmUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIEVuZHBvaW50RXh0cmFPcHRpb25zIGFzIEZldGNoT3B0aW9ucyxcbn0gZnJvbSAnQHJlc3QtaG9va3Mvbm9ybWFsaXpyJztcblxuaW1wb3J0IHsgUkVDRUlWRV9UWVBFIH0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHsgRmV0Y2hBY3Rpb24sIFJlY2VpdmVBY3Rpb24gfSBmcm9tICcuLi8uLi9sZWdhY3lBY3Rpb25zLmpzJztcblxuaW50ZXJmYWNlIE9wdGlvbnM8XG4gIFBheWxvYWQgZXh0ZW5kcyBvYmplY3QgfCBzdHJpbmcgfCBudW1iZXIgfCBudWxsID1cbiAgICB8IG9iamVjdFxuICAgIHwgc3RyaW5nXG4gICAgfCBudW1iZXJcbiAgICB8IG51bGwsXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBhbnksXG4+IGV4dGVuZHMgUGljazxcbiAgICBGZXRjaEFjdGlvbjxQYXlsb2FkLCBTPlsnbWV0YSddLFxuICAgICdzY2hlbWEnIHwgJ2tleScgfCAndHlwZScgfCAndXBkYXRlcnMnIHwgJ3VwZGF0ZScgfCAnYXJncydcbiAgPiB7XG4gIGRhdGFFeHBpcnlMZW5ndGg6IE5vbk51bGxhYmxlPEZldGNoT3B0aW9uc1snZGF0YUV4cGlyeUxlbmd0aCddPjtcbiAgZmV0Y2hlZEF0PzogbnVtYmVyO1xufVxuXG4vKiogVXBkYXRlIHN0YXRlIHdpdGggZGF0YVxuICpcbiAqIEBwYXJhbSBkYXRhXG4gKiBAcGFyYW0gcGFyYW0xIHsgc2NoZW1hLCBrZXksIHR5cGUsIHVwZGF0ZXJzLCBkYXRhRXhwaXJ5TGVuZ3RoIH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gY3JlYXRlUmVjZWl2ZTxcbiAgUGF5bG9hZCBleHRlbmRzIG9iamVjdCB8IHN0cmluZyB8IG51bWJlciB8IG51bGwgPVxuICAgIHwgb2JqZWN0XG4gICAgfCBzdHJpbmdcbiAgICB8IG51bWJlclxuICAgIHwgbnVsbCxcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IGFueSxcbj4oXG4gIGRhdGE6IFBheWxvYWQsXG4gIHtcbiAgICBzY2hlbWEsXG4gICAga2V5LFxuICAgIGFyZ3MsXG4gICAgdXBkYXRlcnMsXG4gICAgZmV0Y2hlZEF0ID0gMCxcbiAgICB1cGRhdGUsXG4gICAgZGF0YUV4cGlyeUxlbmd0aCxcbiAgfTogT3B0aW9uczxQYXlsb2FkLCBTPixcbik6IFJlY2VpdmVBY3Rpb248UGF5bG9hZCwgUz4ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZGF0YUV4cGlyeUxlbmd0aCA8IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05lZ2F0aXZlIGRhdGFFeHBpcnlMZW5ndGggYXJlIG5vdCBhbGxvd2VkLicpO1xuICB9XG4gIGNvbnN0IG5vdyA9IERhdGUubm93KCk7XG4gIGNvbnN0IG1ldGE6IFJlY2VpdmVBY3Rpb25bJ21ldGEnXSA9IHtcbiAgICBzY2hlbWEsXG4gICAga2V5LFxuICAgIGFyZ3MsXG4gICAgZGF0ZTogbm93LFxuICAgIGZldGNoZWRBdCxcbiAgICBleHBpcmVzQXQ6IG5vdyArIGRhdGFFeHBpcnlMZW5ndGgsXG4gIH07XG4gIG1ldGEudXBkYXRlcnMgPSB1cGRhdGVycztcbiAgbWV0YS51cGRhdGUgPSB1cGRhdGU7XG4gIHJldHVybiB7XG4gICAgdHlwZTogUkVDRUlWRV9UWVBFLFxuICAgIHBheWxvYWQ6IGRhdGEsXG4gICAgbWV0YSxcbiAgfTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBS0EsU0FBU0EsWUFBWSxRQUFRLHNCQUFzQjtBQWtCbkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsU0FBU0MsYUFBYUEsQ0FRbkNDLElBQWEsRUFDYjtFQUNFQyxNQUFNO0VBQ05DLEdBQUc7RUFDSEMsSUFBSTtFQUNKQyxRQUFRO0VBQ1JDLFNBQVMsR0FBRyxDQUFDO0VBQ2JDLE1BQU07RUFDTkM7QUFDbUIsQ0FBQyxFQUNLO0VBQzNCO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlILGdCQUFnQixHQUFHLENBQUMsRUFBRTtJQUNsRSxNQUFNLElBQUlJLEtBQUssQ0FBQyw0Q0FBNEMsQ0FBQztFQUMvRDtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLENBQUMsQ0FBQztFQUN0QixNQUFNRSxJQUEyQixHQUFHO0lBQ2xDYixNQUFNO0lBQ05DLEdBQUc7SUFDSEMsSUFBSTtJQUNKWSxJQUFJLEVBQUVILEdBQUc7SUFDVFAsU0FBUztJQUNUVyxTQUFTLEVBQUVKLEdBQUcsR0FBR0w7RUFDbkIsQ0FBQztFQUNETyxJQUFJLENBQUNWLFFBQVEsR0FBR0EsUUFBUTtFQUN4QlUsSUFBSSxDQUFDUixNQUFNLEdBQUdBLE1BQU07RUFDcEIsT0FBTztJQUNMVyxJQUFJLEVBQUVuQixZQUFZO0lBQ2xCb0IsT0FBTyxFQUFFbEIsSUFBSTtJQUNiYztFQUNGLENBQUM7QUFDSCJ9 |
@@ -28,2 +28,2 @@ import { RECEIVE_TYPE } from '../../actionTypes.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUNFSVZFX1RZUEUiLCJjcmVhdGVSZWNlaXZlRXJyb3IiLCJlcnJvciIsInNjaGVtYSIsImtleSIsIm9wdGlvbnMiLCJlcnJvckV4cGlyeUxlbmd0aCIsImZldGNoZWRBdCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwibm93IiwiRGF0ZSIsInR5cGUiLCJwYXlsb2FkIiwibWV0YSIsImRhdGUiLCJleHBpcmVzQXQiLCJlcnJvclBvbGljeSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zdGF0ZS9sZWdhY3ktYWN0aW9ucy9jcmVhdGVSZWNlaXZlRXJyb3IudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgU2NoZW1hLFxuICBFbmRwb2ludEV4dHJhT3B0aW9ucyBhcyBGZXRjaE9wdGlvbnMsXG59IGZyb20gJ0ByZXN0LWhvb2tzL25vcm1hbGl6cic7XG5cbmltcG9ydCB7IFJFQ0VJVkVfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB7IEZldGNoQWN0aW9uLCBSZWNlaXZlQWN0aW9uIH0gZnJvbSAnLi4vLi4vbGVnYWN5QWN0aW9ucy5qcyc7XG5cbmludGVyZmFjZSBPcHRpb25zPFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBhbnk+XG4gIGV4dGVuZHMgUGljazxGZXRjaEFjdGlvbjxhbnksIFM+WydtZXRhJ10sICdzY2hlbWEnIHwgJ2tleScgfCAnb3B0aW9ucyc+IHtcbiAgZXJyb3JFeHBpcnlMZW5ndGg/OiBOb25OdWxsYWJsZTxGZXRjaE9wdGlvbnNbJ2Vycm9yRXhwaXJ5TGVuZ3RoJ10+O1xuICBmZXRjaGVkQXQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlY2VpdmVFcnJvcjxTIGV4dGVuZHMgU2NoZW1hIHwgdW5kZWZpbmVkID0gYW55PihcbiAgZXJyb3I6IEVycm9yLFxuICB7XG4gICAgc2NoZW1hLFxuICAgIGtleSxcbiAgICBvcHRpb25zLFxuICAgIGVycm9yRXhwaXJ5TGVuZ3RoID0gNjAwMDAsXG4gICAgZmV0Y2hlZEF0ID0gMCxcbiAgfTogT3B0aW9uczxTPixcbik6IFJlY2VpdmVBY3Rpb24ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZXJyb3JFeHBpcnlMZW5ndGggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBlcnJvckV4cGlyeUxlbmd0aCBhcmUgbm90IGFsbG93ZWQuJyk7XG4gIH1cbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBSRUNFSVZFX1RZUEUsXG4gICAgcGF5bG9hZDogZXJyb3IsXG4gICAgbWV0YToge1xuICAgICAgc2NoZW1hLFxuICAgICAga2V5LFxuICAgICAgZGF0ZTogbm93LFxuICAgICAgZmV0Y2hlZEF0LFxuICAgICAgZXhwaXJlc0F0OiBub3cgKyBlcnJvckV4cGlyeUxlbmd0aCxcbiAgICAgIGVycm9yUG9saWN5OiBvcHRpb25zPy5lcnJvclBvbGljeSxcbiAgICB9LFxuICAgIGVycm9yOiB0cnVlLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFLQSxTQUFTQSxZQUFZLFFBQVEsc0JBQXNCO0FBU25ELGVBQWUsU0FBU0Msa0JBQWtCQSxDQUN4Q0MsS0FBWSxFQUNaO0VBQ0VDLE1BQU07RUFDTkMsR0FBRztFQUNIQyxPQUFPO0VBQ1BDLGlCQUFpQixHQUFHLEtBQUs7RUFDekJDLFNBQVMsR0FBRztBQUNGLENBQUMsRUFDRTtFQUNmO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlKLGlCQUFpQixHQUFHLENBQUMsRUFBRTtJQUNuRSxNQUFNLElBQUlLLEtBQUssQ0FBQyw2Q0FBNkMsQ0FBQztFQUNoRTtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLEVBQUU7RUFDdEIsT0FBTztJQUNMRSxJQUFJLEVBQUVkLFlBQVk7SUFDbEJlLE9BQU8sRUFBRWIsS0FBSztJQUNkYyxJQUFJLEVBQUU7TUFDSmIsTUFBTTtNQUNOQyxHQUFHO01BQ0hhLElBQUksRUFBRUwsR0FBRztNQUNUTCxTQUFTO01BQ1RXLFNBQVMsRUFBRU4sR0FBRyxHQUFHTixpQkFBaUI7TUFDbENhLFdBQVcsRUFBRWQsT0FBTyxvQkFBUEEsT0FBTyxDQUFFYztJQUN4QixDQUFDO0lBQ0RqQixLQUFLLEVBQUU7RUFDVCxDQUFDO0FBQ0gifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSRUNFSVZFX1RZUEUiLCJjcmVhdGVSZWNlaXZlRXJyb3IiLCJlcnJvciIsInNjaGVtYSIsImtleSIsIm9wdGlvbnMiLCJlcnJvckV4cGlyeUxlbmd0aCIsImZldGNoZWRBdCIsInByb2Nlc3MiLCJlbnYiLCJOT0RFX0VOViIsIkVycm9yIiwibm93IiwiRGF0ZSIsInR5cGUiLCJwYXlsb2FkIiwibWV0YSIsImRhdGUiLCJleHBpcmVzQXQiLCJlcnJvclBvbGljeSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zdGF0ZS9sZWdhY3ktYWN0aW9ucy9jcmVhdGVSZWNlaXZlRXJyb3IudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgU2NoZW1hLFxuICBFbmRwb2ludEV4dHJhT3B0aW9ucyBhcyBGZXRjaE9wdGlvbnMsXG59IGZyb20gJ0ByZXN0LWhvb2tzL25vcm1hbGl6cic7XG5cbmltcG9ydCB7IFJFQ0VJVkVfVFlQRSB9IGZyb20gJy4uLy4uL2FjdGlvblR5cGVzLmpzJztcbmltcG9ydCB7IEZldGNoQWN0aW9uLCBSZWNlaXZlQWN0aW9uIH0gZnJvbSAnLi4vLi4vbGVnYWN5QWN0aW9ucy5qcyc7XG5cbmludGVyZmFjZSBPcHRpb25zPFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBhbnk+XG4gIGV4dGVuZHMgUGljazxGZXRjaEFjdGlvbjxhbnksIFM+WydtZXRhJ10sICdzY2hlbWEnIHwgJ2tleScgfCAnb3B0aW9ucyc+IHtcbiAgZXJyb3JFeHBpcnlMZW5ndGg/OiBOb25OdWxsYWJsZTxGZXRjaE9wdGlvbnNbJ2Vycm9yRXhwaXJ5TGVuZ3RoJ10+O1xuICBmZXRjaGVkQXQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVJlY2VpdmVFcnJvcjxTIGV4dGVuZHMgU2NoZW1hIHwgdW5kZWZpbmVkID0gYW55PihcbiAgZXJyb3I6IEVycm9yLFxuICB7XG4gICAgc2NoZW1hLFxuICAgIGtleSxcbiAgICBvcHRpb25zLFxuICAgIGVycm9yRXhwaXJ5TGVuZ3RoID0gNjAwMDAsXG4gICAgZmV0Y2hlZEF0ID0gMCxcbiAgfTogT3B0aW9uczxTPixcbik6IFJlY2VpdmVBY3Rpb24ge1xuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdkZXZlbG9wbWVudCcgJiYgZXJyb3JFeHBpcnlMZW5ndGggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdOZWdhdGl2ZSBlcnJvckV4cGlyeUxlbmd0aCBhcmUgbm90IGFsbG93ZWQuJyk7XG4gIH1cbiAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgcmV0dXJuIHtcbiAgICB0eXBlOiBSRUNFSVZFX1RZUEUsXG4gICAgcGF5bG9hZDogZXJyb3IsXG4gICAgbWV0YToge1xuICAgICAgc2NoZW1hLFxuICAgICAga2V5LFxuICAgICAgZGF0ZTogbm93LFxuICAgICAgZmV0Y2hlZEF0LFxuICAgICAgZXhwaXJlc0F0OiBub3cgKyBlcnJvckV4cGlyeUxlbmd0aCxcbiAgICAgIGVycm9yUG9saWN5OiBvcHRpb25zPy5lcnJvclBvbGljeSxcbiAgICB9LFxuICAgIGVycm9yOiB0cnVlLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFLQSxTQUFTQSxZQUFZLFFBQVEsc0JBQXNCO0FBU25ELGVBQWUsU0FBU0Msa0JBQWtCQSxDQUN4Q0MsS0FBWSxFQUNaO0VBQ0VDLE1BQU07RUFDTkMsR0FBRztFQUNIQyxPQUFPO0VBQ1BDLGlCQUFpQixHQUFHLEtBQUs7RUFDekJDLFNBQVMsR0FBRztBQUNGLENBQUMsRUFDRTtFQUNmO0VBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxhQUFhLElBQUlKLGlCQUFpQixHQUFHLENBQUMsRUFBRTtJQUNuRSxNQUFNLElBQUlLLEtBQUssQ0FBQyw2Q0FBNkMsQ0FBQztFQUNoRTtFQUNBLE1BQU1DLEdBQUcsR0FBR0MsSUFBSSxDQUFDRCxHQUFHLENBQUMsQ0FBQztFQUN0QixPQUFPO0lBQ0xFLElBQUksRUFBRWQsWUFBWTtJQUNsQmUsT0FBTyxFQUFFYixLQUFLO0lBQ2RjLElBQUksRUFBRTtNQUNKYixNQUFNO01BQ05DLEdBQUc7TUFDSGEsSUFBSSxFQUFFTCxHQUFHO01BQ1RMLFNBQVM7TUFDVFcsU0FBUyxFQUFFTixHQUFHLEdBQUdOLGlCQUFpQjtNQUNsQ2EsV0FBVyxFQUFFZCxPQUFPLG9CQUFQQSxPQUFPLENBQUVjO0lBQ3hCLENBQUM7SUFDRGpCLEtBQUssRUFBRTtFQUNULENBQUM7QUFDSCJ9 |
@@ -55,2 +55,2 @@ import { fetchReducer } from './fetchReducer.js'; | ||
}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmZXRjaFJlZHVjZXIiLCJpbnZhbGlkYXRlUmVkdWNlciIsInNldFJlZHVjZXIiLCJTRVRfVFlQRSIsIklOVkFMSURBVEVfVFlQRSIsIlJFU0VUX1RZUEUiLCJGRVRDSF9UWVBFIiwiR0NfVFlQRSIsIk9QVElNSVNUSUNfVFlQRSIsIklOVkFMSURBVEVBTExfVFlQRSIsImNyZWF0ZVJlZHVjZXIiLCJjb250cm9sbGVyIiwicmVkdWNlciIsInN0YXRlIiwiYWN0aW9uIiwiX2FjdGlvbiRkYXRlIiwiaW5pdGlhbFN0YXRlIiwidHlwZSIsImVudGl0aWVzIiwiZm9yRWFjaCIsImtleSIsInBrIiwiX2VudGl0aWVzJGtleSIsIl9lbnRpdHlNZXRhJGtleSIsImVudGl0eU1ldGEiLCJyZXN1bHRzIiwiZmV0Y2hLZXkiLCJtZXRhIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZGF0ZSIsInVuZGVmaW5lZCIsImNvbnNvbGUiLCJ3YXJuIiwibGFzdFJlc2V0IiwiRGF0ZSIsIm5vdyIsImluZGV4ZXMiLCJvcHRpbWlzdGljIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL3JlZHVjZXIvY3JlYXRlUmVkdWNlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmZXRjaFJlZHVjZXIgfSBmcm9tICcuL2ZldGNoUmVkdWNlci5qcyc7XG5pbXBvcnQgeyBpbnZhbGlkYXRlUmVkdWNlciB9IGZyb20gJy4vaW52YWxpZGF0ZVJlZHVjZXIuanMnO1xuaW1wb3J0IHsgc2V0UmVkdWNlciB9IGZyb20gJy4vc2V0UmVkdWNlci5qcyc7XG5pbXBvcnQge1xuICBTRVRfVFlQRSxcbiAgSU5WQUxJREFURV9UWVBFLFxuICBSRVNFVF9UWVBFLFxuICBGRVRDSF9UWVBFLFxuICBHQ19UWVBFLFxuICBPUFRJTUlTVElDX1RZUEUsXG4gIElOVkFMSURBVEVBTExfVFlQRSxcbn0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi8uLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBPbGRBY3Rpb25UeXBlcywgQWN0aW9uVHlwZXMsIFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWR1Y2VyKGNvbnRyb2xsZXI6IENvbnRyb2xsZXIpOiBSZWR1Y2VyVHlwZSB7XG4gIHJldHVybiBmdW5jdGlvbiByZWR1Y2VyKFxuICAgIHN0YXRlOiBTdGF0ZTx1bmtub3duPiB8IHVuZGVmaW5lZCxcbiAgICBhY3Rpb246IE9sZEFjdGlvblR5cGVzLFxuICApOiBTdGF0ZTx1bmtub3duPiB7XG4gICAgaWYgKCFzdGF0ZSkgc3RhdGUgPSBpbml0aWFsU3RhdGU7XG4gICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgY2FzZSBHQ19UWVBFOlxuICAgICAgICAvLyBpbmxpbmUgZGVsZXRlcyBhcmUgZmluZSBhcyB0aGVzZSBzaG91bGQgaGF2ZSAwIHJlZmNvdW50c1xuICAgICAgICBhY3Rpb24uZW50aXRpZXMuZm9yRWFjaCgoW2tleSwgcGtdKSA9PiB7XG4gICAgICAgICAgZGVsZXRlIChzdGF0ZSBhcyBhbnkpLmVudGl0aWVzW2tleV0/Lltwa107XG4gICAgICAgICAgZGVsZXRlIChzdGF0ZSBhcyBhbnkpLmVudGl0eU1ldGFba2V5XT8uW3BrXTtcbiAgICAgICAgfSk7XG4gICAgICAgIGFjdGlvbi5yZXN1bHRzLmZvckVhY2goZmV0Y2hLZXkgPT4ge1xuICAgICAgICAgIGRlbGV0ZSAoc3RhdGUgYXMgYW55KS5yZXN1bHRzW2ZldGNoS2V5XTtcbiAgICAgICAgICBkZWxldGUgKHN0YXRlIGFzIGFueSkubWV0YVtmZXRjaEtleV07XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgICBjYXNlIEZFVENIX1RZUEU6XG4gICAgICAgIHJldHVybiBmZXRjaFJlZHVjZXIoc3RhdGUsIGFjdGlvbik7XG5cbiAgICAgIGNhc2UgT1BUSU1JU1RJQ19UWVBFOlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWZhbGx0aHJvdWdoXG4gICAgICBjYXNlIFNFVF9UWVBFOlxuICAgICAgICByZXR1cm4gc2V0UmVkdWNlcihzdGF0ZSwgYWN0aW9uLCBjb250cm9sbGVyKTtcblxuICAgICAgY2FzZSBJTlZBTElEQVRFQUxMX1RZUEU6XG4gICAgICBjYXNlIElOVkFMSURBVEVfVFlQRTpcbiAgICAgICAgcmV0dXJuIGludmFsaWRhdGVSZWR1Y2VyKHN0YXRlLCBhY3Rpb24pO1xuXG4gICAgICBjYXNlIFJFU0VUX1RZUEU6XG4gICAgICAgIGlmIChcbiAgICAgICAgICBwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nICYmXG4gICAgICAgICAgYWN0aW9uLmRhdGUgPT09IHVuZGVmaW5lZFxuICAgICAgICApIHtcbiAgICAgICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICAgICBgJHtSRVNFVF9UWVBFfSBzZW50IHdpdGhvdXQgJ2RhdGUnIG1lbWJlci4gVGhpcyBpcyBkZXByZWNhdGVkLiBQbGVhc2UgdXNlIGNyZWF0ZVJlc2V0KCkgYWN0aW9uIGNyZWF0b3IgdG8gZW5zdXJlIGNvcnJlY3QgYWN0aW9uIHNoYXBlLmAsXG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4geyAuLi5pbml0aWFsU3RhdGUsIGxhc3RSZXNldDogYWN0aW9uLmRhdGUgPz8gRGF0ZS5ub3coKSB9O1xuXG4gICAgICBkZWZhdWx0OlxuICAgICAgICAvLyBBIHJlZHVjZXIgbXVzdCBhbHdheXMgcmV0dXJuIGEgdmFsaWQgc3RhdGUuXG4gICAgICAgIC8vIEFsdGVybmF0aXZlbHkgeW91IGNhbiB0aHJvdyBhbiBlcnJvciBpZiBhbiBpbnZhbGlkIGFjdGlvbiBpcyBkaXNwYXRjaGVkLlxuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgfVxuICB9IGFzIGFueTtcbn1cblxuZXhwb3J0IGNvbnN0IGluaXRpYWxTdGF0ZTogU3RhdGU8dW5rbm93bj4gPSB7XG4gIGVudGl0aWVzOiB7fSxcbiAgaW5kZXhlczoge30sXG4gIHJlc3VsdHM6IHt9LFxuICBtZXRhOiB7fSxcbiAgZW50aXR5TWV0YToge30sXG4gIG9wdGltaXN0aWM6IFtdLFxuICBsYXN0UmVzZXQ6IDAsXG59O1xuXG50eXBlIFJlZHVjZXJUeXBlID0gKFxuICBzdGF0ZTogU3RhdGU8dW5rbm93bj4gfCB1bmRlZmluZWQsXG4gIGFjdGlvbjogQWN0aW9uVHlwZXMsXG4pID0+IFN0YXRlPHVua25vd24+O1xuXG50eXBlIFdyaXRhYmxlPFQ+ID0geyBbUCBpbiBrZXlvZiBUXTogTm9uTnVsbGFibGU8V3JpdGFibGU8VFtQXT4+IH07XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFlBQVksUUFBUSxtQkFBbUI7QUFDaEQsU0FBU0MsaUJBQWlCLFFBQVEsd0JBQXdCO0FBQzFELFNBQVNDLFVBQVUsUUFBUSxpQkFBaUI7QUFDNUMsU0FDRUMsUUFBUSxFQUNSQyxlQUFlLEVBQ2ZDLFVBQVUsRUFDVkMsVUFBVSxFQUNWQyxPQUFPLEVBQ1BDLGVBQWUsRUFDZkMsa0JBQWtCLFFBQ2Isc0JBQXNCO0FBSTdCLGVBQWUsU0FBU0MsYUFBYUEsQ0FBQ0MsVUFBc0IsRUFBZTtFQUN6RSxPQUFPLFNBQVNDLE9BQU9BLENBQ3JCQyxLQUFpQyxFQUNqQ0MsTUFBc0IsRUFDTjtJQUFBLElBQUFDLFlBQUE7SUFDaEIsSUFBSSxDQUFDRixLQUFLLEVBQUVBLEtBQUssR0FBR0csWUFBWTtJQUNoQyxRQUFRRixNQUFNLENBQUNHLElBQUk7TUFDakIsS0FBS1YsT0FBTztRQUNWO1FBQ0FPLE1BQU0sQ0FBQ0ksUUFBUSxDQUFDQyxPQUFPLENBQUMsQ0FBQyxDQUFDQyxHQUFHLEVBQUVDLEVBQUUsQ0FBQyxLQUFLO1VBQUEsSUFBQUMsYUFBQSxFQUFBQyxlQUFBO1VBQ3JDLENBQUFELGFBQUEsR0FBUVQsS0FBSyxDQUFTSyxRQUFRLENBQUNFLEdBQUcsQ0FBQyxtQkFBbkMsT0FBT0UsYUFBQSxDQUErQkQsRUFBRSxDQUFDO1VBQ3pDLENBQUFFLGVBQUEsR0FBUVYsS0FBSyxDQUFTVyxVQUFVLENBQUNKLEdBQUcsQ0FBQyxtQkFBckMsT0FBT0csZUFBQSxDQUFpQ0YsRUFBRSxDQUFDO1FBQzdDLENBQUMsQ0FBQztRQUNGUCxNQUFNLENBQUNXLE9BQU8sQ0FBQ04sT0FBTyxDQUFDTyxRQUFRLElBQUk7VUFDakMsT0FBUWIsS0FBSyxDQUFTWSxPQUFPLENBQUNDLFFBQVEsQ0FBQztVQUN2QyxPQUFRYixLQUFLLENBQVNjLElBQUksQ0FBQ0QsUUFBUSxDQUFDO1FBQ3RDLENBQUMsQ0FBQztRQUNGLE9BQU9iLEtBQUs7TUFDZCxLQUFLUCxVQUFVO1FBQ2IsT0FBT04sWUFBWSxDQUFDYSxLQUFLLEVBQUVDLE1BQU0sQ0FBQztNQUVwQyxLQUFLTixlQUFlO01BQ3BCO01BQ0EsS0FBS0wsUUFBUTtRQUNYLE9BQU9ELFVBQVUsQ0FBQ1csS0FBSyxFQUFFQyxNQUFNLEVBQUVILFVBQVUsQ0FBQztNQUU5QyxLQUFLRixrQkFBa0I7TUFDdkIsS0FBS0wsZUFBZTtRQUNsQixPQUFPSCxpQkFBaUIsQ0FBQ1ksS0FBSyxFQUFFQyxNQUFNLENBQUM7TUFFekMsS0FBS1QsVUFBVTtRQUNiLElBQ0V1QixPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFlBQVksSUFDckNoQixNQUFNLENBQUNpQixJQUFJLEtBQUtDLFNBQVMsRUFDekI7VUFDQUMsT0FBTyxDQUFDQyxJQUFJLENBQ1QsR0FBRTdCLFVBQVcsMEhBQXlILENBQ3hJO1FBQ0g7UUFDQSxPQUFPO1VBQUUsR0FBR1csWUFBWTtVQUFFbUIsU0FBUyxHQUFBcEIsWUFBQSxHQUFFRCxNQUFNLENBQUNpQixJQUFJLFlBQUFoQixZQUFBLEdBQUlxQixJQUFJLENBQUNDLEdBQUc7UUFBRyxDQUFDO01BRWxFO1FBQ0U7UUFDQTtRQUNBLE9BQU94QixLQUFLO0lBQUM7RUFFbkIsQ0FBQztBQUNIO0FBRUEsT0FBTyxNQUFNRyxZQUE0QixHQUFHO0VBQzFDRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO0VBQ1pvQixPQUFPLEVBQUUsQ0FBQyxDQUFDO0VBQ1hiLE9BQU8sRUFBRSxDQUFDLENBQUM7RUFDWEUsSUFBSSxFQUFFLENBQUMsQ0FBQztFQUNSSCxVQUFVLEVBQUUsQ0FBQyxDQUFDO0VBQ2RlLFVBQVUsRUFBRSxFQUFFO0VBQ2RKLFNBQVMsRUFBRTtBQUNiLENBQUMifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmZXRjaFJlZHVjZXIiLCJpbnZhbGlkYXRlUmVkdWNlciIsInNldFJlZHVjZXIiLCJTRVRfVFlQRSIsIklOVkFMSURBVEVfVFlQRSIsIlJFU0VUX1RZUEUiLCJGRVRDSF9UWVBFIiwiR0NfVFlQRSIsIk9QVElNSVNUSUNfVFlQRSIsIklOVkFMSURBVEVBTExfVFlQRSIsImNyZWF0ZVJlZHVjZXIiLCJjb250cm9sbGVyIiwicmVkdWNlciIsInN0YXRlIiwiYWN0aW9uIiwiX2FjdGlvbiRkYXRlIiwiaW5pdGlhbFN0YXRlIiwidHlwZSIsImVudGl0aWVzIiwiZm9yRWFjaCIsImtleSIsInBrIiwiX2VudGl0aWVzJGtleSIsIl9lbnRpdHlNZXRhJGtleSIsImVudGl0eU1ldGEiLCJyZXN1bHRzIiwiZmV0Y2hLZXkiLCJtZXRhIiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZGF0ZSIsInVuZGVmaW5lZCIsImNvbnNvbGUiLCJ3YXJuIiwibGFzdFJlc2V0IiwiRGF0ZSIsIm5vdyIsImluZGV4ZXMiLCJvcHRpbWlzdGljIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3N0YXRlL3JlZHVjZXIvY3JlYXRlUmVkdWNlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmZXRjaFJlZHVjZXIgfSBmcm9tICcuL2ZldGNoUmVkdWNlci5qcyc7XG5pbXBvcnQgeyBpbnZhbGlkYXRlUmVkdWNlciB9IGZyb20gJy4vaW52YWxpZGF0ZVJlZHVjZXIuanMnO1xuaW1wb3J0IHsgc2V0UmVkdWNlciB9IGZyb20gJy4vc2V0UmVkdWNlci5qcyc7XG5pbXBvcnQge1xuICBTRVRfVFlQRSxcbiAgSU5WQUxJREFURV9UWVBFLFxuICBSRVNFVF9UWVBFLFxuICBGRVRDSF9UWVBFLFxuICBHQ19UWVBFLFxuICBPUFRJTUlTVElDX1RZUEUsXG4gIElOVkFMSURBVEVBTExfVFlQRSxcbn0gZnJvbSAnLi4vLi4vYWN0aW9uVHlwZXMuanMnO1xuaW1wb3J0IHR5cGUgQ29udHJvbGxlciBmcm9tICcuLi8uLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHR5cGUgeyBPbGRBY3Rpb25UeXBlcywgQWN0aW9uVHlwZXMsIFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVSZWR1Y2VyKGNvbnRyb2xsZXI6IENvbnRyb2xsZXIpOiBSZWR1Y2VyVHlwZSB7XG4gIHJldHVybiBmdW5jdGlvbiByZWR1Y2VyKFxuICAgIHN0YXRlOiBTdGF0ZTx1bmtub3duPiB8IHVuZGVmaW5lZCxcbiAgICBhY3Rpb246IE9sZEFjdGlvblR5cGVzLFxuICApOiBTdGF0ZTx1bmtub3duPiB7XG4gICAgaWYgKCFzdGF0ZSkgc3RhdGUgPSBpbml0aWFsU3RhdGU7XG4gICAgc3dpdGNoIChhY3Rpb24udHlwZSkge1xuICAgICAgY2FzZSBHQ19UWVBFOlxuICAgICAgICAvLyBpbmxpbmUgZGVsZXRlcyBhcmUgZmluZSBhcyB0aGVzZSBzaG91bGQgaGF2ZSAwIHJlZmNvdW50c1xuICAgICAgICBhY3Rpb24uZW50aXRpZXMuZm9yRWFjaCgoW2tleSwgcGtdKSA9PiB7XG4gICAgICAgICAgZGVsZXRlIChzdGF0ZSBhcyBhbnkpLmVudGl0aWVzW2tleV0/Lltwa107XG4gICAgICAgICAgZGVsZXRlIChzdGF0ZSBhcyBhbnkpLmVudGl0eU1ldGFba2V5XT8uW3BrXTtcbiAgICAgICAgfSk7XG4gICAgICAgIGFjdGlvbi5yZXN1bHRzLmZvckVhY2goZmV0Y2hLZXkgPT4ge1xuICAgICAgICAgIGRlbGV0ZSAoc3RhdGUgYXMgYW55KS5yZXN1bHRzW2ZldGNoS2V5XTtcbiAgICAgICAgICBkZWxldGUgKHN0YXRlIGFzIGFueSkubWV0YVtmZXRjaEtleV07XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgICBjYXNlIEZFVENIX1RZUEU6XG4gICAgICAgIHJldHVybiBmZXRjaFJlZHVjZXIoc3RhdGUsIGFjdGlvbik7XG5cbiAgICAgIGNhc2UgT1BUSU1JU1RJQ19UWVBFOlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWZhbGx0aHJvdWdoXG4gICAgICBjYXNlIFNFVF9UWVBFOlxuICAgICAgICByZXR1cm4gc2V0UmVkdWNlcihzdGF0ZSwgYWN0aW9uLCBjb250cm9sbGVyKTtcblxuICAgICAgY2FzZSBJTlZBTElEQVRFQUxMX1RZUEU6XG4gICAgICBjYXNlIElOVkFMSURBVEVfVFlQRTpcbiAgICAgICAgcmV0dXJuIGludmFsaWRhdGVSZWR1Y2VyKHN0YXRlLCBhY3Rpb24pO1xuXG4gICAgICBjYXNlIFJFU0VUX1RZUEU6XG4gICAgICAgIGlmIChcbiAgICAgICAgICBwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nICYmXG4gICAgICAgICAgYWN0aW9uLmRhdGUgPT09IHVuZGVmaW5lZFxuICAgICAgICApIHtcbiAgICAgICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICAgICBgJHtSRVNFVF9UWVBFfSBzZW50IHdpdGhvdXQgJ2RhdGUnIG1lbWJlci4gVGhpcyBpcyBkZXByZWNhdGVkLiBQbGVhc2UgdXNlIGNyZWF0ZVJlc2V0KCkgYWN0aW9uIGNyZWF0b3IgdG8gZW5zdXJlIGNvcnJlY3QgYWN0aW9uIHNoYXBlLmAsXG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4geyAuLi5pbml0aWFsU3RhdGUsIGxhc3RSZXNldDogYWN0aW9uLmRhdGUgPz8gRGF0ZS5ub3coKSB9O1xuXG4gICAgICBkZWZhdWx0OlxuICAgICAgICAvLyBBIHJlZHVjZXIgbXVzdCBhbHdheXMgcmV0dXJuIGEgdmFsaWQgc3RhdGUuXG4gICAgICAgIC8vIEFsdGVybmF0aXZlbHkgeW91IGNhbiB0aHJvdyBhbiBlcnJvciBpZiBhbiBpbnZhbGlkIGFjdGlvbiBpcyBkaXNwYXRjaGVkLlxuICAgICAgICByZXR1cm4gc3RhdGU7XG4gICAgfVxuICB9IGFzIGFueTtcbn1cblxuZXhwb3J0IGNvbnN0IGluaXRpYWxTdGF0ZTogU3RhdGU8dW5rbm93bj4gPSB7XG4gIGVudGl0aWVzOiB7fSxcbiAgaW5kZXhlczoge30sXG4gIHJlc3VsdHM6IHt9LFxuICBtZXRhOiB7fSxcbiAgZW50aXR5TWV0YToge30sXG4gIG9wdGltaXN0aWM6IFtdLFxuICBsYXN0UmVzZXQ6IDAsXG59O1xuXG50eXBlIFJlZHVjZXJUeXBlID0gKFxuICBzdGF0ZTogU3RhdGU8dW5rbm93bj4gfCB1bmRlZmluZWQsXG4gIGFjdGlvbjogQWN0aW9uVHlwZXMsXG4pID0+IFN0YXRlPHVua25vd24+O1xuXG50eXBlIFdyaXRhYmxlPFQ+ID0geyBbUCBpbiBrZXlvZiBUXTogTm9uTnVsbGFibGU8V3JpdGFibGU8VFtQXT4+IH07XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFlBQVksUUFBUSxtQkFBbUI7QUFDaEQsU0FBU0MsaUJBQWlCLFFBQVEsd0JBQXdCO0FBQzFELFNBQVNDLFVBQVUsUUFBUSxpQkFBaUI7QUFDNUMsU0FDRUMsUUFBUSxFQUNSQyxlQUFlLEVBQ2ZDLFVBQVUsRUFDVkMsVUFBVSxFQUNWQyxPQUFPLEVBQ1BDLGVBQWUsRUFDZkMsa0JBQWtCLFFBQ2Isc0JBQXNCO0FBSTdCLGVBQWUsU0FBU0MsYUFBYUEsQ0FBQ0MsVUFBc0IsRUFBZTtFQUN6RSxPQUFPLFNBQVNDLE9BQU9BLENBQ3JCQyxLQUFpQyxFQUNqQ0MsTUFBc0IsRUFDTjtJQUFBLElBQUFDLFlBQUE7SUFDaEIsSUFBSSxDQUFDRixLQUFLLEVBQUVBLEtBQUssR0FBR0csWUFBWTtJQUNoQyxRQUFRRixNQUFNLENBQUNHLElBQUk7TUFDakIsS0FBS1YsT0FBTztRQUNWO1FBQ0FPLE1BQU0sQ0FBQ0ksUUFBUSxDQUFDQyxPQUFPLENBQUMsQ0FBQyxDQUFDQyxHQUFHLEVBQUVDLEVBQUUsQ0FBQyxLQUFLO1VBQUEsSUFBQUMsYUFBQSxFQUFBQyxlQUFBO1VBQ3JDLENBQUFELGFBQUEsR0FBUVQsS0FBSyxDQUFTSyxRQUFRLENBQUNFLEdBQUcsQ0FBQyxtQkFBbkMsT0FBT0UsYUFBQSxDQUErQkQsRUFBRSxDQUFDO1VBQ3pDLENBQUFFLGVBQUEsR0FBUVYsS0FBSyxDQUFTVyxVQUFVLENBQUNKLEdBQUcsQ0FBQyxtQkFBckMsT0FBT0csZUFBQSxDQUFpQ0YsRUFBRSxDQUFDO1FBQzdDLENBQUMsQ0FBQztRQUNGUCxNQUFNLENBQUNXLE9BQU8sQ0FBQ04sT0FBTyxDQUFDTyxRQUFRLElBQUk7VUFDakMsT0FBUWIsS0FBSyxDQUFTWSxPQUFPLENBQUNDLFFBQVEsQ0FBQztVQUN2QyxPQUFRYixLQUFLLENBQVNjLElBQUksQ0FBQ0QsUUFBUSxDQUFDO1FBQ3RDLENBQUMsQ0FBQztRQUNGLE9BQU9iLEtBQUs7TUFDZCxLQUFLUCxVQUFVO1FBQ2IsT0FBT04sWUFBWSxDQUFDYSxLQUFLLEVBQUVDLE1BQU0sQ0FBQztNQUVwQyxLQUFLTixlQUFlO01BQ3BCO01BQ0EsS0FBS0wsUUFBUTtRQUNYLE9BQU9ELFVBQVUsQ0FBQ1csS0FBSyxFQUFFQyxNQUFNLEVBQUVILFVBQVUsQ0FBQztNQUU5QyxLQUFLRixrQkFBa0I7TUFDdkIsS0FBS0wsZUFBZTtRQUNsQixPQUFPSCxpQkFBaUIsQ0FBQ1ksS0FBSyxFQUFFQyxNQUFNLENBQUM7TUFFekMsS0FBS1QsVUFBVTtRQUNiLElBQ0V1QixPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFlBQVksSUFDckNoQixNQUFNLENBQUNpQixJQUFJLEtBQUtDLFNBQVMsRUFDekI7VUFDQUMsT0FBTyxDQUFDQyxJQUFJLENBQ1QsR0FBRTdCLFVBQVcsMEhBQ2hCLENBQUM7UUFDSDtRQUNBLE9BQU87VUFBRSxHQUFHVyxZQUFZO1VBQUVtQixTQUFTLEdBQUFwQixZQUFBLEdBQUVELE1BQU0sQ0FBQ2lCLElBQUksWUFBQWhCLFlBQUEsR0FBSXFCLElBQUksQ0FBQ0MsR0FBRyxDQUFDO1FBQUUsQ0FBQztNQUVsRTtRQUNFO1FBQ0E7UUFDQSxPQUFPeEIsS0FBSztJQUNoQjtFQUNGLENBQUM7QUFDSDtBQUVBLE9BQU8sTUFBTUcsWUFBNEIsR0FBRztFQUMxQ0UsUUFBUSxFQUFFLENBQUMsQ0FBQztFQUNab0IsT0FBTyxFQUFFLENBQUMsQ0FBQztFQUNYYixPQUFPLEVBQUUsQ0FBQyxDQUFDO0VBQ1hFLElBQUksRUFBRSxDQUFDLENBQUM7RUFDUkgsVUFBVSxFQUFFLENBQUMsQ0FBQztFQUNkZSxVQUFVLEVBQUUsRUFBRTtFQUNkSixTQUFTLEVBQUU7QUFDYixDQUFDIn0= |
@@ -34,2 +34,2 @@ import createOptimistic from '../../controller/createOptimistic.js'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVPcHRpbWlzdGljIiwiY3JlYXRlUmVjZWl2ZSIsImxlZ2FjeUNyZWF0ZVJlY2VpdmUiLCJmZXRjaFJlZHVjZXIiLCJzdGF0ZSIsImFjdGlvbiIsIl9hY3Rpb24kZW5kcG9pbnQiLCJvcHRpbWlzdGljUmVzcG9uc2UiLCJtZXRhIiwiZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlIiwiZW5kcG9pbnQiLCJyZWNlaXZlQWN0aW9uIiwiYXJncyIsImZldGNoZWRBdCIsImNyZWF0ZWRBdCIsImdldFRpbWUiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwiSW5maW5pdHkiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJjb25zb2xlIiwid2FybiIsIm9wdGltaXN0aWMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RhdGUvcmVkdWNlci9mZXRjaFJlZHVjZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNyZWF0ZU9wdGltaXN0aWMgZnJvbSAnLi4vLi4vY29udHJvbGxlci9jcmVhdGVPcHRpbWlzdGljLmpzJztcbmltcG9ydCB0eXBlIHtcbiAgUmVjZWl2ZUFjdGlvbixcbiAgT3B0aW1pc3RpY0FjdGlvbixcbiAgRmV0Y2hBY3Rpb24sXG59IGZyb20gJy4uLy4uL3ByZXZpb3VzQWN0aW9ucy5qcyc7XG5pbXBvcnQgdHlwZSB7IFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuaW1wb3J0IHsgY3JlYXRlUmVjZWl2ZSBhcyBsZWdhY3lDcmVhdGVSZWNlaXZlIH0gZnJvbSAnLi4vbGVnYWN5LWFjdGlvbnMvaW5kZXguanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZmV0Y2hSZWR1Y2VyKHN0YXRlOiBTdGF0ZTx1bmtub3duPiwgYWN0aW9uOiBGZXRjaEFjdGlvbikge1xuICBjb25zdCBvcHRpbWlzdGljUmVzcG9uc2UgPSBhY3Rpb24ubWV0YS5vcHRpbWlzdGljUmVzcG9uc2U7XG4gIGNvbnN0IGdldE9wdGltaXN0aWNSZXNwb25zZSA9IGFjdGlvbi5lbmRwb2ludD8uZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlO1xuICBsZXQgcmVjZWl2ZUFjdGlvbjogUmVjZWl2ZUFjdGlvbiB8IE9wdGltaXN0aWNBY3Rpb247XG5cbiAgaWYgKGdldE9wdGltaXN0aWNSZXNwb25zZSAmJiBhY3Rpb24uZW5kcG9pbnQpIHtcbiAgICByZWNlaXZlQWN0aW9uID0gY3JlYXRlT3B0aW1pc3RpYyhhY3Rpb24uZW5kcG9pbnQsIHtcbiAgICAgIGFyZ3M6IGFjdGlvbi5tZXRhLmFyZ3MgYXMgcmVhZG9ubHkgYW55W10sXG4gICAgICBmZXRjaGVkQXQ6XG4gICAgICAgIHR5cGVvZiBhY3Rpb24ubWV0YS5jcmVhdGVkQXQgIT09ICdudW1iZXInXG4gICAgICAgICAgPyBhY3Rpb24ubWV0YS5jcmVhdGVkQXQuZ2V0VGltZSgpXG4gICAgICAgICAgOiBhY3Rpb24ubWV0YS5jcmVhdGVkQXQsXG4gICAgfSkgYXMgYW55O1xuICB9IC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqLyBlbHNlIGlmIChvcHRpbWlzdGljUmVzcG9uc2UpIHtcbiAgICAvLyBUT0RPKGJyZWFraW5nKTogdGhpcyBpcyBubyBsb25nZXIgdXNlZCwgcmVtb3ZlIHRoaXMgYnJhbmNoXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZWNlaXZlQWN0aW9uID0gbGVnYWN5Q3JlYXRlUmVjZWl2ZShvcHRpbWlzdGljUmVzcG9uc2UsIHtcbiAgICAgIC4uLmFjdGlvbi5tZXRhLFxuICAgICAgZGF0YUV4cGlyeUxlbmd0aDogSW5maW5pdHksXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgLy8gSWYgJ2ZldGNoJyBhY3Rpb24gcmVhY2hlcyB0aGUgcmVkdWNlciB0aGVyZSBhcmUgbm8gbWlkZGxld2FyZXMgaW5zdGFsbGVkIHRvIGhhbmRsZSBpdFxuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAncHJvZHVjdGlvbicpIHtcbiAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgJ0ZldGNoIGFwcGVhcnMgdW5oYW5kbGVkIC0geW91IGFyZSBsaWtlbHkgbWlzc2luZyB0aGUgTmV0d29ya01hbmFnZXIgbWlkZGxld2FyZScsXG4gICAgICApO1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnU2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL2RvY3MvZ3VpZGVzL3JlZHV4I2luZGV4dHN4IGZvciBob29raW5nIHVwIHJlZHV4JyxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlO1xuICB9XG4gIHJldHVybiB7XG4gICAgLi4uc3RhdGUsXG4gICAgb3B0aW1pc3RpYzogWy4uLnN0YXRlLm9wdGltaXN0aWMsIHJlY2VpdmVBY3Rpb25dLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxnQkFBZ0IsTUFBTSxzQ0FBc0M7QUFPbkUsU0FBU0MsYUFBYSxJQUFJQyxtQkFBbUIsUUFBUSw0QkFBNEI7QUFFakYsT0FBTyxTQUFTQyxZQUFZQSxDQUFDQyxLQUFxQixFQUFFQyxNQUFtQixFQUFFO0VBQUEsSUFBQUMsZ0JBQUE7RUFDdkUsTUFBTUMsa0JBQWtCLEdBQUdGLE1BQU0sQ0FBQ0csSUFBSSxDQUFDRCxrQkFBa0I7RUFDekQsTUFBTUUscUJBQXFCLElBQUFILGdCQUFBLEdBQUdELE1BQU0sQ0FBQ0ssUUFBUSxxQkFBZkosZ0JBQUEsQ0FBaUJHLHFCQUFxQjtFQUNwRSxJQUFJRSxhQUErQztFQUVuRCxJQUFJRixxQkFBcUIsSUFBSUosTUFBTSxDQUFDSyxRQUFRLEVBQUU7SUFDNUNDLGFBQWEsR0FBR1gsZ0JBQWdCLENBQUNLLE1BQU0sQ0FBQ0ssUUFBUSxFQUFFO01BQ2hERSxJQUFJLEVBQUVQLE1BQU0sQ0FBQ0csSUFBSSxDQUFDSSxJQUFzQjtNQUN4Q0MsU0FBUyxFQUNQLE9BQU9SLE1BQU0sQ0FBQ0csSUFBSSxDQUFDTSxTQUFTLEtBQUssUUFBUSxHQUNyQ1QsTUFBTSxDQUFDRyxJQUFJLENBQUNNLFNBQVMsQ0FBQ0MsT0FBTyxFQUFFLEdBQy9CVixNQUFNLENBQUNHLElBQUksQ0FBQ007SUFDcEIsQ0FBQyxDQUFRO0VBQ1gsQ0FBQyxDQUFDLDZCQUE4QixJQUFJUCxrQkFBa0IsRUFBRTtJQUN0RDtJQUNBO0lBQ0FJLGFBQWEsR0FBR1QsbUJBQW1CLENBQUNLLGtCQUFrQixFQUFFO01BQ3RELEdBQUdGLE1BQU0sQ0FBQ0csSUFBSTtNQUNkUSxnQkFBZ0IsRUFBRUM7SUFDcEIsQ0FBQyxDQUFDO0VBQ0osQ0FBQyxNQUFNO0lBQ0w7SUFDQTtJQUNBLElBQUlDLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxRQUFRLEtBQUssWUFBWSxFQUFFO01BQ3pDQyxPQUFPLENBQUNDLElBQUksQ0FDVixnRkFBZ0YsQ0FDakY7TUFDREQsT0FBTyxDQUFDQyxJQUFJLENBQ1YsMEVBQTBFLENBQzNFO0lBQ0g7SUFFQSxPQUFPbEIsS0FBSztFQUNkO0VBQ0EsT0FBTztJQUNMLEdBQUdBLEtBQUs7SUFDUm1CLFVBQVUsRUFBRSxDQUFDLEdBQUduQixLQUFLLENBQUNtQixVQUFVLEVBQUVaLGFBQWE7RUFDakQsQ0FBQztBQUNIIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVPcHRpbWlzdGljIiwiY3JlYXRlUmVjZWl2ZSIsImxlZ2FjeUNyZWF0ZVJlY2VpdmUiLCJmZXRjaFJlZHVjZXIiLCJzdGF0ZSIsImFjdGlvbiIsIl9hY3Rpb24kZW5kcG9pbnQiLCJvcHRpbWlzdGljUmVzcG9uc2UiLCJtZXRhIiwiZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlIiwiZW5kcG9pbnQiLCJyZWNlaXZlQWN0aW9uIiwiYXJncyIsImZldGNoZWRBdCIsImNyZWF0ZWRBdCIsImdldFRpbWUiLCJkYXRhRXhwaXJ5TGVuZ3RoIiwiSW5maW5pdHkiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJjb25zb2xlIiwid2FybiIsIm9wdGltaXN0aWMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc3RhdGUvcmVkdWNlci9mZXRjaFJlZHVjZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGNyZWF0ZU9wdGltaXN0aWMgZnJvbSAnLi4vLi4vY29udHJvbGxlci9jcmVhdGVPcHRpbWlzdGljLmpzJztcbmltcG9ydCB0eXBlIHtcbiAgUmVjZWl2ZUFjdGlvbixcbiAgT3B0aW1pc3RpY0FjdGlvbixcbiAgRmV0Y2hBY3Rpb24sXG59IGZyb20gJy4uLy4uL3ByZXZpb3VzQWN0aW9ucy5qcyc7XG5pbXBvcnQgdHlwZSB7IFN0YXRlIH0gZnJvbSAnLi4vLi4vdHlwZXMuanMnO1xuaW1wb3J0IHsgY3JlYXRlUmVjZWl2ZSBhcyBsZWdhY3lDcmVhdGVSZWNlaXZlIH0gZnJvbSAnLi4vbGVnYWN5LWFjdGlvbnMvaW5kZXguanMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZmV0Y2hSZWR1Y2VyKHN0YXRlOiBTdGF0ZTx1bmtub3duPiwgYWN0aW9uOiBGZXRjaEFjdGlvbikge1xuICBjb25zdCBvcHRpbWlzdGljUmVzcG9uc2UgPSBhY3Rpb24ubWV0YS5vcHRpbWlzdGljUmVzcG9uc2U7XG4gIGNvbnN0IGdldE9wdGltaXN0aWNSZXNwb25zZSA9IGFjdGlvbi5lbmRwb2ludD8uZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlO1xuICBsZXQgcmVjZWl2ZUFjdGlvbjogUmVjZWl2ZUFjdGlvbiB8IE9wdGltaXN0aWNBY3Rpb247XG5cbiAgaWYgKGdldE9wdGltaXN0aWNSZXNwb25zZSAmJiBhY3Rpb24uZW5kcG9pbnQpIHtcbiAgICByZWNlaXZlQWN0aW9uID0gY3JlYXRlT3B0aW1pc3RpYyhhY3Rpb24uZW5kcG9pbnQsIHtcbiAgICAgIGFyZ3M6IGFjdGlvbi5tZXRhLmFyZ3MgYXMgcmVhZG9ubHkgYW55W10sXG4gICAgICBmZXRjaGVkQXQ6XG4gICAgICAgIHR5cGVvZiBhY3Rpb24ubWV0YS5jcmVhdGVkQXQgIT09ICdudW1iZXInXG4gICAgICAgICAgPyBhY3Rpb24ubWV0YS5jcmVhdGVkQXQuZ2V0VGltZSgpXG4gICAgICAgICAgOiBhY3Rpb24ubWV0YS5jcmVhdGVkQXQsXG4gICAgfSkgYXMgYW55O1xuICB9IC8qIGlzdGFuYnVsIGlnbm9yZSBpZiAqLyBlbHNlIGlmIChvcHRpbWlzdGljUmVzcG9uc2UpIHtcbiAgICAvLyBUT0RPKGJyZWFraW5nKTogdGhpcyBpcyBubyBsb25nZXIgdXNlZCwgcmVtb3ZlIHRoaXMgYnJhbmNoXG4gICAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgICByZWNlaXZlQWN0aW9uID0gbGVnYWN5Q3JlYXRlUmVjZWl2ZShvcHRpbWlzdGljUmVzcG9uc2UsIHtcbiAgICAgIC4uLmFjdGlvbi5tZXRhLFxuICAgICAgZGF0YUV4cGlyeUxlbmd0aDogSW5maW5pdHksXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgLy8gSWYgJ2ZldGNoJyBhY3Rpb24gcmVhY2hlcyB0aGUgcmVkdWNlciB0aGVyZSBhcmUgbm8gbWlkZGxld2FyZXMgaW5zdGFsbGVkIHRvIGhhbmRsZSBpdFxuICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgaWYgKHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAncHJvZHVjdGlvbicpIHtcbiAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgJ0ZldGNoIGFwcGVhcnMgdW5oYW5kbGVkIC0geW91IGFyZSBsaWtlbHkgbWlzc2luZyB0aGUgTmV0d29ya01hbmFnZXIgbWlkZGxld2FyZScsXG4gICAgICApO1xuICAgICAgY29uc29sZS53YXJuKFxuICAgICAgICAnU2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL2RvY3MvZ3VpZGVzL3JlZHV4I2luZGV4dHN4IGZvciBob29raW5nIHVwIHJlZHV4JyxcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0YXRlO1xuICB9XG4gIHJldHVybiB7XG4gICAgLi4uc3RhdGUsXG4gICAgb3B0aW1pc3RpYzogWy4uLnN0YXRlLm9wdGltaXN0aWMsIHJlY2VpdmVBY3Rpb25dLFxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxnQkFBZ0IsTUFBTSxzQ0FBc0M7QUFPbkUsU0FBU0MsYUFBYSxJQUFJQyxtQkFBbUIsUUFBUSw0QkFBNEI7QUFFakYsT0FBTyxTQUFTQyxZQUFZQSxDQUFDQyxLQUFxQixFQUFFQyxNQUFtQixFQUFFO0VBQUEsSUFBQUMsZ0JBQUE7RUFDdkUsTUFBTUMsa0JBQWtCLEdBQUdGLE1BQU0sQ0FBQ0csSUFBSSxDQUFDRCxrQkFBa0I7RUFDekQsTUFBTUUscUJBQXFCLElBQUFILGdCQUFBLEdBQUdELE1BQU0sQ0FBQ0ssUUFBUSxxQkFBZkosZ0JBQUEsQ0FBaUJHLHFCQUFxQjtFQUNwRSxJQUFJRSxhQUErQztFQUVuRCxJQUFJRixxQkFBcUIsSUFBSUosTUFBTSxDQUFDSyxRQUFRLEVBQUU7SUFDNUNDLGFBQWEsR0FBR1gsZ0JBQWdCLENBQUNLLE1BQU0sQ0FBQ0ssUUFBUSxFQUFFO01BQ2hERSxJQUFJLEVBQUVQLE1BQU0sQ0FBQ0csSUFBSSxDQUFDSSxJQUFzQjtNQUN4Q0MsU0FBUyxFQUNQLE9BQU9SLE1BQU0sQ0FBQ0csSUFBSSxDQUFDTSxTQUFTLEtBQUssUUFBUSxHQUNyQ1QsTUFBTSxDQUFDRyxJQUFJLENBQUNNLFNBQVMsQ0FBQ0MsT0FBTyxDQUFDLENBQUMsR0FDL0JWLE1BQU0sQ0FBQ0csSUFBSSxDQUFDTTtJQUNwQixDQUFDLENBQVE7RUFDWCxDQUFDLENBQUMsNkJBQThCLElBQUlQLGtCQUFrQixFQUFFO0lBQ3REO0lBQ0E7SUFDQUksYUFBYSxHQUFHVCxtQkFBbUIsQ0FBQ0ssa0JBQWtCLEVBQUU7TUFDdEQsR0FBR0YsTUFBTSxDQUFDRyxJQUFJO01BQ2RRLGdCQUFnQixFQUFFQztJQUNwQixDQUFDLENBQUM7RUFDSixDQUFDLE1BQU07SUFDTDtJQUNBO0lBQ0EsSUFBSUMsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxZQUFZLEVBQUU7TUFDekNDLE9BQU8sQ0FBQ0MsSUFBSSxDQUNWLGdGQUNGLENBQUM7TUFDREQsT0FBTyxDQUFDQyxJQUFJLENBQ1YsMEVBQ0YsQ0FBQztJQUNIO0lBRUEsT0FBT2xCLEtBQUs7RUFDZDtFQUNBLE9BQU87SUFDTCxHQUFHQSxLQUFLO0lBQ1JtQixVQUFVLEVBQUUsQ0FBQyxHQUFHbkIsS0FBSyxDQUFDbUIsVUFBVSxFQUFFWixhQUFhO0VBQ2pELENBQUM7QUFDSCJ9 |
@@ -119,2 +119,2 @@ import { normalize } from '@rest-hooks/normalizr'; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC_TYPE","applyUpdatersToResults","setReducer","state","action","controller","error","reduceError","payload","_state$meta$action$me","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","_e$constructor","constructor","name","result","entities","indexes","entityMeta","schema","date","results","key","updaters","update","Object","keys","forEach","console","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setReducer.ts"],"sourcesContent":["import { normalize } from '@rest-hooks/normalizr';\n\nimport { OPTIMISTIC_TYPE } from '../../actionTypes.js';\nimport type Controller from '../../controller/Controller.js';\nimport type { ReceiveAction, OptimisticAction } from '../../previousActions.js';\nimport type { State } from '../../types.js';\nimport applyUpdatersToResults from '../applyUpdatersToResults.js';\n\nexport function setReducer(\n  state: State<unknown>,\n  action: OptimisticAction | ReceiveAction,\n  controller: Controller,\n) {\n  if (action.error) {\n    return reduceError(state, action, action.payload);\n  }\n  try {\n    let payload: any;\n    // for true receives payload is contained in action\n    if (action.type === OPTIMISTIC_TYPE) {\n      if (!action.endpoint.getOptimisticResponse) return state;\n      try {\n        // compute optimistic response based on current state\n        payload = action.endpoint.getOptimisticResponse.call(\n          action.endpoint,\n          controller.snapshot(state, action.meta.fetchedAt),\n          // if endpoint exists, so must args; TODO: fix typing\n          ...(action.meta.args as any[]),\n        );\n      } catch (e: any) {\n        // AbortOptimistic means 'do nothing', otherwise we count the exception as endpoint failure\n        if (e.constructor?.name === 'AbortOptimistic') {\n          return state;\n        }\n        throw e;\n      }\n    } else {\n      payload = action.payload;\n    }\n    const { result, entities, indexes, entityMeta } = normalize(\n      payload,\n      action.meta.schema,\n      action.meta.args as any,\n      state.entities,\n      state.indexes,\n      state.entityMeta,\n      { fetchedAt: action.meta.date, ...action.meta },\n    );\n    let results = {\n      ...state.results,\n      [action.meta.key]: result,\n    };\n    try {\n      if ('updaters' in action.meta && action.meta.updaters) {\n        results = applyUpdatersToResults(\n          results,\n          result,\n          action.meta.updaters as any,\n        );\n      }\n      if (action.meta.update) {\n        const updaters = action.meta.update(\n          result,\n          ...(action.meta.args || []),\n        );\n        Object.keys(updaters).forEach(key => {\n          results[key] = updaters[key](results[key]);\n        });\n      }\n      // no reason to completely fail because of user-code error\n      // integrity of this state update is still guaranteed\n    } catch (error) {\n      console.error(\n        `The following error occured during Endpoint.update() for ${action.meta.key}`,\n      );\n      console.error(error);\n    }\n    return {\n      entities,\n      indexes,\n      results,\n      entityMeta,\n      meta: {\n        ...state.meta,\n        [action.meta.key]: {\n          date: action.meta.date,\n          expiresAt: action.meta.expiresAt,\n          prevExpiresAt: state.meta[action.meta.key]?.expiresAt,\n        },\n      },\n      optimistic: filterOptimistic(state, action),\n      lastReset: state.lastReset,\n    };\n    // reducer must update the state, so in case of processing errors we simply compute the results inline\n  } catch (error: any) {\n    if (typeof error === 'object') {\n      error.message = `Error processing ${\n        action.meta.key\n      }\\n\\nFull Schema: ${JSON.stringify(\n        action.meta.schema,\n        undefined,\n        2,\n      )}\\n\\nError:\\n${error.message}`;\n      if ('payload' in action) error.payload = action.payload;\n      error.status = 400;\n    }\n\n    // this is not always bubbled up, so let's double sure this doesn't fail silently\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      console.error(error);\n    }\n    return reduceError(state, action, error);\n  }\n}\n\nfunction reduceError(\n  state: State<unknown>,\n  action: ReceiveAction | OptimisticAction,\n  error: any,\n): State<unknown> {\n  if (error.name === 'AbortError') {\n    // In case we abort simply undo the optimistic update and act like no fetch even occured\n    // We still want those watching promises from fetch directly to observed the abort, but we don't want to\n    // Trigger errors in this case. This means theoretically improperly built abortes useResource() could suspend forever.\n    return {\n      ...state,\n      optimistic: filterOptimistic(state, action),\n    };\n  }\n  return {\n    ...state,\n    meta: {\n      ...state.meta,\n      [action.meta.key]: {\n        date: action.meta.date,\n        error,\n        expiresAt: action.meta.expiresAt,\n        errorPolicy: action.meta.errorPolicy?.(error),\n      },\n    },\n    optimistic: filterOptimistic(state, action),\n  };\n}\n/** Filter all requests with same serialization that did not start after the resolving request */\nfunction filterOptimistic(\n  state: State<unknown>,\n  resolvingAction: ReceiveAction | OptimisticAction,\n) {\n  return state.optimistic.filter(\n    optimisticAction =>\n      optimisticAction.meta.key !== resolvingAction.meta.key ||\n      (optimisticAction.type === OPTIMISTIC_TYPE\n        ? optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt\n        : optimisticAction.meta.date > resolvingAction.meta.date),\n  );\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","OPTIMISTIC_TYPE","applyUpdatersToResults","setReducer","state","action","controller","error","reduceError","payload","_state$meta$action$me","type","endpoint","getOptimisticResponse","call","snapshot","meta","fetchedAt","args","e","_e$constructor","constructor","name","result","entities","indexes","entityMeta","schema","date","results","key","updaters","update","Object","keys","forEach","console","expiresAt","prevExpiresAt","optimistic","filterOptimistic","lastReset","message","JSON","stringify","undefined","status","process","env","NODE_ENV","errorPolicy","resolvingAction","filter","optimisticAction"],"sources":["../../../src/state/reducer/setReducer.ts"],"sourcesContent":["import { normalize } from '@rest-hooks/normalizr';\n\nimport { OPTIMISTIC_TYPE } from '../../actionTypes.js';\nimport type Controller from '../../controller/Controller.js';\nimport type { ReceiveAction, OptimisticAction } from '../../previousActions.js';\nimport type { State } from '../../types.js';\nimport applyUpdatersToResults from '../applyUpdatersToResults.js';\n\nexport function setReducer(\n  state: State<unknown>,\n  action: OptimisticAction | ReceiveAction,\n  controller: Controller,\n) {\n  if (action.error) {\n    return reduceError(state, action, action.payload);\n  }\n  try {\n    let payload: any;\n    // for true receives payload is contained in action\n    if (action.type === OPTIMISTIC_TYPE) {\n      if (!action.endpoint.getOptimisticResponse) return state;\n      try {\n        // compute optimistic response based on current state\n        payload = action.endpoint.getOptimisticResponse.call(\n          action.endpoint,\n          controller.snapshot(state, action.meta.fetchedAt),\n          // if endpoint exists, so must args; TODO: fix typing\n          ...(action.meta.args as any[]),\n        );\n      } catch (e: any) {\n        // AbortOptimistic means 'do nothing', otherwise we count the exception as endpoint failure\n        if (e.constructor?.name === 'AbortOptimistic') {\n          return state;\n        }\n        throw e;\n      }\n    } else {\n      payload = action.payload;\n    }\n    const { result, entities, indexes, entityMeta } = normalize(\n      payload,\n      action.meta.schema,\n      action.meta.args as any,\n      state.entities,\n      state.indexes,\n      state.entityMeta,\n      { fetchedAt: action.meta.date, ...action.meta },\n    );\n    let results = {\n      ...state.results,\n      [action.meta.key]: result,\n    };\n    try {\n      if ('updaters' in action.meta && action.meta.updaters) {\n        results = applyUpdatersToResults(\n          results,\n          result,\n          action.meta.updaters as any,\n        );\n      }\n      if (action.meta.update) {\n        const updaters = action.meta.update(\n          result,\n          ...(action.meta.args || []),\n        );\n        Object.keys(updaters).forEach(key => {\n          results[key] = updaters[key](results[key]);\n        });\n      }\n      // no reason to completely fail because of user-code error\n      // integrity of this state update is still guaranteed\n    } catch (error) {\n      console.error(\n        `The following error occured during Endpoint.update() for ${action.meta.key}`,\n      );\n      console.error(error);\n    }\n    return {\n      entities,\n      indexes,\n      results,\n      entityMeta,\n      meta: {\n        ...state.meta,\n        [action.meta.key]: {\n          date: action.meta.date,\n          expiresAt: action.meta.expiresAt,\n          prevExpiresAt: state.meta[action.meta.key]?.expiresAt,\n        },\n      },\n      optimistic: filterOptimistic(state, action),\n      lastReset: state.lastReset,\n    };\n    // reducer must update the state, so in case of processing errors we simply compute the results inline\n  } catch (error: any) {\n    if (typeof error === 'object') {\n      error.message = `Error processing ${\n        action.meta.key\n      }\\n\\nFull Schema: ${JSON.stringify(\n        action.meta.schema,\n        undefined,\n        2,\n      )}\\n\\nError:\\n${error.message}`;\n      if ('payload' in action) error.payload = action.payload;\n      error.status = 400;\n    }\n\n    // this is not always bubbled up, so let's double sure this doesn't fail silently\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      console.error(error);\n    }\n    return reduceError(state, action, error);\n  }\n}\n\nfunction reduceError(\n  state: State<unknown>,\n  action: ReceiveAction | OptimisticAction,\n  error: any,\n): State<unknown> {\n  if (error.name === 'AbortError') {\n    // In case we abort simply undo the optimistic update and act like no fetch even occured\n    // We still want those watching promises from fetch directly to observed the abort, but we don't want to\n    // Trigger errors in this case. This means theoretically improperly built abortes useResource() could suspend forever.\n    return {\n      ...state,\n      optimistic: filterOptimistic(state, action),\n    };\n  }\n  return {\n    ...state,\n    meta: {\n      ...state.meta,\n      [action.meta.key]: {\n        date: action.meta.date,\n        error,\n        expiresAt: action.meta.expiresAt,\n        errorPolicy: action.meta.errorPolicy?.(error),\n      },\n    },\n    optimistic: filterOptimistic(state, action),\n  };\n}\n/** Filter all requests with same serialization that did not start after the resolving request */\nfunction filterOptimistic(\n  state: State<unknown>,\n  resolvingAction: ReceiveAction | OptimisticAction,\n) {\n  return state.optimistic.filter(\n    optimisticAction =>\n      optimisticAction.meta.key !== resolvingAction.meta.key ||\n      (optimisticAction.type === OPTIMISTIC_TYPE\n        ? optimisticAction.meta.fetchedAt !== resolvingAction.meta.fetchedAt\n        : optimisticAction.meta.date > resolvingAction.meta.date),\n  );\n}\n"],"mappings":"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"} |
@@ -9,2 +9,2 @@ /* istanbul ignore file */ | ||
export default reducer; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZWR1Y2VyIiwiQ29udHJvbGxlciIsInJlZHVjZXIiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhdGUvcmVkdWNlckluc3RhbmNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG5pbXBvcnQgY3JlYXRlUmVkdWNlciBmcm9tICcuL3JlZHVjZXIvY3JlYXRlUmVkdWNlci5qcyc7XG5pbXBvcnQgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHsgQWN0aW9uVHlwZXMsIFN0YXRlIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIHVzZSBjcmVhdGVSZWR1Y2VyIGluc3RlYWRcbiAqL1xuY29uc3QgcmVkdWNlcjogKFxuICBzdGF0ZTogU3RhdGU8dW5rbm93bj4gfCB1bmRlZmluZWQsXG4gIGFjdGlvbjogQWN0aW9uVHlwZXMsXG4pID0+IFN0YXRlPHVua25vd24+ID0gY3JlYXRlUmVkdWNlcihuZXcgQ29udHJvbGxlcigpKTtcblxuZXhwb3J0IGRlZmF1bHQgcmVkdWNlcjtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQSxPQUFPQSxhQUFhLE1BQU0sNEJBQTRCO0FBQ3RELE9BQU9DLFVBQVUsTUFBTSw2QkFBNkI7QUFHcEQ7QUFDQTtBQUNBO0FBQ0EsTUFBTUMsT0FHYSxHQUFHRixhQUFhLENBQUMsSUFBSUMsVUFBVSxFQUFFLENBQUM7QUFFckQsZUFBZUMsT0FBTyJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVSZWR1Y2VyIiwiQ29udHJvbGxlciIsInJlZHVjZXIiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RhdGUvcmVkdWNlckluc3RhbmNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG5pbXBvcnQgY3JlYXRlUmVkdWNlciBmcm9tICcuL3JlZHVjZXIvY3JlYXRlUmVkdWNlci5qcyc7XG5pbXBvcnQgQ29udHJvbGxlciBmcm9tICcuLi9jb250cm9sbGVyL0NvbnRyb2xsZXIuanMnO1xuaW1wb3J0IHsgQWN0aW9uVHlwZXMsIFN0YXRlIH0gZnJvbSAnLi4vdHlwZXMuanMnO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIHVzZSBjcmVhdGVSZWR1Y2VyIGluc3RlYWRcbiAqL1xuY29uc3QgcmVkdWNlcjogKFxuICBzdGF0ZTogU3RhdGU8dW5rbm93bj4gfCB1bmRlZmluZWQsXG4gIGFjdGlvbjogQWN0aW9uVHlwZXMsXG4pID0+IFN0YXRlPHVua25vd24+ID0gY3JlYXRlUmVkdWNlcihuZXcgQ29udHJvbGxlcigpKTtcblxuZXhwb3J0IGRlZmF1bHQgcmVkdWNlcjtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQSxPQUFPQSxhQUFhLE1BQU0sNEJBQTRCO0FBQ3RELE9BQU9DLFVBQVUsTUFBTSw2QkFBNkI7QUFHcEQ7QUFDQTtBQUNBO0FBQ0EsTUFBTUMsT0FHYSxHQUFHRixhQUFhLENBQUMsSUFBSUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUVyRCxlQUFlQyxPQUFPIn0= |
{ | ||
"name": "@rest-hooks/core", | ||
"version": "4.4.0-next.0", | ||
"version": "4.4.0", | ||
"description": "Normalized Asynchronous data framework. Protocol and View agnostic.", | ||
@@ -120,3 +120,3 @@ "sideEffects": false, | ||
"@babel/runtime": "^7.17.0", | ||
"@rest-hooks/normalizr": "^11.0.0-next.0", | ||
"@rest-hooks/normalizr": "^11.0.0", | ||
"flux-standard-action": "^2.1.1" | ||
@@ -123,0 +123,0 @@ }, |
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
1079351
1